autonomy analyse
Tools for analysing and verifying AI agents.
This command group consists of a number of functionalities to analyse and verify AI agents, including FSM App skill consistency checks. See the appropriate subcommands for more information.
autonomy analyse docstrings
Analyse FSM App skill docstring definitions.
This command verifies that the AbciApp class docstring is follows a standard format.
Example
The docstring corresponding to the Hello World AI agent is
"""HelloWorldAbciApp
Initial round: RegistrationRound
Initial states: {RegistrationRound}
Transition states:
    1. RegistrationRound
        - done: 1.
    2. CollectRandomnessRound
        - done: 2.
        - no majority: 1.
        - round timeout: 1.
    3. SelectKeeperRound
        - done: 3.
        - no majority: 0.
        - round timeout: 0.
    4. PrintMessageRound
        - done: 4.
        - round timeout: 0.
    5. ResetAndPauseRound
        - done: 1.
        - no majority: 0.
        - reset timeout: 0.
Final states: {}
Timeouts:
    round timeout: 30.0
    reset timeout: 30.0
"""
Usage
autonomy analyse docstrings [OPTIONS]
Options
- --update
- Update docstrings if required.
- --help
- Show the help message and exit.
Examples
To analyse all the FSM App skill docstrings within the local registry, run the following command in the directory containing the registry:
autonomy analyse docstrings
To update/fix the FSM App skill docstrings, run the following command:
autonomy analyse docstrings --update
autonomy analyse fsm-specs
Verify the FSM App against its specification or generate the FSM App specification file.
Usage
Usage: autonomy analyse fsm-specs [OPTIONS]
Options
- --package PATH
- Path to the package containing the FSM App skill.
- --app-class ABCI_APP_CLASS
- Name of the AbciAppclass of the FSM App.
- --update
- Update/create the FSM App definition file if check fails.
- --yaml
- YAML file (default).
- --json
- JSON file.
- --mermaid
- Mermaid file.
- --help
- Show the help message and exit.
Examples
Analyse the FSM App specification for the hello_world_abci:
autonomy analyse fsm-specs --package ./packages/valory/skills/hello_world_abci
Update/create the FSM App specification for the hello_world_abci in YAML format:
autonomy analyse fsm-specs --package ./packages/valory/skills/hello_world_abci --app-class HelloWorldAbciApp --update
Export the FSM App specification for the hello_world_abci in Mermaid format:
autonomy analyse fsm-specs --package ./packages/valory/skills/hello_world_abci --app-class HelloWorldAbciApp --update --mermaid
Analyse all the FSM App specifications in a local registry. This command must be executed in a directory containing the local registry:
autonomy analyse fsm-specs
autonomy analyse handlers
Verify existence of handler definitions.
This command verifies that all the FSM App skills in a local registry (except the explicitly excluded ones) have defined the specified handlers.
Usage
autonomy analyse handlers [OPTIONS]
Options
- -h, --common-handlers HANDLER_NAME
- Specify which handlers to check. E.g., -h handler_a-h handler_b-h handler_c.
- -i, --ignore SKILL_NAME
- Specify which skills to skip. E.g., -i skill_0,-i skill_1,-i skill_2.
- --help
- Show the help message and exit.
Examples
Ensure that handlers http and signing are defined in all the FSM App skills in a local registry, except the skills excluded_skill_1 and excluded_skill_2:
autonomy analyse handlers -h http -h signing -i excluded_skill_1 -i excluded_skill_2
autonomy analyse dialogues
Check dialogues definitions in a skill package.
This command verifies that all the FSM App skills in a local registry (except the explicitly excluded ones) have defined the specified dialogues.
Usage
autonomy analyse dialogues [OPTIONS]
Options
- -d, --dialogue TEXT
- Specify which dialogues to check. Eg. -d dialogue_a,-d dialogue_b,-d dialogue_c.
- -i, --ignore SKILL_NAME
- Specify which skills to skip. E.g., -i skill_0,-i skill_1,-i skill_2.
- --help
- Show the help message and exit.
Examples
Ensure that dialogues abci_dialogues and http_dialogues are defined in all the FSM App skills in a local registry, except the skills excluded_skill_1 and excluded_skill_2:
autonomy analyse dialogues -d abci_dialogues -d http_dialogues -i excluded_skill_1 -i excluded_skill_2
Or
autonomy analyse dialogues -d abci -d http -i excluded_skill_1 -i excluded_skill_2
Since the command will automatically append the _dialogues postfix if not provided by the user.
autonomy analyse logs
Parse logs of an AI agent.
Usage
autonomy analyse logs [OPTIONS]
Options
- --from-dir PATH
- Path to logs directory [required]
- --reset-db
- Use this flag to reset the log database.
- -a, --agent TEXT
- Agent IDs to include in analysis
- --start-time TEXT
- Start time in YYYY-MM-DD H:M:S,MSformat
- --end-time TEXT
- End time in YYYY-MM-DD H:M:S,MSformat
- --log-level [INFO|DEBUG|WARNING|ERROR|CRITICAL]
- Logging level.
- --period INTEGER
- Period ID
- --round TEXT
- Round name
- --behaviour TEXT
- Behaviour name filter
- --fsm
- Print only the FSM execution path
- -ir, --include-regex TEXT
- Regex pattern to include in the result.
- -er, --exclude-regex TEXT
- Regex pattern to exclude from the result.
- --help
- Show the help message and exit.
Examples
Analyze logs from the build directory ./abci_build_hAsH/persistent_data/logs for 2 agents:
autonomy analyse logs --from-dir ./abci_build_hAsH/persistent_data/logs -a 'aea_0' -a 'aea_1'
View logs for 2 agents between specific times:
autonomy analyse logs --from-dir ./abci_build_hAsH/persistent_data/logs -a 'aea_0' --start-time "2024-01-20 10:00:00,000" --end-time "2024-01-20 11:00:00,000"
View logs for period 2 and round RegistrationRound:
autonomy analyse logs --from-dir ./abci_build_hAsH/persistent_data/logs -a 'aea_0' --period 2 --round RegistrationRound
View only the FSM state transitions:
autonomy analyse logs --from-dir ./abci_build_hAsH/persistent_data/logs -a 'aea_0' --fsm
Filter by log level ERROR and behaviour RegistrationBehaviour:
autonomy analyse logs --from-dir ./abci_build_hAsH/persistent_data/logs -a 'aea_0' --log-level ERROR --behaviour RegistrationBehaviour
Use regex patterns to filter logs, include lines with consensus and exclude lines with debug
autonomy analyse logs --from-dir ./abci_build_hAsH/persistent_data/logs -a 'aea_0' -ir ".*consensus.*" -er ".*debug.*"
These examples demonstrate various ways to filter and analyze AI agent logs. You can combine multiple options to narrow down the log output to exactly what you need for debugging or analysis.
autonomy analyse benchmarks
Aggregate benchmark results from AI agent deployments.
This tool requires the benchmark data generated from agent blueprint's runtime. By default the tool will aggregate the output for all the periods and code block types but you can restrict the aggregation to a specific period and/or a specific block type.
Read the guide on how to use the benchmarking tool for more information.
Usage
autonomy analyse benchmarks [OPTIONS] PATH
Options
- -b, --block-type [local|consensus|total|all]
- 
Block type: - local: only consider- localcode blocks,
- consensus: only consider- consensuscode blocks,
- total: consider- local+- consensuscode blocks together.
- all: consider- localand- consensuscode blocks.
 
- -d, --period PERIOD_NUM
- Period.
- -o, --output FILE
- Output file name.
- --help
- Show the help message and exit.
Examples
The benchmark data will be stored in the folder <service_folder>/abci_build_hAsH/persistent_data/benchmarks.
To aggregate stats for all periods, execute:
autonomy analyse benchmarks abci_build_hAsH/persistent_data/benchmarks
To aggregate stats for consensus block type in the second period, execute:
    autonomy analyse benchmarks abci_build_hAsH/persistent_data/benchmarks --period 2 --block-type consensus
autonomy analyse service
Analyse if the AI agent is ready to be deployed or not.
This tool can be used to analyse an AI agent definition and see if there are any potential issues with configuration which can cause issues when running the deployment.
Read the guide on deployment readiness for more information.
Usage
autonomy analyse service [OPTIONS]
Options
- --token-id INTEGER
- Token ID of the AI agent
- --public-id PUBLIC_ID_OR_HASH
- Public ID of the AI agent
- --use-celo
- To use celochain profile to interact with the contracts
- --use-base
- To use basechain profile to interact with the contracts
- --use-optimism
- To use optimismchain profile to interact with the contracts
- --use-arbitrum-one
- To use arbitrum-onechain profile to interact with the contracts
- --use-gnosis
- To use gnosischain profile to interact with the contracts
- --use-polygon
- To use polygonchain profile to interact with the contracts
- --use-ethereum
- To use ethereumchain profile to interact with the contracts
- --use-custom-chain
- To use custom-chainchain profile to interact with the contracts
- --use-local
- To use localchain profile to interact with the contracts
- --help
- Show the help message and exit.
Examples
Analyse the AI agent valory/hello_world using
autonomy analyse service --public-id valory/hello_world
Analyse an on-chain AI agent with token ID 1 using
autonomy analyse service --token-id 1