<p align="center">
<picture>
<img alt="K-Scale Open Source Robotics" src="https://media.kscale.dev/kscale-open-source-header.png" style="max-width: 100%;">
</picture>
</p>
<div align="center">
[![License](https://img.shields.io/badge/license-MIT-green)](https://github.com/kscalelabs/onshape/blob/main/LICENSE)
[![Version](https://img.shields.io/pypi/v/kscale-onshape-library)](https://pypi.org/project/kscale-onshape-library/)
[![Discord](https://img.shields.io/discord/1224056091017478166)](https://discord.gg/k5mSvCkYQh)
[![Wiki](https://img.shields.io/badge/wiki-humanoids-black)](https://humanoids.wiki)
<br />
[![python](https://img.shields.io/badge/-Python_3.11-blue?logo=python&logoColor=white)](https://github.com/pre-commit/pre-commit)
[![black](https://img.shields.io/badge/Code%20Style-Black-black.svg?labelColor=gray)](https://black.readthedocs.io/en/stable/)
[![ruff](https://img.shields.io/badge/Linter-Ruff-red.svg?labelColor=gray)](https://github.com/charliermarsh/ruff)
<br />
[![Publish Python Package](https://github.com/kscalelabs/onshape/actions/workflows/publish.yml/badge.svg)](https://github.com/kscalelabs/onshape/actions/workflows/publish.yml)
[![Python Checks](https://github.com/kscalelabs/onshape/actions/workflows/test.yml/badge.svg)](https://github.com/kscalelabs/onshape/actions/workflows/test.yml)
</div>
# K-Scale OnShape Library
This library is what we use at K-Scale for interacting with OnShape. It is a wrapper around the OnShape API that allows us to easily import parts from OnShape into our projects.
### Getting Started
Install the library using pip:
```bash
pip install kscale-onshape-library
pip install 'kscale-onshape-library @ git+https://github.com/kscalelabs/onshape.git@master' # Install from Github
pip install 'kscale-onshape-library[all]' # Install all dependencies
```
In order to access the OnShape API, you need to define `ONSHAPE_ACCESS_KEY` and `ONSHAPE_SECRET_KEY` using a key generated [here](https://dev-portal.onshape.com/keys).
### Usage
To download and postprocess an assembly, run:
```bash
kol run https://cad.onshape.com/documents/DDDDDDDD/w/WWWWWWWW/e/EEEEEEEE
```
An example run with a config file to download Stompy Mini:
```bash
kol run https://cad.onshape.com/documents/50fe60f593f5c98e8f52552c/w/23cfc61ce40dd25ad76f414c/e/9c37b547deaa42ff258901fe -c config_example.json
```
By default, this will automatically generate both a URDF and MJCF file.
You can visualize the resulting artifacts using MuJoCo Viewer:
```bash
python -m mujoco.viewer
```
For URDF files it's sometimes necessary to first drag the file into the meshes folder before viewing it.
You can also visualize the resulting URDF using PyBullet:
```bash
pip install pybullet
kol pybullet robot/<urdf-name>.urdf
```
### Simulation
The output of the onshape library is simply a robot floating in space. Luckily, most simulators which support URDFs are able to define an environment within code. More changes are needed to make MJCF files simulation ready. We have support for adapting MJCF files to isaac sim here: https://github.com/kscalelabs/sim/blob/master/sim/scripts/create_mjcf.py.
It will be useful to create more automatic scripts for adapting raw URDF and MJCF to various simulators. Feel free to contribute! Support for other file formats like USD files for IsaacLab will be helpful as well.
### Tips and Suggestions
- To avoid mishaps from occuring due to cached files, if making big changes in a single export, or if the robot has undergone major changes since the last export, it's good to start fresh with a new `/robot/` folder.
- There's no guarantee that the robot's starting pose (when all joint positions are set to 0) will be good, or even matching what you see on onshape. It's reccomended to use MuJoCo Viewer to find a good starting position for each joint.
- Robots function much better in simulation when they have less parts. It's very good to make sure that link names are descriptive in onshape so small parts can be better removed using `--skip-small-parts`. This will also make export faster.
- When using functions that can be destructive like `simplify-meshes`, `merge-joints`, and especially `cleanup-mesh-dir`, it's good to make copies of the STL files elsewhere first.
### Development
Since this is a library, it's necessary to upversion after big changes. You can do this by changing the version number in `kol/__init__.py`, then running the Github Action to publish a new version.
Please keep this repo well linted! Specifically, it is quite easy to run into errors with mypy since many of the functions and variables have ambiguous types. To check which files have issues locally, run `mypy kol` and `make static-checks`. Many mypy issues can be alleviated with one of the following:
- Ensure that type annotations properly include `None` when necessary. This is especially important for functions.
- Make good use of classes to ensure everything is well typed. See `kol/onshape/schema/assembly.py`.
- When using functions such as `dict.find`, use a `None` check to guarantee that variable accesses are safe
- Make sure docstrings are descriptive and that there's one for every function, even if it seems trivial. This makes mouseovers and references to those functions much easier elsewhere.
- Save often to make sure that black and ruff don't get confused.
If creating new features, new files that get created that are large/have too many of them should be added to the `.gitignore`.
### Notes
- [OnShape API explorer](https://cad.onshape.com/glassworks/explorer/#/Assembly/getFeatures)
- [OnShape API documentation](https://onshape-public.github.io/docs/api-intro/)
- [OnShape-to-Robot Library](https://github.com/Rhoban/onshape-to-robot)
Raw data
{
"_id": null,
"home_page": "https://github.com/kscalelabs/onshape",
"name": "kscale-onshape-library",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.11",
"maintainer_email": null,
"keywords": null,
"author": "Benjamin Bolte",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/68/76/806310bf8aba7848636ae0d53ad5a1106e155226779b7ffefc735e6b54f2/kscale_onshape_library-0.1.3.tar.gz",
"platform": null,
"description": "<p align=\"center\">\n <picture>\n <img alt=\"K-Scale Open Source Robotics\" src=\"https://media.kscale.dev/kscale-open-source-header.png\" style=\"max-width: 100%;\">\n </picture>\n</p>\n\n<div align=\"center\">\n\n[![License](https://img.shields.io/badge/license-MIT-green)](https://github.com/kscalelabs/onshape/blob/main/LICENSE)\n[![Version](https://img.shields.io/pypi/v/kscale-onshape-library)](https://pypi.org/project/kscale-onshape-library/)\n[![Discord](https://img.shields.io/discord/1224056091017478166)](https://discord.gg/k5mSvCkYQh)\n[![Wiki](https://img.shields.io/badge/wiki-humanoids-black)](https://humanoids.wiki)\n<br />\n[![python](https://img.shields.io/badge/-Python_3.11-blue?logo=python&logoColor=white)](https://github.com/pre-commit/pre-commit)\n[![black](https://img.shields.io/badge/Code%20Style-Black-black.svg?labelColor=gray)](https://black.readthedocs.io/en/stable/)\n[![ruff](https://img.shields.io/badge/Linter-Ruff-red.svg?labelColor=gray)](https://github.com/charliermarsh/ruff)\n<br />\n[![Publish Python Package](https://github.com/kscalelabs/onshape/actions/workflows/publish.yml/badge.svg)](https://github.com/kscalelabs/onshape/actions/workflows/publish.yml)\n[![Python Checks](https://github.com/kscalelabs/onshape/actions/workflows/test.yml/badge.svg)](https://github.com/kscalelabs/onshape/actions/workflows/test.yml)\n\n</div>\n\n# K-Scale OnShape Library\n\nThis library is what we use at K-Scale for interacting with OnShape. It is a wrapper around the OnShape API that allows us to easily import parts from OnShape into our projects.\n\n### Getting Started\n\nInstall the library using pip:\n\n```bash\npip install kscale-onshape-library\npip install 'kscale-onshape-library @ git+https://github.com/kscalelabs/onshape.git@master' # Install from Github\npip install 'kscale-onshape-library[all]' # Install all dependencies\n```\n\nIn order to access the OnShape API, you need to define `ONSHAPE_ACCESS_KEY` and `ONSHAPE_SECRET_KEY` using a key generated [here](https://dev-portal.onshape.com/keys).\n\n### Usage\n\nTo download and postprocess an assembly, run:\n\n```bash\nkol run https://cad.onshape.com/documents/DDDDDDDD/w/WWWWWWWW/e/EEEEEEEE\n```\nAn example run with a config file to download Stompy Mini:\n```bash\nkol run https://cad.onshape.com/documents/50fe60f593f5c98e8f52552c/w/23cfc61ce40dd25ad76f414c/e/9c37b547deaa42ff258901fe -c config_example.json\n```\n\nBy default, this will automatically generate both a URDF and MJCF file.\n\nYou can visualize the resulting artifacts using MuJoCo Viewer:\n\n```bash\npython -m mujoco.viewer\n```\n\nFor URDF files it's sometimes necessary to first drag the file into the meshes folder before viewing it. \n\nYou can also visualize the resulting URDF using PyBullet:\n\n```bash\npip install pybullet\nkol pybullet robot/<urdf-name>.urdf\n```\n\n### Simulation\n\nThe output of the onshape library is simply a robot floating in space. Luckily, most simulators which support URDFs are able to define an environment within code. More changes are needed to make MJCF files simulation ready. We have support for adapting MJCF files to isaac sim here: https://github.com/kscalelabs/sim/blob/master/sim/scripts/create_mjcf.py.\n\nIt will be useful to create more automatic scripts for adapting raw URDF and MJCF to various simulators. Feel free to contribute! Support for other file formats like USD files for IsaacLab will be helpful as well.\n\n### Tips and Suggestions\n\n- To avoid mishaps from occuring due to cached files, if making big changes in a single export, or if the robot has undergone major changes since the last export, it's good to start fresh with a new `/robot/` folder. \n- There's no guarantee that the robot's starting pose (when all joint positions are set to 0) will be good, or even matching what you see on onshape. It's reccomended to use MuJoCo Viewer to find a good starting position for each joint.\n- Robots function much better in simulation when they have less parts. It's very good to make sure that link names are descriptive in onshape so small parts can be better removed using `--skip-small-parts`. This will also make export faster.\n- When using functions that can be destructive like `simplify-meshes`, `merge-joints`, and especially `cleanup-mesh-dir`, it's good to make copies of the STL files elsewhere first.\n\n### Development\n\nSince this is a library, it's necessary to upversion after big changes. You can do this by changing the version number in `kol/__init__.py`, then running the Github Action to publish a new version. \n\nPlease keep this repo well linted! Specifically, it is quite easy to run into errors with mypy since many of the functions and variables have ambiguous types. To check which files have issues locally, run `mypy kol` and `make static-checks`. Many mypy issues can be alleviated with one of the following:\n\n- Ensure that type annotations properly include `None` when necessary. This is especially important for functions.\n- Make good use of classes to ensure everything is well typed. See `kol/onshape/schema/assembly.py`. \n- When using functions such as `dict.find`, use a `None` check to guarantee that variable accesses are safe\n- Make sure docstrings are descriptive and that there's one for every function, even if it seems trivial. This makes mouseovers and references to those functions much easier elsewhere. \n- Save often to make sure that black and ruff don't get confused. \n\nIf creating new features, new files that get created that are large/have too many of them should be added to the `.gitignore`. \n\n### Notes\n\n- [OnShape API explorer](https://cad.onshape.com/glassworks/explorer/#/Assembly/getFeatures)\n- [OnShape API documentation](https://onshape-public.github.io/docs/api-intro/)\n- [OnShape-to-Robot Library](https://github.com/Rhoban/onshape-to-robot)\n",
"bugtrack_url": null,
"license": null,
"summary": "K-Scale's library for programmatically interacting with OnShape",
"version": "0.1.3",
"project_urls": {
"Homepage": "https://github.com/kscalelabs/onshape"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "5c25ab776e2baf22a982b942c912e46fc939e93038e714b10eeb50a03efa6529",
"md5": "7bbc3052062297981b63a1bc7119afac",
"sha256": "4629ab9761fcb85c190a164d414f7d161ded7fa7fa9268dcee30ca049a27edea"
},
"downloads": -1,
"filename": "kscale_onshape_library-0.1.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "7bbc3052062297981b63a1bc7119afac",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.11",
"size": 66118,
"upload_time": "2024-10-23T08:20:26",
"upload_time_iso_8601": "2024-10-23T08:20:26.968417Z",
"url": "https://files.pythonhosted.org/packages/5c/25/ab776e2baf22a982b942c912e46fc939e93038e714b10eeb50a03efa6529/kscale_onshape_library-0.1.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "6876806310bf8aba7848636ae0d53ad5a1106e155226779b7ffefc735e6b54f2",
"md5": "3dbdb32cfc1915298cf2bc87e6dd065a",
"sha256": "cd75bb4a349f87e7ab427219eced9c50e8ef4ae9a524c261d798bdf61fd0ad3d"
},
"downloads": -1,
"filename": "kscale_onshape_library-0.1.3.tar.gz",
"has_sig": false,
"md5_digest": "3dbdb32cfc1915298cf2bc87e6dd065a",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.11",
"size": 57561,
"upload_time": "2024-10-23T08:20:28",
"upload_time_iso_8601": "2024-10-23T08:20:28.388832Z",
"url": "https://files.pythonhosted.org/packages/68/76/806310bf8aba7848636ae0d53ad5a1106e155226779b7ffefc735e6b54f2/kscale_onshape_library-0.1.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-23 08:20:28",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "kscalelabs",
"github_project": "onshape",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "kscale-onshape-library"
}