Skip to main content

Integration and Supervisory control of Autonomous Robots - Open source robot implementation

Project description

isar-robot

ISAR - Integration and Supervisory control of Autonomous Robots - is a tool for integrating robot applications into Equinor systems. Through the ISAR API you can send command to a robot to do missions and collect results from the missions.

Running the full ISAR system requires an installation of a robot which satisfies the required interface. isar-robot is a default implementation of such a robot.

Installation

For installation of isar-robot to use with ISAR, please follow the robot integration installation guide.

Run isar-robot

After installing isar-robot, it can be used through ISAR.

Development

Create a fork of the repository and clone the fork to your machine:

git clone https://github.com/<your-username>/isar-robot
cd isar-robot

Choose if you want to run via uv or manually creating venv

Local development with uv

An easy way to run isar-robot locally is with uv. The pyproject.toml includes a [tool.uv.sources] override that points the isar dependency to the local ../isar folder.

Note that this assumes the following folder structure between isar and isar-robot:

parent-folder/
├── isar/
└── isar-robot/
uv run isar-start

Configurable variables

Specific mission and task behaviours can be configured as environment variables. These are optional and do not have to be set. These allow for always failing specific mission types, failing specific task types, setting custom task durations, and setting custom mission durations. The following list shows all configurable environment variables. In this case "normal" means non-localization or return to home tasks.

The variable names and types are as follows:

TASK_DURATION_IN_SECONDS: float
MISSION_DURATION_IN_SECONDS: float
SHOULD_FAIL_NORMAL_TASK: bool
SHOULD_FAIL_RETURN_TO_HOME_TASK: bool

Every configuration variable is defined in settings.py, and they may all be overwritten by specifying the variables in your ".env" file in ISAR. Note that the configuration variable must be prefixed with ROBOT_ when specified in the ISAR environment file.

Dependencies

The dependencies used for this package are listed in pyproject.toml and pinned in uv.lock. This ensures our builds are predictable and deterministic. This project uses uv for dependency management:

Install local versions (editable):

uv sync

Install pinned versions:

uv sync --no-sources

Pin local version:

uv lock --no-sources

To update the dependencies to the latest versions, run:

uv lock --upgrade --no-sources

Contributing

We welcome all kinds of contributions, including code, bug reports, issues, feature requests, and documentation. The preferred way of submitting a contribution is to either make an issue on github or by forking the project on github and making a pull request.

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

isar_robot-2.0.1.tar.gz (15.0 MB view details)

Uploaded Source

Built Distribution

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

isar_robot-2.0.1-py3-none-any.whl (14.9 MB view details)

Uploaded Python 3

File details

Details for the file isar_robot-2.0.1.tar.gz.

File metadata

  • Download URL: isar_robot-2.0.1.tar.gz
  • Upload date:
  • Size: 15.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for isar_robot-2.0.1.tar.gz
Algorithm Hash digest
SHA256 80f6ce07f80dc21ae4b45cfcf6898d6a7f8dd7e4c1676d21b8e509f74926c3f1
MD5 4b1b765d609b3616d7e4ba69adf9a09c
BLAKE2b-256 cbd55141a764f9436840755e479f723e0a433586f07b432877b178986cf2f56b

See more details on using hashes here.

File details

Details for the file isar_robot-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: isar_robot-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 14.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for isar_robot-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a23232bb396fef080322f0841d5d77ee1ca690e1972bc2aac2076057fc7b1643
MD5 994d2fcb803257d941692316e5427215
BLAKE2b-256 c4e95b5b7475feb6d05b861c1c73866821ff0597ac34813dbf5d77f2c2bca990

See more details on using hashes here.

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