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.3.tar.gz (68.1 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.3-py3-none-any.whl (83.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: cicada_agent-0.7.3.tar.gz
  • Upload date:
  • Size: 68.1 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.3.tar.gz
Algorithm Hash digest
SHA256 b6d52794730c3c01ab1ba7d0f90396fd6ec86df06fd8f645eca05ec9a769e341
MD5 d4b792b7f3361bc1c2d33174b4250e51
BLAKE2b-256 cb2d40f94f47790efbf3e488beacdedd18b7d710c7970fe71b4416c495c305e9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: cicada_agent-0.7.3-py3-none-any.whl
  • Upload date:
  • Size: 83.4 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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3171f5dcb7eb3382943dd243a65fddccac654d5dc49ae13aa1b80017ab289d8e
MD5 0bae65b025044d8615f243d497953231
BLAKE2b-256 2ca6bdfb5703cc19e7f90f7a65dcb6e34a41d2ac15fcc3531bbe0621fa11f0c5

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