Skip to content

openeducationai/manim-eng

 
 

Repository files navigation

manim-eng logo


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.

Why make another circuit library?

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.

Getting started

Head over to the documentation to get started with your first circuit diagrams!

Development

Environment setup

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.git

Then install dependencies with Poetry:

poetry install

Finally, install the pre-commit hooks:

pre-commit install

Testing

manim-eng uses pytest as a testing framework. To run the test suite, you can use

poetry run pytest

though using an IDE integration, such as PyCharm's pytest runner, may be easier!

Licencing and citation

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.

About

A circuit-drawing plugin for Manim Community Edition for circuit-based diagrams and animations.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • Python 100.0%