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.2.tar.gz (70.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.2-py3-none-any.whl (85.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: cicada_agent-0.7.2.tar.gz
  • Upload date:
  • Size: 70.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.2.tar.gz
Algorithm Hash digest
SHA256 f12af9abf6362654f20980914c6afeb7ecbd2a49ccdd5a1333f8d66a926ded43
MD5 d1bfa4b3ff5063b6da8f151761c0f64e
BLAKE2b-256 062790531f990ee5156ff746901f6780628e5efef36634bcbd1cc0e4d7f865b4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: cicada_agent-0.7.2-py3-none-any.whl
  • Upload date:
  • Size: 85.5 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4e2feaf570d88b7732e69fc09726504d3b37ff42f37012af6530a79b86d30d03
MD5 e5d008c98e6003b361cae56abb16fb4b
BLAKE2b-256 10d2f7486ad3ad7118f191796c77be5aaa24c249db2e61913d4a9a4edb6aa009

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