Skip to main content

Package to control CTU/CIIRC robot Bosch SR450 via MARS control unit.

Project description

BOSCH SR450 Robot at CTU/CIIRC

Package to control CTU/CIIRC robot Bosch SR450 via MARS control unit. This code is based on https://github.com/cvut/pyrocon but adds packaging, documentation, and some testing. For the complete documentation see https://robotics-robot-stations.readthedocs.io/

Installation

pip install ctu_bosch_sr450

Usage

from ctu_bosch_sr450 import RobotBosch

robot = RobotBosch()  # set argument tty_dev=None if you are not connected to robot, it will allow you to compute FK and IK offline
robot.initialize()  # initialize connection to the robot
robot.move_to_q([0.1, 0.0, 0.0, 0.0])  # move robot
robot.wait_for_motion_stop()
robot.close()  # close the connection

Kinematics

robot = RobotBosch(tty_dev=None)  # initialize object without connection to the robot
x, y, z, phi = robot.fk([0, 0, 0, 0])  # compute forward kinematics
q = robot.ik([x, y, z, phi])[0]  # compute inverse kinematics, get the first solution

Coordinate systems

The library uses meters and radians for all values. Variable q is used to denote joint configuration, i.e. the array of joint angles/joint distance for revolute and prismatic joints, respectively. Variables x, y, z, and phi are used to denote position and orientation of the end-effector in the base frame. The orientation is given as rotation around the z-axis of the base frame. The reference base frame is located as shown in the figure below.

Joint configuration

The joint configuration is defined as follows:

  • the first joint is revolute and its angle is measured w.r.t. the x-axis of the base frame
  • the second joint is revolute and is measured w.r.t. the previous link
  • the third joint is prismatic and controls the height (i.e. motion in z-axis)
  • the last joint is revolute and measured w.r.t. the x-axis of the base frame (i.e. * not* w.r.t. the previous link)

How to control the robot

In case robot does anything unexpected, press the emergency button immediately.

Starting the robot

  • power up the robot with red switch on the Mars control panel
  • create RobotBosh() instance and call initialize()
  • you will be asked to press the yellow button (Arm Power) on the Mars control panel
  • robot will perform homing after which you are able to control it with this library

Finishing the work with the robot

  • to turn robot of call soft_home() followed by the close() methods
  • turn red switch off

Entering the cage

  • to enter the cage, you need to call release() function, that will power-off the motors and activate breaks

Recovering from error

Emergency stop or cage entry

  • unblock emergency stop button and/or closed the cage
  • press red button called MotionStop on the Mars control panel
  • press yellow button called ArmPower on the Mars control panel
  • continue with normal operation

Motor error

  • in case green led above motor axis is blinking and red led is on, there is a motor error
  • to reset motors call reset_motors() method

Hard home

Hard home is needed after the control unit power was turned off. It is performed automatically in the initialize() method. However, it needs to be performed only after the power was turned off and on again. In case the connection needs to be reestablished, you can call initialize without homing by setting the argument home to False.

Acknowledgment

Preparation of the course materials was partially supported by:

For developers

git clone git@github.com:CTURobotics/ctu_bosch_sr450.git
cd ctu_bosch_sr450
uv sync
uv pip install -e ".[dev]"
pre-commit install

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

ctu_bosch_sr450-1.0.5.tar.gz (11.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ctu_bosch_sr450-1.0.5-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file ctu_bosch_sr450-1.0.5.tar.gz.

File metadata

  • Download URL: ctu_bosch_sr450-1.0.5.tar.gz
  • Upload date:
  • Size: 11.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ctu_bosch_sr450-1.0.5.tar.gz
Algorithm Hash digest
SHA256 e093ce1eb5ffded2f895d9a088d049f0fb21bab5f998e53c61a75bcebde070c8
MD5 fb7f27f95a8e4bb8d7f9bec97efe7245
BLAKE2b-256 3caa5f72c510d1694acd9b00ed384e65e684a7c7c09903fa4efb4bfb87132d8e

See more details on using hashes here.

Provenance

The following attestation bundles were made for ctu_bosch_sr450-1.0.5.tar.gz:

Publisher: release.yml on CTURobotics/ctu_bosch_sr450

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ctu_bosch_sr450-1.0.5-py3-none-any.whl.

File metadata

File hashes

Hashes for ctu_bosch_sr450-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 9e753ab87f756eb2ec5815faf87b76d799e3c33ee44c9e1500f337f0ce90ecfc
MD5 9393c31b89c8fb90a3994e8d627f4178
BLAKE2b-256 d43aded8dd3b95e651eb564ef7ee52249f94f959756a5fb69138953542500873

See more details on using hashes here.

Provenance

The following attestation bundles were made for ctu_bosch_sr450-1.0.5-py3-none-any.whl:

Publisher: release.yml on CTURobotics/ctu_bosch_sr450

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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