manim-eng is a plugin for the Manim Community animation engine that introduces symbols and utilities for drawing engineering diagrams. Currently this only includes circuits, but the goal is to extend this to structures in the future as well.
Quite simply, because the other options available just don't cut it for me. The manim-circuit plugin, which was released during early development of this plugin, comes closer to what I want, but still isn't quite there. My goal can be summed up as 'manim-eng should be to ManimCE what CircuiTikZ is to LaTeX'. This means:
- Easy to configure and automatically placed labels, annotations, and current and voltage indications.
- Automatic, sensible animations for when these labels are introduced, removed, or changed.
- Automatic component connections.
- Ability to specify component types (i.e. European or American), with as much or as little granularity as you wish.
Those who know CircuiTikZ will know that it can't actually do all of the above, but why not make something better than your inspiration? On top of these features, I wanted a clean, intuitive, Pythonic interface to the library. No available option that I could find had all of this. Making my own was also an excellent way to get familiar with Manim, and a fun project.
Head over to the documentation to get started with your first circuit diagrams!
manim-eng, like Manim itself, uses Poetry as a build system. You will need Poetry installed before proceeding. First, clone the repository with Git:
git clone https://github.com/overegneered/manim-eng.gitThen install dependencies with Poetry:
poetry installFinally, install the pre-commit hooks:
pre-commit installmanim-eng uses pytest as a testing framework. To run the test suite, you can use
poetry run pytestthough using an IDE integration, such as PyCharm's pytest runner, may be easier!
If you use this project in your work, I ask that you cite it using the information contained in the CITATION.cff file. The easiest way to do this is to go to the repository page on GitHub and click on 'Cite this repository'. For more info on CITATION.cff files, check out this website.
This project is mostly licenced under the MIT licence, like Manim itself. However, I specifically revoke any right or permissions to use the contents of this repository for the training of AI models without my prior written approval.
