FPGA in Data Acquisition Using cRIO and LabVIEW:
User Manual
Joanne Sirois and Joe Voelmle
Dr. Zalewski CDA 4104
May 2, 2009
Table of Contents
1.
Introduction...........................................................................................................................................3
2.
Working with NI 9401..........................................................................................................................4
3.
4.
5.
2.1
Introduction...................................................................................................................................4
2.2
Running the Example Program.....................................................................................................6
Working with NI 9263........................................................................................................................10
3.1
Introduction.................................................................................................................................10
3.2
Running the Example Program...................................................................................................10
Working with NI 9205........................................................................................................................14
4.1
Introduction.................................................................................................................................14
4.2
Running the Example Program...................................................................................................15
Conclusion..........................................................................................................................................20
References...................................................................................................................................................22
Appendix A.................................................................................................................................................23
Data Acquisition using the cRIO-9074 FPGA Modules.........................................................................23
Creating a VI for NI 9401...................................................................................................................23
Creating a VI using NI 9263...............................................................................................................32
Creating a VI using NI 9205...............................................................................................................34
Appendix B.................................................................................................................................................36
1. Introduction
The NI cRIO-9074 integrated system, shown in Figure 1, combines a real-time processor
and a reconfigurable field-programmable gate array (FPGA) within the same chassis for
embedded machine control and monitoring applications. It integrates a 400 MHz industrial
real-time processor with a 2M gate FPGA and has eight slots for NI C Series I/O modules.
This system features 128 MB of DRAM for embedded operation and 256 MB of nonvolatile
memory for data logging. [1]
The cRIO-9074 features two 10/100 Mb/s Ethernet ports that you can use to conduct
programmatic communication over the network and built-in Web (HTTP) and file (FTP)
servers as well as to add expansion and distributed I/O to the system. [1]
Figure 1 cRIO-9074 [1]
In this project there are three modules attach to the cRIO-9074: the NI 9401 digital inputoutput module, the NI 9263 analog output module, and the NI 9205 analog input module.
2. Working with NI 9401
2.1 Introduction
The National Instruments NI 9401, shown in Figure 2, is an 8-channel, 100 ns
bidirectional digital input-output module for any NI CompactDAQ or CompactRIO chassis.
One can configure the direction of the digital lines on the NI 9401 for input or output by
nibble (4 bits). Thus, one can program the NI 9401 for three configurations - eight digital
inputs, eight digital outputs, or four digital inputs and four digital outputs. With
reconfigurable I/O (RIO) technology (CompactRIO only), one can use LabVIEW FPGA to
program the NI 9401 for implementing custom, high-speed counter/timers, digital
communication protocols, pulse generation, and much more. Each channel is compatible with
5 V/TTL signals and features 1,000 V root mean square (rms) transient isolation between the
I/O channels and the backplane. [2]
Figure 2 - NI 9401 [2]
Figure 3 - NI 9401 Pin Assignments[2]
In the following example we will use the NI 9401 module to output a 5V signal through
Channel 0, pins 14 and 1. The connector pinout is shown in Figure 3.
2.2 Running the Example Program
Below we present a sequence of steps to run a LabVIEW VI, showing how to use the NI
9401 digital I/O module to send a digital signal to an output line.
1. Start LabVIEW.
Figure 4 - LabVIEW Getting Started Window
2. Under Open of the Getting Started window (Figure 5), browse for C:\CDA 4170\
Digital Line Output - cRIO.lvproj.
3. This opens the Project Explorer Window for Digital Line Output - cRIO.lvproj.
4. Expand RT CompactRIO Target, and expand FPGA Target. You will see the screen
show in Figure 5.
Figure 5 - Project Explorer
5. Double Click Digital Line Output.vi and the VI will appear as shown in Figure 6:
Figure 6 - Digital Line Output.vi
6. Click the Run button to start the VI.
Figure 7 - Digital Line Output Running
7. Connect loose wires to pins 14 and 1 of the D-subconnector (Figure 3)
8. Connect a multimeter to the wires at set up to read DC voltage (make sure pin 14 is
connected to HI and 1 is connected to ground). The multimeter will display a value of
0V or 5V.
9. Toggle DO0 on the VI which will cause a 5V to 0V reading to appear on the
multimeter, showing that we can control the NI 9401 through our VI. This step ends
this simple example.
3. Working with NI 9263
3.1 Introduction
NI 9263, shown in Figure 8, is a 4-channel, 100 kSample/s simultaneously updating
analog output module for any NI CompactDAQ or CompactRIO chassis. The NI 9263 also
features 30 V overvoltage protection, short-circuit protection, low crosstalk, fast slew rate,
high relative accuracy, and NIST-traceable calibration. The NI 9263 module includes a
channel-to-earth ground double isolation barrier for safety and noise immunity[3].
Figure 8 - NI 9263 [3]
3.2 Running the Example Program
This section shows, step-by-step, how to run a simple example of sending an analog
signal to the NI 9263 module output line.
1. Repeat Steps 1-4 of Section 2.2
2. In the Project Explorer window Double click on Analog Line Output.vi. The
following VI, shown in Figure 9, should open.
10
Figure 9 - Analog Line Output.vi
3. Click the Run button to start the VI.
11
Figure 10 - Analog Line Output.vi Running
4. Connect external wires to pins 0 and 1 of the D-subconnector (Figure 11).
5. Connect a multimeter to the wires at set up to read frequency.
6. Under phase increment (Figure 10), enter 1073743 corresponding to 10 kHz. This is
what should be displayed on the multimeter.
7. Now enter 1288490 in phase increment. The multimeter should now display 12 kHz.
This shows that we can control the NI 9263 through our VI, and concludes this
example.
12
Figure 11 NI 9263 terminal assignments
13
4. Working with NI 9205
4.1 Introduction
The NI 9205, shown in Figure 12, is an analog input module that features 32 single-ended
or 16 differential analog inputs, 16-bit resolution, and a maximum sampling rate of 250
kSamples/s. Each channel has programmable input ranges of 200 mV, 1, 5, and 10 V.
To protect against signal transients, the NI 9205 includes up to 60 V of overvoltage
protection between input channels and common ground (COM). In addition, the NI 9205 also
includes a channel-to-earth-ground double isolation barrier for safety, noise immunity, and
high common-mode voltage range. It is rated for 1,000 V rms transient overvoltage
protection. [4]
Figure 12 - NI 9205 [4]
14
4.2 Running the Example Program
This example attempts to show step-by-step how to read an analog input signal from the
NI 9205 with LabVIEW.
1. Repeat Steps 1-4 of Section 2.2
2. In the Project Explorer window Double click on Analog Line Intput.vi. The front
panel shown in Figure 13 should open.
3. Make sure that terminal mode is set to DIFF. To do this, in the Project Explorer
Window, right click on Mod 1 (Slot 1, NI 9205) and select Properties. Change
Channel 0 (AI0) from RSE to DIFF, as shown in Figure 14. Figure 16 shows the NI
9205 Terminal and Pin Assignments, Figure 17 shows the NI 9205 Differential Pairs
which shows that for Channel 0 AI0 and AI8 must be used, and Figure 18 shows how
to connect a device to the NI 9205 using Differential Connections.
Figure 13 - Analog Line Input.vi
15
Figure 14 C Series Module Properties
4. Click the Run button to start the VI (Figure 15).
16
Figure 15 - Analog Line Input.vi Running
5. Connect external wires to pins 1 and 20 of the D-subconnector.
6. Connect a battery or other source of DC signal to the wires.
7. Under Mod1/AI0 the meter should jump as the voltage of the voltage source changes,
showing the actual value of the signal amplitude. This concludes this example.
17
Figure 16 NI 9205 Terminal and Pin Assignments [4]
Figure 17 NI 9205 Differential Pairs [4]
18
Figure 18 Connecting a Device to the NI 9205 Using Differential Connections [4]
19
5. Conclusion
There were several difficulties that were encountered in the course of this project. The
most serious was the lack of availability of resources to use LabVIEW with cRIO and its
FPGA. There seems to be an abundance of information available on the Internet, but no clear
starting point at which a novice can begin. The problem was finally resolved by a phone call
to technical support at National Instruments to walk us through how to create simple VIs in
LabVIEW. However, much time was spent setting up this phone conversation. Days were
spent emailing back and forth to get answers to questions. The authors feel that a more timely
resolution would have been to have a field engineer on sight to conduct a tutorial in creating
LabVIEW VIs using cRIO. Appendix B lists an email detailing how National Instrument
support was used.
As the initial learning curve is overcome, many more substantial VIs can be developed
using CRIO. The rudimentary VIs developed in this report were to gain experience in using
cRIO within the LabVIEW environment. Basic signal acquisition was demonstrated, using
simple voltage sources. As confidence and knowledge is gained in using cRIO, more
substantial data acquisition using sophisticated VIs and advanced transducers should be
possible. Once cRIO and LabVIEW are mastered, it is the authors opinion that the design of
advanced data acquisition systems should possible in a much shorter period of time and with
less cost than traditional methods.
LabVIEW provides the user with the ability to integrate applications written in VHDL
code into a LabVIEW FPGA without having to recreate the application in LabVIEW. The
20
user can enter the code in LabVIEWs HDL Interface Node. This utility creates a LabVIEW
VI or function from the users code so that it can be used in the graphical programming
environment of a LabVIEW Block Diagram just like any other VI or function. This saves
development time by allowing the user to the user use proven VHDL code in their
application. More details are given in Importing HDL Code into FPGA VIs Using the HDL
Interface Node [7].
21
References
[1] NI cRIO-9074- Products and Services - National Instruments, National Instruments Corp,
Austin, TX, http://sine.ni.com/nips/cds/view/p/lang/en/nid/203964
[2] NI 9401 - Products and Services - National Instruments, National Instruments Corp, Austin,
TX, http://sine.ni.com/nips/cds/view/p/lang/en/nid/205926
[3] NI 9263 - Products and Services - National Instruments, National Instruments Corp, Austin,
TX, http://sine.ni.com/nips/cds/view/p/lang/en/nid/205923
[4] NI 9205 - Products and Services - National Instruments, National Instruments Corp, Austin,
TX, http://sine.ni.com/nips/cds/view/p/lang/en/nid/202571
[5] LabVIEW FPGA and CompactRIO Getting Started Tutorial, National Instruments Corp,
Austin, TX, http://www.ni.com/pdf/labview/us/fpga_compactrio_getting_started.pdf
[6] Getting Results with CompactRIO and LabVIEW, National Instruments Corp, Austin, TX,
2006, http://ftp.uniroma2.it/Natinst/support/ind_comm/manuals/371012c.pdf
[7] Importing HDL Code into FPGA VIs Using the HDL Interface Node, National Instruments
Corp, Austin, TX, 2008, http://zone.ni.com/devzone/cda/tut/p/id/3483
22
Appendix A
Data Acquisition using the cRIO-9074 FPGA Modules
Objective: Three basic programs will be developed to output 5V from the NI 9401,
output Frequency from NI 9263 and read an input voltage from NI 9205.
Background: The student is required to know:
Chapters 1 & 2 from the Bishops textbook, and
Chapters 1 & 2 from LabVIEW Getting Started, as listed in Module #4 Student Activities.
Creating a VI for NI 9401
Adding a new VI for the Digital IO Module
1. Start LabVIEW and click Go under Targets FPGA Project in LabVIEW getting
Started Window (see Figure A1).
23
Figure A1 LabVIEW Getting Started
2. Select Compact RIO Reconfigurable Embedded Systems under Select FPGA Project
Type in the Create New LabVIEW FPGA Project window and click Next, as shown
in Figure A2
Figure A2 Create New LabVIEW FPGA Project
24
3. In the next window (Figure A3), select either Discover existing system or Create
new system. We will pursue further with the former choice, Discover existing
system (It refers to the existing hardware). If you are sure that the cRIO device is
connected and has an IP address, then also select Device is connected to a remote
Subset and enter the devices IP address.
Figure A3 Create New CompactRIO FPGA Project Window- Discover existing system
25
4. When LabVIEW discovers cRIO, click Next on the next screen as shown in Figure
A4.
Figure A4 Create New CompactRIO FPGA Project Window- select a controller
26
5. As a result, the screen in Figure A5 appears with the cRIO IP address. Click Finish
Figure A5 Create New CompactRIO FPGA Project Window- Finish
27
6. On the next screen, close the FPGA Wizard and expand the FPGA Target menu. A
screen shown in Figure A6 appears.
Figure A6 Project Explorer
28
7. Right click on FPGA Target (Figure A6), select New and VI. A new VI Front Panel
appears (Figure A7).
Figure A7 VI Front Panel
8. Open Block Diagram in this VI.
29
9. Project Explorer Mod3 folder
a. Drop and drag Mod3/DIO0 to Block Diagram (as shown in Figure A8)
Figure A8 - Drop Mod3 node to Block Diagram
b. Expand the moved node down to show Mod3/DIO0, Mod3/DIO1,
Mod3/DIO2, and Mod3/DIO3 (See Figure A9)
Figure A9 Expanded Mod3 node
30
10. In this node, right click Mod3/ DIO0 Change to Write and repeat it for DIO1,
DIO2, and DIO3
11. Now you need to use a While Loop. Right click in the Block Diagram, select
Structures, and then select While Loop, and drop into the Block Diagram, and expand
it to include the Mods node.
12. Inside while loop - Right Click Boolean - true constant, drop four of these in
while loop
13. Wire one true constant to one DIO input (See Figure A10)
14. Hover over step sign and right click Create Control, a Stop Button will appear and
the entire Block Diagram will look like Figure A10.
Figure A10 VI for the Digital I/O Module Example
31
15. In Project Explorer (Figure A6), right click on Mod3 (Slot 3, NI 9401) and select
properties. Make sure that DIO 3:0 has Output in the drop down menu (Figure A11).
Figure A11 - Mod3 (Slot 3, NI 9401) Properties Window
16. Click Run Button (To compile)
Creating a VI using NI 9263
1. Starting at step 7 of the previous section, Adding a new VI for the Digital IO Module,
right click on FPGA Target (Figure A6), select New and VI. A new VI Front Panel
appears (Figure A7).
2. Open Block Diagram in this VI. Right click Block Diagram - Function window FPGA
Math & Analysis Generation Sine Wave. Drop Sine Wave Generator into Block
Diagram.
3. Right click Front Panel diagram Numeric Numeric Control. Drop on Front Panel
and name Phase increment. Enter 1073743 in Numeric Control.
32
4. Right click on Block Diagram Programming Structures While Loop
5. Hover over stop sign
6. Right click Create Control (Stop Button)
7. Project Explorer Mod2 folder
a. Drop and drag Mod2/AO0 to Block Diagram inside while loop
b. Wire phase increment to Sine Wave Generator and Sine Wave Generator to
Mod2/AO0. Block Diagram should look like Figure A12.
Figure A12 NI 9263 Analog Output VI Block Diagram
8. Save VI.
9. Press Run Button (To compile)
33
Creating a VI using NI 9205
1. Starting at step 7 of the previous section, Adding a new VI for the Digital IO Module,
right click on FPGA Target (Figure A6), select New and VI. A new VI Front Panel
appears (Figure A7).
2. Open Block Diagram in this VI.
3. Project Explorer - Mod 1 folder. Drop and drag Mod1/AI0 to Block Diagram
4. Right Click Mod1/ AI0 create indicator
5. From the Front Panel right click - indicator numeric meter. Change numbers from 0
to 10. Your front panel should look like Figure A13.
Figure A13 - Meter in Front Panel
6. Right click in the Block Diagram Numeric Quotient & Remainder. Drop in Block
Diagram.
7. Right click in the Block Diagram Numeric Numeric Constant. Drop in Block
Diagram. Enter 300 in Numeric Constant.
8. In the Block Diagram right click and add while loop, enclosing everything within it.
9. Hover over step sign. Right click Create Control (Stop Button)
10. Wire Mod1/AI0 to x in Quotient & Remainder and Numeric Constant to y. Wire Q in
Quotient & Remainder to Meter. Block Diagram should look like A14.
34
Figure A14 - NI 9205 Analog Input VI Block Diagram
11. Save VI
12. Press Run Button (To compile)
35
Appendix B
Date:Wed,1Apr200915:45:550500
From:support@ni.com
Replyto:support@ni.com
To:jjvoelml@eagle.fgcu.edu
Subject:RE:(Reference#1348229)Fw:ProblemswithcRIOandFPGA
Note:Yourreferencenumberisincludedinthesubjectfieldofthis
message.Itisveryimportantnottoremoveormodifythisreference
number,oryourmessagemaybereturnedtoyou.
HiJoe,
Asdiscussedoverthephonetoday,wewillplantogooverthesettingof
thecRIOonthephoneonFriday,April3rdat1pmEST,12pmCST.
Pleaseletmeknowifyouwillberunninglateorcannotmakeitbyeither
emailingmebackorcallingin.
Thanks!
KarunyaRavindran
ApplicationsEngineer
NationalInstruments
http://www.ni.com/support
HelloKarunya,
Thankyouforwillingtoworkwithusonthisproblemoverthephone.
Weareavailabletomorrow,Friday,03/27,beginning9:30EST,till
around1:00pm.
Pleaseletusknowyourbesttimetocall,maybetwowindows,since
36
Allheaders
we'llbebusywiththeclassduringthistime.Thenwe'lldecideonthe
timingwhocallswhom.(Wedon'thaveatelephoneinthisroom,but
canuseoneofourcellphones.)
KindRegards,
Janusz
________________________________________
From:support@ni.com[support@ni.com]
Sent:Wednesday,March25,20095:27PM
To:Zalewski,Janusz
Cc:jjvoelml@eagle.fgcu.edu;Michele.Yackel@ni.com;Zalewski,Janusz;
JoanneSirois
Subject:RE:(Reference#1348229)Fw:ProblemswithcRIOandFPGA
Note:Yourreferencenumberisincludedinthesubjectfieldofthis
message.Itisveryimportantnottoremoveormodifythisreference
number,oryourmessagemaybereturnedtoyou.
HiJansuz,
Itmightbeeasiertotroubleshootthisoverthephonethanoveremail.If
thereisaphonenumberwhereIcangetintouchwithyoutotroubleshoot
overthephone,pleaseletmeknow.Oryoucangetintouchwithmeat
18662756964andreferenceyourservicerequestnumber.Thephonecall
willgetroutedtomeandmoveaheadwiththis.
37
Thanks!
KarunyaRavindran
ApplicationsEngineer
NationalInstruments
http://www.ni.com/support
HelloKarunya,
IwilltrytoansweryourquestionsasmuchasIcan:
>Thesofwareonthehostsystemisn'tasbigasaconcernasthesoftware
on
>thecRIOitself.WasthecRIOeverworkingproperly.
WenevertriedtouseitforaccessingtheFPGAorthemodulesplugged
intothechassis,soitthissenseitwasnevertested.Thisisthefirst
attempt.
>HowareyouconnectedtothecRIO?Areyouusingacrossovercableora
>networkswitch?Ifyouaren'tusingacrossovercable,pleaseconnectto
>thecRIOusingthatmethod.
ThecRIOboxisconnectedtothehostviatheEthernet,andIdon't
thinkwehavethecrossovercable.Thisishowwewanttouseit:
accessibleviatheIPaddress.
>Areyouabletoinstalloruninstallanysoftwareatall?
38
Ithinkwedid.Joanne,couldyouprovidemoredetails?
>HaveyoutriedformattingthecRIOonce?Pleaseensurethatyouhave
access
>tothesoftwareonthecRIObeforeyoudecidetoformatthecRIO.
NotsurewhatyoumeanbyformattingcRIO?Neverdonethat,Ithink.
Overall,I'dsaythatwearenotgoinganywherewiththis,since
thereistoomanyunknownstoushere.Isthereachancesome
NationalInstrumentstechnicianorsupportpersoncancomehere
tocheckonit?
ThanksandKindRegards,
JanuszZalewski
________________________________________
From:support@ni.com[support@ni.com]
Sent:Friday,March20,20092:02PM
To:JoanneSirois
Cc:jjvoelml@eagle.fgcu.edu;Zalewski,Janusz
Subject:Re:(Reference#1348229)Fw:ProblemswithcRIOandFPGA
Note:Yourreferencenumberisincludedinthesubjectfieldofthis
message.Itisveryimportantnottoremoveormodifythisreference
number,oryourmessagemaybereturnedtoyou.
39
HiJoanne,
IjusthaveafewquestionsontheworkingsonyourcRIO.
Thesofwareonthehostsystemisn'tasbigasaconcernasthesoftwareon
thecRIOitself.WasthecRIOeverworkingproperly.
HowareyouconnectedtothecRIO?Areyouusingacrossovercableora
networkswitch?Ifyouaren'tusingacrossovercable,pleaseconnectto
thecRIOusingthatmethod.
Areyouabletoinstalloruninstallanysoftwareatall?
Forexample,whenyouselectthecRIOinMAX,Rightclickonsoftware,
selectAdd/Removesoftware,andselectcustominsall,doesitinstantly
disconnect?DoestheSystemStatesaydisconnectedwhenyouexitofthethe
softwarewindow.
Iwouldliketoknowwhenexactlythedisconnecthappens.Usingacross
overcabletoconnectthecRIOtothehostsystemshouldeliminatethis
problem.
HaveyoutriedformattingthecRIOonce?Pleaseensurethatyouhaveaccess
tothesoftwareonthecRIObeforeyoudecidetoformatthecRIO.
Pleaseletmeknowtheresultsofthis.
KarunyaRavindran
ApplicationsEngineer
NationalInstruments
40
http://www.ni.com/support
Hello,
WhenIselectaddandremovesoftwarecRIOdisconnects.SoInevergetthe
optionfor
custominstallation.
Ididaprintscreenofthesoftwarethatisinstalledandversionnumbers
ofthehost
computer.(Attached)
JoanneSirois
OnWed,18Mar200912:40:020500,supportwrote
>Note:Yourreferencenumberisincludedinthesubjectfieldofthis
>message.Itisveryimportantnottoremoveormodifythisreference
>number,oryourmessagemaybereturnedtoyou.
>
>HelloJoanne,
>
>SinceKarunyaisleadingacustomertrainingtoday,Iwantedtoreplyto
>youonherbehalf.
>
41
>TheVariableClientsupportdoesneedtobeinstalledonthecontroller,
>andtheversionsometimesdoesmatter.Iamnotsurewhichversionof
>LabVIEWandLVRealTimethatyouhave,soIcannotanswerthisquestion
>forsureyet.WhatIsuggestthatyoudo,iswhenyouareconnectedto
>yourhostcomputer,openMAXandrightclickSoftwareunderneathyour
>RemoteSystemstarget,andselectAdd/RemoveSoftware.Selecttheoption
>forcustomisntallation,andensurethatthelatestversionoftheNIRIO
>driverandtheRTcomponentsfromyourhostcomputer(suchasVariable
>ClientSupport&VariableEngine)areselectedforisntallationonthe
>CompactRIO.
>
>Incaseyourunintoanyissues,pleaseletusknow,andalsotellus
what
>theversionsofsoftwareonyourhostcomputerandtargetare.
>(Screenshotsmaybehelpfulhere).
>
>Thanks.
>
>Regards
>
>KamalinaSrikant
42
>ApplicationsEngineer
>NationalInstruments
>
http://www.ni.com/support
>
>
>
>Karunya,
>
>BothVariableClientSupportandNetworkvariableareinstalledalthough
>theyare
>
>version1.4.0insteadof1.5.0
>
>Wouldthatcauseaproblem?
>
>Thankyou,
>
>JoanneSirois
43
>
>OnThu,12Mar200915:00:550500,supportwrote
>
>>Note:Yourreferencenumberisincludedinthesubjectfieldofthis
>
>>message.Itisveryimportantnottoremoveormodifythisreference
>
>>number,oryourmessagemaybereturnedtoyou.
>
>>
>
>>HiJanusz,
>
>>
>
>>Thankyouforgettingintouchwithsupport.MynameisKarunya
Ravindran
>
>>andIwillbehelpingyouwiththisissue.
44