Quanser QBot 3
The Quanser QBot 3 is an Unmanned Ground Vehicle (UGV) built and sold by Quanser, Inc. The Quanser QBot 3 is based around a Raspberry Pi 4, which has a quad-core 1.5 GHz ARM Cortex-A72 processor with 4 GB RAM running Raspbian. The QUARC Target associated with the Quanser QBot 3 is the QUARC Raspberry Linux Pi 4 Target. The Quanser QBot 3 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 3 with QUARC:
* Communications channels are accessed through the Stream API blocks, see Serial protocol,
SPI protocol and I2C protocol.
The Quanser QBot 3 also supports specialized quantities such as the following:
The QUARC driver name for this card is qbot3.
To select the Quanser QBot 3 HIL board, pass qbot2e as the card type argument to the hil_open function.
Note that the QUARC Raspberry Linux Pi 4 Target must be selected to use the Quanser QBot 3 board. |
The Quanser QBot 3 supports different means of communicating with it as a target. It supports wireless (WiFi) communications, which are most readily configured initially by connecting a monitor, mouse and keyboard and using the Raspbian Pi OS desktop to connect to the WiFi router. If a wireless connection is used then its IP address will show up on the LCD display with a WiFi symbol beside it. Once configured, it should reconnect automatically whenever the WiFi signal is available.
The Quanser QBot 3 also supports a 10/100/1000 Mbps wired LAN connection. If the LAN connection is used, its IP address will show up on the LCD display with a LAN symbol beside it. If both WiFi and LAN are connected then the LAN IP address will be displayed on the LCD display, as it is the fastest connection. In the case of WiFi or LAN the IP address is determined by the adapter settings. Typically, the IP address is assigned dynamically by a DHCP server on the network.
Display
The LCD display on the Quanser QBot 3 typically displays the battery voltage and IP address of the card, as well as status messages.
The LCD display on the Quanser QBot 3 may also be driven from external applications. In Python,
this can be done using the ST7066UDisplay
class in the quanser.devices
package.
The URI to use for this display is serial://qbot3:0?baud=921600,device='/dev/qbot3_lcd'.
The LCD has a refresh rate of 84.7 Hz, thus it would not show the display characters if the LCD is being written faster than that. In certain conditions,
if the LCD is not able to keep up, a message |
Communications
The communications ports provided on the Quanser QBot 3 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 3 to support serial communications is a bit more involved. Edit the to add the line:
dtoverlay=uart5,ctsrts=on
After changing , reboot the Raspberry Pi for the changes to take effect.
Use the raspi-gpio get
command to confirm that the
TxD (GPIO 12), RxD (GPIO 13) CTS (GPIO 14), and RTS (GPIO 15) pins for the UART
are in alt=4 mode. The serial port is /dev/ttyAMA1.
Clocks
There are currently no configuration options for the Quanser QBot 3 clocks.
Analog Inputs
The Quanser QBot 3 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 3 card does not support analog outputs.
Digital Inputs
The Quanser QBot 3 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 3, 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 3 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 3, 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 3 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 3 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 18 |
disabled |
|
disabled |
GPIO 19 |
|
GPIO 18 |
GPIO 19 |
|
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 3 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 3 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 3 card, or its driver, does not support any interrupt sources.
Watchdog
The Quanser QBot 3 card does not support a watchdog timer.
Board-Specific Options
The Quanser QBot 3 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 value is 18 corresponding to GPIO 18.
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 value is 19 corresponding to GPIO 19.
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 3 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 3 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 ↔ | 40 | 39 | ― Ground |
GPIO 20 ↔ | 38 | 37 | ↔ GPIO 26 |
GPIO 16 ↔ | 36 | 35 | ↔ GPIO 19 / → PWM 1 |
Ground ― | 34 | 33 | ↔ GPIO 13 / ← UART RXD |
UART TXD ← / GPIO 12 ↔ | 32 | 31 | ↔ GPIO 6 |
Ground ― | 30 | 29 | ↔ GPIO 5 |
ID SC / GPIO 1 ↔ | 28 | 27 | ↔ GPIO 0 / ID SD |
SPI CE1 ← / GPIO 7 ↔ | 26 | 25 | ― Ground |
SPI CE0 ← / GPIO 8 ↔ | 24 | 23 | ↔ GPIO 11 / → SPI SCLK |
GPIO 25 ↔ | 22 | 21 | ↔ GPIO 9 / ← SPI MISO |
Ground ― | 20 | 19 | ↔ GPIO 10 / → SPI MOSI |
GPIO 24 ↔ | 18 | 17 | ― 3.3V |
GPIO 23 ↔ | 16 | 15 | ↔ GPIO 22 |
Ground ― | 14 | 13 | ↔ GPIO 27 |
PWM 0 ← / GPIO 18 ↔ | 12 | 11 | ↔ GPIO 17 |
UART RTS → / GPIO 15 ↔ | 10 | 9 | ― Ground |
UART CTS ← / GPIO 14 ↔ | 8 | 7 | ↔ GPIO 4 |
Ground ― | 6 | 5 | ↔ GPIO 3 / I2C SCL |
5V ― | 4 | 3 | ↔ GPIO 2 / I2C SDA |
5V ― | 2 | 1 | ― 3.3V |
Legend
→▯← | = | input |
←▯→ | = | output |
↔▯↔ | = | bidirectional I/O |
= | 3.3V signal | |
= | power | |
= | ground |
Targets
Target |
Supported |
Comments |
---|---|---|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
Yes |
Only supported with a QBot 3 device. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
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
Copyright ©2023 Quanser Inc. This page was generated Thu 05/04/2023. Submit feedback to Quanser about this page.