Skip to content

loonwerks/AgreeDog

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

95 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

AgreeDog

AgreeDog is an AI-Copilot for the AGREE tool, designed to enhance AADL-based system design and analysis. It provides counterexample explanations and contract updates, assisting engineers in automating proof synthesis and repair. By leveraging AI capabilities, AgreeDog improves the efficiency and reliability of system verification processes.

We recently presented a workshop paper [ERSA24] on AgreeDog and are actively developing a command-line interface for seamless integration into automated pipelines. The first official release is expected in Spring 2025.

How to Run Agree-Dog from the Command Line

You can run the INSPECTA-Dog application directly from the command line.
First, ensure you have activated your Python virtual environment (tested on python 3.9.7):

Setup Instructions

  1. Clone the Repository Run the following command to clone the repository and navigate into the project directory:

    git clone https://github.com/loonwerks/AgreeDog.git
    cd AgreeDog
  2. Create a Virtual Environment to isolate the project dependencies:

    python3 -m venv venv
  3. Activate your virtual environment (as applicable):

    On Unix-like systems:

    source venv/bin/activate

    On Windows (Command Prompt):

    venv\Scripts\activate
  4. Install the required dependencies:

    pip install -r requirements.txt
  5. Run the script with --help to see available options:

    python INSPECTA_Dog.py --help

    e.g., on Windows:

       PS C:\Users\amer_\AgreeDog> python INSPECTA_Dog.py --help
       usage: INSPECTA_Dog.py [-h] [--working-dir WORKING_DIR] [--user-open-api-key USER_OPEN_API_KEY]
       [--counter-example COUNTER_EXAMPLE] [--start-file START_FILE]

Example Usage

python INSPECTA_Dog.py --working-dir path/to/work_dir --start-file MySystem.aadl --counter-example path/to/counter_example.txt --user-open-api-key [YOUR_API_KEY_HERE]

You can adjust these paths and options as needed.

on Linux

  1. Example of cli:
python INSPECTA_Dog.py \
  --working-dir /home/AgreeDog/uploaded_dir/car/packages \
  --counter-example /home/AgreeDog/counter_examples/car_model_cex_3.txt \
  --start-file Car.aadl \
  --user-open-api-key [YOUR_API_KEY_HERE]

on Windows

  1. Example of cli:
python INSPECTA_Dog.py \
  --working-dir C:\Users\AgreeDog\uploaded_dir\car\packages \
  --counter-example C:\Users\AgreeDog\counter_examples\car_model_cex_3.txt\
  --start-file Car.aadl \
  --user-open-api-key [YOUR_API_KEY_HERE]

Note: The --user-open-api-key option is optional. If you prefer, you can save your API key in the .env file located in the AgreeDog directory. If no key is provided, the application will attempt to read it from .env.

Debugging Instructions

To enable or disable debugging mode in INSPECTA_Dog.py:

  1. Comment out the first two lines of INSPECTA_Dog.py: These lines are specifically meant for debugging mode.

  2. Set the debug flag in the last line of the file to False: This ensures that the application runs without debugging enabled.

    Note: Debugging mode is designed for development purposes. In this mode, you can set up a PyCharm debug configuration and specify the command-line flags one time. This allows you to save time while testing and debugging your application.