Skip to main content

K-Scale's library for programmatically interacting with OnShape

Project description

K-Scale Open Source Robotics

License Version Discord Wiki
python black ruff
Publish Python Package Python Checks

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:

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.

Usage

To download and postprocess an assembly, run:

kol run https://cad.onshape.com/documents/DDDDDDDD/w/WWWWWWWW/e/EEEEEEEE

An example run with a config file to download Stompy Mini:

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:

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:

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

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

kscale_onshape_library-0.1.3.tar.gz (57.6 kB view details)

Uploaded Source

Built Distribution

kscale_onshape_library-0.1.3-py3-none-any.whl (66.1 kB view details)

Uploaded Python 3

File details

Details for the file kscale_onshape_library-0.1.3.tar.gz.

File metadata

File hashes

Hashes for kscale_onshape_library-0.1.3.tar.gz
Algorithm Hash digest
SHA256 cd75bb4a349f87e7ab427219eced9c50e8ef4ae9a524c261d798bdf61fd0ad3d
MD5 3dbdb32cfc1915298cf2bc87e6dd065a
BLAKE2b-256 6876806310bf8aba7848636ae0d53ad5a1106e155226779b7ffefc735e6b54f2

See more details on using hashes here.

File details

Details for the file kscale_onshape_library-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for kscale_onshape_library-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 4629ab9761fcb85c190a164d414f7d161ded7fa7fa9268dcee30ca049a27edea
MD5 7bbc3052062297981b63a1bc7119afac
BLAKE2b-256 5c25ab776e2baf22a982b942c912e46fc939e93038e714b10eeb50a03efa6529

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page