Clocks Analog Inputs Analog Outputs Digital Inputs Digital Outputs Encoder Inputs PWM Outputs Other Inputs Other Outputs Interrupts Watchdog Board-Specific Options Properties Targets See Also navigation bar

Quanser QBot 2e

The Quanser QBot 2e is an Unmanned Ground Vehicle (UGV) built and sold by Quanser, Inc. The Quanser QBot 2e is based around a Raspberry Pi 3 B+, which has a quad-core 1.4 GHz ARM Cortex-A53 processor with 1 GB RAM running Raspbian. The QUARC Target associated with the Quanser QBot 2e is the QUARC Linux Raspberry Pi 3 Target. The Quanser QBot 2e HIL card may only be used with QUARC when this target is selected. The following characteristics are of particular interest when using the Quanser QBot 2e with QUARC:

* Communications channels are accessed through the Stream API blocks, see Serial protocol, SPI protocol and I2C protocol.

The Quanser QBot 2e also supports specialized quantities such as the following:

The QUARC driver name for this card is qbot2e.

To select the Quanser QBot 2e HIL board, pass qbot2e as the card type argument to the hil_open function.

Warning

Note that the QUARC Linux Raspberry Pi 3 Target must be selected to use the Quanser QBot 2e board.

Communications

The communications ports provided on the Quanser QBot 2e board can be utilized through the QUARC Communications blockset and the Quanser Stream API (see QUARC Communications Protocols).

For SPI communications, a sample URI for communications would be:

spi://localhost:0?baud='1000000',phase='off',lsb='off',frame='0'

where the frame option selects the SPI CE line to frame the SPI bus transaction (0 or 1). Note that the SPI port must be enabled using the raspi-config utility for SPI communications to be used. Once the SPI port is enabled, the corresponding digital I/O (pins 19, 21, 23, 24 and 26) will no longer be available as digital I/O.

SPI can also be enabled via the file by setting spi=on in the Device Tree Overlay parameters. For example:

dtparam=spi=on

After changing , reboot the Raspberry Pi for the changes to take effect.

For I2C communications, a sample URI for communications would be:

i2c://localhost:0?baud='400000',address=0x69

where the address option specifies the I2C slave address. Note that the I2C port must be enabled using the raspi-config utility for I2C communications to be used. Once the I2C port is enabled, the corresponding digital I/O (pins 3 and 5) will no longer be available as digital I/O.

To set the baud rate for the I2C, the file must be edited and the Raspbery Pi rebooted. For example, to enable I2C and set the I2C baud rate to 400000 baud, change the Device Tree Overlay parameters to:

dtparam=i2c_arm=on,i2c_arm_baudrate=400000

After changing , reboot the Raspberry Pi for the changes to take effect.

For serial communications, a sample URI for communications would be:

serial://localhost:1?baud='115200',word='8',parity='none',stop='1'

Configuring the Quanser QBot 2e to support serial communications is a bit more involved. First, use the raspi-config utility to disable the serial port use by the kernel console. Then edit the so that:

enable_uart=1

Also add the line:

dtoverlay=pi3-disable-bt

in order to disable bluetooth, which makes use of the UART otherwise (see Pi Zero W WiFi interference with TTY). Alternatively, to maintain bluetooth and use the UART, use the lines:

dtoverlay=pi3-miniuart.txt

core_freq=250

Refer to this Raspberry Pi forum topic for details.

After changing , reboot the Raspberry Pi for the changes to take effect. Use the gpio readall command to confirm that the TxD and RxD pins for the UART are in ALT0 mode. The serial port is /dev/ttyAMA0.

Clocks

There are currently no configuration options for the Quanser QBot 2e clocks.

Analog Inputs

The Quanser QBot 2e supports 6 analog inputs. Hence, analog input channel numbers range from 0 to 5. The full suite of analog inputs are enumerated in the table below:

Channel

Description

0

Battery voltage (typically 16.7V when fully charged)

1

Raw voltage from right cliff sensor1

2

Raw voltage from central cliff sensor1

3

Raw voltage from left cliff sensor1

4

Right motor current in Amps.

5

Left motor current in Amps.

1 For the non-linear relationship between the raw voltage from a cliff sensor to actual distance, refer to the Sharp Analog Output Type Distance Measuring Sensor Data Sheet.

Analog Outputs

The Quanser QBot 2e card does not support analog outputs.

Digital Inputs

The Quanser QBot 2e supports 59 digital inputs. The first 28 channels are user-accessible reconfigurable digital I/O lines that may be used as digital inputs. Channels 0 and 1, however, are reserved for a HAT EEPROM I2C interface. A digital I/O line cannot be used as an input and output at the same time. Nor can it be used for communications (SPI, I2C or UART) or PWM at the same time. The full suite of digital inputs are enumerated in the following table:

Since the digital I/O lines may be individually programmed as inputs or outputs on the Quanser QBot 2e, all channels which will be used for digital inputs should be configured using the hil_set_digital_directions function.

Channel

Description

0-27

User-accessible bidirectional digital I/O lines. Note that channels 0 and 1 are reserved by the O/S for identifying custom Pi 3 daughterboards and cannot be used.

28

Right bumper (0 = not pressed, 1 = pressed)

29

Central bumper (0 = not pressed, 1 = pressed)

30

Left bumper (0 = not pressed, 1 = pressed)

31

Right wheel drop (0 = wheel up, 1 = wheel down)

32

Left wheel drop (0 = wheel up, 1 = wheel down)

33

Right cliff (0 = no cliff, 1 = cliff detected)

34

Central cliff (0 = no cliff, 1 = cliff detected)

35

Left cliff (0 = no cliff, 1 = cliff detected)

36

Button B0 (0 = not pressed, 1 = pressed)

37

Button B1 (0 = not pressed, 1 = pressed)

38

Button B2 (0 = not pressed, 1 = pressed)

39

Right motor overcurrent (0 = normal operation, 1 = overcurrent detected)

40

Left motor overcurrent (0 = normal operation, 1 = overcurrent detected)

41

Right dock IR near right sensor (0 = not detected, 1 = detected)

42

Right dock IR near center sensor (0 = not detected, 1 = detected)

43

Right dock IR near left sensor (0 = not detected, 1 = detected)

44

Right dock IR far right sensor (0 = not detected, 1 = detected)

45

Right dock IR far center sensor (0 = not detected, 1 = detected)

46

Right dock IR far left sensor (0 = not detected, 1 = detected)

47

Central dock IR near right sensor (0 = not detected, 1 = detected)

48

Central dock IR near center sensor (0 = not detected, 1 = detected)

49

Central dock IR near left sensor (0 = not detected, 1 = detected)

50

Central dock IR far right sensor (0 = not detected, 1 = detected)

51

Central dock IR far center sensor (0 = not detected, 1 = detected)

52

Central dock IR far left sensor (0 = not detected, 1 = detected)

53

Left dock IR near right sensor (0 = not detected, 1 = detected)

54

Left dock IR near center sensor (0 = not detected, 1 = detected)

55

Left dock IR near left sensor (0 = not detected, 1 = detected)

56

Left dock IR far right sensor (0 = not detected, 1 = detected)

57

Left dock IR far center sensor (0 = not detected, 1 = detected)

58

Left dock IR far left sensor (0 = not detected, 1 = detected)

Note that the dock IR signals may oscillate when the IR signal is detected. This oscillation is a function of the way the docking IR signals work.

Digital Outputs

The Quanser QBot 2e supports 36 digital outputs. The first 28 channels are user-accessible reconfigurable digital I/O lines that may be used as digital outputs. Channels 0 and 1, however, are reserved for a HAT EEPROM I2C interface. A digital I/O line cannot be used as an input and output at the same time. Nor can it be used for communications (SPI, I2C or UART) or PWM at the same time.

Since the digital I/O lines may be individually programmed as inputs or outputs on the Quanser QBot 2e, all the channels which will be used for digital outputs should be configured using the hil_set_digital_directions function.

The full suite of digital outputs are enumerated in the following table:

Channel

Description

0-27

User-accessible bidirectional digital I/O lines. Note that channels 0 and 1 are reserved by the O/S for identifying custom Pi 3 daughterboards and cannot be used.

28

Chassis LED1 red

29

Chassis LED1 green

30

Chassis LED2 red

31

Chassis LED2 green

32

Enable 3.3V power

33

Enable 5V power

34

Enable 12V/5A power1

35

Enable 12V/1.5A power

1 Disabling the 12V/5A power will power down the Raspbery Pi 3 processor. The chassis will have to be turned off and back on in order to restore power and wireless communications with the Pi 3 target.

Encoder Inputs

The Quanser QBot 2e supports two encoder inputs. The encoder channels are enumerated in the table below:

Channel

Description

0

Right wheel

1

Left wheel

In order to set the encoder counters to a particular count, use the hil_set_encoder_counts function.

PWM Outputs

The Quanser QBot 2e driver supports up to 2 PWM output channels. Hence, PWM output channels range from 0 to 1. Each PWM channel is completely independent and can have its own duty cycle and frequency.

Before the PWM channels may be used, they must be configured in the file and in the board-specific options. The file must be edited with root privileges. For example, to use the vi editor, enter the command:

sudo vi /boot/config.txt

in a terminal window.

The lines which must be added to the file depend on the number of PWM channels desired, and the pins to which they are assigned. The following table documents the lines that must be added to the file for each combination of options:

PWM 0

PWM 1

Line to Add

disabled

disabled

Do not add any lines

GPIO 12

disabled

dtoverlay=pwm,pin=12,func=4

GPIO 18

disabled

dtoverlay=pwm,pin=18,func=2

disabled

GPIO 13

dtoverlay=pwm,pin=13,func=4

disabled

GPIO 19

dtoverlay=pwm,pin=19,func=2

GPIO 12

GPIO 13

dtoverlay=pwm-2chan,pin=12,func=4,pin2=13,func2=4

GPIO 12

GPIO 19

dtoverlay=pwm-2chan,pin=12,func=4,pin2=19,func2=2

GPIO 18

GPIO 13

dtoverlay=pwm-2chan,pin=18,func=2,pin2=13,func2=4

GPIO 18

GPIO 19

dtoverlay=pwm-2chan,pin=18,func=2,pin2=19,func2=2

Warning

Note that once a GPIO is configured as a PWM channel then it will no longer be recognized as a digital I/O line.

In order to configure the PWM mode or frequency, use the hil_set_pwm_mode and hil_set_pwm_frequency functions respectively.

The PWM outputs are generic PWM outputs that are capable of producing the standard analog ESC protocols, namely standard PWM (1000us to 2000us), Oneshot125 (125us to 250us), Oneshot42 (42us to 84us) and Multishot (5us to 25us). They may also be used to drive R/C servos.

The PWM parameters for each of these protocols are tabulated below:

Protocol

PWM Frequency

Pulse Time Range

Duty Cycle Range

Standard PWM

50 Hz (20ms)

0.001 to 0.002 seconds (1ms to 2ms)

0.05 to 0.1 (5% to 10%)

Oneshot125

2000 Hz (500us)

125e-6 to 250e-6 seconds (125us to 250us)

0.25 to 0.5 (25% to 50%)

Oneshot42

11905 Hz (84us)

42e-6 to 84e-6 seconds (42us to 84us)

0.25 to 0.5 (25% to 50%)

Multishot

20000 Hz (50us)

5e-6 to 25e-6 seconds (5us to 25us)

0.1 to 0.5 (10% to 50%)

The PWM outputs are not restricted to these parameter values as they are generic PWM outputs. The maximum output frequency is 50 MHz. The number of bits of resolution decreases with increasing PWM output frequency.

The PWM mode is set using the hil_set_pwm_mode_c function. The duty cycle mode (PWM_DUTY_CYCLE_MODE) or time mode (PWM_TIME_MODE) is typically used when driving ESCs or R/C servos. The PWM output frequency (a.k.a., pulse rate) is set using the hil_set_pwm_frequency function.

Other Inputs

The Quanser QBot 2e supports eight other input channels. The other input channels are defined as follows:

Other Input Channel

Description

Units

1002

Angle in Z-axis

(rad)

3000

Gyroscope in X

(rad/s)

3001

Gyroscope in Y

(rad/s)

3002

Gyroscope in Z

(rad/s)

11000

Right wheel PWM

(%)

11001

Left wheel PWM

(%)

12000

Timestamp

(s)

16000

Charger state

1

1 The charger state takes on discrete values depending on whether the docking station is being used and whether the battery is fully charged. The following table shows the charger state values:

State

Description

0

Discharging battery

2

Battery charged at docking station

6

Battery charging at docking station

18

Battery charged using adapter

22

Battery charging using adapter

As a reference, the generic table for the Other channels for any HIL Data Acquisition Card is reproduced below. SI units are used.

Other Channel

Description

Units

0 - 999

Linear position along the X, Y and Z axis

(m)

1000 - 1999

Angular position around the X, Y and Z axis

(rad)

2000 - 2999

Linear velocity along the X, Y and Z axis

(m/s)

3000 - 3999

Angular velocity around the X, Y and Z axis

(rad/s)

4000 - 4999

Linear acceleration along the X, Y and Z axis

(m/s2)

5000 - 5999

Angular acceleration around the X, Y and Z axis

(rad/s2)

6000 - 6999

Force along the X, Y and Z axis

(N)

7000 - 7999

Torque around The X, Y and Z axis

(N.m)

8000 - 8999

Magnetic Field Along The X, Y and Z axis

(T)

9000 - 9999

Pressure along the X, Y and Z axis

(Pa)

10000 - 10999

Temperature along the X, Y and Z axis

(°C)

11000 - 11999

Operating capacity as a percentage (0.0 to 1.0 represending 0% to 100%)

(%)

12000 - 12999

Time

(s)

13000 - 13999

Counts

(counts)

14000 - 14999

Counts per second

(counts/s)

15000 - 15999

Counts per second2

(counts/s2)

16000 - 16999

Enumerated quantity

Other Outputs

The Quanser QBot 2e supports four other output channels, allowing the wheel velocities to be controlled and sounds to be generated. Refer to the table below for a list of the channels:

Channel

Description

Units

2000

Right wheel velocity

(m/s)

2001

Left wheel velocity

(m/s)

14000

Pitch of custom sound

(Hz)

16000

Predefined sound

(0-6)

Interrupts

The Quanser QBot 2e card, or its driver, does not support any interrupt sources.

Watchdog

The Quanser QBot 2e card does not support a watchdog timer.

Board-Specific Options

The Quanser QBot 2e has a number of board-specific options to control specialized functionality of the board. These options configure the PWM.

pwm0_en

This option is a boolean value that enable or disables PWM 0. If PWM 0 is disabled then the PWM pin may be used as a regular digital I/O. Valid values are 0, 1, false, true, off, on, no or yes.

pwm1_en

This option is a boolean value that enable or disables PWM 1. If PWM 1 is disabled then the PWM pin may be used as a regular digital I/O. Valid values are 0, 1, false, true, off, on, no or yes.

pwm0_pin

This option determines which pin will be used for PWM 0. Valid values are 12 or 18 corresponding to GPIO 12 or GPIO 18 respectively.

Warning

Note that once a GPIO is configured as a PWM channel then it will no longer be recognized as a digital I/O line.

pwm1_pin

This option determines which pin will be used for PWM 1. Valid values are 13 or 19 corresponding to GPIO 13 or GPIO 19 respectively.

Warning

Note that once a GPIO is configured as a PWM channel then it will no longer be recognized as a digital I/O line.

Properties

The Quanser QBot 2e driver currently supports the following read-only properties:

Property

Type

Description

PROPERTY_INTEGER_MAJOR_VERSION

Integer

Major version number of the hardware

PROPERTY_INTEGER_MINOR_VERSION

Integer

Minor version number of the hardware

PROPERTY_INTEGER_BUILD

Integer

Build number of the hardware (currently always zero)

PROPERTY_INTEGER_REVISION

Integer

Revision or patch number of the hardware

PROPERTY_INTEGER_FIRMWARE_MAJOR_VERSION

Integer

Major version number of the firmware

PROPERTY_INTEGER_FIRMWARE_MINOR_VERSION

Integer

Minor version number of the firmware

PROPERTY_INTEGER_FIRMWARE_BUILD

Integer

Build number of the firmware (currently always zero)

PROPERTY_INTEGER_FIRMWARE_REVISION

Integer

Revision or patch number of the firmware

PROPERTY_INTEGER_KOBUKI_UDID0

Integer

Unique identifier 0

PROPERTY_INTEGER_KOBUKI_UDID1

Integer

Unique identifier 1

PROPERTY_INTEGER_KOBUKI_UDID2

Integer

Unique identifier 2

The following properties may be both read and written:

Property

Type

Description

PROPERTY_DOUBLE_KOBUKI_P_GAIN

Double

Proportional gain for the onboard controller. The factory value is 100.

PROPERTY_DOUBLE_KOBUKI_I_GAIN

Double

Integral gain for the onboard controller. The factory value is 0.1.

PROPERTY_DOUBLE_KOBUKI_D_GAIN

Double

Derivative gain for the onboard controller. The factory value is 2.

Connectors

The Quanser QBot 2e board has one connector for expansion I/O. The pinouts for this connector are listed below. Note that all pins are 3.3V and are not 5V tolerant unless marked otherwise. Exceeding these voltages may damage the board!

Raspberry Pi GPIO Connector

GPIO 21

4039

Ground

GPIO 20

3837

GPIO 26

GPIO 16

3635

GPIO 19 / → PWM 1

Ground

3433

GPIO 13 / → PWM 1

PWM 0 ← / GPIO 12

3231

GPIO 6

Ground

3029

GPIO 5

ID SC / GPIO 1

2827

GPIO 0 / ID SD

SPI CE1 ← / GPIO 7

2625

Ground

SPI CE0 ← / GPIO 8

2423

GPIO 11 / → SPI SCLK

GPIO 25

2221

GPIO 9 / ← SPI MISO

Ground

2019

GPIO 10 / → SPI MOSI

GPIO 24

1817

3.3V

GPIO 23

1615

GPIO 22

Ground

1413

GPIO 27

PWM 0 ← / GPIO 18

1211

GPIO 17

UART RXD → / GPIO 15

109

Ground

UART TXD ← / GPIO 14

87

GPIO 4

Ground

65

GPIO 3 / I2C SCL

5V

43

GPIO 2 / I2C SDA

5V

21

3.3V

Legend

→▯←

=

input

←▯→

=

output

↔▯↔

=

bidirectional I/O

=

3.3V signal

=

power

=

ground

Targets

Target

Supported

Comments

QUARC Win32 Target

No

Not supported.

QUARC Win64 Target

No

Not supported.

QUARC Linux Nvidia Target

No

Not supported.

QUARC Linux Raspberry Pi 3 Target

No

Not supported.

QUARC Linux Raspberry Pi 4 Target

No

Not supported.

QUARC Linux RT ARMv7 Target

No

Not supported.

QUARC Linux x64 Target

No

Not supported.

QUARC Linux DuoVero Target

No

Not supported.

QUARC Linux DuoVero 2016 Target

No

Not supported.

QUARC Linux Verdex Target

No

Not supported.

QUARC QNX x86 Target

No

Not supported.

Rapid Simulation (RSIM) Target

Yes

Supported with no communication to the hardware.

Normal simulation

Yes

Supported with no communication to the hardware.

See Also

 

navigation bar