Quanser QBall 2
This card is no longer available. For a newer card with much improved capabilities, visit the Quanser website for the Quanser QDrone.
The Quanser QBall 2 is an Unmanned Aerial Vehicle (UAV) built and sold by Quanser, Inc. The QBall2 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 QBall2 is the QUARC Linux DuoVero Target. The QBall2 HIL card may only be used with QUARC when this target is selected. The following characteristics are of particular interest when using the QBall2 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 QUARC driver name for this card is qball2.
The Quanser QBall 2 uses the Quanser standard reference frame for UAVs, as shown below:
To select the Quanser QBall 2 HIL board, pass qball2 as the card type argument to the hil_open function.
Note that the Linux DuoVero target must be selected to use the Quanser QBall 2 board. |
The Quanser QBall 2 I/O channels are described below.
Clocks
There are currently no configuration options for the Quanser QBall 2 clocks.
Analog Inputs
The Quanser QBall 2 supports 3 analog inputs. Hence, analog input channel numbers range from 0 to 2. The first two analog inputs have 0-5V range and 12-bit resolution. The last analog input channel is actually the battery voltage, which can be used to monitor when the battery voltage is getting low. The battery voltage range is 0-20V with 12-bit resolution.
Analog Outputs
The Quanser QBall 2 card does not support analog outputs.
Digital Inputs
The Quanser QBall 2 supports 8 reconfigurable digital I/O lines that may be used as digital inputs.
Digital Outputs
The Quanser QBall 2 supports 8 reconfigurable digital I/O lines that may be used as digital outputs.
It also supports two dedicated digital output lines. Digital channel 8 drives an onboard LED, and channel 9 is used to enable the quadrotor motors. An enable signal is provided so that the motors may be disabled without powering down the device, which is useful for motor calibration.
Encoder Inputs
The Quanser QBall 2 card does not support encoder inputs.
PWM Outputs
The Quanser QBall 2 driver supports two PWM output channels. Hence, PWM output channels range from 0 to 1.
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 QBall 2 supports eight other input channels. The other input channels are defined as follows:
Other Input Channel |
Description |
Units |
---|---|---|
0 |
Sonar distance |
(m) |
3000 |
Gyroscope X-axis |
(rad/s) |
3001 |
Gyroscope Y-axis |
(rad/s) |
3002 |
Gyroscope Z-axis |
(rad/s) |
4000 |
Accelerometer X-axis |
(m/s2) |
4001 |
Accelerometer Y-axis |
(m/s2) |
4002 |
Accelerometer Z-axis |
(m/s2) |
10000 |
Temperature |
(°C) |
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) |
Other Outputs
The Quanser QBall 2 supports four other output channels, defined in the table below. The four channels drive the motors for the quadrator. Full throttle (100%) is represented by a real value of 1.0, while zero throttle (0%) is denoted by a value of 0.0. Quantities in between are used for intermediate throttle values.
Other Output Channel |
Description |
Units |
---|---|---|
11000 |
Left motor throttle |
(%) |
11001 |
Right motor throttle |
(%) |
11002 |
Front motor throttle |
(%) |
11003 |
Back motor throttle |
(%) |
Interrupts
The Quanser QBall 2 card, or its driver, does not support any interrupt sources.
Watchdog
The Quanser QBall 2 supports a watchdog timer for resetting the outputs on watchdog expiry. Namely, the first nine digital output channels, the four other outputs (rotor motors) and the two 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 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
gyro_bw
This option determines the low-pass filter cutoff frequency used by the gyroscope. The gyroscope uses a low-pass filter to reduce noise when it samples the sensors. Valid cutoff frequencies depend on the selected output data rate (see gyro_rate). Valid values range between 12.5 and 110 Hz. If a value is specified within this range then it chooses the closest bandwidth that is valid for the output data rate. The specific bandwidths available for each data rate are shown in the table below:
Output Data Rate (Hz) |
Valid Filter Bandwidths (Hz) |
---|---|
100 |
12.5 or 25 |
200 |
12.5, 25, 60 or 70 |
400 |
20, 25, 50, or 110 |
800 |
30, 35, 50 or 110 |
gyro_fs
This option determines the full-scale range of the gyroscope. The gyroscope supports full-scale ranges of 250 deg/s, 500 deg/s or 2000 deg/s. The full-scale range should be specified in deg/s. If a value is chosen between 250 and 2000 deg/s that does not match a valid full-scale range then it chooses the closest range that encompasses the requested range.
Note that the output of the other input channels for the gyroscope, however, will be in rad/s. |
gyro_rate
This option determines the output data rate (ODR) used by the gyroscope. The gyroscope has its own internal clock with which it samples the sensors. Valid rates are 100, 200, 400 or 800 Hz. If a value is chosen between 100-800 Hz that does not match a valid rate then it chooses the closest rate.
Properties
The Quanser QBall 2 card does not support any properties.
Targets
Target |
Supported |
Comments |
---|---|---|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
No |
Not supported. |
|
Yes |
Only supported with a QBall 2 device. |
|
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.