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 QBall 2

Deprecated 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:

Quanser UAV Reference Frame

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

Warning

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.

Warning

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

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 QBall 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