Skip to main content

Package to control CTU/CIIRC robots CRS93 and CRS97 via MARS control unit.

Project description

CRS robots control at CTU/CIIRC

Package to control CTU/CIIRC robots CRS93 and CRS97 via MARS control unit.

Installation

pip install ctu_crs

Command-Line Scripts

This package includes command-line scripts for direct robot control from your terminal. After installing the package, you can use the move_crs97 or move_crs93 script to move the robot by a relative offset for specified joints.

Usage:

move_crs93 <joint_name> <angle_degrees> [<joint_name> <angle_degrees> ...]
move_crs97 <joint_name> <angle_degrees> [<joint_name> <angle_degrees> ...]

To move the first joint (q0) by 10 degrees and the second joint (q1) by -5 degrees, run:

move_crs93 q0 10 q1 -5
move_crs97 q0 10 q1 -5

Simple python script to control the robot

from ctu_crs import CRS93 # or CRS97
robot = CRS93()  # 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, perform hard and soft home
q = robot.get_q()  # get current joint configuration
robot.move_to_q(q + [0.1, 0.0, 0.0, 0.0, 0.0, 0.0])  # move robot all values in radians
robot.wait_for_motion_stop() # wait until the robot stops
robot.close()  # close the connection

Step-by-Step Procedure for Operating the Robot

  • Power On the Robot Turn on the robot using the red switch on the front panel of the control unit (the switch will light up). Press the yellow Arm Power button (a yellow LED will light up above it).
  • Initialize Communication and Setup in Python Run the following commands to initiate communication and perform necessary setup:
from ctu_crs import CRS93 # or CRS97
robot = CRS93()  # 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, perform hard and soft home
  • Move the Robot After initialization, you can continue with your desired commands for operating the robot.

  • End of Session - Return Robot to Home Position To finish working and return the robot to the home position, execute:

robot.soft_home()
robot.close()  # close the connection

Turn off the robot by switching off the red rocker switch on the front panel.

Accessing the Robot Within the Safety Cage

If you need to work inside the protective cage: Stop the robot (wait until movement stops completely). You can check with:

robot.in_motion()

Run the following command to release the robot:

robot.release()

This will engage the brakes and disconnect feedback. Be cautious, as the robot arm might slightly drop, so avoid performing this command directly above the work surface. Open the cage door (the yellow Arm Power LED will turn off).

Emergency Stop Procedure

If the robot behaves unexpectedly, immediately press the Emergency Stop button (red mushroom-shaped button).

Restoring Operation After Emergency Stop or Working Inside the Cage

Unlock the emergency stop by pressing the blue button on the side of the emergency button, or close the cage door if open. Press the Motion Stop button. Press the yellow Arm Power button (the yellow Arm Power LED will turn on). Resume sending movement commands to the robot. If the motor enters an error state (indicated by a flashing green status LED above the motor’s letter and a red error LED), reset the motor state with:

robot.reset_motors()

Note: Re-homing the robot is not necessary, even after activating the emergency stop or opening the cage door, as long as the control unit is not powered off.

For developers

git clone git@github.com:CTURobotics/ctu_crs.git
cd ctu_crs
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_crs-1.0.5.tar.gz (12.8 kB view details)

Uploaded Source

Built Distribution

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

ctu_crs-1.0.5-py3-none-any.whl (14.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for ctu_crs-1.0.5.tar.gz
Algorithm Hash digest
SHA256 d4fe4aa3ad58ba090e5b966ca63b1e241a6c35c1144d8c5243067842f56d1326
MD5 2809a66fe63140999cb9dedbb81b7d14
BLAKE2b-256 f41892822d236240b54e6d315f96aa1b79530163d543bcacc6ce22850c73700a

See more details on using hashes here.

Provenance

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

Publisher: release.yml on CTURobotics/ctu_crs

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_crs-1.0.5-py3-none-any.whl.

File metadata

  • Download URL: ctu_crs-1.0.5-py3-none-any.whl
  • Upload date:
  • Size: 14.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ctu_crs-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 42531efdd36bb240acdf40f2e8ed33473e70c1e1497d28a15196af74c9acb5ba
MD5 1ed6ea7fe30ae5d325bc9467241af4ca
BLAKE2b-256 393a93c3d6b0904379fcfdd35ca2fafae819db7da2ccd81a5afe8a84d8f56956

See more details on using hashes here.

Provenance

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

Publisher: release.yml on CTURobotics/ctu_crs

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