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 2

Deprecated This card is no longer available. For a newer card with similar capabilities, visit the Quanser website for the Quanser Qbot 2e.

The Quanser QBot 2 is an Unmanned Ground Vehicle (UGV) built and sold by Quanser, Inc. The QBot2 is based around a dual-core 1 GHz ARM Cortex-A9 processor with 1 GB RAM running Yocto Linux. The QUARC Target associated with the QBot2 is the QUARC Linux DuoVero Target. The QBot2 HIL card may only be used with QUARC when this target is selected. The following characteristics are of particular interest when using the QBot2 with QUARC:

**The serial port is accessed through the Stream API blocks, see Serial protocol.

***The SPI port is accessed through the Stream API blocks, see SPI protocol.

****The I2C port is accessed through the Stream API blocks, see I2C protocol.

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

The QUARC driver name for this card is qbot2.

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

Warning

Note that the Linux DuoVero target must be selected to use the Quanser QBot 2 board.

The Quanser QBot 2 I/O channels are described below.

Clocks

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

Analog Inputs

The Quanser QBot 2 supports 10 analog inputs. Hence, analog input channel numbers range from 0 to 9. The first four analog inputs are user accessible channels with a 0-5V range and 12-bit resolution. The full suite of analog inputs are enumerated in the table below:

Channel

Description

0-3

User-accessible analog inputs with 0-5V range and 12-bit resolution

4

Battery voltage (typically 16.7V when fully charged)

5

Raw voltage from right cliff sensor1

6

Raw voltage from central cliff sensor1

7

Raw voltage from left cliff sensor1

8

Right motor current in Amps.

9

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 2 card does not support analog outputs.

Digital Inputs

The Quanser QBot 2 supports 39 digital inputs. The first eight channels are user-accessible reconfigurable digital I/O lines that may be used as digital inputs. The full suite of digital inputs are enumerated in the following table:

Channel

Description

0-7

User-accessible bidirectional digital I/O lines

8

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

9

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

10

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

11

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

12

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

13

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

14

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

15

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

16

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

17

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

18

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

19

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

20

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

21

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

22

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

23

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

24

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

25

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

26

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

27

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

28

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

29

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

30

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

31

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

32

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

33

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

34

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

35

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

36

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

37

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

38

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 2 supports 17 digital outputs. The first eight channels are user-accessible reconfigurable digital I/O lines that may be used as digital outputs. The full suite of digital outputs are enumerated in the following table:

Channel

Description

0-7

User-accessible bidirectional digital I/O lines

8

User LED (underneath board)

9

Chassis LED1 red

10

Chassis LED1 green

11

Chassis LED2 red

12

Chassis LED2 green

13

Enable 3.3V power

14

Enable 5V power

15

Enable 12V/5A power1

16

Enable 12V/1.5A power

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

Encoder Inputs

The Quanser QBot 2 supports four encoder inputs. The first two channels are user-accessible quadrature encoder inputs with 24-bit count values. These two channels support non-quadrature as well as full quadrature modes, along with the index pulse. The encoder channels are enumerated in the table below:

Channel

Description

0-1

User-accessible encoder inputs with 24-bit counters

2

Right wheel

3

Left wheel

In order to set the encoder counters to a particular count or to change the default quadrature, use the hil_set_encoder_counts and hil_set_encoder_quadrature_mode functions respectively.

The Quanser QBot 2 supports non-quadrature (count and direction) and 4X quadrature modes for the first two encoder channels. The Quanser QBot 2 uses a filter frequency of 20 MHz which is not configurable.

The direction of the first two encoder channels may be reversed via the board-specific enc<n>_dir options. The ability to reverse the direction in which the encoder counts is convenient when connecting to hardware because it obviates the need for confusing sign changes in code.

The Quanser QBot 2 provides support for the index pulse on the first two encoder channels. The encoder count values when the last index pulses occurred are available as additional outputs. Refer to output input channels below for details.

The first two encoder counters may also be programmed to reload from the initial value when an index pulse occurs. Set the appropriate enc<n>_reload flag in the board-specific options to enable this feature. However, for control purposes, it is probably better to look for changes in the most recent index position as reported by the other input channels than to have the actual encoder counts change asynchronously with respect to the software.

The index pulse is detected when the A, B and Z signals of the encoder have a particular polarity. The polarity of each of these signals used to detect an index pulse is programmed through the board-specific options (see below). Doing so typically allows the index position to be determined with full quadrature accuracy. If the other input channels reflecting the position of the last index pulse continuously change as the encoder is rotated then the polarity of Z is likely incorrect.

The first two encoder inputs are sampled simultaneously when measured using a single HIL Read block.

Furthermore, the encoder positions and index positions are all sampled together simultaneously (in hardware) when measured using a single HIL Read block. This functionality is very useful for complex mechanical devices in which it is important to know the joint angles at a particular instant in time because small errors in these quantities could lead to inaccurate kinematic calculations. Without simultaneous sampling the mechanical system could not be guaranteed to be in exactly the same position when the different joint angles were measured.

PWM Outputs

The Quanser QBot 2 driver supports four generic user-accessible PWM output channels. Hence, PWM output channels range from 0 to 3.

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

The PWM output frequency (a.k.a., pulse rate) is suitable for a variety of applications, including driving additional R/C servos. To drive an R/C servo, set the PWM frequency to 50 Hz, which is equivalent to a PWM output period of 20 ms. Then drive a duty cycle between 0.05 and 0.10 to get a 1 ms to 2 ms pulse.

Other Inputs

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

Other Input Channel

Description

Units

13000

Encoder 0 index position

(counts)

13001

Encoder 1 index position

(counts)

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 2 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 2 card, or its driver, does not support any interrupt sources.

Watchdog

The Quanser QBot 2 supports a watchdog timer for resetting the user-accessible outputs on watchdog expiry. Namely, the first nine digital output channels and the first four PWM channels will be reset to zero on watchdog expiry. Resetting of the outputs occurs without software intervention, and therefore may be used as a safety mechanism in the event of software failure.

To enable the watchdog, use the hil_watchdog_start function. Be sure to reload the watchdog periodically using the hil_watchdog_reload function to prevent the watchdog from expiring.

Once the watchdog has expired, further I/O on the user-accessible outputs is disabled until the watchdog state is cleared.

Use the hil_watchdog_clear function to clear the watchdog state. Note that stopping the watchdog does not clear the watchdog state. The watchdog state must be cleared explicitly.

The watchdog timer may be programmed for any timeout period between 12.8 microseconds and 0.8389 seconds exclusive.

Board-Specific Options

pwm0_immediate

Set this option to "yes", "y" or "1" to update PWM outputs as soon as a value is written to PWM channel 0. Normally, the changes in the duty cycle of the PWM outputs are synchronized to the beginning of the PWM period to avoid glitches in the PWM outputs. Setting this option to "yes" causes the outputs to be updated immediately, even if it means producing a second pulse within the same PWM period. For example, when using trailing edge alignment, switching from a 90% duty cycle to a 10% duty cycle near the middle of the PWM period could cause the 90% duty cycle to be truncated immediately and then restarted near the end of the PWM period to generate the 10% duty cycle pulse. Some systems, however, do perform better when the PWM outputs are updated immediately, so this option is provided.

Similar options exist for the other PWM channels e.g. pwm1_immediate, pwm2_immediate, etc.

enc0_dir

Set this option to "yes", "y" or "1" to reverse the direction of encoder 0. This feature makes it easier to migrate to the Quanser QBot 2 hardware from another data acquisition card. It also allows models to be more portable to other cards.

Similar options exist for the other encoder channel i.e. enc1_dir.

enc0_filter

Set this option to "yes", "y" or "1" to enable filtering on encoder channel 0. The Quanser QBot 2 filtering oversamples the A, B and Z channels are tries to eliminate spurious glitches in the inputs. However, use of filtering slows down the maximum encoder velocity that may be measured.

Similar options exist for the other encoder channel i.e. enc1_filter.

enc0_a

This option determine the state of the A signal required for an index pulse to be recognized. Set this option to "yes", "y" or "1" to require that the A signal be high for an index pulse to be detected. Set it to "no", "n" or "0" to require the A signal to be low. If a Quanser QBot 2 terminal board is being used, then these polarities are reversed because the buffers on the terminal board are inverting. In that case, select "1" to require that A is low, and "0" to require that it be high.

Similar options exist for the other encoder channel i.e. enc1_a.

enc0_b

This option determine the state of the B signal required for an index pulse to be recognized. Set this option to "yes", "y" or "1" to require that the B signal be high for an index pulse to be detected. Set it to "no", "n" or "0" to require the B signal to be low. If a Quanser QBot 2 terminal board is being used, then these polarities are reversed because the buffers on the terminal board are inverting. In that case, select "1" to require that B is low, and "0" to require that it be high.

Similar options exist for the other encoder channel i.e. enc1_b.

enc0_z

This option determine the state of the Z signal required for an index pulse to be recognized. Set this option to "yes", "y" or "1" to require that the Z signal be high for an index pulse to be detected. Set it to "no", "n" or "0" to require the Z signal to be low. If a Quanser QBot 2 terminal board is being used, then these polarities are reversed because the buffers on the terminal board are inverting. In that case, select "1" to require that Z is low, and "0" to require that it be high.

Similar options exist for the other encoder channel i.e. enc1_z.

Warning If this option is set incorrectly then an index pulse is detected every time the A and B signals match the criteria defined by the enc0_a and enc0_b options - which is basically "all" the time. If the index position vary seemingly continuously, try changing this option to the opposite polarity.

enc0_reload

Set this option to "yes", "y" or "1" to reload encoder counter 0 when the index pulse occurs. This option is generally not recommended because it wreaks havoc on controllers if the controller is not carefully designed. The Quanser QBot 2 keeps track of the last position at which an index pulse occurred in a separate set of registers, so reloading the encoder counter on an index pulse is less important.

Similar options exist for the other encoder channel i.e. enc1_reload.

Properties

The Quanser QBot 2 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.

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

Yes

Only supported with a QBot 2 device.

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