Skip to content

A python based light weight robot simulator for the algorithm development of robotics navigation, control, and learning

License

Notifications You must be signed in to change notification settings

hanruihua/ir-sim

Repository files navigation

Intelligent Robot Simulator (IR-SIM)

Github Release License PyPI Downloads Read the Docs

Documentation: https://ir-sim.readthedocs.io/en

IR-SIM is an open-source, lightweight robot simulator based on Python, specifically designed for intelligent robotics navigation and learning. Primarily intended for research and educational purposes, it is user-friendly and easily customizable.

It provides the following features:

  • Versatile and User-Friendly Framework: Simulate a wide range of robot platforms with diverse kinematics and sensors.
  • Easy Configuration with YAML: Easily set up and modify simulation scenarios using straightforward YAML files, no complex coding required for quick and flexible environment customization.
  • Real-Time Visualization: Visualize simulation outcomes in real time for immediate feedback and analysis.
  • Predefined Benchmark Behaviors: Utilize a comprehensive library of pre-defined behaviors that serve as benchmarks for evaluating and comparing algorithm performance.
  • Ideal for Algorithm Development: Suitable for developing and testing algorithms related to robot navigation, motion planning, optimal control, and reinforcement learning.
Robot Car
robot car

Prerequisite

  • Python: >= 3.7

Installation

  • Install this package from PyPi:
pip install ir-sim

This does not include dependencies for all features of the simulator. To install additional optional dependencies, use the following pip commands:

# install dependencies for keyboard control
pip install ir-sim[keyboard]

# install all optional dependencies
pip install ir-sim[all]  
  • Or for development, you may install from source:
git clone https://github.com/hanruihua/ir-sim.git    
cd ir-sim   
pip install -e .  

Usage

Quick Start

import irsim

env = irsim.make('robot_world.yaml') # initialize the environment with the configuration file

for i in range(300): # run the simulation for 300 steps

    env.step()  # update the environment
    env.render() # render the environment

    if env.done(): break # check if the simulation is done
        
env.end() # close the environment

YAML Configuration: robot_world.yaml

world:
  height: 10  # the height of the world
  width: 10   # the height of the world
  step_time: 0.1  # 10Hz calculate each step
  sample_time: 0.1  # 10 Hz for render and data extraction 
  offset: [0, 0] # the offset of the world on x and y 

robot:
  kinematics: {name: 'diff'}  # omni, diff, acker
  shape: {name: 'circle', radius: 0.2}  # radius
  state: [1, 1, 0]  # x, y, theta
  goal: [9, 9, 0]  # x, y, theta
  behavior: {name: 'dash'} # move toward to the goal directly 
  color: 'g' # green

Advanced Usage

The advanced usages are listed in the irsim/usage

Academic Cases

Acknowledgement

About

A python based light weight robot simulator for the algorithm development of robotics navigation, control, and learning

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages