Skip to main content

A Python package for the Cicada project

Project description

CICADA: Collaborative Intelligent CAD Automation Design Agent

中文 | English

Welcome to CICADA, the Collaborative Intelligent CAD Automation Design Agent. CICADA is a cutting-edge framework designed to streamline and enhance the CAD design process through intelligent automation and collaboration. This repository contains the core modules and utilities that power CICADA, enabling seamless integration with CAD workflows.

📖 Documentation: Explore comprehensive guides, tutorials, and API references at our official documentation site: CICADA Documentation

For quick setup and usage instructions, continue reading below.


Repository Structure

The repository is organized into the following main modules:

  • core: Core utilities and shared functionalities across the framework.
  • geometry_pipeline: Tools for processing and converting 3D models, including point cloud generation and snapshots.
  • describe: Components for generating and managing descriptive metadata for 3D models.
  • coding: Code generation, execution, and debugging tools for CAD automation.
  • feedbacks: Modules for analyzing and providing feedback on design iterations.
  • retrieval: Tools for retrieving and management of documentation, model data, and design resources.
  • workflow: Orchestration of CICADA's automation workflows and agent management.

Setting Up the Environment

Prerequisites

Before setting up CICADA, ensure you have the following installed:

  • Python 3.10+
  • Conda or pip (for dependency management)

Installation Steps (Quick Start)

# activate your venv or conda env first
pip install cicada-agent

CodeCAD Modules

pip install cicada-agent[codecad]

Installation Steps (For Developers)

1. Clone the Repository

git clone https://github.com/Oaklight/cicada.git
cd cicada

2. Install Dependencies

Always recommend to use conda or other tool to make an exclusive dev environment for CICADA

conda env create -f environment.yml
conda activate cicada

Then install local repo as pip package, remember you need to have [all] to build docs

pip install -e . # for just `core` features
pip install -e .[codecad] # for codecad related
pip install -e .[all] # for everything here

3. Update API Keys

The provided API keys in the config files are deprecated. Update the api_key and api_base_url in config.yaml or config/*.yaml in each module:


Key Modules and Usage

geometry_pipeline

  • convert.py: Converts 3D models (STEP, OBJ, STL) to point cloud data (PLY) or other formats.

    python geometry_pipeline/convert.py --step_file <path_to_step_file> --convert_step2obj
    

    Options:
    --convert_step2obj, --convert_obj2pc, --convert_step2stl, --convert_obj2stl, --convert_stl2obj, --convert_stl2pc, --reaxis_gravity

  • snapshots.py: Generates preview snapshots of 3D models from multiple angles.

    python geometry_pipeline/snapshots.py --step_file <path_to_step_file> --snapshots
    

    Options:
    --obj_file, --step_file, --stl_file, -o OUTPUT_DIR, -r RESOLUTION, -d DIRECTION, -p, --reaxis_gravity

describe

  • describer_v2.py: Generates descriptive metadata for 3D models using advanced language models.
    python describe/describer_v2.py "Describe the 3D model" --config <path_to_config> --prompts <path_to_prompts>
    
    Options:
    --config CONFIG, --prompts PROMPTS, -img REF_IMAGES, -o OUTPUT

coding

  • coder.py: Generates CAD scripts based on design goals.
    python coding/coder.py "Design a mechanical part" --config <path_to_config> --prompts <path_to_prompts>
    
    Options:
    --config CONFIG, --master_config_path MASTER_CONFIG_PATH, --prompts PROMPTS, -o OUTPUT_DIR

feedbacks

  • visual_feedback.py: Analyzes rendered images of a design against the design goal.
    python feedbacks/visual_feedback.py --design_goal "Design a mechanical part" --rendered_images <path_to_images>
    
    Options:
    --config CONFIG, --prompts PROMPTS, --reference_images REFERENCE_IMAGES, --rendered_images RENDERED_IMAGES

retrieval

  • tools/build123d_retriever.py: Retrieves and manages documentation for CAD tools and libraries.

    python retrieval/tools/build123d_retriever.py [--force-rebuild] [--interactive] [--metric {l2,cosine}] [--query QUERY] [--debug]
    

    Options:
    --force-rebuild: Force rebuild the database.
    --interactive: Run in interactive mode to ask multiple questions.
    --metric {l2,cosine}: Distance metric to use for similarity search.
    --query QUERY: Query text to search in the database.
    --debug: Enable debug mode for detailed logging.

    Examples:
    Interactive mode:

    python retrieval/tools/build123d_retriever.py --interactive
    

    Single query:

    python retrieval/tools/build123d_retriever.py --query "How to extrude a shape?"
    

workflow

  • codecad_agent.py: Orchestrates the automation workflows for CAD design.

    python workflow/codecad_agent.py "Design a mechanical part" --config <path_to_config> --prompts <path_to_prompts>
    

    Options:
    --config CONFIG: Path to the configuration file.
    --prompts PROMPTS: Path to the prompts file.
    -img REF_IMAGES: Path to reference images (optional).
    -o OUTPUT_DIR: Directory to save output files (optional).

    Example:

    python workflow/codecad_agent.py "Design a mechanical part" --config workflow/config/code-llm.yaml --prompts workflow/prompts/code-llm.yaml -o output/
    

Contributing

We welcome contributions from the community! If you'd like to contribute to CICADA, please follow these steps:

  1. Fork the repository.
  2. Create a new branch for your feature or bugfix.
  3. Submit a pull request with a detailed description of your changes.

License

CICADA is licensed under the MIT License. For more details, see the LICENSE file.


Contact

For questions, feedback, or support, please post via GitHub Issues or contact us at [dingpeng]@@uchicago[dot]edu.


Citation

If you use Cicada in your research, please consider citing:

@software{Cicada,
  author = {Peng Ding},
  title = {Cicada: Collaborative Intelligent CAD Automation Design Agent},
  month = {January},
  year = {2025},
  url = {https://github.com/Oaklight/cicada}
}

CICADA — Revolutionizing CAD Design with Intelligent Automation. 🚀

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cicada_agent-0.7.4.tar.gz (68.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cicada_agent-0.7.4-py3-none-any.whl (84.2 kB view details)

Uploaded Python 3

File details

Details for the file cicada_agent-0.7.4.tar.gz.

File metadata

  • Download URL: cicada_agent-0.7.4.tar.gz
  • Upload date:
  • Size: 68.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.0

File hashes

Hashes for cicada_agent-0.7.4.tar.gz
Algorithm Hash digest
SHA256 c634507c14776c8e19950d237623db794d7e2539489fc947bf9d8af52606cc53
MD5 a1cfd69c1e3f6eac8ebf9fdbc1e94399
BLAKE2b-256 aa1ee955b4274ac64896522ba60e2619ce7972f40c278956dd39e1a6dd0416eb

See more details on using hashes here.

File details

Details for the file cicada_agent-0.7.4-py3-none-any.whl.

File metadata

  • Download URL: cicada_agent-0.7.4-py3-none-any.whl
  • Upload date:
  • Size: 84.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.0

File hashes

Hashes for cicada_agent-0.7.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a3ae5d78020c76160d58f78c503a119acd7d51bbb2a1874068abf4a00e38275e
MD5 7e641f0ae7cfc8b99ec29fb8d673a9d2
BLAKE2b-256 add27f51bff40ab95438b5fe2ebf6e5db68fc4a7995239d45d3532fedd7df268

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page