EngScript is an experimental library aiming to provide fast OpenSCAD-like, python tool, with integrated rendering and assembly capabilities
Project description
EngScript
What is EngScript
EngScript is an experimental library aiming to provide fast OpenSCAD-like, python tool, with integrated rendering and assembly capabilities.
Ideally EngScript will eventually be able to support complex projects like the OpenFlexure microscope.
Installation
The project is not yet on PyPi, so you have to clone this repository and install directly.
To install EngScript you must have Python 3.10 or greater installed, and pip installed. You can then run:
pip install engscript
from your terminal.
A more complete getting started guide is available.
Why write another code CAD program?
This is a fair question. The open source code-CAD space is very crowded, and there is arguably very little to gain from creating another similar tool. This tool is experimental and is based on extensive experience building complex hardware in OpenSCAD.
We created the OpenFlexure Microscope in OpenSCAD (repo). OpenSCAD allowed us to build a very compact, complex, precision translation stage for 3D printing a microscope body. We also have written a lot of custom assembly scripts allowing us to automatically generate the images for our assembly instructions in OpenSCAD:
While OpenSCAD has taken us a long way we still have issues with:
- A lack of language specific tools such linters (we wrote our own SCAD linter), unit test frameworks, package managers, etc.
- Difficulty handling data for a large complex project
- Speed issues
- Faulty meshs
As OpenSCAD moves to the manifold kernel the mesh quality and speed will improve. But a project the size and complexity of OpenFlexure really feels that it needs advanced language features and tools that OpenSCAD. For this it makes sense to look for an alternative in an established general purpose language.
Other options include:
- CadQuery - CadQuery is a really ambitious project, bringing full B-rep modelling (and STEP file compatibility) to the open source code CAD world. Moving away from meshes would open up opportunities outside 3D printing. For OpenFlexure the microscope is designed entirely around 3D printing, and relies heavily on operations not supported in the underlying OCC kernel. Porting to CadQuery would be a huge task, and would require a lot of work on CADQuery to reproduce our renders (This work is ongoing in CadQuery and is very exciting).
- Python OpenSCAD - Another cool project which brings Python to OpenSCAD. However, as the python runs within OpenSCAD this ties the project still to many of the pitfalls of the OpenSCAD internals. I also worry that this approach makes it hard to run python virtual environments so that different projects can have different libraries installed, and so that packages can be handled with a package manager.
- Web-based CAD such as ManifoldCAD - The web provides easy options for getting started, nothing to install, just start coding. However, I think that as a project becomes more complex and has multiple files and even external packages this simplicity goes away. Either you need a fully hosted solution with storage, multiple files, and package management; or you need to run things locally, hosting dev servers, installing packages with npm. I don't see an easy way for this to scale.
- One of the many other PythonCADs - There are lots of other programs similar to EngScript which are Python based, using the same or different underlying kernel. While many look really cool, none I found seem to be very mature and stable. (Not that EngScript is mature or stable either).
The purpose of EngScript is to take all the lessons we learned in creating the OpenFlexure in OpenSCAD, the lessons we learned making auto-updating rendered assembly manuals, and the lessons collaborating on the code with a growing community. EngScript doesn't offer to solve these problems yet, but it is a space for us to experiment with features that are needed for complex projects. A key focus of this will be object oriented code so that object properties can be queried during the design process. This should help mitigate some data handling issues, but should also make it easier to capture design intent.
EngScript may be a successful new code CAD program adopted by the OpenFlexure project. It may just be a place to try new things and to learn from that experience.
Should I use EngScript
- If you want to play around with something new - Yes
- If you want to help develop it - Very yes
- If you want a good stable CAD package - Nope!
See also
This package heavily uses manifold and trimesh.
It also too a lot of inspiration from badcad.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file engscript-0.0.1.tar.gz
.
File metadata
- Download URL: engscript-0.0.1.tar.gz
- Upload date:
- Size: 720.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8121fbe21eb83764773462f07f40189d7f68d2b7c53b8ffc5b0a360ed9a7f7e9 |
|
MD5 | 7bd76b5161762de28478a0dd874c6041 |
|
BLAKE2b-256 | 128332afd667d4812254adc03a3d782922e0650b91a32a95f278660109834efb |
File details
Details for the file engscript-0.0.1-py3-none-any.whl
.
File metadata
- Download URL: engscript-0.0.1-py3-none-any.whl
- Upload date:
- Size: 40.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ff749dfcc43bc3665f54261ea6fbedcfb377a0d772005c759cffcda9b32cfd54 |
|
MD5 | 6cf61ff5b668ce1c0e2c81b48c16a078 |
|
BLAKE2b-256 | fc544f38fdcf76848066644defaa1f19449f4055fab2fe72ddc68bc3ffd10676 |