Skip to content

Tutorials: Setup

Maxime Busy edited this page Sep 2, 2019 · 17 revisions

Launching and stopping a simulation

The simulation can be launched using two different modes, as pictured below.

The simulation can be launched using a SimulationManager object:

from qibullet import SimulationManager

if __name__ == "__main__":
    simulation_manager = SimulationManager()
    client_id = simulation_manager.launchSimulation(gui=True)

    # Your code here...

This code snippet will launch a simulated instance, and will spawn an OpenGL rendering window. The gui parameter allows the user to choose between the GUI or DIRECT mode. You can theoretically launch an unlimited amount of simulated instance in DIRECT mode (the limit is set by the computing power available), but only one at a time in GUI mode.

from qibullet import SimulationManager

if __name__ == "__main__":
    simulation_manager = SimulationManager()
    client_gui = simulation_manager.launchSimulation(gui=True)
    client_direct_0 = simulation_manager.launchSimulation(gui=False)
    client_direct_1 = simulation_manager.launchSimulation(gui=False)
    ###
    client_direct_n = simulation_manager.launchSimulation(gui=False)

    # Your code here...

In this snippet, we launch a simulation instance in GUI mode, and n instances in DIRECT mode. Note that the launchSimulation method will return the id of the created instance. The SimulationManager object can also be used to reset or stop a simulated instance:

simulation_manager = SimulationManager()
client_id = simulation_manager.launchSimulation(gui=True)
simulation_manager.resetSimulation(client_id)
simulation_manager.stopSimulation(client_id)

# Your code here...

The methods can be called independently, resetSimulation will remove all of the simulated objects in an instance but leave the instance running, while stopSimulation will stop the instance.

Spawning a virtual robot in the simulation

A Virtual robot can be spawned using the simulation manager:

from qibullet import SimulationManager
from qibullet import PepperVirtual
from qibullet import NaoVirtual

if __name__ == "__main__":
    simulation_manager = SimulationManager()
    client_id = simulation_manager.launchSimulation(gui=True)
    pepper = simulation_manager.spawnPepper(
        client_id,
        spawn_ground_plane=True)

    nao = simulation_manager.spawnNao(
        client_id,
        translation=[0, 2, 0],
        quaternion=[0, 0, 0, 1])

    # Your code here...

In this snippet:

  • A virtual Pepper will be spawned in the client_id instance, at the origin of the simulation world frame with no rotation on its base. A ground will also be spawned at the same time.
  • A virtual NAO will be spawned in the client_id instance, at the position [0, 2, 0] in the simulation world frame with no rotation.

By default, the translation and quaternion parameters are respectively set to [0, 0, 0] and [0, 0, 0, 1]. The spawn_ground_plane parameter is set to False by default.

A virtual robot can also be spawned using the PepperVirtual or NaoVirtual class directly, but the virtual environment needs to be launched first:

pepper = PepperVirtual()
nao = NaoVirtual()

pepper.loadRobot(
    translation=[0, 0, 0],
    quaternion=[0, 0, 0, 1],
    physicsClientId=client_id)

nao.loadRobot(
    translation=[0, 2, 0],
    physicsClientId=client_id)

# Your code here...