generated from blooop/python_template
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add docs env and generator task in pixi
- Loading branch information
Showing
4 changed files
with
542 additions
and
14 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,18 +1,143 @@ | ||
Intro | ||
PyRCF | ||
===== | ||
|
||
Python Robot Control Framework | ||
|Python| |GitHub release| |License| | ||
|
||
A Python Robot Control Framework for quickly prototyping control | ||
algorithms for different robot embodiments. | ||
|
||
## Continuous Integration Status | ||
Primarily, this library provides an implementation of a typical control | ||
loop (via a ``MinimalCtrlLoop`` (extended from | ||
``SimpleManagedCtrlLoop``) class), and defines interfaces for the | ||
components in a control loop that can be used directly in these control | ||
loop implementations. It also provides utility and debugging tools that | ||
will be useful for developing controllers and planners for different | ||
robots. This package also provides implementations of basic controllers | ||
and planners. | ||
|
||
[data:image/s3,"s3://crabby-images/58d8b/58d8b4d16aa9d6216c3fd7b57225cce8d6284254" alt="Ci"](https://github.com/justagist/pyrcf/actions/workflows/ci.yml?query=branch%3Amain) | ||
[data:image/s3,"s3://crabby-images/3d60a/3d60a83470c10df91bc8d2bc4eb6b8fc09a3f2d9" alt="Codecov"](https://codecov.io/gh/justagist/pyrcf) | ||
[data:image/s3,"s3://crabby-images/6abc3/6abc3af757adf255a6f6970a18302e5b44b15dd7" alt="GitHub issues"](https://github.com/justagist/pyrcf/issues/) | ||
[data:image/s3,"s3://crabby-images/0cf39/0cf399c93ae53746eca0dc8b0840c809dd047d6f" alt="GitHub pull-requests merged"](https://github.com/justagist/pyrcf/pulls?q=is%3Amerged) | ||
[data:image/s3,"s3://crabby-images/d0e1c/d0e1cf7c2415fe95db016f6050c13468288c95b4" alt="GitHub release"](https://github.com/justagist/pyrcf/releases/) | ||
[data:image/s3,"s3://crabby-images/fe9c3/fe9c37a51df74ba58c1ec1bc4b4497906db2c5bd" alt="License"](https://opensource.org/license/mit/) | ||
[data:image/s3,"s3://crabby-images/1a293/1a2936fe2bfab5747778efc2386464e455fd6434" alt="Python"](https://www.python.org/downloads/release/python-310/) | ||
In the long run, this package will also provide implementations of | ||
popular motion planners and controllers from literature and using | ||
existing libraries. | ||
|
||
[!WARNING] **THIS PROJECT IS STILL IN ACTIVE DEVELOPMENT.** | ||
|
||
To set up your project run the vscode task "pull updates from template repo" and then task "rename project template name" | ||
Continuous Integration Status | ||
----------------------------- | ||
|
||
|Ci| |Codecov| |GitHub issues| |GitHub pull-requests merged| | ||
|
||
Installation | ||
------------ | ||
|
||
From pypi | ||
~~~~~~~~~ | ||
|
||
|PyPI version| | ||
|
||
- ``pip install pyrcf`` | ||
|
||
From source | ||
~~~~~~~~~~~ | ||
|
||
- Clone repo and run from inside the directory ``pip install .`` | ||
(recommended to use virtual env) or run ``pixi install`` (if using | ||
`Pixi <https://pixi.sh>`__). | ||
|
||
Testing Installation | ||
~~~~~~~~~~~~~~~~~~~~ | ||
|
||
After installation, you should be able to run a robot visualiser script | ||
installed globally called ``pyrcf-visualise-robot``. Run it with the | ||
first argument as any of the robot descriptions mentioned in the | ||
`robot_descriptions.py | ||
repo <https://github.com/robot-descriptions/robot_descriptions.py/tree/main?tab=readme-ov-file#descriptions>`__; | ||
e.g. ``pyrcf-visualise-robot pepper_description``. This should start a | ||
visualiser in pybullet, where you should be able to move all robot | ||
joints and base pose using sliders in the pybullet GUI. | ||
|
||
You should also be able to run all the scripts in the ``examples`` | ||
folder. | ||
|
||
**More examples and demos will be added soon.** | ||
|
||
PyRCF Philosophy | ||
---------------- | ||
|
||
PyRCF follows the principle of a single thread control loop where | ||
components are communicating with each other strictly using pre-defined | ||
message types, and run sequentially. | ||
|
||
PyRCF is designed to be a prototyping tool to test different controllers | ||
and algorithms in simulation, and **NOT** optimised for real-time | ||
control on a real robot. Although the framework has been tested on real | ||
robot interfaces, it is not recommended to do so unless you know what | ||
you are doing. | ||
|
||
A generic control loop | ||
~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
.. code:: text | ||
LOOP: | ||
# Read latest robot state | ||
robot_state = ROBOT_INTERFACE->read_robot_state() | ||
# Update robot state with estimations (when all states are not directly measurable) | ||
robot_state = STATE_ESTIMATOR->update_robot_state_estimates(robot_state) | ||
# Generate global plan (high-level task objective or target) | ||
global_plan = GLOBAL_PLANNER->generate_global_plan() | ||
# Generate local plan based on state and global plan | ||
local_plan = LOCAL_PLANNER->generate_local_plan(robot_state, global_plan) | ||
# Generate control command based on state and local plan | ||
cmd = CONTROLLER->compute_commands(robot_state, local_plan) | ||
# Send command to robot | ||
ROBOT_INTERFACE->write_robot_command(cmd) | ||
# Maintain loop frequency (naive implementation) | ||
SLEEP(period) | ||
END LOOP | ||
This package provides interfaces to define custom components (such as | ||
controller, robot interface, global planner, local planner, etc) that | ||
can be run in a control loop, as well as provides an implementation of a | ||
control loop class which can execute these components in the required | ||
order at the specified rate. Implementations of simple forms of all | ||
components are also available in this package, including simulated | ||
interfaces for many robot embodiments. | ||
|
||
Custom controllers and planners can be implemented and quickly tested on | ||
existing robot interfaces or on custom robot interfaces (which can be | ||
easily defined). | ||
|
||
More complex algorithms for control and planning will be provided by | ||
this package over time. | ||
|
||
Tutorials and more details about concepts will be provided soon in the | ||
`tutorials <https://github.com/justagist/pyrcf/tree/main/examples/tutorials>`__ folder. | ||
|
||
|Pixi Badge| | ||
|
||
.. |Python| image:: https://img.shields.io/badge/python-3.10%20%7C%203.11%20%7C%203.12-blue | ||
:target: https://www.python.org/downloads/ | ||
.. |GitHub release| image:: https://img.shields.io/github/release/justagist/pyrcf.svg | ||
:target: https://github.com/justagist/pyrcf/releases/ | ||
.. |License| image:: https://img.shields.io/pypi/l/bencher | ||
:target: https://opensource.org/license/mit/ | ||
.. |Ci| image:: https://github.com/justagist/pyrcf/actions/workflows/ci.yml/badge.svg?branch=main | ||
:target: https://github.com/justagist/pyrcf/actions/workflows/ci.yml?query=branch%3Amain | ||
.. |Codecov| image:: https://codecov.io/gh/justagist/pyrcf/branch/main/graph/badge.svg?token=Y212GW1PG6 | ||
:target: https://codecov.io/gh/justagist/pyrcf | ||
.. |GitHub issues| image:: https://img.shields.io/github/issues/justagist/pyrcf.svg | ||
:target: https://github.com/justagist/pyrcf/issues/ | ||
.. |GitHub pull-requests merged| image:: https://badgen.net/github/merged-prs/justagist/pyrcf | ||
:target: https://github.com/justagist/pyrcf/pulls?q=is%3Amerged | ||
.. |PyPI version| image:: https://badge.fury.io/py/pyrcf.svg | ||
:target: https://badge.fury.io/py/pyrcf | ||
.. |Pixi Badge| image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/prefix-dev/pixi/main/assets/badge/v0.json | ||
:target: https://pixi.sh |
Oops, something went wrong.