 
    
NI PCI-6040e
The National Instruments PCI-6040e is an E Series card for a PCI slot. For more information, visit the National Instruments' website for the NI PCI-6040e.
The QUARC driver name for this card is ni_pci_6040e .
             
        
| 
 | This driver is currently a beta version. Quanser does not guarantee that this driver will work as expected and shall not be liable for any damage resulting from its use. However, if you are using this driver, we would appreciate any feedback at tech@quanser.com. | 
Clocks
This card is part of the DAQmx API, and therefore the hardware clocks cannot be directly accessed. The clocks can only be set indirectly with the functions that utilize them such as the timebase blocks.
 Only one hardware timebase may be used at a time. In addition, immediate I/O and task-based I/O cannot use the same channels with the NI PCI-6040e card, even
            if they use different resources. For instance, if a task created using hil_task_create_analog_reader
            is reading from analog input 0, then hil_read_analog cannot be used to read from
            analog input 0 while the task is running.
            Only one hardware timebase may be used at a time. In addition, immediate I/O and task-based I/O cannot use the same channels with the NI PCI-6040e card, even
            if they use different resources. For instance, if a task created using hil_task_create_analog_reader
            is reading from analog input 0, then hil_read_analog cannot be used to read from
            analog input 0 while the task is running.
        
 The hil_task_create functions only support a samples_in_buffer argument of 1 when used with the NI PCI-6040e card. Attempting to use a
            different buffer size will result in the error: "The specified buffer size is not valid. It may be out of an acceptable range."
            The hil_task_create functions only support a samples_in_buffer argument of 1 when used with the NI PCI-6040e card. Attempting to use a
            different buffer size will result in the error: "The specified buffer size is not valid. It may be out of an acceptable range."
        
Analog Inputs
The NI PCI-6040e supports 16 analog inputs (channels 0 to 15) with 12-bit resolution.
The valid input ranges are ±10V, ±5V, ±2.5V, ±1V, ±0.5V, ±0.25V, ±0.1V, ±0.05V, 0-10V, 0-5V, 0-2V, 0-1V, 0-0.5V, 0-0.2V, and 0-0.1V. To change from the default range of ±10V, use the hil_set_analog_input_ranges function.
The supported analog input configurations are Referenced singled-ended (0), Non-referenced singled-ended (1), Differential (2). In order to change the analog input configuration, use the hil_set_analog_input_configuration function.
By default, all NI 60xx (E Series), NI 62xx (M Series), NI 63xx (X Series) boards have the default analog input configuration as:
| For devices with 8 channels: | Differential for the first four channels, referenced single-ended for the next four channels. | 
| For devices with 16 channels or more: | Differential for eight channels followed by referenced single-ended for eight channels. For instance, channels 0-7, 16-23, and 32-39 are differential. Channels 8-15, 24-31, and 40-47 are referenced-single ended. | 
Note that when configuring for differential inputs, the positive and negative pairs of the signals must be connected as indicated above. For example for cards that have 32 analog input channels, and if you want to use the maximum number of differential inputs (i.e. 16 differential inputs), then the first differential input's positive line must be connected to channel 0, and negative line to channel 8. The second differential input's positive line must be connected to channel 1, and negative line to channel 9. This continues for the first eight differential inputs. Then the ninth differential input's positive line must be connected to channel 16, and negative line to channel 24. The tenth differential input's positive line must be connected to channel 17, and negative line to channel 25. This continues for the remaining channels. In order to read the differential input values, the input channels must be set to [0-7, 16-23].
| 
 | Note that when using task-based I/O, the samples_in_buffer argument to the hil_task_create function must be set to 1 for this card. | 
Analog Outputs
The NI PCI-6040e supports 2 analog outputs (channels 0 to 1) with 12-bit resolution.
The valid output ranges are ±10V and 0-10V. To change from the default range of ±10V, use the hil_set_analog_output_ranges function.
| 
 | Note that when using task-based I/O, the samples_in_buffer argument to the hil_task_create function must be set to 1 for this card. | 
Digital Inputs
The NI PCI-6040e supports 8 digital input lines (lines 0 to 7).
A digital I/O line cannot be used as an input and output at the same time.
Since the digital I/O lines may be individually programmed as inputs or outputs, all the channels which will be used for digital inputs should be configured with the hil_set_digital_directions function. Set the input_channels argument to all the digital I/O channels that will be used as digital inputs on the board.
Digital Outputs
The NI PCI-6040e supports 8 digital output lines (lines 0 to 7).
A digital I/O line cannot be used as an input and output at the same time.
Since the digital I/O lines may be individually programmed as inputs or outputs, all the channels which will be used for digital outputs should be configured with the hil_set_digital_directions function. Set the output_channels argument to all the digital I/O channels that will be used as digital outputs on the board.
Encoder Inputs
The NI PCI-6040e supports 2 encoder inputs with 24-bit count values (channels 0 and 1). Note that since this card uses its counters for both encoder inputs and PWM outputs, you can only use a counter as either an encoder input or a PWM output channel.
In order to set the encoder counters to a particular count, use the hil_set_encoder_counts function. Configure the quadrature mode using the hil_set_encoder_quadrature_mode function. The NI PCI-6040e only supports non-quadrature (count and direction) counting. The NI PCI-6040e does not support encoder filtering.
PWM Outputs
The NI PCI-6040e supports 2 24-bit PWM Outputs using its 2 counters (channels 0 and 1). The PWM outputs on this card use a counter timebase rate of 20 MHz. Note that since this card uses its counters for both encoder inputs and PWM outputs, you can only use a counter as either an encoder input or a PWM output channel.
Use the hil_set_pwm_mode function to set the desired PWM output mode. The NI PCI-6040e supports all the PWM output modes: duty cycle, frequency or period. See the description of the PWM Output Configurations for details on these modes. Then use the hil_set_pwm_frequency or hil_set_pwm_duty_cycle function to set the desired frequency or duty cycle respectively. Note that this card is part of the National Instruments' DAQmx API and one of the limitations of this API is that you cannot output a PWM signal with a 0% or 100% duty cycle. Furthermore, a value of 0 for frequency is also not acceptable. When in duty cycle mode, the acceptable range of duty cycles are:
Note that the PWM signal period is the frequency inverted. Therefore, the acceptable value for duty cycle is related to the frequency at which the signal is being generated. In frequency mode, the acceptable range of frequencies are related to the duty cycle of the signal and are as follows:
In period mode, the maximum and minimum values for period are recipricols of the minimum/maximum values for frequency above.
| 
 | As mentioned earlier in this section, the counters cannot be used as both encoder inputs and PWM outputs. Attempting to do so would produce an error message. | 
| 
 | Due to the DAQmx API limitations, a value of 0 (0%) and 1 (100%) for duty cycle is not accepted. Also, a frequency or a period with value of 0 is also unacceptable. However, attempting to command a value which is out of range would not produce an error. The driver would simply saturate the value at the limits. | 
Other Inputs
The NI PCI-6040e card does not support other inputs.
Other Outputs
The NI PCI-6040e card does not support other outputs.
Interrupts
The NI PCI-6040e card, or its driver, does not support any interrupt sources.
Watchdog
The NI PCI-6040e card does not support a watchdog timer.
Board-Specific Options
The board-specific options are set using the hil_set_card_specific_options function. All of the options follow the form:
option1=value[,option2=value...]
Multiple options are entered on the same line separated by semicolons. Note that there are no spaces in the line. The options and their values are not case sensitive for the National Instruments boards. The following are the available options and valid values for this board.
Properties
The NI PCI-6040e card does not support any properties.
Targets
| Target | Supported | Comments | 
|---|---|---|
| Yes | Fully supported. | |
| Yes | Fully supported. | |
| No | Not supported. | |
| No | Not supported. | |
| No | Not supported. | |
| No | Not supported. | |
| No | Not supported. | |
| No | Not supported. | |
| No | Not supported. | |
| 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 ©2025 Quanser Inc. This page was generated 2025-06-17. " Submit feedback to Quanser about this page.