# TECHNICAL DESCRIPTION CRIO LVDT 9312 Module Compact RIO

Art. Nr. 89299



This document is a technical description of the cRIO LVDT 9312 Module

- **Note** Before you begin, complete the Software and Hardware installation procedures applicable to your application.
- Note The guidelines in this document are specific to the cRIO LVDT 9312 Module. The other components in the system might not meet the same safety ratings. Refer to the documentation of each component in the system to determine the safety and EMC ratings for the entire system.

#### MORE INFORMATION ON OUR WEBSITE:

www.smart-e-tech.de/slsc

#### Copyrights:

SET GmbH All rights reserved.

Information contained herein is the property of SET GmbH and shall not be duplicated, copied, used or disclosed in whole or in part of any purpose. The right of duplication, use or disclosure is permitted only by written agreement of SET GmbH, August Braun Str. 1, 88239 Wangen/Germany. LabVIEW, CompactRIO, TestStand are Trademarks of National Instruments

1 of 37www.smart-e-tech.comcRIO LVDT 9312 ModuleIssue 0522.02.23Technical Description



# **Table Of Contents**

| 1.      | Important Instructions                                            | 4    |
|---------|-------------------------------------------------------------------|------|
| 1.1     | Initial Inspection                                                | 4    |
| 1.2     | Safety Instructions                                               | 4    |
| 1.2.1   | Module Failure                                                    | 4    |
| 1.2.2   | Impermissible Applications                                        | 4    |
| 1.2.3   | Module Installation And Removal                                   | 4    |
| 1.2.4   | Electrical Connections                                            | 4    |
| 2.      | Module Overview                                                   | 5    |
| 3.      | Getting Started                                                   | 6    |
| 3.1     | Software-Requirements                                             | 6    |
| 3.2     | Driver-Installation                                               | 6    |
| 3.3     | LVDT9312 Compact RIO LabVIEW Drivers                              | 7    |
| 3.4     | NI PCI/PXI FPGA-Card Driver Application                           | 10   |
| 3.4.1.1 | Creation of a new Project                                         | .10  |
| 3.4.1.2 | Creating a New FPGA-Target                                        | . 11 |
| 3.4.1.3 | Adding An R-Series Expansion Chassis                              | 13   |
| 3.4.1.4 | Adding The LVDT9312 Driver Components To A Project                | . 14 |
| 3.4.1.5 | Adding LVDT9312 Drivers To The Project Via Drag-And-Drop Function | 15   |
| 3.4.1.6 | Adding LVDT9312 Modules To The Project Via The Discovery-Function | 16   |
| 3.4.1.7 | Adding FPGA Example-Applications                                  | .17  |
| 3.4.1.8 | Compiling And Running The Example Application                     | 19   |
| 3.5     | Using The Driver Together With A NI RealTime CompactRIO           | 20   |
| 3.5.1.1 | Compiling And Running The Example Application                     | 23   |
| 4.      | Connecting The LVDT Demodulator                                   | 24   |
| 4.1     | Running The Application Example                                   | 25   |
| 5.      | Application Development                                           | 26   |
| 5.1.1   | LVDT9312 Driver And Communication                                 | 26   |
| 5.1.1.1 | Driver-VI Implementation                                          | 26   |
| 5.1.1.2 | Triggering LVDT9312 Functions Via Functions-VIs                   | .27  |
| 5.1.1.3 | Initialising And Clearing The FIFO Buffers                        | 28   |
| 5.1.1.4 | Application To Module Communication Diagram                       | 29   |
| 5.2     | LVDT9312 Driver-Instructions                                      | 31   |
| 5.3     | LVDT9312 Driver Error Codes                                       | 34   |
| 5.4     | Module Identification Under LabVIEW                               | 35   |
| 5.5     | Saving The Setup                                                  | 35   |
| 6.      | Technical Specification                                           | 35   |
| 6.1     | Housing                                                           | 35   |
|         |                                                                   |      |



| External Power Supply    | 35                                                                                                                                                                                    |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Excitation Output        | 35                                                                                                                                                                                    |
| Ua and Ub Signal Inputs  | 36                                                                                                                                                                                    |
| Position Processing      | 36                                                                                                                                                                                    |
| Environmental Conditions | 36                                                                                                                                                                                    |
| Connector Pinout         | 37                                                                                                                                                                                    |
| Module Calibration       | 37                                                                                                                                                                                    |
| Module Maintenance       | 37                                                                                                                                                                                    |
| Service Address          | 37                                                                                                                                                                                    |
|                          | External Power Supply<br>Excitation Output<br>Ua and Ub Signal Inputs<br>Position Processing<br>Environmental Conditions<br>Connector Pinout<br>Module Calibration<br>Service Address |



# 1. IMPORTANT INSTRUCTIONS

Please read all instructions carefully before the LVDT9312 is installed into a cRIO chassis or connected to other equipment!

# 1.1 INITIAL INSPECTION

Check that the shipment is complete and note whether any damage has occurred during transport. If the contents are incomplete or there is damage, fill a claim with the carrier immediately, and notify the SET GmbH service contact to facilitate the repair or replacement of the module. The address is listed in the back of the manual.

The following parts should be included in the shipment:

- ✓ LVDT9312 cRIO module
- ✓ CD-ROM with driver software, application examples and manual

#### 1.2 SAFETY INSTRUCTIONS

#### 1.2.1 MODULE FAILURE



Do not install the LVDT9312 module into a cRIO chassis when the module is obviously damaged:

- physical damage
- lose parts inside the module

#### **1.2.2** IMPERMISSIBLE APPLICATIONS

The module is designed for laboratory use. Installing or operating the module in explosive or hazardous environments is not permissible and may result in serious injury or death!

#### **1.2.3 MODULE INSTALLATION AND REMOVAL**



# Hot Surface! The module may be hot. Touching the module may result in body injury!

#### **1.2.4 ELECTRICAL CONNECTIONS**



The module is not designed to isolate voltage levels of more than  $50V_{DC}$ . Do not exceed the voltage levels according to the technical specifications. Not following this instruction may result in module damage.



# 2. MODULE OVERVIEW

LVDT9312 is a compact, reliable and highly versatile LVDT-to-digital conversion module. Most commonly used LVDTs can easily be used with the module without any additional signal adaption. The module has a built-in excitation oscillator inclusive power stage which can drive most LVDT's directly without the necessity of an external power booster. All module parameter are interactively adjustable via software.



The LVDT9312 accepts a wide voltage supply range from 9V to 36V and provides galvanic isolation between the cRIO and the demodulator interface. The module is useable within the NI cRIO real time environment and can also be plugged into a NI R-series expansion chassis with PCI / PXI FPGA card. We provide all drivers required for the cRIO system and LabVIEW integration examples.



LVDT9312 applications include industrial and military position control systems such as motor control, robotics and many kinds of servo loops which use LVDT.



#### 3. GETTING STARTED

#### 3.1 SOFTWARE-REQUIREMENTS

To use the LVDT FPGA-Driver the following NI Software Components must be installed first:

- LabVIEW version 2012 (12.0) or later
- LabVIEW FPGA Module
- SET C-Series Module Drivers ("Setup.exe" included on the SET LVDT Driver-CD)

#### 3.2 DRIVER-INSTALLATION

After installation of the NI Software Components, the LVDT driver software must be installed. To do this use the LVDT9312 CD-ROM and follow instructions.

To start the installation process, execute the "setup.exe" program on the CD-ROM.

Setup.exe

Please follow the instructions of the setup program to complete the driver installation.



When the installation is completed successfully, the host system is ready to use LVDT9312 modules in a LabVIEW project.



# 3.3 LVDT9312 COMPACT RIO LABVIEW DRIVERS DEFINITION

The driver application is demonstrated within a LabVIEW example project. To copy the driver components into a new project, use the drag & drop function. (see 3.4.1.4)



#### LabVIEW driver components

The LabVIEW FPGA software driver for the LVDT9312 module includes eight driver VIs which control the serial data transfer between the modules and the FPGA backplane. (Refer to the VI-library "SET\_SPI\_Drivers.lvlib"). For each possible cRIO chassis slot a dedicated driver VI is provided.



Each module slot applies to its own driver-VI

Each driver VI uses 2 FIFO buffers to communicate with the LabVIEW application. The FIFO buffers are organized in CommandIN-FIFOs and CommandOUT-FIFOs for bidirectional data flow from the application to the module and vice versa. Note that these buffers are pre-defined in the example project in terms of name and size and must not be modified to ensure correct operation. (see 3.4.1.4)



Each driver-VI uses two command FIFOs

The user interface is formed from eight slot specific "Functions-VIs", which perform the driver calls by use of the communication-FIFOs.

(Refer to the VI-library "SET\_LVDT\_9312\_Functions.lvlib").

To make the driver VIs and its dedicated FIFOs for the application accessible, a high level function VI is provided. For each possible cRIO slot one function VI. These VIs control the correct data flow and the organisation between the application and the drivers. Again these VIs are predefined and must not be modified to ensure proper operation.





Each slot applies a specific functions-VI

The folder "TypeDefs" contains data type definitions used within he previous VIs.



LabVIEW driver data type definitions

- USRCMD.ctl
- Defines the applicable LVDT9312 commands
  - MODULE\_ERROR.ctl
- Defines the driver error codes
  - LVDTCMD.ctl

For driver internal use

CALLSTATES.ctl

For driver internal use

• FPGASTATES.ctl

For driver internal use

The example project already covers all module slots with the maximum number of modules, which is four, when an R-Series Expansion Chassis is applied and up to eight modules for a cRIO-Chassis. The names of the modules in the project and the correlating modules I/O channels are pre-defined and must not be changed for correct operation.



The example project includes all module slots

8 of 37 www.smart-e-tech.com Issue 05 22.02.23



The example project also defines all required data signals:



Example project data signal definitions

The example project modules can be copied to a new project. Alternatively, when the automatic LabVIEW module detection mechanism "Discover C-Series Modules" is used, attention on identifier assignment should be paid to avoid naming conflicts

Three example files are included to demonstrate the driver-VI application:

- 🔜 SET\_LVDT\_9312\_Example\_Slot\_1.vi - 🔜 SET\_LVDT\_9312\_Example\_Slot\_1-4.vi - 属 SET\_LVDT\_9312\_Example\_Slot\_1-8.vi

#### Tree example programmes for the R-Series Expansion Chassis and cRIO-Chassis

• SET\_LVDT\_9312\_Example\_Slot\_1.vi

Program example which demonstrates the application of a single LVDT9312 module connected to slot 1 of a (PCI) FPGA R-Series Expansion-Chassis or a cRIO-Chassis.

• SET\_LVDT\_9312\_Example\_Slot\_1-4.vi

Program example which demonstrates the application of four LVDT9312 modules connected to a (PCI) FPGA R-Series Expansion-Chassis or a cRIO-Chassis.

• SET\_LVDT\_9312\_Example\_Slot\_1-8.vi

Program example which demonstrates the application of eight LVDT9312 modules connected to a cRIO-Chassis.



# 3.4 NI PCI/PXI FPGA-CARD DRIVER APPLICATION

The example below demonstrates the driver integration for a NI PCI-FPGA card together with an R-Series Expansion Chassis.

# 3.4.1.1 CREATION OF A NEW PROJECT

Copy all example project files included in .../LabVIEW on your local disk. We recommend to copy the complete Folder in your LabVIEW project stricter. To integrate the driver into a new LabVIEW project, the target project must be opened subsequently. Alternatively, to start a new project "File  $\rightarrow$  New Project" must be clicked.

| 📴 Project Explorer -                   | TestProject.lvp               | oroj 📃 🗖 🔀                  |
|----------------------------------------|-------------------------------|-----------------------------|
| <u>File E</u> dit <u>V</u> iew Project | <u>O</u> perate <u>T</u> ools | <u>W</u> indow <u>H</u> elp |
| New VI<br><u>N</u> ew                  | Ctrl+N                        | 🖽 🕶 🚰 🛕  ] 🛼 🇊 🤮            |
| Open                                   | Ctrl+O                        |                             |
| ⊆lose                                  | Ctrl+W                        |                             |
| Close All                              |                               |                             |
| Close All (this Project)               |                               | _                           |
| <u>S</u> ave                           | Ctrl+S                        |                             |
| Save <u>A</u> s                        |                               | ).98)                       |
| Sa <u>v</u> e All                      | Ctrl+Shift+S                  |                             |
| Save All (this Project)                |                               | 0-9104)                     |
| Save for Previous Versio               | оп                            |                             |
| <u>R</u> evert                         |                               | _                           |
| New Project                            |                               | ж)                          |
| Open Proj <u>e</u> ct                  |                               | ж)                          |
| Save Project                           |                               | ж                           |
| Close Project                          |                               | ж                           |
| Page Se <u>t</u> up                    |                               | ж)                          |
| Print                                  |                               | ж)                          |
| Print Window                           | Ctrl+P                        | ж)                          |
| VI Propert <u>i</u> es                 | Ctrl+I                        | — ж)<br>Slot_1.vi           |
| Recent Projects                        |                               | •                           |
| Recent Files                           |                               | •                           |
| E <u>x</u> it                          | Ctrl+Q                        |                             |

Opening the target project or creating a new project



# 3.4.1.2 CREATING A NEW FPGA-TARGET

Both project windows can be aligned as shown below. The driver components can be copied into a new project via drag-and-drop function Note that the STRG-key must be pressed during drag-and-drop to copy the element. Otherwise the element will be removed from the example project.

| 😰 Project Explorer - SET_LVDT_9312.lvproj 🗖 🗖 🔀                                                  | 🔁 Project Explorer - Untitled Project 1 💦 🗖 🗙                                                    |
|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| <u>File E</u> dit <u>V</u> iew Project <u>O</u> perate <u>T</u> ools <u>W</u> indow <u>H</u> elp | <u>File E</u> dit <u>V</u> iew Project <u>O</u> perate <u>T</u> ools <u>W</u> indow <u>H</u> elp |
| 🏝 😅 🗿    X 🗈 🗈 X    🗟 尾   🔜 - 📽 🛕                                                                | *1 🗃 🗊   X 🗅 🗅 X    🖬 尾   🖽 - 😭 🔬                                                                |
|                                                                                                  |                                                                                                  |
| Items Files                                                                                      | Items Files                                                                                      |
| 🖃 🙀 Project: SET_LVDT_9312.lvproj                                                                | 🖃 👪 Project: Untitled Project 1                                                                  |
| 🖨 💂 My Computer                                                                                  | 🖨 💂 My Computer                                                                                  |
| 📄 🚺 FPGA Target (PCI-7833R)                                                                      |                                                                                                  |
| LVDT-9312 Module Channels                                                                        | 🐫 🛬 Build Specifications                                                                         |
|                                                                                                  |                                                                                                  |
| Generation (Connector 1)     Mod1 (Slot 1, SET 9312 LVDT)                                        |                                                                                                  |
|                                                                                                  |                                                                                                  |
| Mod2 (Slot 2, SET 9312 LVDT)                                                                     |                                                                                                  |
| Mod4 (Slot 4, SET 9312 LVDT)                                                                     |                                                                                                  |
| 🔜 SET_LVDT_9312_Example_Slot_1.vi                                                                |                                                                                                  |
| 🔜 SET_LVDT_9312_Example_Slot_1-4.vi                                                              |                                                                                                  |
| 腕 40 MHz Onboard Clock                                                                           |                                                                                                  |
|                                                                                                  |                                                                                                  |
| Build Specifications                                                                             |                                                                                                  |
|                                                                                                  |                                                                                                  |
|                                                                                                  |                                                                                                  |
|                                                                                                  |                                                                                                  |
| 🖨 📴 FPGA Target cRIO (RIO0, cRIO-9104)                                                           |                                                                                                  |
| E DT-9312 Module Channels                                                                        |                                                                                                  |
| 🖨 📁 Driver Components                                                                            |                                                                                                  |
| 🕀 📁 TypeDefs                                                                                     |                                                                                                  |
| 🖶 💭 SPI Communication FIFOs                                                                      |                                                                                                  |
| ET_SPI_Drivers.lvlib                                                                             |                                                                                                  |
|                                                                                                  |                                                                                                  |
|                                                                                                  |                                                                                                  |
|                                                                                                  |                                                                                                  |
| 👘 Mod4 (Slot 4, SET 9312 LVDT)                                                                   |                                                                                                  |
| 動 Mod5 (Slot 5, SET 9312 LVDT)                                                                   |                                                                                                  |
| \min Mod6 (Slot 6, SET 9312 LVDT)                                                                |                                                                                                  |
| 👥 Mod7 (Slot 7, SET 9312 LVDT)                                                                   |                                                                                                  |
| Mod8 (Slot 8, SET 9312 LVDT)                                                                     |                                                                                                  |
|                                                                                                  |                                                                                                  |
| R SET_LVDT_9312_Example_Slot_1-4.vi<br>R SET_LVDT_9312_Example_Slot_1-8.vi                       |                                                                                                  |
| - Re 40 MHz Onboard Clock                                                                        |                                                                                                  |
|                                                                                                  |                                                                                                  |
| Build Specifications                                                                             |                                                                                                  |
|                                                                                                  |                                                                                                  |
| 📖 🔆 Build Specifications                                                                         |                                                                                                  |
|                                                                                                  |                                                                                                  |

The driver components can be copied by use of the drag-and-drop function

11 of 37www.smart-e-tech.comIssue 0522.02.23



To add a new FPGA-Target use the mouse and click (right button) onto the "my computer" symbol and select: "New  $\rightarrow$  Targets and Devices".



Select an existing FPGA-Target or define a new device.



The new FGPA-Target is now added to the project-structure.





### 3.4.1.3 Adding An R-Series Expansion Chassis

To use an LVDT9312 module together with a FPGA chassis, an "R-Series Expansion Chassis" must be added to the actual project structure. Use the mouse and click with the right button onto the newly added FPGA-Target and select "New  $\rightarrow$  R Series Expansion Chassis".

| <u>File Edit V</u> iew | Project Operate Tool | s <u>W</u> ind | ow <u>H</u> elp           |
|------------------------|----------------------|----------------|---------------------------|
| 160                    | X 🗅 🗋 X 🛛 🖬          |                | 🖽 – 🥐 🔥 🛛 🐎 🍅 👩           |
| Items Files            |                      |                |                           |
|                        | : Untitled Project 1 |                |                           |
|                        | Computer             | _              |                           |
| ė 🖪 🛽                  | New                  | •              | VI                        |
|                        | New                  | •              | VI<br>Virtual Folder      |
|                        | New                  | •              | AG 6:95                   |
| 🖨 📴 🛽                  | New<br>Execute VI on | •              | Virtual Folder<br>Control |

Confirm the dialog with "OK".

| Name    |                                                                                                      |                                            |                                   |                            |      |
|---------|------------------------------------------------------------------------------------------------------|--------------------------------------------|-----------------------------------|----------------------------|------|
| Chassi  | s1                                                                                                   |                                            |                                   |                            |      |
| Locatio | n                                                                                                    |                                            |                                   |                            |      |
| Conne   | ctor 1                                                                                               |                                            |                                   | ~                          |      |
|         | over C Series m                                                                                      | odules                                     |                                   |                            |      |
|         | Discover C Series m<br>Discovering C<br>execution and<br>Make sure you<br>connected to I<br>control. | Series Moo<br>I writes to (<br>J have an F | digital lines or<br>R Series Expa | n the FPGA<br>Insion chass | is Č |

The newly added R-Series Expansion Chassis is now included in the project structure:





# 3.4.1.4 Adding The LVDT9312 Driver Components To A Project

To include the driver components to the new project the files must be copied. Using drag & drop



Copying the Driver Components via Drag'n Drop



# 3.4.1.5 Adding LVDT9312 Drivers To The Project Via Drag-And-Drop Function



As all driver components for all slots are already defined within the example project they can be copied with the drag-and-drop function. Components which are not used in the new application can be removed from the new project.

Caution:

It is importent to Name the Modules Mod1(...) and not Chassis1/Mod1(...) like the default naming of the "Discovery Function" suggests.

Do not erase the contents of the libraries "SET\_SPI\_Drivers.lvlib" and "SET\_LVDT\_9312\_Functions.lvlib".



# 3.4.1.6 Adding LVDT9312 Modules To The Project Via The Discovery-Function (not recommended)

The LabVIEW function "Discover C-Series Modules" automatically detects and integrates cRIO modules which are plugged into an R-Series Expansion Chassis or a cRIO-Chassis.

| Name        |
|-------------|
| Chassis1    |
| Location    |
| Connector 1 |
|             |

This initiates LabVIEW to check the chassis for cRIO modules.

When the search procedure is complete, LabVIEW adds an module item for each detected module and a virtual folder including the module IOs.



Automatik Detektion, with wrong name for Module

It is important that the I/O names of the Module match the names expected by the driver. Normally the correct I/O name are created by LabVIEW within the discovery function. However on some LabVIEW versions the I/O Names are different. In this case you need to change the names of the I/O's to the names used in the example project, or copy the I/Os and module from the example project and delete the automatically created ones.





# 3.4.1.7 Adding FPGA Example-Applications

To illustrate the driver use, small example programs are provided with the module on the CD. Use the copy & paste function to copy these examples into the new application.





All driver components and the example application are now added to the new project.





# 3.4.1.8 COMPILING AND RUNNING THE EXAMPLE APPLICATION

Open the "SET\_LVDT\_9312\_Example\_Slot\_1.vi" file within the project structure to start the slot 1 single module application example. Then click the run button.



Now the compilation process starts and may take up to 60 minutes. Note that the number of modules used in the application has an impact on the compilation time as every module uses separate driver-VIs, function-VIs and FIFOs. Compilation time depends on the used PC Hard- and Software.



# 3.5 USING THE DRIVER TOGETHER WITH A NI REALTIME COMPACTRIO

The procedure illustrated before (see 3.4) refers to a PCI-/PXI FPGA-Target, but all driver components are fully compatible with a cRIO target. The only exception is the eight-slot example application which is only operable on an eight-slot cRIO chassis.\_

#### cRIO-Chassis (with FPGA-Target):

When the cRIO chassis and FPGA target does not exist in the new application, it must be installed as shown in chapter 3.4.1.2: select "New  $\rightarrow$  Targets and Devices" device type "cRIO Realtime" by clicking the "+" button. LabVIEW now detects the connected cRIO chassis. On detection of the chassis it must be selected and "OK" must be checked.

LabVIEW then asks for the I/O acquisition mode. Select method "LabVIEW FPGA Interface".

| Select Programming Mode                                                                                                 | × |
|-------------------------------------------------------------------------------------------------------------------------|---|
| Select the programming mode you want to start programming your selected system(s) with:                                 |   |
| Programming Mode                                                                                                        | 8 |
| ○ Scan Interface                                                                                                        |   |
| The Scan Interface enables you to use C Series modules directly from LabVIEW Real-Time.                                 |   |
| The LabVIEW FPGA Interface enables you to use C Series modules from LabVIEW FPGA VIs.                                   |   |
| <b>Note:</b> Selecting LabVIEW FPGA Interface mode stops any Scan Interface mode applications running on the system(s). |   |
| Continue Cancel Help                                                                                                    | ] |

When a new chassis is added, LabVIEW automatically triggers the "Discover C-Series Modules" procedure.



LabVIEW now detects newly installed cRIO modules.

The external supply is not required for module detection.





On completion of the detection process, LabVIEW adds the detected modules to the project structure as illustrated below. Additionally a virtual I/O-folder for every new module is automatically installed within the project.

| 😫 Project Explorer - Untitled Project 1 * 🛛 🗖 🔀                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>File E</u> dit <u>V</u> iew <u>P</u> roject <u>O</u> perate <u>T</u> ools <u>W</u> indow <u>H</u> elp                                                                                                                                                                                                                                                                                                         |
| 🏠 🗃 🎒   🗶 🔖 🕼 🗙     💕 尾   🎟 🕶 🕐 🛕                                                                                                                                                                                                                                                                                                                                                                                |
| Items Files                                                                                                                                                                                                                                                                                                                                                                                                      |
| <ul> <li>Project: Untitled Project 1</li> <li>My Computer</li> <li>Build Specifications</li> <li>Example Chassis (cRIO-9104)</li> <li>FPGA Target cRIO (RIO0, cRIO-9104)</li> <li>FPGA Target cRIO (RIO0, cRIO-9104)</li> <li>Mod1</li> <li>Mod1</li> <li>Mod1 (Slot 1, SET 9316 RDK)</li> <li>Dependencies</li> <li>Build Specifications</li> <li>Build Specifications</li> <li>Build Specifications</li> </ul> |



Now the virtual folder "Driver Components" must be copied from the example project to the new FPGA target within the LabVIEW project.





# 3.5.1.1 COMPILING AND RUNNING THE EXAMPLE APPLICATION

Open the "SET\_LVDT\_9312\_Example\_Slot\_1.vi" file within the project structure to start the slot 1 single module application example. Then click the run button.

Note: This example is designed for an LVDT9312 Module in Slot 1. However it is easy to alter the example to work for a different slot.



Now the compilation process starts and may take up to 60 minutes. Note that the number of modules used in the application has an impact on the compilation time as each module uses separate driver-VIs, function-VIs and FIFOs.



# 4. CONNECTING THE LVDT DEMODULATOR

To make the LVDT9312 ready for use plug the module into the correct slot on the cRIO Chassis. Make sure to select the correct slot according to the LabVIEW project definition. Then connect the module external power supply ( $9V_{DC} - 36V_{DC}$ ) as shown below. Connect the LVDT interface as shown below (see also paragraph 6.7 Connector Pinout).

#### Connecting a 6 Wire LVDT:



Connection a 6 Wire LVDT



Connecting a 4 Wire LVDT:

Connecting a 4 Wire LVDT



# 4.1 RUNNING THE APPLICATION EXAMPLE

Make sure that:

- $\checkmark$  Application compiling process is complete
- $\checkmark$  The module is plugged into the correct slot according to the application
- ✓ The Resolver and the external supply is connected

The application example can now be started by clicking the "Run"-Button in LabVIEW.

Use parameters *Amplitude* [mV] *and Frequency* [Hz] to adjust the excitation signal to their correct levels.

After that specify the LVDT Type for the demodulation Stage.

The transfer Function for 6 Wire LVDT mode is  $Pos = \frac{Ua - Ub}{Ua + Ub}$ 

The transfer Function for 4Wire LVDT mode is  $= \frac{Ua}{exc}$ ,

(the sign in 4W mode is determined by a separate phase detection).

Note: All settings are stored in non-volatile memory within the LVDT module and restored after each power cycle.



# 5. APPLICATION DEVELOPMENT

# 5.1.1 LVDT9312 DRIVER AND COMMUNICATION

The LVDT driver package includes eight driver-VIs, eight functions-VIs and 16 communication-FIFOs which are used internally. The driver- and function-VIs are located in two different libraries, "SET\_LVDT\_9312\_Drivers.lvlib" and "SET\_LVDT\_9312\_Functions.lvlib". All driver components are located in the project structure of the shipped example projects (folder "Driver Components").

#### LVDT9312 Driver-VI's:

The driver VI controls the communication between the FPGA and the LVDT9312 modules and operates as server. This VI waits for an application call. On reception of an instruction The VI communicates with the module and returns the response data to the calling process.

#### LVDT9312 Functions-VI's:

The Functions-VI provide the user interface for the application and transfer instructions and data to the driver VI. These VIs act as clients for the transfer instructions and data to the driver-VIs.

#### 5.1.1.1 DRIVER-VI IMPLEMENTATION

The implementation of the LVDT9312 drivers into a LabVIEW application takes place by simply locating the relevant VI's on the main programs block diagram. Each chassis slot uses its own driver-VI.

| Slot1 Slot2 |        |        |        |        |        | 21010  |
|-------------|--------|--------|--------|--------|--------|--------|
| SPIDRV      | SPIDRV | SPIDRV | SPIDRV | SPIDRV | SPIDRV | SPIDRV |
| Slot1       | Slot 3 | Slot 4 | Slat 5 | Slat 6 | Slot 7 | Slat®  |

When the LabVIEW application is started, all involved driver VIs are also processed. The driver VIs act as server and wait for instructions from the application.

<u>Important notice</u>: The driver VIs run cautiously. Therefore the Drivers may block the application. We recommend placing them separately on the block diagram<sup>1</sup>. When the driver-VI's are used inside a data flow or a sequence they will block the program.



<sup>&</sup>lt;sup>1</sup> Not added tot he data flow

# 5.1.1.2 TRIGGERING LVDT9312 FUNCTIONS VIA FUNCTIONS-VIS

The Functions-VI's are located in the "SET\_LVDT\_9312\_Functions.lvlib". Note that each chassis slot requires a specific functions-VI. (e.g. slot 1, slot 2 ...)



When a Function-VI is executed, instructions and data are transferred to the corresponding FIFOs "SlotN\_CommandIN". The applicable driver-VI then communicates with the LVDT9312 module via the driver internal FIFO "SlotN\_CommandOUT".

| 🖷 Slot1_CommandIn 🚻 |            |     |  |  |  |  |
|---------------------|------------|-----|--|--|--|--|
|                     | Write      | - 1 |  |  |  |  |
|                     | Element    |     |  |  |  |  |
|                     | Timeout    |     |  |  |  |  |
| -                   | Timed Out? | •   |  |  |  |  |

|            | Slot1_CommandOut | ╢┝   |
|------------|------------------|------|
| 5 <u>6</u> | Read             |      |
| 1          | Element          | •    |
|            | Timeout          | - 10 |
| -          | Timed Out?       | •    |

Driver internal FIFOs for data transfer between Function-VI and Driver-VI (Slot1 example)



# 5.1.1.3 INITIALISING AND CLEARING THE FIFO BUFFERS

To ensure a correct data transfer it is essential to clear the FIFO contents during the programs initialisation sequence. This is done by executing the "Clear" function after program start.

Important notice: Execute the "Clear" instruction before any other VI call.

The example below illustrates the FIFO buffer clearing of an application which uses eight modules:

| ⊶ Slot1_CommandIn ∦⊮<br>Clear  | ● Slot1_CommandOut III Clear            |
|--------------------------------|-----------------------------------------|
| ⊶ Slot2_CommandIn ∦⊮<br>Clear  | Hire Slot2_CommandOut Hire Clear        |
| ⊶ Slot3_CommandIn +#+          | ··✦ Slot3_CommandOut -III→              |
| Clear                          | Clear                                   |
| ⊶ Slot4_CommandIn +#+          | •+ Slot4_CommandOut +II+                |
| Clear                          | Clear                                   |
| ⊶ Slot5_CommandIn +#+<br>Clear | Hint Hint Hint Hint Hint Hint Hint Hint |
| ··.♦ Slot6_CommandIn {   →     | ··✦ Slot6_CommandOut ╢→                 |
| Clear                          | Clear                                   |
| ⊶ Slot7_CommandIn ╢→           | High Slot7_CommandOut High              |
| Clear                          | Clear                                   |
| ⊶ Slot8_CommandIn +#+          | "➡ Slot8_CommandOut -   →               |
| Clear                          | Clear                                   |

| Clear all used | Communication-FIFOs on Startup |
|----------------|--------------------------------|
|----------------|--------------------------------|

Clearing all (used) communication FIFOs during program start



# 5.1.1.4 APPLICATION TO MODULE COMMUNICATION DIAGRAM

Communication with a single LVDT9312 module:

The diagram below illustrates the communication scheme between application, Function-VI, Driver-VI and LVDT9312 module (slot 1). From the diagram it can be noticed that the Driver-VI of the FPGA driver (slot 1) is located outside and parallel to the code section which triggers the instructions. However, the Function-VI may be used within any LabVIEW structure like loops, cases or sequences. Furthermore, multiple calls are allowed which are operated sequentially. Note that the Function-VIs use non-re-entrant structures.



Communication between application and LVDT9312 module



Communication with multiple LVDT9312 modules:

The diagram below illustrates the communication scheme between application, Function-VI, Driver-VI and multiple LVDT9312 modules. From the diagram it can be noticed that the Driver-VIs of the FPGA drivers are located outside and parallel to the code section which triggers the instructions. However, the Function-VI may be used within any LabVIEW structure like loops, cases or sequences. Furthermore, multiple calls are allowed which then are operated sequentially. Note that the Function-VIs use non-re-entrant structures.



Communication between application and multiple LVDT9312 modules

30 of 37 www.smart-e-tech.com Issue 05 22.02.23



# 5.2 LVDT9312 DRIVER-INSTRUCTIONS

The LVDT9312 driver instructions are defined within the type definition file "USRCMD.ctl". The instruction names correlate with an identification number which is given in brackets (), below.

Command execution requires a specific execution time and varies due to asynchronous processing principles. Hence a timeout should be defined for an instruction call which by default is 40.000.000 system ticks (equal to 1 second for a 40MHz FPGA). When no timeout is connected to the input terminal of the Function-VI, the default timeout value is active. To specify a timeout other than the default value, the input must be connected to a new timeout value. Note that specifying a timeout less than 40.000.000 has no effect because the default value cannot be reduced. If an instruction takes longer than the specified timeout, a fault is generated from the driver (refer to the drivers fault codes).

This instruction reads the actual LVDT position. The data scaling is binary data within the range of -32768 to 32767 equal to -1 to 1. It takes 24us (+/-1us) to receive the position data. The maximum position sampling rate for cyclic reading is 40kHz. To calculate the resolver position in engineering units use the following equation:

$$Position = DATA \cdot \frac{1}{2^{15}}$$

Note that dividing by  $2^{15}$  equals a logical shift of 15.

| Instruction [U8]:  | <u> Tx-Data [U8]:</u> | <u>Receive-Data [U16]:</u>             | <u>Data Sink:</u> |
|--------------------|-----------------------|----------------------------------------|-------------------|
| Read Amplitude (3) | no data               | Excit. Amplitude. [mV <sub>RMS</sub> ] | LVDT Controller   |
|                    |                       | Read Amplitude  KUDT Function Stat1    |                   |

This instruction reads the programmed amplitude of the excitation voltage. The return data format is a 16bit engineering value in  $[mV_{RMS}]$ .



Instruction [U8]: Tx-Read Frequency (4) no o

<u>Tx-Data [U8]:</u> no data Receive-Data [U16]: Excit. Frequency. [Hz] <u>Data Sink:</u> LVDT Controller

Read Frequency

This instruction reads the programmed frequency of the excitation voltage. The return data format is a 16bit engineering value in [Hz].



This instruction reads input channel A voltage amplitude. The return data format is a 16bit engineering value with dimension  $[mV_{RMS}]$ . This value is NOT for Position calculation and updated only 9 times per Second

| Instruction [U8]:<br>Read Channel B (7) | <u>Tx-Data [U8]:</u><br>no data | <u>Receive-Data [U16]:</u><br>Ch B Voltage [mV <sub>RMS</sub> ] | <u>Data Sink:</u><br>LVDT Controller                            |
|-----------------------------------------|---------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------|
|                                         | Rea                             | d Channel B rms  CHANNEL POR Function Stat1                     |                                                                 |
|                                         | •                               | <b>o</b>                                                        | a format is a 16bit engineering<br>and updated only 9 times per |
| Instruction [U8]:                       | <u>Tx-Data [U8]:</u>            | Receive-Data [U16]:                                             | Data Sink:                                                      |

 Instruction [Od].
 IX-Data [Od].
 Receive-Data [Ol].
 Data Sink.

 Set Amplitude (9)
 Excit. Amp.[mV<sub>RMS</sub>]
 Excit. Amp.[mV<sub>RMS</sub>]
 LVDT Controller

 Set Amplitude  $\neg$  Set Amplitude  $\neg$  Set Amplitude  $\neg$  IVOT Controller

 This instruction programs the excitation amplitude. The data format is a 16bit engineering value with dimension [mV<sub>RMS</sub>].
 IVOT Controller

Valid Amplitude Range: 2000  $[mV_{RMS}]$ .. 7000  $[mV_{RMS}]$ 



| Instruction [U8]:<br>Set Frequency (10)                                                                                                                              | <u>Tx-Data [U8]:</u><br>Exc. Freq.[Hz]                             |                          | <u>Receive</u><br>Exc. Fre |                                 | <u>U16]:</u>   |                        | <u>ata Sink:</u><br>VDT Control  | ler                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------|----------------------------|---------------------------------|----------------|------------------------|----------------------------------|------------------------------|
|                                                                                                                                                                      |                                                                    | Set I                    | Frequenc                   | y 🔽 — 🔛 S<br>LVI<br>Func<br>Siz | DT             |                        |                                  |                              |
| This instruction programs the excitation frequency. The data format is a 16bit engineering value with dimension [Hz].<br>Valid Frequency Range: 1000 [Hz] 10000 [Hz] |                                                                    |                          |                            | ering value with                |                |                        |                                  |                              |
| Instruction [U8]:<br>Set LVDT Type (8)                                                                                                                               | <u>Tx-Da</u><br>Res.Mode                                           | <u>ta [U8]:</u><br>Res.I | <u>Rece</u><br>Mode        | eive-Da                         | ita [U16       | <u>]: [</u><br>LVDT Co | ) <u>ata Sink:</u><br>ntroller   |                              |
|                                                                                                                                                                      |                                                                    | Set I                    | LVDT Typ                   | B V LV<br>Fund<br>Sla           | DT             |                        |                                  |                              |
| This instruction prog<br>following table.                                                                                                                            | grams the dem                                                      | odulation                | stage.                     | The da                          | ata form       | nat is enu             | umeration a                      | ccording to the              |
| Valid position resolu                                                                                                                                                | tion data:                                                         | Data<br>Data             | =<br>=                     | 0,<br>1,                        | 6<br>4         | Wire<br>Wire           | LVDT<br>LVDT                     | demodulation<br>demodulation |
| Instruction [U8]:<br>Close Device (16)                                                                                                                               | <u>Tx-Da</u><br>No Da                                              | <u>ta [U8]:</u><br>.ta   | <u>Rece</u><br>No E        |                                 | <u>ta [U16</u> |                        | <u>)ata Sink:</u><br>PGA Driver- | -VI                          |
|                                                                                                                                                                      |                                                                    | Ćlo:                     | se Device                  | VD<br>Functi<br>Slat            | T              |                        |                                  |                              |
| This instruction stop                                                                                                                                                | This instruction stops and terminates the applicable EDCA driver M |                          |                            |                                 |                |                        |                                  |                              |

This instruction stops and terminates the applicable FPGA driver-VI.



| 5.3                   | LVDT9312 Dr                | RIVER ERROR (      | Codes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------|----------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Error<br>Code<br>[U8] | Error Type                 | Error<br>Detection | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0                     | No Error                   | none               | If no error has appeared during communication with the LVDT9312 module, the received telegram has error code "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1                     | Unknown<br>Command         | LVDT<br>Module     | This error occurs when the LVDT Module receives an unknown instruction code.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2                     | Communication<br>Error     | LVDT<br>Module     | This error occurs when the FPGA aborts a telegram transmission to the LVDT Module or when an internal communication error of the module occured                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3                     | Invalid<br>Parameter       | LVDT<br>Module     | This error occurs when the parameter "Data" is out of range.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8                     | Excitation<br>ShortCircuit | LVDT<br>Module     | This error occurs if the Excitation is in Short Circuit and<br>deactivated due to thermal limits. The Excitation will be<br>disabled for 5 seconds and the Error will remain 10 more<br>seconds. Regularly driving the Excitation in its thermal limit<br>will degrade performance!                                                                                                                                                                                                                                                                                                                                                                 |
| 100                   | No Module                  | FPGA<br>Driver-VI  | This error occurs when no LVDT Module is connected to the applicable slot.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 101                   | Module Busy                | Functions-<br>VI   | The busy signal to the FPGA indicates module readiness.<br>When a time consuming instruction is processed by the<br>module, the busy signal becomes valid for a certain amount<br>of time. However, if a new instruction is sent to the module<br>while the module still processes a previous instruction (and<br>therefore the busy line still is active), the FPGA driver waits<br>for the busy line to return to the ready state. The maximum<br>idle time for the FPGA driver is a default value and can be<br>increased from the user. When the specified timeout is<br>exceeded, the error "Module Busy" is generated by the<br>functions-VI. |
| 103                   | Transmit<br>Incomplete     | FPGA<br>Driver-VI  | This error occurs when the LVDT Module aborts telegrams or exceeds the driver timing constraints.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 104                   | Wrong Driver<br>Answer     | Functions-<br>VI   | This error occurs when the replied telegram does not match<br>with the instruction telegram.<br>Note: This error may occur subsequently to a module power<br>interrupt while the application is still running. However, this<br>is only a singular error.                                                                                                                                                                                                                                                                                                                                                                                           |
| 105                   | FIFO Timeout               | Functions-<br>VI   | This error occurs if a FIFO fault takes place during data<br>transfer from the functions-VI to the applicable driver-VI.<br>Note: To reset this error scenario, both communication FIFOs<br>(SlotN_CommandIN und SlotNCommandOUT) of the<br>applicable module must be cleared with the "Clear"<br>Slot1_CommandIn IIIP<br>Clear Clear                                                                                                                                                                                                                                                                                                               |
| 106                   | Power Error                | Functions<br>VI    | This Error occurs if the external Supply of the Module is not in it's limits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 107                   | Loose of<br>Tracking       | LVDT<br>Module     | This error occurs if both signals (Ua/Ub) are below 350mVrms.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                       |                            |                    | <ul> <li>In 4 Wire mode this error occurs only if Excitation and Ua are below 350mVRms.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |



# 5.4 MODULE IDENTIFICATION UNDER LABVIEW

LabVIEW automatically detects the cRIO module type (Discover C-Series Modules), even if the external Supply is not applied.

# 5.5 SAVING THE SETUP

The LVDT9312 automatically saves the setup (Excitation Amplitude, Excitation Frequency and LVDT demodulation mode) in a non-volatile memory. After a power cycle the last set Parameters are active when the Module is switched on.

### 6. TECHNICAL SPECIFICATION

# 6.1 Housing

- NI CompactRIO 9952 Standard Housing
- Dimensions: appr. 71mm x 72mm x 23mm



#### 6.2 EXTERNAL POWER SUPPLY

- Supply Voltage:
- $9V_{DC} 36V_{DC}$
- Power Consumption: max. 1.5 Watt without Resolver

#### Caution:

The external power supply input is isolated from the cRIO chassis signals with a maximum isolation voltage of  $500V_{DC}$ . Note that the excitation output and the Signals Ua and Ub are galvanically connected to the external power supply.

# 6.3 EXCITATION OUTPUT

| • | Frequency: | 1kHz – 10kHz, adjustable via software |
|---|------------|---------------------------------------|
|---|------------|---------------------------------------|

- Amplitude:  $2V_{RMS} 7 V_{RMS}$ , adjustable via software
- Current: max. 120mA<sub>RMS</sub>

#### Caution:

.

The excitation output can be damaged when a power source is connected to its terminals. Driving the excitation regularly in short circuit condition will degrade performance!



# 6.4 UA AND UB SIGNAL INPUTS

- Voltage Range:  $OV_{RMS} 7 V_{RMS}$
- Zin (differential): 108kOhm
- Zin (single-ended): 27.5kOhm

#### Caution:

The signal inputs can be damaged, when the input voltage exceeds a limit of  $40V_{\text{peak}}$ .

#### 6.5 Position Processing

- Resolution: 16Bit
- Bandwidth ½ Excitation Frequency
- Accuracy: 0.1% (accuracy of the module, the Position accuracy depends on the xVDT, the wiring and the Position of the xVDT)

#### 6.6 Environmental Conditions

- Temperature Range: 0°C 70°C
- Humidity: 10% 90% relative, non-condensing



# 6.7 CONNECTOR PINOUT

User Interface Connector (25-pin Sub-D / male):

| Pin     | Function         |
|---------|------------------|
| 1       | V <sub>SUP</sub> |
| 2       | СОМ              |
| 3       | GND              |
| 4       | A+               |
| 5       | A-               |
| 6       | GND              |
| 7       | B+               |
| 8       | В-               |
| 9       | GND              |
| 10      | +EXC             |
| 11      | -EXC             |
| 12 - 25 | n.c.             |

# 7. MODULE CALIBRATION

The LVDT9312 is calibrated when shipped. A recalibration can be done by SET GmbH.

#### 8. MODULE MAINTENANCE

No maintenance is required for the LVDT Module.

#### 9. SERVICE ADDRESS

For technical support contact the SET service address:

SET GmbH August-Braun-Str. 1 88239 Wangen/Allgäu Germany Tel.: +49 (0)7522 91687-600 Fax: +49 (0)7522 91687-899 e-Mail: <u>support.crio@smart-e-tech.de</u>

