# C Series Reference and Procedures





## Contents

| C Series                                                                   | 19        |
|----------------------------------------------------------------------------|-----------|
| C Series Module IDs                                                        | 19        |
| Analog Input Modules                                                       | 27        |
| Overview                                                                   | 27        |
| Converting and Calibrating CompactRIO Analog Input Values (FPGA Interface) | )         |
| Detecting Out of Dange Channels for Compact DIO Analog Input Channels      | 21        |
| (FPGA Interface)                                                           | 32        |
| Synchronizing Multiple Modules (FPGA Interface)                            | 35        |
| Configuring the Master Timebase Source for a Module (FPGA Interface).      |           |
|                                                                            | <br>39    |
| Modules with a Selectable Timebase Source                                  | 41        |
| Understanding the Maximum Sample Rate when Synchronizing Multiple          | <u>e</u>  |
| Modules (FPGA Interface)                                                   | 42        |
| Acquiring Data from a Module (FPGA Interface)                              | 43        |
| Configuring the Data Rate for a Module (FPGA Interface)                    | 45        |
| Accessing TEDS Information from a Module (FPGA Interface)                  | 46        |
| Understanding Loop Timing (FPGA Interface)                                 | 49        |
| NI 9201                                                                    | 51        |
| NI 9201 (FPGA Interface).                                                  | 52        |
| C Series Module Properties Dialog Box for the NI 9201/9221 (FPGA           | <b>F2</b> |
| Interface).                                                                | 53        |
| Configuring the Minimum Time Between Conversions for the NI                | 51        |
| Understanding NI 9201/9221 Scanning (EPGA Interface)                       | 56        |
| NI 9201 (Scan Interface)                                                   | 57        |
| NI 9202                                                                    | 58        |
| NI 9202 (FPGA Interface)                                                   | 59        |
| C Series Module Properties Dialog Box for the NI 9202 (FPGA                | 55        |
| Interface)                                                                 | 61        |
| Converting NI 9202 Data (FPGA Interface)                                   | 62        |
| NI 9203                                                                    | 63        |
| NI 9203 (FPGA Interface)                                                   | 64        |

| C Series Module Properties Dialog Box for the NI 9203 (FPGA      |                |
|------------------------------------------------------------------|----------------|
| Interface)6                                                      | 66             |
| NI 9203 (Scan Interface) 6                                       | 67             |
| NI 9205                                                          | 58             |
| NI 9205 (FPGA Interface)                                         | 59             |
| C Series Module Properties Dialog Box for the NI 9205/9206 (FPGA |                |
| Interface)                                                       | 76             |
| IO Sample Method (FPGA Interface)                                | 77             |
| Set Terminal Mode Method (FPGA Interface)                        | 31             |
| Set Triggers Method (FPGA Interface)                             | 33             |
| Set Voltage Range Method (FPGA Interface)                        | 37             |
| Conversion Timing for the NI 9205/9206 (FPGA Interface) 8        | 39             |
| Self-Calibration for the NI 9205/9206 (FPGA Interface)           | <del>)</del> 2 |
| NI 9205 (Scan Interface) 9                                       | <del>)</del> 3 |
| NI 9206                                                          | 94             |
| NI 9206 (FPGA Interface)                                         | <del>)</del> 5 |
| C Series Module Properties Dialog Box for the NI 9205/9206 (FPGA |                |
| Interface)                                                       | )1             |
| IO Sample Method (FPGA Interface)                                | )2             |
| Set Terminal Mode Method (FPGA Interface)                        | )6             |
| Set Triggers Method (FPGA Interface)                             | )8             |
| Set Voltage Range Method (FPGA Interface)                        | 12             |
| Conversion Timing for the NI 9205/9206 (FPGA Interface) 11       | 14             |
| Self-Calibration for the NI 9205/9206 (FPGA Interface) 11        | L7             |
| NI 9206 (Scan Interface)                                         | 18             |
| NI 9207 11                                                       | L9             |
| NI 9207 (FPGA Interface)                                         | 20             |
| C Series Module Properties Dialog Box for the NI 9207 (FPGA      |                |
| Interface) 12                                                    | 22             |
| Converting NI 9207 Data (FPGA Interface)                         | 23             |
| NI 9207 (Scan Interface)                                         | 23             |
| NI 9208 12                                                       | 25             |
| NI 9208 (FPGA Interface)                                         | 25             |
| C Series Module Properties Dialog Box for the NI 9208 (FPGA      |                |
| Interface) 12                                                    | 27             |

| Converting NI 9208 Data (FPGA Interface)                    | 128 |
|-------------------------------------------------------------|-----|
| NI 9208 (Scan Interface)                                    | 128 |
| NI 9209                                                     | 129 |
| NI 9209 (FPGA Interface)                                    | 130 |
| C Series Module Properties Dialog Box for the NI 9209 (FPGA |     |
| Interface)                                                  | 132 |
| Converting NI 9209 Data (FPGA Interface)                    | 133 |
| NI 9209 (Scan Interface)                                    | 134 |
| NI 9210                                                     | 135 |
| NI 9210 (FPGA Interface)                                    | 136 |
| C Series Module Properties Dialog Box for the NI 9210 (FPGA |     |
| Interface)                                                  | 137 |
| Converting NI 9210 Data (FPGA Interface)                    | 138 |
| NI 9210 (Scan Interface)                                    | 139 |
| NI 9211                                                     | 141 |
| NI 9211 (FPGA Interface)                                    | 141 |
| C Series Module Properties Dialog Box for the NI 9211 (FPGA |     |
| Interface)                                                  | 143 |
| Converting NI 9211 Data (FPGA Interface)                    | 144 |
| NI 9211 (Scan Interface)                                    | 145 |
| NI 9212                                                     | 147 |
| NI 9212 (FPGA Interface)                                    | 148 |
| C Series Module Properties Dialog Box for the NI 9212 (FPGA |     |
| Interface)                                                  | 151 |
| Converting NI 9212 Data (FPGA Interface)                    | 152 |
| NI 9212 (Scan Interface)                                    | 153 |
| NI 9213                                                     | 155 |
| NI 9213 (FPGA Interface)                                    | 156 |
| C Series Module Properties Dialog Box for the NI 9213 (FPGA |     |
| Interface)                                                  | 159 |
| Converting NI 9213 Data (FPGA Interface)                    | 160 |
| NI 9213 (Scan Interface)                                    | 161 |
| NI 9214                                                     | 163 |
| NI 9214 (FPGA Interface)                                    | 164 |

| C Series Module Properties Dialog Box for the NI 9214 (FPGA    |     |
|----------------------------------------------------------------|-----|
| Interface)                                                     | 168 |
| Converting NI 9214 Data (FPGA Interface)                       | 169 |
| NI 9214 (Scan Interface)                                       | 170 |
| NI 9215                                                        | 172 |
| NI 9215 (FPGA Interface)                                       | 173 |
| C Series Module Properties Dialog Box for the NI 9215 (FPGA    |     |
| Interface)                                                     | 175 |
| NI 9215 (Scan Interface)                                       | 175 |
| NI 9216                                                        | 176 |
| NI 9216 (FPGA Interface)                                       | 177 |
| C Series Module Properties Dialog Box for the NI 9216 (FPGA    |     |
| Interface)                                                     | 179 |
| Converting Nominal Values to Temperature Values for the NI 921 | 6   |
| (FPGA Interface)                                               | 179 |
| NI 9216 (Scan Interface)                                       | 180 |
| NI 9217                                                        | 181 |
| NI 9217 (FPGA Interface)                                       | 182 |
| C Series Module Properties Dialog Box for the NI 9217 (FPGA    |     |
| Interface)                                                     | 184 |
| Converting Nominal Values to Temperature Values for the NI 921 | 7   |
| (FPGA Interface).                                              | 185 |
| NI 9217 (Scan Interface)                                       | 185 |
| NI 9218                                                        | 187 |
| NI 9218 (FPGA Interface)                                       | 189 |
| C Series Module Properties Dialog Box for the NI 9218 (FPGA    |     |
| Interface).                                                    | 193 |
| NI 9218 Data Rates.                                            | 195 |
| Loop Timing for the NI 9218 (FPGA Interface)                   | 196 |
| NI 9218 (Scan Interface)                                       | 197 |
| NI 9219                                                        | 198 |
| NI 9219 (FPGA Interface)                                       | 200 |
| C Series Module Properties Dialog Box for the NI 9219 (FPGA    |     |
| Interface)                                                     | 202 |
| Converting NI 9219 Data (FPGA Interface)                       | 204 |

| Configuring Modes and Ranges for the NI 9219 (FPGA Interface).     | 206   |
|--------------------------------------------------------------------|-------|
| Configuring the Digital In Threshold for the NI 9219 (FPGA Interfa | ice). |
|                                                                    | 207   |
| NI 9219 (Scan Interface)                                           | 209   |
| NI 9220                                                            | 211   |
| NI 9220 (FPGA Interface)                                           | 212   |
| C Series Module Properties Dialog Box for the NI 9220 (FPGA        |       |
| Interface)                                                         | 214   |
| NI 9220 (Scan Interface)                                           | 215   |
| NI 9221                                                            | 216   |
| NI 9221 (FPGA Interface)                                           | 216   |
| C Series Module Properties Dialog Box for the NI 9201/9221 (FPG    | A     |
| Interface)                                                         | 218   |
| Configuring the Minimum Time Between Conversions for the NI        |       |
| 9201/9221 (FPGA Interface)                                         | 219   |
| Understanding NI 9201/9221 Scanning (FPGA Interface)               | 221   |
| NI 9221 (Scan Interface)                                           | 222   |
| NI 9222                                                            | 223   |
| NI 9222 (FPGA Interface)                                           | 223   |
| C Series Module Properties Dialog Box for the NI 9222/9223 (FPG    | А     |
| Interface)                                                         | 226   |
| NI 9222 (Scan Interface)                                           | 226   |
| NI 9223                                                            | 227   |
| NI 9223 (FPGA Interface)                                           | 228   |
| C Series Module Properties Dialog Box for the NI 9222/9223 (FPG    | А     |
| Interface)                                                         | 230   |
| NI 9223 (Scan Interface)                                           | 231   |
| NI 9224                                                            | 232   |
| NI 9224 (FPGA Interface)                                           | 233   |
| C Series Module Properties Dialog Box for the NI 9224 (FPGA        |       |
| Interface)                                                         | 235   |
| Converting NI 9224 Data (FPGA Interface)                           | 236   |
| NI 9224 (Scan Interface)                                           | 236   |
| NI 9225                                                            | 237   |
| NI 9225 (FPGA Interface)                                           | 238   |
|                                                                    |       |

| C Series Module Properties Dialog Box for the NI                |     |
|-----------------------------------------------------------------|-----|
| 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)             | 241 |
| NI 9225 (Scan Interface)                                        | 242 |
| NI 9226                                                         | 243 |
| NI 9226 (FPGA Interface)                                        | 244 |
| C Series Module Properties Dialog Box for the NI 9226 (FPGA     |     |
| Interface)                                                      | 246 |
| Converting Nominal Values to Temperature Values for the NI 9226 | 5   |
| (FPGA Interface)                                                | 246 |
| NI 9226 (Scan Interface)                                        | 247 |
| NI 9227                                                         | 248 |
| NI 9227 (FPGA Interface)                                        | 249 |
| C Series Module Properties Dialog Box for the NI                |     |
| 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)             | 252 |
| NI 9227 (Scan Interface)                                        | 253 |
| NI 9228                                                         | 254 |
| NI 9228 (FPGA Interface)                                        | 255 |
| C Series Module Properties Dialog Box for the NI 9228 (FPGA     |     |
| Interface)                                                      | 257 |
| Converting NI 9228 Data (FPGA Interface)                        | 258 |
| NI 9228 (Scan Interface)                                        | 258 |
| NI 9229                                                         | 259 |
| NI 9229 (FPGA Interface)                                        | 260 |
| C Series Module Properties Dialog Box for the NI                |     |
| 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)             | 263 |
| NI 9229 (Scan Interface)                                        | 264 |
| NI 9230                                                         | 265 |
| NI 9230 (FPGA Interface)                                        | 266 |
| C Series Module Properties Dialog Box for the NI 9230/9232/9234 |     |
| (FPGA Interface).                                               | 270 |
| Configuring the NI 9230/9232/9234 Channel Input Modes (FPGA     |     |
| Interface).                                                     | 271 |
| NI 9231                                                         | 273 |
| NI 9231 (FPGA Interface)                                        | 274 |
|                                                                 |     |

| C Series Module Properties Dialog Box for the NI 9231 (FPGA      |     |
|------------------------------------------------------------------|-----|
| Interface)                                                       | 277 |
| Configuring the NI 9231 Channel Input Modes (FPGA Interface)     | 278 |
| Converting NI 9231 Data (FPGA Interface)                         | 280 |
| NI 9232                                                          | 280 |
| NI 9232 (FPGA Interface)                                         | 281 |
| C Series Module Properties Dialog Box for the NI 9230/9232/9234  |     |
| (FPGA Interface)                                                 | 285 |
| Configuring the NI 9230/9232/9234 Channel Input Modes (FPGA      |     |
| Interface)                                                       | 286 |
| NI 9234                                                          | 288 |
| NI 9234 (FPGA Interface)                                         | 289 |
| C Series Module Properties Dialog Box for the NI 9230/9232/9234  |     |
| (FPGA Interface)                                                 | 292 |
| Configuring the NI 9230/9232/9234 Channel Input Modes (FPGA      |     |
| Interface)                                                       | 293 |
| NI 9234 (Scan Interface)                                         | 295 |
| NI 9235                                                          | 297 |
| NI 9235 (FPGA Interface)                                         | 298 |
| C Series Module Properties Dialog Box for the NI 9235/9236 (FPG/ | A   |
| Interface)                                                       | 301 |
| NI 9235 (Scan Interface)                                         | 302 |
| NI 9236                                                          | 302 |
| NI 9236 (FPGA Interface)                                         | 303 |
| C Series Module Properties Dialog Box for the NI 9235/9236 (FPG/ | A   |
| Interface)                                                       | 306 |
| NI 9236 (Scan Interface)                                         | 307 |
| NI 9237                                                          | 308 |
| NI 9237 (FPGA Interface)                                         | 309 |
| C Series Module Properties Dialog Box for the NI 9237 (FPGA      |     |
| Interface)                                                       | 312 |
| NI 9237 (Scan Interface)                                         | 313 |
| NI 9238                                                          | 314 |
| NI 9238 (FPGA Interface)                                         | 315 |

| C Series Module Properties Dialog Box for the NI                |     |
|-----------------------------------------------------------------|-----|
| 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)             | 318 |
| NI 9239                                                         | 319 |
| NI 9239 (FPGA Interface)                                        | 320 |
| C Series Module Properties Dialog Box for the NI                |     |
| 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)             | 323 |
| NI 9239 (Scan Interface).                                       | 324 |
| NI 9242                                                         | 325 |
| NI 9242 (FPGA Interface)                                        | 326 |
| C Series Module Properties Dialog Box for the NI 9242/9244 (FPG | A   |
| Interface)                                                      | 328 |
| Converting NI 9242 and NI 9244 Data (FPGA Interface)            | 329 |
| NI 9242 (Scan Interface)                                        | 330 |
| NI 9244                                                         | 331 |
| NI 9244 (FPGA Interface)                                        | 332 |
| C Series Module Properties Dialog Box for the NI 9242/9244 (FPG | A   |
| Interface)                                                      | 334 |
| Converting NI 9242 and NI 9244 Data (FPGA Interface)            | 335 |
| NI 9244 (Scan Interface)                                        | 336 |
| NI 9246                                                         | 337 |
| NI 9246 (FPGA Interface)                                        | 338 |
| C Series Module Properties Dialog Box for the NI                |     |
| 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)             | 341 |
| NI 9247                                                         | 342 |
| NI 9247 (FPGA Interface)                                        | 343 |
| C Series Module Properties Dialog Box for the NI                |     |
| 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)             | 346 |
| NI 9250                                                         | 347 |
| NI 9250 (FPGA Interface)                                        | 349 |
| C Series Module Properties Dialog Box for the NI 9250 (FPGA     |     |
| Interface)                                                      | 351 |
| Configuring the NI 9250 Channel Input Modes (FPGA Interface)    | 352 |
| Converting NI 9250 Data (FPGA Interface)                        | 354 |
| NI 9251                                                         | 354 |
| NI 9251 (FPGA Interface)                                        | 355 |
|                                                                 |     |

| C Series Module Properties Dialog Box for the NI 9251 (FPGA      | 57       |
|------------------------------------------------------------------|----------|
| Configuring the NI 9251 Channel Input Modes (EPGA Interface) 3   | 58       |
| Converting NI 9251 Data (EPGA Interface)                         | 60       |
| NI 9252                                                          | 61       |
| NI 9252 (FPGA Interface) 36                                      | 62       |
| C Series Module Properties Dialog Box for the NI 9252 (FPGA      | 02       |
| Interface)                                                       | 64       |
| Converting NI 9252 Data (FPGA Interface)                         | 65       |
| NI 9253                                                          | 66       |
| NI 9253 (FPGA Interface)                                         | 67       |
| C Series Module Properties Dialog Box for the NI 9253 (FPGA      |          |
| Interface)                                                       | 70       |
| Converting NI 9253 Data (FPGA Interface)                         | 72       |
| NI 9253 (Scan Interface)                                         | 72       |
| NI 9381                                                          | 75       |
| NI 9381 (FPGA Interface)                                         | 76       |
| Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface) 38 | 82       |
| C Series Module Properties Dialog Box for the NI 9381 (FPGA      |          |
| Interface)                                                       | 83       |
| Converting Voltage Values to Binary Values for the NI 9381 (FPGA | ~ 4      |
| Interface)                                                       | 84       |
| NI 9381 (Scan Interface)                                         | 85       |
|                                                                  | 81<br>07 |
| Overview                                                         | 81<br>07 |
| NI 9260                                                          | 01<br>00 |
| C Series Medule Properties Dialog Poy for the NL 0260 (EDCA      | 00       |
| Interface)                                                       | 91       |
| Converting Voltage Values to Binary Values for the NI 9260 (FPGA | 51       |
| Interface)                                                       | 92       |
| Outputting Data from an NI 9260 (FPGA Interface)                 | 93       |
| NI 9262                                                          | 94       |
| NI 9262 (FPGA Interface)                                         | 95       |

| C Series Module Properties Dialog Box for the NI                 |     |
|------------------------------------------------------------------|-----|
| 9262/9263/9264/9269 (FPGA Interface)                             | 397 |
| Converting Voltage Values to Binary Values for the NI            |     |
| 9262/9263/9264/9269 (FPGA Interface)                             | 398 |
| NI 9263                                                          | 399 |
| NI 9263 (FPGA Interface)                                         | 400 |
| Converting Voltage Values to Binary Values for the NI            |     |
| 9262/9263/9264/9269 (FPGA Interface)                             | 403 |
| C Series Module Properties Dialog Box for the NI                 |     |
| 9262/9263/9264/9269 (FPGA Interface)                             | 404 |
| NI 9263 (Scan Interface)                                         | 405 |
| NI 9264                                                          | 406 |
| NI 9264 (FPGA Interface)                                         | 407 |
| C Series Module Properties Dialog Box for the NI                 |     |
| 9262/9263/9264/9269 (FPGA Interface)                             | 410 |
| Converting Voltage Values to Binary Values for the NI            |     |
| 9262/9263/9264/9269 (FPGA Interface)                             | 411 |
| NI 9264 (Scan Interface)                                         | 412 |
| NI 9265                                                          | 413 |
| NI 9265 (FPGA Interface)                                         | 414 |
| C Series Module Properties Dialog Box for the NI 9265 (FPGA      |     |
| Interface)                                                       | 419 |
| Converting Current Values to Binary Values for the NI 9265 (FPGA |     |
| Interface)                                                       | 420 |
| NI 9265 (Scan Interface)                                         | 421 |
| NI 9266                                                          | 422 |
| NI 9266 (FPGA Interface)                                         | 423 |
| C Series Module Properties Dialog Box for the NI 9266 (FPGA      |     |
| Interface)                                                       | 428 |
| Converting Current Values to Binary Values for the NI 9266 (FPGA | ١   |
| Interface)                                                       | 429 |
| NI 9266 (Scan Interface)                                         | 430 |
| NI 9269                                                          | 431 |
| NI 9269 (FPGA Interface)                                         | 432 |
|                                                                  |     |

| C Series Module Properties Dialog Box for the NI                                                                             |     |
|------------------------------------------------------------------------------------------------------------------------------|-----|
| 9262/9263/9264/9269 (FPGA Interface)                                                                                         | 437 |
| Converting Voltage Values to Binary Values for the NI                                                                        |     |
| 9262/9263/9264/9269 (FPGA Interface)                                                                                         | 438 |
| NI 9269 (Scan Interface)                                                                                                     | 439 |
| NI 9381                                                                                                                      | 440 |
| NI 9381 (FPGA Interface)                                                                                                     | 441 |
| Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface)<br>C Series Module Properties Dialog Box for the NI 9381 (FPGA | 447 |
| Interface)                                                                                                                   | 448 |
| Converting Voltage Values to Binary Values for the NI 9381 (FPGA                                                             |     |
| Interface)                                                                                                                   | 449 |
| NI 9381 (Scan Interface)                                                                                                     | 450 |
| Counter Input Modules                                                                                                        | 452 |
| Overview                                                                                                                     | 452 |
| NI 9326                                                                                                                      | 452 |
| NI 9326 (FPGA Interface)                                                                                                     | 453 |
| C Series Module Properties Dialog Box for the NI 9326 (FPGA                                                                  |     |
| Interface)                                                                                                                   | 461 |
| Advanced Configuration Dialog Box (FPGA Interface)                                                                           | 464 |
| Synchronizing Multiple NI 9326 Modules (FPGA Interface)                                                                      | 465 |
| NI 9361                                                                                                                      | 465 |
| NI 9361 (FPGA Interface)                                                                                                     | 466 |
| C Series Module Properties Dialog Box for the NI 9361 (FPGA                                                                  |     |
| Interface)                                                                                                                   | 472 |
| NI 9361 I/O Method Parameters                                                                                                | 476 |
| Advanced Configuration Dialog Box (FPGA Interface)                                                                           | 484 |
| Synchronizing Multiple NI 9361 Modules (FPGA Interface)                                                                      | 485 |
| Digital Input Modules                                                                                                        | 485 |
| Overview                                                                                                                     | 485 |
| NI 9344                                                                                                                      | 486 |
| NI 9344 (FPGA Interface)                                                                                                     | 486 |
| C Series Module Properties Dialog Box for the NI 9344 (FPGA<br>Interface)                                                    | 490 |
| NI 9344 (Scan Interface)                                                                                                     | 491 |
|                                                                                                                              |     |

| NI 9375                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 492                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| NI 9375 (FPGA Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 492                                                                                     |
| Avoiding Timing Uncertainty with the NI 9375 (FPGA Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 494                                                                                     |
| C Series Module Properties Dialog Box for the NI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                         |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/98                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 02                                                                                      |
| (FPGA Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 495                                                                                     |
| NI 9375 (Scan Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 495                                                                                     |
| NI 9381                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 496                                                                                     |
| NI 9381 (FPGA Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 497                                                                                     |
| Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 503                                                                                     |
| C Series Module Properties Dialog Box for the NI 9381 (FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                         |
| Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 504                                                                                     |
| Converting Voltage Values to Binary Values for the NI 9381 (FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                         |
| Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 505                                                                                     |
| NI 9381 (Scan Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 506                                                                                     |
| NI 9401                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 508                                                                                     |
| NI 9401 (FPGA Interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 509                                                                                     |
| C Series Module Properties Dialog Box for the NI 9401 (FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 000                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                         |
| Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 512                                                                                     |
| Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 512<br>ace)                                                                             |
| Interface)<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interfa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 512<br>ace)<br>513                                                                      |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 512<br>ace)<br>513<br>514                                                               |
| Interface)<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface)<br>NI 9401 (Scan Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 512<br>ace)<br>513<br>514<br>515                                                        |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (EPGA Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 512<br>ace)<br>513<br>514<br>515<br>516                                                 |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 512<br>ace)<br>513<br>514<br>515<br>516                                                 |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface)                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 512<br>ace)<br>513<br>514<br>515<br>516                                                 |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA Interface).<br>Configuring the Line Direction for the NI 9402 (EPGA Interface).                                                                                                                                                                                                                                                                                                                                                                                        | 512<br>ace)<br>513<br>514<br>515<br>516<br>520<br>521                                   |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).                                                                                                                                                                                                                                                                                                                                                                                     | 512<br>ace)<br>513<br>514<br>515<br>516<br>520<br>521                                   |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).<br>NI 9402 (Scan Interface).                                                                                                                                                                                                                                                                                                                                                        | 512<br>513<br>514<br>515<br>516<br>520<br>521<br>523                                    |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).<br>NI 9402 (Scan Interface).<br>NI 9403.<br>NI 9403.                                                                                                                                                                                                                                                                                                                                | 512<br>ace)<br>513<br>514<br>515<br>516<br>520<br>521<br>523<br>524                     |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).<br>NI 9402 (Scan Interface).<br>NI 9403.<br>NI 9403.<br>NI 9403.<br>NI 9403 (FPGA Interface).                                                                                                                                                                                                                                                                                       | 512<br>513<br>514<br>515<br>516<br>520<br>521<br>523<br>524<br>525                      |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).<br>NI 9402 (Scan Interface).<br>NI 9403 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA                                                                                                                                                                              | 512<br>513<br>514<br>515<br>516<br>520<br>521<br>523<br>524<br>525                      |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).<br>NI 9402 (Scan Interface).<br>NI 9403.<br>NI 9403 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA                  | 512<br>513<br>514<br>515<br>516<br>520<br>521<br>523<br>524<br>525<br>528               |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).<br>NI 9402 (Scan Interface).<br>NI 9403.<br>NI 9403 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9403 (FPGA Interface). | 512<br>513<br>514<br>515<br>516<br>520<br>521<br>523<br>524<br>525<br>528<br>529        |
| Interface).<br>Configuring the Initial Line Direction for the NI 9401 (FPGA Interface).<br>NI 9401 (Scan Interface).<br>NI 9402.<br>NI 9402 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9402 (FPGA<br>Interface).<br>Configuring the Line Direction for the NI 9402 (FPGA Interface).<br>NI 9402 (Scan Interface).<br>NI 9403.<br>NI 9403 (FPGA Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>C Series Module Properties Dialog Box for the NI 9403 (FPGA<br>Interface).<br>NI 9403 (FPGA Interface).<br>NI 9403 (Scan Interface).<br>NI 9403 (Scan Interface).                                                            | 512<br>513<br>514<br>515<br>516<br>520<br>521<br>523<br>524<br>525<br>528<br>529<br>531 |

| NI 9411 (FPGA Interface)                                   | 533 |
|------------------------------------------------------------|-----|
| NI 9411 (Scan Interface)                                   | 537 |
| NI 9421                                                    | 538 |
| NI 9421 (FPGA Interface)                                   | 538 |
| C Series Module Properties Dialog Box for the NI           |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/980 | )2  |
| (FPGA Interface)                                           | 542 |
| NI 9421 (Scan Interface)                                   | 542 |
| NI 9422                                                    | 543 |
| NI 9422 (FPGA Interface)                                   | 544 |
| C Series Module Properties Dialog Box for the NI           |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/980 | )2  |
| (FPGA Interface)                                           | 547 |
| NI 9422 (Scan Interface)                                   | 548 |
| NI 9423                                                    | 549 |
| NI 9423 (FPGA Interface)                                   | 550 |
| C Series Module Properties Dialog Box for the NI           |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/980 | )2  |
| (FPGA Interface)                                           | 553 |
| NI 9423 (Scan Interface)                                   | 554 |
| NI 9425                                                    | 555 |
| NI 9425 (FPGA Interface)                                   | 556 |
| C Series Module Properties Dialog Box for the NI           |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/980 | )2  |
| (FPGA Interface)                                           | 558 |
| NI 9425 (Scan Interface)                                   | 558 |
| NI 9426                                                    | 559 |
| NI 9426 (FPGA Interface)                                   | 560 |
| C Series Module Properties Dialog Box for the NI           |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/980 | )2  |
| (FPGA Interface)                                           | 562 |
| NI 9426 (Scan Interface)                                   | 562 |
| NI 9435                                                    | 563 |
| NI 9435 (FPGA Interface)                                   | 564 |

| C Series Module Properties Dialog Box for the NI              |     |
|---------------------------------------------------------------|-----|
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/98     | 02  |
| (FPGA Interface)                                              | 567 |
| NI 9435 (Scan Interface)                                      | 568 |
| NI 9436                                                       | 569 |
| NI 9436 (FPGA Interface)                                      | 570 |
| C Series Module Properties Dialog Box for the NI              |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/98     | 02  |
| (FPGA Interface)                                              | 573 |
| NI 9436 (Scan Interface)                                      | 574 |
| NI 9437                                                       | 575 |
| NI 9437 (FPGA Interface)                                      | 576 |
| C Series Module Properties Dialog Box for the NI              |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/98     | 02  |
| (FPGA Interface)                                              | 579 |
| NI 9437 (Scan Interface)                                      | 580 |
| Digital Output Modules.                                       | 581 |
| Overview                                                      | 581 |
| Advanced Configuration Dialog Box (FPGA Interface)            | 581 |
| NI 9344                                                       | 582 |
| NI 9344 (FPGA Interface)                                      | 583 |
| C Series Module Properties Dialog Box for the NI 9344 (FPGA   |     |
| Interface)                                                    | 587 |
| NI 9375                                                       | 587 |
| NI 9375 (FPGA Interface)                                      | 588 |
| Avoiding Timing Uncertainty with the NI 9375 (FPGA Interface) | 590 |
| C Series Module Properties Dialog Box for the NI              |     |
| 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x/98     | 02  |
| (FPGA Interface)                                              | 590 |
| NI 9375 (Scan Interface)                                      | 591 |
| NI 9381                                                       | 592 |
| NI 9381 (FPGA Interface)                                      | 593 |
| Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface) | 599 |
| C Series Module Properties Dialog Box for the NI 9381 (FPGA   |     |
| Interface)                                                    | 600 |
|                                                               |     |

| Converting Voltage Values to Binary Values for the NI 9381 (FPGA     |      |
|----------------------------------------------------------------------|------|
| Interface)                                                           | 601  |
| NI 9381 (Scan Interface)                                             | 602  |
| NI 9401                                                              | 604  |
| NI 9401 (FPGA Interface)                                             | 605  |
| C Series Module Properties Dialog Box for the NI 9401 (FPGA          |      |
| Interface)                                                           | 608  |
| Configuring the Initial Line Direction for the NI 9401 (FPGA Interfa | ice) |
|                                                                      | 609  |
| NI 9401 (Scan Interface)                                             | 610  |
| NI 9402                                                              | 611  |
| NI 9402 (FPGA Interface)                                             | 612  |
| C Series Module Properties Dialog Box for the NI 9402 (FPGA          |      |
| Interface)                                                           | 616  |
| Configuring the Line Direction for the NI 9402 (FPGA Interface)      | 617  |
| NI 9402 (Scan Interface)                                             | 619  |
| NI 9403                                                              | 620  |
| NI 9403 (FPGA Interface)                                             | 621  |
| C Series Module Properties Dialog Box for the NI 9403 (FPGA          |      |
| Interface)                                                           | 624  |
| Configuring the Line Direction for the NI 9403 (FPGA Interface).     | 625  |
| NI 9403 (Scan Interface)                                             | 627  |
| NI 9470                                                              | 629  |
| NI 9470 (FPGA Interface)                                             | 629  |
| C Series Module Properties Dialog Box for the NI 9470                | 635  |
| Configuring Channels on the NI 9470                                  | 636  |
| Synchronizing the NI 9470 with Other Modules (FPGA Interface).       | 638  |
| NI 9472                                                              | 640  |
| NI 9472 (FPGA Interface)                                             | 641  |
| C Series Module Properties Dialog Box for the NI                     | 011  |
| 9472/9474/9475/9481/9482/9485 (FPGA Interface)                       | 643  |
| NI 9472 (Scan Interface)                                             | 644  |
| NI 9474                                                              | 645  |
| NI 9474 (EDCA Intorfaco)                                             | 615  |
| N J T T T T T T T T                                                  | 040  |

| C Series Module Properties Dialog Box for the NI                 |     |
|------------------------------------------------------------------|-----|
| 9472/9474/9475/9481/9482/9485 (FPGA Interface)                   | 648 |
| NI 9474 (Scan Interface)                                         | 648 |
| NI 9475                                                          | 649 |
| NI 9475 (FPGA Interface)                                         | 650 |
| C Series Module Properties Dialog Box for the NI                 |     |
| 9472/9474/9475/9481/9482/9485 (FPGA Interface)                   | 652 |
| NI 9475 (Scan Interface)                                         | 653 |
| NI 9476                                                          | 654 |
| NI 9476 (FPGA Interface)                                         | 654 |
| C Series Module Properties Dialog Box for the NI 9476/9477 (FPG/ | A   |
| Interface)                                                       | 657 |
| NI 9476 (Scan Interface)                                         | 658 |
| NI 9477                                                          | 659 |
| NI 9477 (FPGA Interface)                                         | 660 |
| C Series Module Properties Dialog Box for the NI 9476/9477 (FPG/ | A   |
| Interface)                                                       | 662 |
| NI 9477 (Scan Interface)                                         | 662 |
| NI 9478                                                          | 663 |
| NI 9478 (FPGA Interface)                                         | 664 |
| C Series Module Properties Dialog Box for the NI 9478 (FPGA      |     |
| Interface)                                                       | 668 |
| Configuring Current Limits for the NI 9478 (FPGA Interface)      | 669 |
| NI 9478 (Scan Interface)                                         | 671 |
| NI 9481                                                          | 672 |
| NI 9481 (FPGA Interface)                                         | 673 |
| C Series Module Properties Dialog Box for the NI                 |     |
| 9472/9474/9475/9481/9482/9485 (FPGA Interface)                   | 675 |
| NI 9481 (Scan Interface)                                         | 676 |
| NI 9482                                                          | 677 |
| NI 9482 (FPGA Interface)                                         | 677 |
| C Series Module Properties Dialog Box for the NI                 |     |
| 9472/9474/9475/9481/9482/9485 (FPGA Interface)                   | 680 |
| NI 9482 (Scan Interface)                                         | 680 |
| NI 9485                                                          | 681 |
|                                                                  |     |

| NI 9485 (FPGA Interface)                                    | 682 |
|-------------------------------------------------------------|-----|
| C Series Module Properties Dialog Box for the NI            |     |
| 9472/9474/9475/9481/9482/9485 (FPGA Interface)              | 684 |
| NI 9485 (Scan Interface)                                    | 685 |
| Functional Safety Modules                                   | 686 |
| Overview                                                    | 686 |
| NI 9350                                                     | 686 |
| NI 9350 (Scan Interface)                                    | 687 |
| NI 9351                                                     | 692 |
| NI 9351 (Scan Interface)                                    | 692 |
| Modular Instruments                                         | 697 |
| Overview                                                    | 697 |
| NI 9770                                                     | 698 |
| NI 9770 (FPGA Interface)                                    | 699 |
| C Series Module Properties Dialog Box for the NI 9770 (FPGA |     |
| Interface)                                                  | 705 |
| Synchronizing Multiple NI 9770 Modules (FPGA Interface)     | 705 |
| NI 9775                                                     | 708 |
| NI 9775 (FPGA Interface)                                    | 709 |
| C Series Module Properties Dialog Box for the NI 9775 (FPGA |     |
| Interface)                                                  | 714 |
| NI 9775 Acquisition Modes (FPGA Interface)                  | 715 |
|                                                             |     |

### C Series Reference and Procedures

Use this book as a reference for information about using C Series modules with NI CompactRIO Device Drivers in LabVIEW. This book contains information about the FPGA I/O functions, I/O resources, arbitration options, methods, and properties each C Series module supports in FPGA Programming mode; and information about the I/O variables and properties each C Series module supports in Scan Interface mode.

**\*** 

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

© 2004–2023 National Instruments. All rights reserved.

#### C Series Module IDs

You can use the Module ID property with the <u>FPGA I/O Property Node</u> to read the IDs associated with C Series modules. You also can wire a reference to a module in Scan Interface mode to a generic-class property node in a VI block diagram, and select the **ProductID** property to read the ID programmatically. Note that the **ProductID** output will be displayed in decimal by default, and the following IDs are in hexadecimal.

By ID

| ID     | Module                      |
|--------|-----------------------------|
| 0x709C | <u>NI 9435</u>              |
| 0x709D | <u>NI 9411</u>              |
| 0x709E | <u>NI 9423</u>              |
| 0x709F | NI 9421 with screw terminal |
| 0x70A0 | <u>NI 9474</u>              |
| 0x70A1 | NI 9472 with screw terminal |
| 0x70A2 | <u>NI 9481</u>              |

| 0x70A3 | <u>NI 9211</u>               |
|--------|------------------------------|
| 0x70A4 | <u>NI 9201</u>               |
| 0x70A5 | <u>NI 9221</u>               |
| 0x70A6 | NI 9215 with screw terminal  |
| 0x70A7 | <u>NI 9263</u>               |
| 0x7129 | <u>NI 9203</u>               |
| 0x712A | NI 9205 with DSUB            |
| 0x712B | <u>NI 9217</u>               |
| 0x712C | <u>NI 9265</u>               |
| 0x712E | NI 9421 with DSUB            |
| 0x712F | <u>NI 9425</u>               |
| 0x7130 | <u>NI 9401</u>               |
| 0x7131 | <u>NI 9403</u>               |
| 0x7132 | NI 9472 with DSUB            |
| 0x7133 | <u>NI 9476</u>               |
| 0x7135 | NI 9215 with BNC             |
| 0x714F | <u>NI 9853</u>               |
| 0x71A1 | NI 9201 with DSUB            |
| 0x71A2 | NI 9221 with DSUB            |
| 0x71C2 | <u>NI 9239</u>               |
| 0x71C3 | NI 9237 with RJ-50           |
| 0x71CA | <u>NI 9422</u>               |
| 0x71CB | <u>NI 9477</u>               |
| 0x71EA | NI 9205 with spring terminal |
| 0x71EB | <u>NI 9206</u>               |
| 0x71ED | <u>NI 9505</u>               |
| 0x71F3 | <u>NI 9852</u>               |
| 0x71F6 | <u>NI 9485</u>               |
| 0x72B5 | <u>NI 9234</u>               |
| 0x72F6 | <u>NI 9264</u>               |
| 0x72FD | NI 9229 with screw terminal  |
| 0x7304 | <u>NI 9375</u>               |

| 0x7305 | <u>NI 9870</u>               |
|--------|------------------------------|
| 0x7306 | <u>NI 9871</u>               |
| 0x730C | <u>NI 9219</u>               |
| 0x731A | <u>NI 9478</u>               |
| 0x7328 | <u>NI 9402</u>               |
| 0x732A | <u>NI 9235</u>               |
| 0x732B | <u>NI 9236</u>               |
| 0x736A | <u>NI 9426</u>               |
| 0x7367 | NI 9239 with BNC             |
| 0x7368 | NI 9229 with BNC             |
| 0x7377 | <u>NI 9475</u>               |
| 0x7383 | <u>NI 9225</u>               |
| 0x73A4 | NI 9237 with DSUB            |
| 0x73E0 | NI 9220 with spring terminal |
| 0x7408 | NI 9225E                     |
| 0x7409 | <u>NI 9481E</u>              |
| 0x740A | <u>NI 9211E</u>              |
| 0x740B | <u>NI 9203E</u>              |
| 0x740C | <u>NI 9403E</u>              |
| 0x740D | <u>NI 9215E</u>              |
| 0x7415 | NI 9269                      |
| 0x7416 | <u>NI 9227</u>               |
| 0x741C | <u>NI 9239E</u>              |
| 0x741D | <u>NI 9229E</u>              |
| 0x741E | NI 9263E                     |
| 0x741F | <u>NI 9237E</u>              |
| 0x743A | <u>NI 9213E</u>              |
| 0x743B | <u>NI 9478E</u>              |
| 0x743F | <u>NI 9870E</u>              |
| 0x7440 | <u>NI 9871E</u>              |
| 0x7441 | <u>NI 9219E</u>              |
| 0x7442 | NI 9265E                     |

| 0x7445 | <u>NI 9222</u>               |
|--------|------------------------------|
| 0x7446 | <u>NI 9222E</u>              |
| 0x7447 | <u>NI 9264E</u>              |
| 0x7449 | <u>NI 9213</u>               |
| 0x744B | <u>NI 9205E</u>              |
| 0x744C | <u>NI 9227E</u>              |
| 0x744D | <u>NI 9269E</u>              |
| 0x745D | NI 9215E with BNC            |
| 0x747A | NI 9375 with DSUB            |
| 0x749B | NI 9201E with screw terminal |
| 0x749C | NI 9221E with screw terminal |
| 0x749D | NI 9201E with DSUB           |
| 0x749E | NI 9221E with DSUB           |
| 0x74A1 | <u>NI 9505E</u>              |
| 0x74AA | NI 9207E with DSUB           |
| 0x74AB | NI 9208E with DSUB           |
| 0x74AC | NI 9208 with DSUB            |
| 0x74AD | NI 9207 with DSUB            |
| 0x74EC | <u>NI 9223</u>               |
| 0x74ED | <u>NI 9223E</u>              |
| 0x74EE | <u>NI 9214</u>               |
| 0x753F | <u>NI 9232</u>               |
| 0x7615 | NI 9220 with DSUB            |
| 0x7642 | <u>NI 9381</u>               |
| 0x76E3 | <u>NI 9482</u>               |
| 0x76E8 | <u>NI 9244</u>               |
| 0x77EA | <u>NI 9250</u>               |
| 0x77B8 | <u>NI 9247</u>               |
| 0x77C5 | <u>NI 9344</u>               |
| 0x77CC | <u>NI 9230</u>               |
| 0x77E3 | <u>NI 9246</u>               |
| 0x77E9 | <u>NI 9251</u>               |

| 0x777E | <u>NI 9361</u>               |
|--------|------------------------------|
| 0x7786 | NI 9260 with BNC             |
| 0x778C | NI 9260 with mini XLR        |
| 0x780D | <u>NI 9224</u>               |
| 0x780E | <u>NI 9228</u>               |
| 0x7827 | <u>NI 9770</u>               |
| 0x7889 | <u>NI 9775</u>               |
| 0x788A | NI 9202 with DSUB            |
| 0x788C | NI 9202 with spring terminal |
| 0x788F | <u>NI 9266</u>               |
| 0x78B1 | <u>NI 9210</u>               |
| 0x78B6 | NI 9262 with DSUB            |
| 0x7900 | NI 9476 with spring terminal |
| 0x7930 | <u>NI 9231</u>               |
| 0x79C4 | <u>NI 9253</u>               |
| 0x79C8 | NI 9252 with screw terminal  |
| 0x79CA | NI 9252 with DSUB            |
| 0x7A59 | <u>NI 9470</u>               |
| 0x7A5E | <u>NI 9326</u>               |

#### By Module

| Module                       | ID     |
|------------------------------|--------|
| <u>NI 9201</u>               | 0x70A4 |
| NI 9201 with DSUB            | 0x71A1 |
| NI 9201E with DSUB           | 0x749D |
| NI 9201E with screw terminal | 0x749B |
| NI 9202 with DSUB            | 0x788A |
| NI 9202 with spring terminal | 0x788C |
| <u>NI 9203</u>               | 0x7129 |
| <u>NI 9203E</u>              | 0x740B |
| NI 9205 with DSUB            | 0x712A |
| NI 9205 with spring terminal | 0x71EA |

| <u>NI 9205E</u>              | 0x744B |
|------------------------------|--------|
| <u>NI 9206</u>               | 0x71EB |
| NI 9207 with DSUB            | 0x74AD |
| NI 9207E with DSUB           | 0x74AA |
| NI 9208 with DSUB            | 0x74AC |
| NI 9208E with DSUB           | 0x74AB |
| NI 9210                      | 0x78B1 |
| <u>NI 9211</u>               | 0x70A3 |
| NI 9211E                     | 0x740A |
| NI 9213                      | 0x7449 |
| NI 9213E                     | 0x743A |
| NI 9214                      | 0x74EE |
| NI 9215 with BNC             | 0x7135 |
| NI 9215 with screw terminal  | 0x70A6 |
| NI 9215E with BNC            | 0x745D |
| NI 9215E with screw terminal | 0x740D |
| NI 9217                      | 0x712B |
| NI 9219                      | 0x730C |
| <u>NI 9219E</u>              | 0x7441 |
| NI 9220 with spring terminal | 0x73E0 |
| NI 9220 with DSUB            | 0x7615 |
| NI 9221                      | 0x70A5 |
| NI 9221 with DSUB            | 0x71A2 |
| NI 9221E with DSUB           | 0x749E |
| NI 9221E with screw terminal | 0x749C |
| NI 9222                      | 0x7445 |
| NI 9222E                     | 0x7446 |
| NI 9223                      | 0x74EC |
| <u>NI 9223E</u>              | 0x74ED |
| <u>NI 9224</u>               | 0x780D |
| <u>NI 9225</u>               | 0x7383 |
| <u>NI 9225E</u>              | 0x7408 |

| <u>NI 9227</u>              | 0x7416 |
|-----------------------------|--------|
| <u>NI 9227E</u>             | 0x744C |
| NI 9228                     | 0x780E |
| NI 9229 with screw terminal | 0x72FD |
| NI 9229E                    | 0x741D |
| NI 9229 with BNC            | 0x7368 |
| <u>NI 9230</u>              | 0x77CC |
| <u>NI 9231</u>              | 0x7930 |
| <u>NI 9232</u>              | 0x753F |
| NI 9234                     | 0x72B5 |
| <u>NI 9235</u>              | 0x732A |
| <u>NI 9236</u>              | 0x732B |
| NI 9237 with DSUB           | 0x73A4 |
| NI 9237 with RJ-50          | 0x71C3 |
| NI 9237E                    | 0x741F |
| NI 9239                     | 0x71C2 |
| <u>NI 9239E</u>             | 0x741C |
| NI 9239 with BNC            | 0x7367 |
| <u>NI 9244</u>              | 0x76E8 |
| <u>NI 9246</u>              | 0x77E3 |
| <u>NI 9247</u>              | 0x77B8 |
| NI 9250                     | 0x77EA |
| <u>NI 9251</u>              | 0x77E9 |
| NI 9252 with screw terminal | 0x79C8 |
| NI 9252 with DSUB           | 0x79CA |
| NI 9253                     | 0x79C4 |
| NI 9260 with BNC            | 0x7786 |
| NI 9260 with mini XLR       | 0x778C |
| NI 9262 with DSUB           | 0x78B6 |
| <u>NI 9263</u>              | 0x70A7 |
| <u>NI 9263E</u>             | 0x741E |
| <u>NI 9264</u>              | 0x72F6 |

| <u>NI 9264E</u>              | 0x7447 |
|------------------------------|--------|
| <u>NI 9265</u>               | 0x712C |
| NI 9265E                     | 0x7442 |
| NI 9266                      | 0x788F |
| NI 9269                      | 0x7415 |
| NI 9269E                     | 0x744D |
| NI 9326                      | 0x7A5E |
| <u>NI 9344</u>               | 0x77C5 |
| NI 9361                      | 0x777E |
| NI 9375                      | 0x7304 |
| NI 9375 with DSUB            | 0x747A |
| <u>NI 9381</u>               | 0x7642 |
| <u>NI 9401</u>               | 0x7130 |
| NI 9402                      | 0x7328 |
| <u>NI 9403</u>               | 0x7131 |
| NI 9403E                     | 0x740C |
| <u>NI 9411</u>               | 0x709D |
| NI 9421 with DSUB            | 0x712E |
| NI 9421 with screw terminal  | 0x709F |
| <u>NI 9422</u>               | 0x71CA |
| <u>NI 9423</u>               | 0x709E |
| <u>NI 9425</u>               | 0x712F |
| <u>NI 9426</u>               | 0x736A |
| <u>NI 9435</u>               | 0x709C |
| <u>NI 9470</u>               | 0x7A59 |
| NI 9472 with DSUB            | 0x7132 |
| NI 9472 with screw terminal  | 0x70A1 |
| <u>NI 9474</u>               | 0x70A0 |
| <u>NI 9475</u>               | 0x7377 |
| <u>NI 9476</u>               | 0x7133 |
| NI 9476 with spring terminal | 0x7900 |
| <u>NI 9477</u>               | 0x71CB |

| <u>NI 9478</u> | 0x731A |
|----------------|--------|
| NI 9478E       | 0x743B |
| NI 9481        | 0x70A2 |
| NI 9481E       | 0x7409 |
| NI 9482        | 0x76E3 |
| NI 9485        | 0x71F6 |
| NI 9505        | 0x71ED |
| NI 9505E       | 0x74A1 |
| <u>NI 9770</u> | 0x7827 |
| <u>NI 9775</u> | 0x7889 |
| NI 9852        | 0x71F3 |
| <u>NI 9853</u> | 0x714F |
| <u>NI 9870</u> | 0x7305 |
| NI 9870E       | 0x743F |
| NI 9871        | 0x7306 |
| NI 9871E       | 0x7440 |

#### Analog Input Modules

**\*** 

Use this book as a reference for the following information:

- FPGA I/O functions, I/O resources, arbitration options, methods, and properties each C Series analog input module supports in FPGA Interface mode
- I/O variables and properties each C Series analog input module supports in Scan Interface mode
- Instructions for using LabVIEW with CompactRIO analog input devices

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

<u>NI 9253</u>
NI 9381

# Converting and Calibrating CompactRIO Analog Input Values (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the **C Series Module Properties** dialog box for an analog input module if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node returns uncalibrated, binary values for the following analog input modules:

| <u>NI 9201</u> | <u>NI 9222</u> | <u>NI 9234</u> |
|----------------|----------------|----------------|
| <u>NI 9202</u> | <u>NI 9223</u> | <u>NI 9235</u> |
| <u>NI 9203</u> | <u>NI 9224</u> | <u>NI 9236</u> |
| <u>NI 9205</u> | <u>NI 9225</u> | <u>NI 9237</u> |
| <u>NI 9206</u> | <u>NI 9226</u> | <u>NI 9238</u> |
| <u>NI 9215</u> | <u>NI 9227</u> | <u>NI 9239</u> |
| <u>NI 9216</u> | <u>NI 9228</u> | <u>NI 9246</u> |
| <u>NI 9217</u> | <u>NI 9229</u> | <u>NI 9247</u> |
| <u>NI 9218</u> | <u>NI 9230</u> | <u>NI 9250</u> |
| <u>NI 9220</u> | <u>NI 9231</u> | <u>NI 9251</u> |

NI 9232

<u>NI 9221</u>

If you set the **Calibration Mode** to **Raw**, you must convert the binary values into meaningful engineering units and apply calibration constants to achieve more accurate results. You must convert and calibrate these values in the host VI.

NI 9252



| Module         | Link for More                                         |
|----------------|-------------------------------------------------------|
|                | Information                                           |
| <u>NI 9202</u> | <u>Converting NI 9202 Dat</u><br><u>a</u>             |
| <u>NI 9207</u> | <u>Converting NI 9207 Dat</u><br><u>a</u>             |
| <u>NI 9208</u> | <u>Converting NI 9208 Dat</u><br><u>a</u>             |
| <u>NI 9211</u> | <u>Converting NI 9211 Dat</u><br><u>a</u>             |
| <u>NI 9212</u> | <u>Converting NI 9212 Dat</u><br><u>a</u>             |
| <u>NI 9213</u> | Converting NI 9213 Dat<br>a                           |
| <u>NI 9214</u> | Converting NI 9214 Dat<br>a                           |
| <u>NI 9219</u> | Converting NI 9219 Dat<br>a                           |
| <u>NI 9224</u> | Converting NI 9224 Dat<br>a                           |
| <u>NI 9228</u> | <u>Converting NI 9228 Dat</u><br><u>a</u>             |
| <u>NI 9231</u> | <u>Converting NI 9231 Dat</u><br><u>a</u>             |
| <u>NI 9242</u> | <u>Converting NI 9242 an</u><br><u>d NI 9244 Data</u> |
| <u>NI 9244</u> | <u>Converting NI 9242 an</u><br><u>d NI 9244 Data</u> |
| <u>NI 9250</u> | Converting NI 9250 Dat<br>a                           |
| <u>NI 9251</u> | Converting NI 9251 Dat<br>a                           |
| <u>NI 9252</u> | Converting NI 9252 Dat<br>a                           |
| <u>NI 9253</u> | Converting NI 9253 Dat<br>a                           |

#### Using a VI to Convert and Calibrate Values

For the NI 9205, you can also refer to the Binary to Nominal Polynomial (Host) VI in the labview\examples\CompactRIO\Module Specific\NI 9205\NI 9205 Linearization Coefficients\NI 9205 Linearization Coeff icients.lvproj for an example of using the straight-line conversion algorithm along with the NI-MCal linearization correction to convert binary analog input values to calibrated engineering units. You can use the Binary to Nominal Polynomial (Host) VI as a subVI in the host VI.

🛃 Open example (NI 9205)

For the NI 9206, you can also refer to the Binary to Nominal Polynomial (Host) VI in the labview\examples\CompactRIO\Module Specific\NI 9206\NI 9206 Linearization Coefficients\NI 9206 Linearization Coeff icients.lvproj for an example of using the straight-line conversion algorithm along with the NI-MCal linearization correction to convert binary analog input values to calibrated engineering units. You can use the Binary to Nominal Polynomial (Host) VI as a subVI in the host VI.

🛃 Open example (NI 9206)

#### Using an Equation to Convert and Calibrate Values

You can use the following equation in the host VI to convert binary analog input values to calibrated engineering units:

#### Input Engineering Units = (Binary Value × LSB Weight – Offset)\*

| where | <b>Binary Value</b> is the signed or unsigned value returned by the FPGA I/O Node |
|-------|-----------------------------------------------------------------------------------|
|       | <b>LSB Weight</b> is the value returned by the LSB<br>Weight property             |
|       | <b>Offset</b> is the value returned by the Offset property.                       |

The units of **LSB Weight** and **Offset** differ per module. Refer to the reference topic for the module you are using for the **LSB Weight** and **Offset** units. You can find the reference topic for the module by navigating on the **Contents** tab to **FPGA** 

#### Module»CompactRIO Reference and Procedures»Analog Input Modules»NI 9xxx.

To convert to calibrated engineering units, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert to uncalibrated engineering units by using the following values for **Offset** and **LSB Weight**:

#### **Offset** = $0^{\dagger}$

where

#### LSB Weight = Typical Input Span ÷ 2<sup>ADC Resolution</sup>

**Typical Input Span** is the value for the module in the table below **ADC Resolution** is the ADC resolution value in the <u>hardware documentation for the module</u>

| Module  | Typical Input Span                      |
|---------|-----------------------------------------|
| NI 9201 | 21.06 V                                 |
| NI 9203 | 21.56 mA (unipolar), 43.12 mA (bipolar) |
| NI 9205 | 20.8 V                                  |
| NI 9206 | 21.5 V                                  |
| NI 9215 | 20.8 V                                  |
| NI 9216 | 100 Ω RTD                               |
| NI 9217 | 100 Ω RTD                               |
| NI 9218 | Varies by mode                          |
| NI 9220 | 20.8 V                                  |
| NI 9221 | 125 V                                   |
| NI 9222 | 21.2 V                                  |
| NI 9223 | 21.2 V                                  |
| NI 9225 | 850 V                                   |
| NI 9226 | 1000 Ω RTD                              |
| NI 9227 | 29.954 A                                |
| NI 9229 | 125.28 V                                |
| NI 9230 | 63 V                                    |
| NI 9232 | 63 V                                    |

| NI 9234 | 10.2 V    |
|---------|-----------|
| NI 9235 | 52.6 mV/V |
| NI 9236 | 52.6 mV/V |
| NI 9237 | 50 mV/V   |
| NI 9238 | 1.25 V    |
| NI 9239 | 21.04 V   |
| NI 9246 | 62.5 A    |
| NI 9247 | 294 A     |
| NI 9381 | 5 V       |

<sup>\*</sup>When converting and calibrating data acquired from the NI 9203 in ±20 mA range, the equation is:

#### Input Engineering Units = ((Binary Value - 32768) × LSB Weight - Offset)

<sup>†</sup>When calculating engineering units for the NI 9203 in ±20 mA range, **Offset** = 20 mA.

Detecting Out-of-Range Channels for CompactRIO Analog Input Channels (FPGA Interface)

You can detect an out-of-range CompactRIO analog input channel when you <u>read</u> the channel. If you set the **Calibration Mode** to **Calibrated** in the **C Series Module Properties** dialog box and the <u>FPGA I/O Node</u> returns a value greater than the minimum operating range value, the channel might be out of range. Refer to the <u>hardware documentation for the module</u> for more information about module specifications.

If you set the **Calibration Mode** to **Raw** in the **C Series Module Properties** dialog box and a channel is out of range, the FPGA I/O Node returns the full-scale binary value, as shown in the table below.

| Module           | Full-Scale Binary Value                             |
|------------------|-----------------------------------------------------|
| NI 9201          | -2,048 (0xF800) or 2,047 (0x7FF)                    |
| <u>NI 9202</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9203</u>   | 0 (0x0000) or 65,535 (0xFFFF)                       |

| <u>NI 9205</u> * | -32,768 (0x8000) or 32,767 (0x7FFF)                 |
|------------------|-----------------------------------------------------|
| <u>NI 9206</u> * | -32,768 (0x8000) or 32,767 (0x7FFF)                 |
| <u>NI 9207</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9208</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9209</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9210</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9211</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9212</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9213</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9214</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9215</u>   | -32,768 (0x8000) or 32,767 (0x7FFF)                 |
| <u>NI 9217</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9218</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9219</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9220</u>   | -32,768 (0x8000) or 32,767 (0x7FFF)                 |
| <u>NI 9221</u>   | -2,048 (0xF800) or 2,047 (0x7FF)                    |
| NI 9222          | -32,768 (0x8000) or 32,767 (0x7FFF)                 |
| NI 9223          | -32,768 (0x8000) or 32,767 (0x7FFF)                 |
| <u>NI 9224</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9225</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9227</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |

| <u>NI 9228</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFF<br>)  |
|------------------|-----------------------------------------------------|
| <u>NI 9229</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9230</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9231</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9232</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9234</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9235</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9236</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9237</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9238</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9239</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9242</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9244</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9246</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9247</u>   | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9250</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9251</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF<br>) |
| <u>NI 9252</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF)     |

| <u>NI 9253</u> * | -8,388,608 (0xFF800000) or 8,388,607 (0x7FFFFF |
|------------------|------------------------------------------------|
|                  | )                                              |
| <u>NI 9381</u>   | 0 (0x0000) or 4,095 (0x0FFF)                   |

<sup>\*</sup>For the NI 9202/9205/9206/9224/9228/9231/9242/9244/9250/9251/9252/9253, a channel might be out of range before the FPGA I/O Node reaches the minimum or maximum full-scale binary value.

#### Synchronizing Multiple Modules (FPGA Interface)

You can synchronize multiple modules that are connected to the same FPGA device if your application meets the following requirements:

- The modules must use the same master timebase source
- The modules must start acquisition mode at the same time
- A single <u>FPGA I/O Node</u> function must read the synchronous data

You must <u>create FPGA I/O items</u> for the module before you can configure the items using the FPGA I/O Node. Develop the FPGA VI to meet the guidelines described in the following table.

For delta-sigma modules, you will need to synchronize multiple sample rates.

| Guideline                          | Details                                                                                                                                                                                                                                                                                                                |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Share a master timebase source     | Configure the modules to share master timebas <u>e source</u> .                                                                                                                                                                                                                                                        |
| Start the synchronized acquisition | <ul> <li>Configure an FPGA I/O Node with Start channels for the module you want to sync hronize.</li> <li>Wire a Boolean constant set to TRUE to each Start channel.</li> <li>Ensure that all I/O channels are in the s ame FPGA I/O Node. Otherwise, the FPGA I/O Node will not return synchronized dat a.</li> </ul> |

| Acquire data from synchronized modules with t<br>he same data rate      | <ul> <li>Configure an FPGA I/O Node with all of t<br/>he channels from which you want to sync<br/>hronously sample.</li> <li>Ensure that all I/O channels are in the s<br/>ame FPGA I/O Node. Otherwise, the FPGA<br/>I/O Node will not return synchronized dat<br/>a.</li> <li>Refer to the Synchronizing NI 923x Mod<br/>ules (FPGA) VI in labview\examples\<br/>CompactRIO\Module Specific\NI<br/>923x\Synchronizing NI 923x M<br/>odules\Synchronizing NI 923x M<br/>odules.lvproj for an example of sy<br/>nchronizing multiple modules with the sa<br/>me data rate.</li> </ul>                                                                                                                  |
|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acquire data from synchronized modules with d<br>ifferent data rates    | <ul> <li>If you synchronize modules that are configured for different data rates, create a separate loop for each data rate in the FPGA VI.</li> <li>In each loop, configure an FPGA I/O Nod e with all of the channels that are configured for the data rate of that loop. If you place channels that are configured for different rates in the same loop, LabVIEW return s an overrun warning, error 65539, from the FPGA I/O Node when you run the VI.</li> <li>A delay occurs before the FPGA I/O Nod e returns the first data point. The length o f the delay depends on the data rate and model number of the module. The equati on for the delay is provided in the following table.</li> </ul> |
| Understand the maximum sample rate when sy nchronizing multiple modules | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### Equation for synchronizing multiple samples rates

| Module | Decimation Rate, <b>m</b> | Clock Divider, <b>n</b> | Time to First Sample (s) |
|--------|---------------------------|-------------------------|--------------------------|
|--------|---------------------------|-------------------------|--------------------------|
| NI 9231, NI 9250, NI 925<br>1                                    | 32          | n = 1      | (281.625 * m * n + 5.5) *<br>Master_Timebase_Per<br>iod ± 1 Master_Timeba<br>se_Period |
|------------------------------------------------------------------|-------------|------------|----------------------------------------------------------------------------------------|
|                                                                  | 64          | n = 1      | (281.625 * m * n + 8.5) *<br>Master_Timebase_Per<br>iod ± 1 Master_Timeba<br>se_Period |
|                                                                  | 128,, 1,024 | n = 1      | (281.625 * m * n + 6.5) *<br>Master_Timebase_Per<br>iod ± 1 Master_Timeba<br>se_Period |
|                                                                  | 32,, 1,024  | n = 2,, 12 | (281.625 * m * n + 5.5) *<br>Master_Timebase_Per<br>iod ± 1 Master_Timeba<br>se_Period |
| NI 9218, NI 9225, NI 922<br>7, NI 9229, NI 9234, NI 9            | 256         | n = 1      | (8.5 + n * 34,152) * Mast<br>er_Timebase_Period                                        |
| 237, NI 9238, NI 9239, N<br>I 9242, NI 9244, NI 9246,<br>NI 9247 |             | n = 2,, 31 | (5.5 + n * 34,152) * Mast<br>er_Timebase_Period                                        |
| NI 9230, NI 9232                                                 | 64          | n = 1,, 31 | 77/Fs + 4-5 Master_Ti<br>mebase_Period                                                 |
|                                                                  | 128         | n = 1,, 31 | 72/Fs + 4-5 Master_Ti<br>mebase_Period                                                 |
|                                                                  | 256         | n = 1,, 31 | 68/Fs + 4-5 Master_Ti<br>mebase_Period                                                 |
| NI 9235, NI 9236                                                 | 512         | n = 1,, 31 | 39/ <b>Fs</b> + 110.5 MClk + 1<br>OClk + <b>Analog Delay</b>                           |

#### Notes:

**Master\_Timebase\_Period** = period of the internal or external clock that the module uses (1/13.1 072 MHz, 1/12.8 MHz, or 1/10 MHz).

**Fs** = sample rate.

The divider and decimation rate depend on which sample rate you select. The datasheet for each modules provides an equation to help you determine the clock divider and decimation rate and/ or lists the clock divider and decimation rate for each sample rate.

• For example, the NI 9232 Datasheet lists the decimation rate as 64 and clock divider as 1 when sampling at 102.4 kHz.

• Using the equation in the NI 9218 Datasheet, we can determine that the clock divider is 1 when the sample rate is 51.2 kHz. **n** = Master\_Timebase\_Frequency/256/**fs** (this is the equat ion provided in the NI 9218 Datasheet reorganized to solve for **n**).

Equation for synchronizing multiple samples rates

| Module  | Clock Divider, <b>b</b> | Time to First Sample (s)                                                                         |
|---------|-------------------------|--------------------------------------------------------------------------------------------------|
| NI 9202 | 1                       | ((5.40625 + e) * a * b * c * d + 4.5<br>) * Master_Timebase_Period ±<br>1 Master_Timebase_Period |
|         | 2,, 11                  | ((5.40625 + e) * a * b * c * d + 5.5<br>) * Master_Timebase_Period ±<br>1 Master_Timebase_Period |

#### Notes:

**Master\_Timebase\_Period** = period of the internal or external clock that the module uses (1/13.1 072 MHz, 1/12.8 MHz, or 1/10 MHz).

- **a** = ADC Decimation Rate
- **b** = Timebase Clock Divider
- **c** = ADC Clock Divider
- **d** = Filter Decimation Rate
- **e** = Filter Frequency
  - 0 for notch at Fs
  - 1 for notch at Fs/2
  - 3 for notch at Fs/4
  - 7 for notch at Fs/8
  - 15 for notch at Fs/16

Refer to the NI 9202 Datasheet on ni.com for the values of **a**, **b**, **c**, and **d** for each sample rate.

| Module               | Filter | Clock Divider, <b>b</b> | Time to First Sample (s)                                                                       |
|----------------------|--------|-------------------------|------------------------------------------------------------------------------------------------|
| NI 9252, NI 9253 Con | Comb   | 2                       | ((5.40625 + b) * 128 * a<br>+ 8.5) * Master_Timeba<br>se_Period ± 1 Master_<br>Timebase_Period |
|                      |        | Others                  | ((5.40625 + b) * <b>128</b> * a<br>+ <b>5</b> .5) * Master_Timeb                               |

Equation for synchronizing multiple samples rates

|             |        | ase_Period ± 1 Master<br>_Timebase_Period                                                              |
|-------------|--------|--------------------------------------------------------------------------------------------------------|
| Butterworth | 2      | (5.40625 * <b>128</b> * <b>a</b> + 8.5)<br>* Master_Timebase_P<br>eriod ± 1 Master_Time<br>base_Period |
|             | Others | (5.40625 * <b>128</b> * <b>a</b> + 5.5)<br>* Master_Timebase_P<br>eriod ± 1 Master_Time<br>base_Period |

#### Notes:

**Master\_Timebase\_Period** = period of the internal or external clock that the module uses (1/13.1 072 MHz, 1/12.8 MHz, or 1/10 MHz).

**a** = Decimation Rate

**b** = Filter Frequency

- 0 for Filter Frequency—1 (notch at Fs)
- 1 for Filter Frequency—2 (notch at Fs/2)
- 3 for Filter Frequency—3 (notch at Fs/4)
- 7 for Filter Frequency—4 (notch at Fs/8)
- 15 for Filter Frequency—5 and 6 (notch at Fs/16)

Refer to the NI 9252 or NI 9253 Datasheet on ni.com for the values of **a** for each sample rate.

#### Related Topics

#### Configuring the Master Timebase Source for a Module

<u>Understanding the Maximum Sample Rate when Synchronizing Multiple Modules</u> (FPGA Interface)

Configuring the Master Timebase Source for a Module (FPGA Interface)

#### The information in this topic applies to the following modules:

- NI 9202
- NI 9232

NI 9235

- NI 9242
- NI 9253

- NI 9218
- NI 9225
- <u>NI 9234</u>
- <u>NI 9244</u>
  NI 9246
- NI 9260
- NI 9469

| <u>NI 9227</u> | <u>NI 9236</u> | <u>NI 9247</u> | <u>NI 9770</u> |
|----------------|----------------|----------------|----------------|
| <u>NI 9229</u> | NI 9237        | <u>NI 9250</u> | <u>NI 9775</u> |
| <u>NI 9230</u> | <u>NI 9238</u> | <u>NI 9251</u> | <u>NI 9470</u> |
| NI 9231        | NI 9239        | NI 9252        |                |

In a system that contains more than one of these modules, you can configure one module as the master timebase source (**master**) and configure the other modules to use that master timebase source (**slaves**). Sharing the same master timebase source allows you to <u>synchronize multiple modules</u>. The master timebase source is divided to acquire data at the <u>data rate</u> you configure.

| EX. | <b>Note</b> The NI 9151 R Series Expansion chassis does not support synchronizing multiple modules.                                                                                                        |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | <b>Note</b> The NI 9770 does not support synchronization with other non-NI 9770 modules.                                                                                                                   |
|     | <b>Note</b> You can only use another NI 9775 or the NI 9469 as the master timebase source for the NI 9775. If you select the NI 9469, you can only use the 12.8 MHz clock as the exported clock frequency. |

Configuring the Onboard Clock of a Module as the Master Timebase Source

Complete the following steps to configure the internal Onboard Clock of one module as the master timebase source.

- 1. <u>Configure the CompactRIO system</u>, and add a module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to launch the **C Series Module Properties** dialog box.
- 3. Select **<Onboard Clock>** from the **Master Timebase Source** pull-down menu.
- 4. Click the **OK** button.
- 5. Select File»Save All in the Project Explorer window.

# Configuring a Master Module to Share the Master Timebase Source with Slaves

Complete the following steps to configure the master timebase source for a master module and share that timebase with slave modules.

- 1. Configure the CompactRIO system, and add the module you want to use as the master.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to launch the **C Series Module Properties** dialog box.
- 3. Select **<Onboard Clock>** from the **Master Timebase Source** pull-down menu.
- 4. Place a checkmark in the **Export Onboard Clock** checkbox.
- 5. Add a module you want to use as a slave.
- 6. Right-click the slave module in the **Project Explorer** window and select **Properties** to display the **C Series Module Properties** dialog box.
- 7. Select the name of the master module from the **Master Timebase Source** pull-down menu.
- 8. Repeat steps 5 through 7 for each slave module you want to configure.
- 9. Click the **OK** button.
- 10. Select File»Save All in the Project Explorer window.

**Related Topics** 

Synchronizing Multiple Modules (FPGA Interface)

#### <u>Understanding the Maximum Sample Rate when Synchronizing Multiple Modules</u> (FPGA Interface)

Modules with a Selectable Timebase Source

To <u>synchronize multiple modules</u>, you must configure the modules to share the same master timebase source. You can select the timebase source for the following modules, which allows you to configure them to share the same master timebase source:

|   | <u>NI 9202</u> | <ul> <li><u>NI 9234</u></li> </ul> | <ul> <li><u>NI 9246</u></li> </ul>                                             | <ul> <li><u>NI 9770</u></li> </ul>                           |
|---|----------------|------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------|
|   | <u>NI 9218</u> | <u>NI 9235</u>                     | <u>NI 9247</u>                                                                 | <u>NI 9775</u>                                               |
|   | <u>NI 9225</u> | <u>NI 9236</u>                     | <u>NI 9250</u>                                                                 |                                                              |
|   | <u>NI 9227</u> | <u>NI 9237</u>                     | <u>NI 9251</u>                                                                 |                                                              |
|   | <u>NI 9229</u> | <u>NI 9238</u>                     | <u>NI 9252</u>                                                                 |                                                              |
|   | NI 9230        | <u>NI 9239</u>                     | NI 9253                                                                        |                                                              |
|   | NI 9231        | <u>NI 9242</u>                     | NI 9260                                                                        |                                                              |
|   | <u>NI 9232</u> | <u>NI 9244</u>                     | <u>NI 9469</u>                                                                 |                                                              |
| Ø |                |                                    | <b>Note</b> The NI 9151 R se<br>does not support syncl<br>modules.             | ries Expansion chassis<br>hronizing multiple                 |
| e |                |                                    | <b>Note</b> The NI 9770 doe<br>synchronization with o<br>modules.              | s not support<br>ther non-NI 9770                            |
| V |                |                                    | <b>Note</b> The NI 9775 can<br>9469 module with a 12<br>Otherwise, it can only | only be a slave to an NI<br>.8 MHz timebase.<br>be a master. |

Related Topics

Configuring the Master Timebase Source for a Module

<u>Understanding the Maximum Sample Rate when Synchronizing Multiple Modules</u> (FPGA Interface)

Synchronizing Multiple Modules (FPGA Interface)

Understanding the Maximum Sample Rate when Synchronizing Multiple Modules (FPGA Interface)

The modules listed below derive their sampling rate from the internal master timebase.

Select a module to show more information about the internal master timebase and maximum sample rate for each module.

#### Show information for:

#### number

| Internal master timebase |                                                        | value                                                                                                       |                                                                                                                                                                                      |
|--------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Maximum sample rate      |                                                        |                                                                                                             |                                                                                                                                                                                      |
|                          | when module uses internal master timebase <sup>1</sup> |                                                                                                             | value                                                                                                                                                                                |
|                          | when module is                                         | a slave <sup>2</sup> to                                                                                     | value                                                                                                                                                                                |
| 1                        |                                                        | The maximum s<br>the internal mas<br>sourcing the tim                                                       | ample rate for a module using<br>ster timebase and is not<br>nebase to different model types.                                                                                        |
| 2                        |                                                        | When synchron<br>maximum samp<br>depends on the<br>internal master<br>sample rate of t<br>rate of all the m | izing multiple modules, the<br>ole rate of a slave module<br>frequency of the master module<br>timebase. The maximum<br>he system is the lowest sample<br>odules being synchronized. |

#### Related Topics

<u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Synchronizing Multiple Modules (FPGA Interface)</u>

# Acquiring Data from a Module (FPGA Interface)

The information in this topic applies to the following modules:

- <u>NI 9202</u>
- NI 9218
- NI 9225
- NI 9227
- NI 9229

- NI 9234
- NI 9235
- NI 9236
- NI 9237
- NI 9238

- NI 9246
- NI 9247
- NI 9250
- NI 9251
- NI 9252

| <u>NI 9230</u> | <u>NI 9239</u> | NI 9253 |
|----------------|----------------|---------|
| <u>NI 9231</u> | <u>NI 9242</u> | NI 9770 |
| <u>NI 9232</u> | <u>NI 9244</u> | NI 9775 |

The module has input channels that are sampled simultaneously at the data rate for which you have configured the module. Use the **Start** and **Stop** channels to put the module in and out of acquisition mode, in which the module can only acquire data. Use the <u>FPGA I/O Node</u> to read the data from the module. While the module is in acquisition mode, you cannot perform other operations with the module, such as accessing properties or, for some modules, TEDS information.

**Note** You must <u>create FPGA I/O items</u> for the module before you can configure the items using the FPGA I/O Node.

Putting the Module in Acquisition Mode

Complete the following steps to put the module in acquisition mode.

- 1. Configure an FPGA I/O Node with the **Start** channel of the module.
- 2. Wire a Boolean constant set to TRUE to the **Start** input of the FPGA I/O Node to send a synchronization pulse to the module. The module starts acquiring data at the data rate you configure.

#### Reading Data from the Module

When the module starts acquiring data, you can use an FPGA I/O Node to read data from the module. You can connect the AI output of the FPGA I/O Node (or, for the NI 9770, the RF In/I or RF In/Q items) to various types of functions, including an FPGA Memory function or an FPGA FIFO function. If you read from multiple channels on the module, place the channels in the same FPGA I/O Node to ensure that the VI reads the data synchronously.

Because the module internally acquires data at a specified rate, the FPGA I/O Node does not return data until new data has been acquired by the module. If the module did not start acquiring data or stops acquiring data while an FPGA I/O Node is waiting for data from the module, the FPGA I/O Node returns <u>I/O Not Start error</u> <u>65582</u>.

e/

#### Exiting Acquisition Mode

Complete the following steps to exit acquisition mode.

- 1. Configure an FPGA I/O Node with the **Stop** channel of the module.
- 2. Write a TRUE to the **Stop** input. The module is no longer in acquisition mode and you can now access its properties or, for some modules, TEDS information.

#### Example

Refer to the module Getting Started (FPGA) VI at labview\examples\Compact RIO\Module Specific\<**module**>\<**module**> Getting Started for an example of reading from the module.

# Configuring the Data Rate for a Module (FPGA Interface)

The information in this topic applies to the following modules:

| <u>NI 9202</u> | <ul> <li><u>NI 9232</u></li> </ul> | <u>NI 9242</u> | <ul> <li><u>NI 9253</u></li> </ul> |
|----------------|------------------------------------|----------------|------------------------------------|
| NI 9218        | <u>NI 9234</u>                     | <u>NI 9244</u> | <u>NI 9260</u>                     |
| <u>NI 9225</u> | <u>NI 9235</u>                     | <u>NI 9246</u> | <u>NI 9770</u>                     |
| NI 9227        | <u>NI 9236</u>                     | <u>NI 9247</u> | <u>NI 9775</u>                     |
| <u>NI 9229</u> | <u>NI 9237</u>                     | <u>NI 9250</u> |                                    |
| <u>NI 9230</u> | <u>NI 9238</u>                     | <u>NI 9251</u> |                                    |
| <u>NI 9231</u> | <u>NI 9239</u>                     | NI 9252        |                                    |

You can configure the rate at which the module acquires and returns data at edit time using the **C Series Module Properties** dialog box. You can programmatically change the data rate at run time using the <u>FPGA I/O Property Node</u>. The execution of an I/O Property Node that is configured with a **Data Rate** property overwrites the value you configured in the **C Series Module Properties** dialog box.

#### Configuring the Data Rate Using the C Series Module Properties Dialog Box

Complete the following steps to configure the data rate for the module using the **C** Series Module Properties dialog box.

- 1. <u>Configure the CompactRIO system</u>, and add the module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to launch the **C Series Module Properties** dialog box.
- 3. Select the rate from the **Data Rate** pull-down menu.
- 4. Click the **OK** button.
- 5. Select File»Save All in the Project Explorer window.

#### Configuring the Data Rate Using the FPGA I/O Property Node

Complete the following steps to configure the data rate for the module using the FPGA I/O Property Node.

- 1. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the module.
- 2. Click the **Property** section and select **Data Rate** from the shortcut menu.
- 3. Right-click the **Data Rate** input and select **Create»Control** from the shortcut menu.
- 4. On the front panel of the VI, select a rate from the **Data Rate** pull-down menu.

You can change the data rate at run time by writing to the control from the host VI. Refer to the module Getting Started (FPGA) VI at labview\examples\Compact RIO\Module Specific\<module>\<module> Getting Started for an example of configuring the data rate using the FPGA I/O Property Node.

#### Troubleshooting

The **Data Rate** property might return <u>error 65538</u> if the module is acquiring data. You must use the **Stop** channel to stop acquiring data before you can write properties to the module.

# Accessing TEDS Information from a Module (FPGA Interface)

The information in this topic applies to the following modules:

NI 9218

NI 9231

NI 9237

NI 9219

NI 9232

NI 9230

NI 9234

NI 9250

You can access Transducer Electronic Data Sheet (TEDS) information from TEDScompatible transducers connected to the channels of the module. You must enable TEDS support for the module before you can read TEDS information. You can access TEDS information only from the host VI.

# Enabling TEDS Support

Complete the following steps to enable TEDS support for the module.

- 1. Configure the CompactRIO system, and add the module.
- 2. Right-click the module in the **Project Explorer** window and select Properties to launch the C Series Module Properties dialog box.
- 3. Place a checkmark in the **Enable TEDS Support** checkbox.
- 4. Click the **OK** button.

The FPGA VI must have an FPGA I/O Node or an FPGA I/O Property Node that communicates with the module. If it does not, the LabVIEW FPGA Compile Server optimizes the VI when you compile it, and the host VI cannot communicate with the module.

# **Reading TEDS Information in the Host VI**

After you develop the FPGA VI and open a reference to it in the host VI, complete the following steps to read TEDS information from the module.

> **Note** The host VI cannot access TEDS information while the module is in acquisition mode. The module must exit acquisition mode before the host VI can access TEDS information.

- 1. Place an Invoke Method function on the block diagram.
- 2. Wire the **FPGA VI Reference Out** output of the <u>Open FPGA VI Reference</u> function to the **FPGA VI Reference In** input of the Invoke Method function.
- 3. Click **Method** on the Invoke Method function and select <u>Read TEDS</u> from the shortcut menu.
- Right-click the Slot or Connector input of the Invoke Method function and select Create»Constant or Create»Control from the shortcut menu. Configure the constant or control for the slot of the module. Valid slot values are 1 through N, where N is the number of slots in the chassis.
- 5. Right-click the **Channel** input of the Invoke Method function and select **Create**»**Constant** from the shortcut menu. Configure the constant for the channel on the module for which you want to read TEDS information.

| Modules | Valid Channel Values |  |
|---------|----------------------|--|
| NI 9218 | 0 through 1          |  |
| NI 9219 | 0 through 3          |  |
| NI 9230 | 0 through 2          |  |
| NI 9231 | 0 through 7          |  |
| NI 9232 | 0 through 2          |  |
| NI 9234 | 0 through 3          |  |
| NI 9237 | 0 through 3          |  |
| NI 9250 | 0 through 1          |  |

6. Add a TEDS\_Parse Binary TEDS VI, available on the **TEDS** palette, to the block diagram.



7. Add a TEDS\_Data to Table VI, available on the **TEDS** palette, to the block diagram.



8. Wire the **TEDS Binary** output of the Invoke Method function to the **binary TEDS array** input of the TEDS\_Parse Binary TEDS VI.

- 9. Wire the v0.9 (TEDS) output of the Invoke Method function to the v0.9 TEDS (F) input of the TEDS\_Data to Table VI.
- 10. Wire the **TEDS data out** output of the TEDS\_Parse Binary VI to the **TEDS data in** input of the TEDS\_Data to Table VI.

When you run the VI, LabVIEW reads the TEDS from the sensor, and the LabVIEW TEDS Toolkit parses the TEDS information and outputs it as a table.

I

**Note** You must enable error handling in the FPGA VI to receive consistent error messages in the host VI.

## Example

Refer to the module Getting Started (FPGA) VI at labview\examples\Compact RIO\Module Specific\<**module**>\<**module**> Getting Started for an example of how to access TEDS information.

# Understanding Loop Timing (FPGA Interface)

The following modules have an internal master timebase and are internally timed:

| <ul> <li>NI 9202</li> </ul> | <ul> <li>NI 9235</li> </ul> | <ul> <li>NI 9247</li> </ul> |
|-----------------------------|-----------------------------|-----------------------------|
| <ul> <li>NI 9225</li> </ul> | <ul> <li>NI 9236</li> </ul> | <ul> <li>NI 9250</li> </ul> |
| <ul> <li>NI 9227</li> </ul> | <ul> <li>NI 9237</li> </ul> | <ul> <li>NI 9251</li> </ul> |
| <ul> <li>NI 9229</li> </ul> | <ul> <li>NI 9238</li> </ul> | <ul> <li>NI 9252</li> </ul> |
| <ul> <li>NI 9230</li> </ul> | <ul> <li>NI 9239</li> </ul> | <ul> <li>NI 9253</li> </ul> |
| <ul> <li>NI 9231</li> </ul> | <ul> <li>NI 9242</li> </ul> | <ul> <li>NI 9260</li> </ul> |
| <ul> <li>NI 9232</li> </ul> | NI 9244                     | <ul> <li>NI 9770</li> </ul> |
| <ul> <li>NI 9234</li> </ul> | <ul> <li>NI 9246</li> </ul> | <ul> <li>NI 9775</li> </ul> |
|                             |                             |                             |

Do not use the <u>Loop Timer</u> or <u>Wait</u> functions in a loop with an <u>FPGA I/O Node</u> that acquires data from one of these modules.

When you create a loop that reads data from one of these modules, make sure the loop does not execute slower than the data rate of the module. If the loop execution time is slower than the data rate, the FPGA I/O Node returns an overrun warning and

continues to read data. The overrun warning means that the data the FPGA I/O Node returns is valid, but the function missed one or more data points since the last time it read data from the module. The function returns the overrun warning when all of the following conditions are true:

- The module is in acquisition mode.
- An FPGA I/O Node that is acquiring data from the module executes at least once after you put the module in acquisition mode.
- The FPGA I/O Node did not read one or more data points since the previous time the function executed.

If the application acquires multiple buffers of data from the module and the timing relationship between them is not important, you can ignore the overrun warning returned with the first point of each buffer.

#### Avoiding Overrun Warnings

To avoid overrun warnings, develop the FPGA VI to meet the following guidelines:

| Conditions                                                                                                              | Guidelines                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Your application acquires multiple buffers of da<br>ta from a module with an internal master timeb<br>ase.              | If the timing relationship between the buffers is<br>not important, you can ignore the overrun warni<br>ng returned with the first point of each buffer.                                                                                                                                                                                                                          |
| You are reading from multiple modules with an i<br>nternal master timebase in the same loop.                            | <ul> <li>Use one FPGA I/O Node to read the channels.</li> <li>Configure the modules to share a master timebase source and have the same data rate.</li> </ul>                                                                                                                                                                                                                     |
| You are reading from a module with an internal<br>master timebase and another analog input mod<br>ule in the same loop. | <ul> <li>If the rate at which you can acquire data from the other module is as fast or faster t han the data rate configured for the modu le with an internal master timebase, you c an read from both modules in the same lo op.</li> <li>If you use the same FPGA I/O Node to re ad data from all modules, the FPGA I/O No de does not return data for the other mod</li> </ul> |

ule until the module with an internal mast er timebase acquires data.

• If the other module has a slower data ra te than the module with an internal maste r timebase and you read from both modul es in the same loop, the FPGA I/O Node fo r the module with an internal master time base returns an overrun warning and cont inues reading data. To avoid missing data, you can either change the data rate of the module with an internal master timebase or read from each module in a different lo op.

#### NI 9201

CompactRIO 8-Channel, ±10 V, 12-Bit Analog Input Module

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

# NI 9201 Pinout





# **Related Topics**

Converting and Calibrating CompactRIO Analog Input Values

# NI 9201 (FPGA Interface)

CompactRIO 8-Channel, ±10 V, 12-Bit Analog Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9201 has AI channels 0 to<br>7. |

You can <u>configure the minimum time between conversions</u> and <u>understand</u> <u>scanning</u> for these channels.

# Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

Property

Description

| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>l. Use this value to <u>convert and calibrate</u> NI 9201<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>01 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x70A4.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9201/9221 (FPGA Interface)

Right-click an <u>NI 9201</u> or <u>NI 9221</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 16 bits and an integer word length of 5 bits for the NI 9201 and 7 bits for the NI 9221. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is Calibrated.

• Minimum Time Between Conversions—Specifies the <u>minimum time</u> <u>between conversions</u> in µs.

Configuring the Minimum Time Between Conversions for the NI 9201/9221 (FPGA Interface)

You can configure the minimum time between conversions for the <u>NI 9201/9221</u> in the <u>C Series Module Properties</u> dialog box.

Complete the following steps to configure the minimum time between conversions for the NI 9201/9221.

- 1. Configure the CompactRIO system, and add an NI 9201/9221.
- 2. Right-click the NI 9201/9221 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Enter a value between 0 and 10 μs in increments of 25 ns in the **Minimum Time Between Conversions** text box.
- 4. Click the **OK** button.
- 5. Select File»Save All in the Project Explorer window.

**Note** The default minimum time between conversions for the NI 9201 is 2 µs, and the default minimum time between conversions for

the NI 9221 is 1.25 μs. The accuracy specifications in the NI 9201 and NI 9221 hardware documentation on ni.com/manuals are based on these default values. Refer to the following tables for examples of how the value you enter in the

Minimum Time Between Conversions text box affects the actual time between conversions and the accuracy of the module.

Refer to the following table if you are using a chassis other than the NI 9151 R Series Expansion chassis.

| Module                     | Sampling Data<br>from a Single<br>or Multiple Channel<br>s? | Minimum Time<br>Between Conversio<br>ns <sup>*</sup> | Able to Achieve<br>Specified Time<br>Between Conversio<br>ns? <sup>**</sup> | Module Accuracy               |
|----------------------------|-------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------|-------------------------------|
| NI 9201                    | Single                                                      | ≥ 1.25 µs                                            | Yes                                                                         | Module accuracy n ot affected |
|                            |                                                             | < 1.25 µs                                            | No                                                                          | Module accuracy n ot affected |
| Multiple                   | ≥2 µs                                                       | Yes                                                  | Module accuracy n ot affected                                               |                               |
|                            |                                                             | < 2 µs                                               | No                                                                          | Module accuracy d<br>egrades  |
| NI 9221 Single<br>Multiple | ≥ 1.25 µs                                                   | Yes                                                  | Module accuracy n ot affected                                               |                               |
|                            |                                                             | < 1.25 µs                                            | No                                                                          | Module accuracy n ot affected |
|                            | Multiple                                                    | ≥ 1.25 µs                                            | Yes                                                                         | Module accuracy n ot affected |
|                            | < 1.25 µs                                                   | No                                                   | Module accuracy d<br>egrades                                                |                               |

Refer to the following table if you are using the NI 9151 R Series Expansion chassis.

| from a Single Between Conversio Specified Time | Module | Sampling Data<br>from a Single | Minimum Time<br>Between Conversio<br>ns <sup>*</sup> | Able to Achieve<br>Specified Time | Module Accuracy |
|------------------------------------------------|--------|--------------------------------|------------------------------------------------------|-----------------------------------|-----------------|
|------------------------------------------------|--------|--------------------------------|------------------------------------------------------|-----------------------------------|-----------------|

|                | or Multiple Channel       |                               | Between Conversio             |                               |
|----------------|---------------------------|-------------------------------|-------------------------------|-------------------------------|
|                | 5:                        |                               | ns?                           |                               |
| NI 9201 Single | ≥ 2.1 µs                  | Yes                           | Module accuracy n ot affected |                               |
|                |                           | < 2.1 µs                      | No                            | Module accuracy n ot affected |
|                | Multiple                  | ≥ 2.1 µs                      | Yes                           | Module accuracy n ot affected |
|                |                           | < 2.1 $\mu s$ and ≥ 2 $\mu s$ | No                            | Module accuracy n ot affected |
|                |                           | < 2 µs                        | No                            | Module accuracy d<br>egrades  |
| NI 9221 Single | ≥ 2.1 µs                  | Yes                           | Module accuracy n ot affected |                               |
|                |                           | < 2.1 µs                      | No                            | Module accuracy n ot affected |
| Multiple       | ≥2.1 µs                   | Yes                           | Module accuracy n ot affected |                               |
|                | < 2.1 µs and ≥ 1.25<br>µs | No                            | Module accuracy n ot affected |                               |
|                |                           | < 1.25 µs                     | No                            | Module accuracy d<br>egrades  |

<sup>\*</sup> The value you set in the **C Series Module Properties** dialog box.

<sup>\*\*</sup> The actual time between conversions depends on how you develop the FPGA VI. Y es indicates that it is possible to write an FPGA VI that can sustain the minimum time between conversions specified in the **C Series Module Properties** dialog box. No indicates that the minimum time between conversions specified in the **C Series Module Properties** dialog box is too low and you may not be able to write an FPGA VI that can sustain the specified time.

#### Understanding NI 9201/9221 Scanning (FPGA Interface)

To scan the channels of the <u>NI 9201/9221</u>, configure an <u>FPGA I/O Node</u> with the channels you want to acquire from the module. The module implements a pipeline that is automatically managed by the FPGA I/O Node. Channels within the FPGA I/O

Node are sampled in numerical order regardless of the order they appear in the node.

The first time an FPGA I/O Node configured with channels on an NI 9201/9221 module executes, the module performs two setup conversions before converting the first channel. The two setup conversions prime the pipeline for subsequent FPGA I/O Node reads. The module does not repeat the setup conversions unless the FPGA I/O Node channel configuration changes and the pipeline needs to be primed again.

## NI 9201 (Scan Interface)

CompactRIO 8-Channel, ±10 V, 12-Bit Analog Input Module

📄 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9201 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9201, <b>x</b> is 0 to 7. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9201. Right-click the NI 9201 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

#### NI 9202

CompactRIO 16-Channel, 24-Bit Differential Analog Input Module

#### Software Reference (?)

FPGA Interface

NI 9202

# NI 9202 Pinout

| f     |           | 1     |
|-------|-----------|-------|
| AI0+  |           | A10-  |
| Al1+  | 2022000   | AI1-  |
| AI2+  | 1032101   | A12-  |
| AI3+  | 10422     | A13-  |
| AI4+  | 1052301   | A14-  |
| AI5+  | 1062400   | A15-  |
| AI6+  | 127252    | A16-  |
| A17+  | 0082600   | AI7-  |
| AI8+  | 2019/2701 | A18-  |
| A19+  | 102800    | A19-  |
| AI10+ | 20112901  | AI10- |
| AI11+ | 12123000  | AI11- |
| AI12+ | 10133100  | AI12- |
| AI13+ | 00143200  | AI13- |
| AI14+ | 30153300  | AI14- |
| AI15+ | 163450    | AI15- |
| COM   | 10173501  | COM   |
| NC    |           | NC    |
| Ę     |           | -     |



# **Related Topics**

FPGA Interface
<u>C Series Module Properties Dialog Box</u>
<u>Converting and Calibrating CompactRIO Analog Input Values</u>
<u>Detecting Out-of-Range Channels for CompactRIO Analog Input Channels</u>
<u>Acquiring Data from a Module</u>
<u>Configuring the Data Rate for a Module (FPGA Interface)</u>
<u>Converting NI 9202 Data</u>
<u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9202/9260 Modules</u>
<u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9202 (FPGA Interface)

CompactRIO 16-Channel, 24-Bit Differential Analog Input Module

🔊 Open example

🔍 Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9202 has channels 0 to 15                                                                                                                                                                                     |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The onboard clock frequency i<br>s 12.8 MHz. Use the FPGA I/O Node in a <u>single-cy</u><br><u>cle timed loop</u> to access this channel. You must<br><u>export the onboard clock of the NI 9202</u> to acces<br>s this channel. |

| Start | Channel that controls when the NI 9202 starts a cquiring data. If TRUE is written to the <b>Start</b> cha nnel, the NI 9202 starts acquiring data. When th e NI 9202 is acquiring data, you must write TRUE to the <b>Stop</b> channel before you can access prop erties for the module. If FALSE is written to the <b>S</b> tart channel, no operation is performed.                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop  | Channel that controls when the NI 9202 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9202 stops acquiring data. When the<br>NI 9202 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |

# Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property                | Description                                                                             |
|-------------------------|-----------------------------------------------------------------------------------------|
| Data Rate               | Sets the rate at which the NI 9202 acquires data.                                       |
| Module ID               | Returns the module ID, 0x788C for the spring ter minal and 0x788A for the DSUB variant. |
| Serial Number           | Returns the unique serial number of the module .                                        |
| Vendor ID               | Returns the NI vendor ID, 0x1093.                                                       |
| Input Delay             | Returns the filter delay based on the data rate a nd filter setting.                    |
| Filter Frequency Config | Sets the frequency of the first notch in the filter response.                           |



**Note** Changes to the filter settings apply to all channels.

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9202 (FPGA Interface)

Right-click an <u>NI 9202</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. The fixed-point data is signed, with 24-bits word length and 4-bits integer word length. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must <u>convert</u> the binary data to the actual analog input values in the host VI. In Raw mode, you also need to apply some gain correction constants for some data rates. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

• Filter Frequency Config—Sets the frequency of the first notch in the filter response. Setting changes apply to all channels. Available values:

- Data Rate/1
- Data Rate/2
- Data Rate/4
- Data Rate/8
- Data Rate/16

Converting NI 9202 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9202</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module.

Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI as demonstrated in the labview\examples\CompactRIO \Module Specific\NI 9202\NI 9202 Scaling\NI 9202 Raw To Sc aled.lvproj.

The binary values are not uniform across data rates. Therefore, to get the **Corrected Raw**, multiply the binary value with the **Gain Correction** with respect to the data rate used as demonstrated in the labview\examples\CompactRI O\Module Specific\NI 9202\NI 9202 Raw Correction\NI 9202 R aw Correction.lvproj.

Open example (NI 9202 Raw To Scaled) Open example (NI 9202 Raw Correction)

| Data Rates <sup>[1]</sup> | Scaling                                  | Gain Correction                                     |
|---------------------------|------------------------------------------|-----------------------------------------------------|
| 10 kS/s, 5 kS/s           | Volts = Binary Value × 2018176<br>pV/LSB | Corrected Binary Value = Bina<br>ry Value × 1.6     |
| 60 S/s <sup>[2]</sup>     | Volts = Binary Value × 1356704<br>pV/LSB | Corrected Binary Value = Bina<br>ry Value × 1.07563 |

| 400 S/s, 200 S/s, 100 S/s, 10 S/s <sup>[</sup>                      | <b>Volts = Binary Value</b> × 1291512<br>pV/LSB | Corrected Binary Value = Bina<br>ry Value × 1.024    |
|---------------------------------------------------------------------|-------------------------------------------------|------------------------------------------------------|
| 2 kS/s, 1 kS/s, 500 S/s, 250 S/s,<br>125 S/s, 50 S/s <sup>[2]</sup> | <b>Volts = Binary Value</b> × 1614448<br>pV/LSB | Corrected Binary Value = Bina<br>ry Value × 1.28     |
| 60 S/s <sup>[3]</sup>                                               | Volts = Binary Value × 2274057<br>pV/LSB        | Corrected Binary Value = Bina<br>ry Value × 1.802817 |
| 10 S/s <sup>[3]</sup> , 50 S/s <sup>[3]</sup> , Others              | Volts = Binary Value × 1261244<br>pV/LSB        | Corrected Binary Value = Bina<br>ry Value × 1        |

where

**Binary Value** is the value returned by the FPGA I/O Node.

<sup>1</sup> The actual data rate changes with the master timebase when using an external master timebase. In order to provide power line frequency rejection when using master timebase frequencies of both 12.8 MHz and 13.1072 MHz, there are two sets of settings for the data rates of 10 S/s, 50 S/s and 60 S/s. Refer to the following footnotes for the correct scaling constants and gain corrections, depending on your master timebase frequency.

<sup>2</sup> Data rates setting when using internal master timebase or an external master timebase of 12.8 MHz.

<sup>3</sup> Data rates setting when using an external master timebase of 13.1072 MHz.

NI 9203

CompactRIO 8-Channel, ±20 mA, 16-Bit Analog Input Module

Software Reference (?)

FPGA Interface | Scan Interface

## NI 9203 Pinout



# **Related Topics**

Converting and Calibrating CompactRIO Analog Input Values

# NI 9203 (FPGA Interface)

CompactRIO 8-Channel, ±20 mA, 16-Bit Analog Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| Alx | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9203 has AI channels 0 to<br>7. |
|-----|------------------------------------------------------------------------------------------------------------------------|
|-----|------------------------------------------------------------------------------------------------------------------------|

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method          | Description                                                                                                                                                                  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Input Range | Sets the input range for a channel as either 0–20 mA or ±20 mA. This method overwrites the valu e you configure in the <u>C Series Module Propertie</u> <u>s</u> dialog box. |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property                   | Description                                                                                                                                                                                                                                                                   |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±20 mA range)  | Returns the LSB weight in pA/LSB for the chann<br>el. Use this value to <u>convert and calibrate</u> NI 920<br>3 data if you set the <b>Calibration Mode</b> to <b>Raw</b><br>in the <u>C Series Module Properties</u> dialog box, an<br>d you set the input range to ±20 mA. |
| LSB Weight (4–20 mA range) | Returns the LSB weight in pA/LSB for the chann<br>el. Use this value to convert and calibrate NI 920<br>3 data if you set the <b>Calibration Mode</b> to <b>Raw</b><br>in the <b>C Series Module Properties</b> dialog box<br>, and you set the input range to 0–20 mA.       |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property               | Description                                                                                                                                                                                                                                                                              |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module ID              | Returns the module ID, 0x7129.                                                                                                                                                                                                                                                           |
| Offset (±20 mA range)  | Returns the calibration offset in pA for the chan<br>nel. Use this value to <u>convert and calibrate</u> NI 92<br>03 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <u>C Series Module Properties</u> dialog box,<br>and you set the input range to ±20 mA. |
| Offset (4–20 mA range) | Returns the calibration offset in pA for the chan<br>nel. Use this value to convert and calibrate NI 92<br>03 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox, and you set the input range to 0–20 mA.      |
| Serial Number          | Returns the unique serial number of the module .                                                                                                                                                                                                                                         |
| Vendor ID              | Returns the NI vendor ID, 0x1093.                                                                                                                                                                                                                                                        |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9203 (FPGA Interface)

Right-click an <u>NI 9203</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of amps. The fixed-point data is signed, with a word length of 21 bits and an integer word length of –4 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• Minimum Time Between Conversions—Specifies the minimum time between conversions in µs.

• Channel Configuration—Specifies the input range for each channel.

• **Channels**—Specifies the channel(s) for which you want to select the input range.

• Input Range—Specifies the input range for the selected channel(s) as either 0–20 mA or ±20 mA.

#### NI 9203 (Scan Interface)

CompactRIO 8-Channel, ±20 mA, 16-Bit Analog Input Module

🔊 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in amps.

#### **Module Channels**

The NI 9203 has the following channels.

Channel

Description

Analog input channel **x**, where **x** is the number of the channel. For the NI 9203, **x** is 0 to 7.

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9203. Right-click the NI 9203 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

• **Channel Configuration**—You can specify the input range for each channel.

• **Channels**—Specifies the channel(s) for which you want to select the input range.

• Input Range—Specifies the input range for the selected channel(s) as either 0–20 mA or ±20 mA.

#### NI 9205

CompactRIO 32-Channel Single-Ended/16-Channel Differential, ±200 mV to ±10 V, 16-Bit Analog Input Module

Software Reference (?)

🔁 FPGA Interface | 🞯 Scan Interface

|       | $\square$ |          | 2     |
|-------|-----------|----------|-------|
|       |           |          | 7     |
|       |           |          |       |
| A10   |           |          | A10   |
| Alt   | 21        | 0 2 200  | AIO   |
| A12   |           | 0 2 20   | Alto  |
| A12   | 22        | 0 4 22 0 | Alti  |
| ALA   | 0         | 0 5 22 0 | A112  |
| A15   | 1         | 6 6 24 6 | A112  |
| AIG   |           | 0 7 25 0 | Alta  |
| AI7   | 8         | 0 9 250  | Alts  |
| Alte  |           | 0 0 27 0 | Alla  |
| Alto  | 8         | 010200   | AIDE  |
| A110  | 13        | 011200   | Allog |
| Alto  | 8         | 011290   | A120  |
| Allao |           | 012300   | AIDR  |
| AI20  | 2         | 014 22 0 | A120  |
| A122  | 3         | 015 33 0 | A120  |
| A100  | 2         | 015 33 0 | A130  |
| COM   | 2         | 017 25 0 | AIST  |
| DOO   | 8         | 017 350  | DEIO  |
| 000   |           |          | PERO  |
|       |           |          |       |
|       |           |          |       |
| 1     |           |          | 7     |

NI 9205 Pinout



# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels IO Sample Method Set Terminal Mode Method Set Triggers Method Set Voltage Range Method Conversion Timing for the NI 9205/9206 Self-Calibration for the NI 9205/9206

# NI 9205 (FPGA Interface)

CompactRIO 32-Channel Single-Ended/16-Channel Differential, ±200 mV to ±10 V, 16-Bit Analog Input Module

📄 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9205 has AI channels 0 to<br>31. The channel is sampled using the currently c<br>onfigured terminal mode and voltage range. Yo<br>u can configure these settings at edit time using<br>the <u>C Series Module Properties</u> dialog box or at r<br>un time using the <u>Set Terminal Mode</u> or <u>Set Volt</u><br><u>age Range</u> methods. |
| D10      | Digital input channel used to access the module<br>digital line, which is labeled PFI0. This terminal i<br>s not available for an onboard NI 9205 on a <u>Singl</u><br><u>e-Board RIO</u> (sbRIO) device.                                                                                                                                                                                                                            |
| Trig     | Returns the output of the module trigger circuit<br>ry. Use the <u>Set Triggers</u> method to configure the<br>trigger circuit.                                                                                                                                                                                                                                                                                                      |
| DO0      | Digital output channel 0. This terminal is not av<br>ailable for an onboard NI 9205 on an sbRIO devi<br>ce.                                                                                                                                                                                                                                                                                                                          |

Refer to the <u>Conversion Timing</u> topic for information about the order and timing of conversions for these I/O channels.

# Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method           | Description                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <u>IO Sample</u> | Acquires a single sample from the module. The<br>channel number, terminal mode, and voltage ra<br>nge are all configurable at run time.                                                                                                                                                                                                                                                                        |  |
|                  | Note NI suggests that<br>you do not configure th<br>e VI to run an IO Sampl<br>e method and another<br>FPGA I/O Method Node<br>in parallel when both a<br>re targeted to the same<br>C Series module. Simil<br>arly, NI suggests that y<br>ou do not configure th<br>e VI to run multiple IO<br>Sample methods in par<br>allel when the IO Samp<br>le methods are targete<br>d to the same C Series<br>module. |  |
|                  | Refer to the NI 9205 Basic IO VI and the NI 9205<br>Advanced IO VI in the labview\examples\C<br>ompactRIO\Module Specific\NI 9205<br>\NI 9205 Basic IO\NI 9205 Basic<br>IO.lvproj and labview\examples\Com<br>pactRIO\Module Specific\NI 9205\N<br>I 9205 Advanced IO\NI 9205 Advan<br>ced IO.lvproj for examples related to this<br>method.                                                                   |  |
|                  | 🔊 Open example (NI 9205 Basic IO)                                                                                                                                                                                                                                                                                                                                                                              |  |
|                  | 📄 Open example (NI 9205 Advanced IO)                                                                                                                                                                                                                                                                                                                                                                           |  |

| Restore Last External Calibration Constants | Restores the calibration constants of the modul<br>e to the factory values. You must enable <u>self-cali</u><br><u>bration</u> on the <u>C Series Module Properties</u> dialo<br>g box to use this method.                                                         |                                                                                                                                                                   |  |
|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                             |                                                                                                                                                                                                                                                                    | <b>Caution</b> The Restore<br>Last External Calibratio<br>n Constants method n<br>ode must be used with<br>the example VI to prev<br>ent damaging the mod<br>ule. |  |
|                                             | Refer to the NI 9205 Sel<br>bview\examples\C<br>Specific\NI 9205\<br>ibration\NI 9205<br>n.lvproj for an exan                                                                                                                                                      | f-Calibration VI in the la<br>CompactRIO\Module<br>NI 9205 Self Cal<br>5 Self Calibratio<br>nple of using this method                                             |  |
| <u>Set Terminal Mode</u>                    | Sets the terminal mode<br>erenced single-ended),<br>ngle-ended ), or DIFF (d<br>overwrites the value yo<br>es Module Propertie                                                                                                                                     | e for a channel as RSE (ref<br>NRSE (non-referenced si<br>lifferential). This method<br>ou configure in the <b>C Seri</b><br><b>s</b> dialog box.                 |  |
| <u>Set Triggers</u>                         | <ul> <li>Sets the trigger output to one of the following v alues:</li> <li>None</li> <li>AI Below Low</li> <li>AI Above High</li> <li>AI Inside Region</li> <li>AI Below Low with Hysteresis</li> <li>AI Above High with Hysteresis</li> <li>DI Trigger</li> </ul> |                                                                                                                                                                   |  |
|                                             | ev                                                                                                                                                                                                                                                                 | <b>Note</b> The onboard NI<br>9205 on sbRIO devices                                                                                                               |  |
|                                     | does not support DI tri<br>ggering.<br>Refer to the NI 9205 Basic Triggering VI and the<br>NI 9205 Advanced Triggering VI in the labview<br>\examples\CompactRIO\Module Spec<br>ific\NI 9205\NI 9205 Basic Trigge<br>ring\NI 9205 Basic Triggering.lv<br>proj and labview\examples\CompactR<br>IO\Module Specific\NI 9205\NI 920<br>5 Advanced Triggering\NI 9205 Ad<br>vanced Triggering.lvproj for example<br>s related to this method.<br>Open example (NI 9205 Basic Triggering)<br>Open example (NI 9205 Advanced Triggering<br>)                                                          |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>Set Voltage Range</u>            | Sets the input range for a channel as ±10 V, ±5 V,<br>±1 V, or ±200 mV. This method overwrites the val<br>ue you configure in the <b>C Series Module Prop</b><br><b>erties</b> dialog box.                                                                                                                                                                                                                                                                                                                                                                                                      |
| Write<br>Self-Calibration Constants | <ul> <li>Replaces the calibration constants of the modul e with new values. You must enable <u>self-calibrat</u> ion on the <u>C Series Module Properties</u> dialog bo x to use this method.</li> <li>Self-Calibration Constants—Contain s offset and gain constants for the analog i nput ranges of the module.</li> <li>Caution The Write Sel f-Calibration Constants method node must be used with the example VI to prevent damaging the module.</li> <li>Refer to the NI 9205 Self-Calibration VI in the la bview\examples\CompactRIO\Module Specific\NI 9205 Self Calibration</li> </ul> |

n.lvproj for an example of using this method

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

.

| Property                    | Description                                                                                                                                                                                                                                                                                                         |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Linearization Coefficient x | (Optional) NI-MCal linearization coefficient x, w<br>here <b>x</b> is the number of the linearization coeffici<br>ent. The NI 9205 has linearization coefficients 3 t<br>o 0. You can use these coefficients in calibration<br>to compensate for some types of measurement<br>nonlinearity inherent in this device. |
|                             | O Node, the Linearization Coefficients are not us<br>ed to calculate the calibrated data. This means t<br>hat calibrated data returned in FPGA does not c<br>ompensate for the measurement nonlinearities<br>in the device.                                                                                         |
|                             | Refer to the NI 9205 Advanced IO VI in the labv<br>iew\examples\CompactRIO\Module S<br>pecific\NI 9205\NI 9205 Advanced<br>IO\NI 9205 Advanced IO.lvproj for a<br>n example of this concept.                                                                                                                        |
| LSB Weight (±10 V range)    | Returns the LSB weight in pV/LSB for the ±10 V r<br>ange. Use this value to <u>convert and calibrate</u> NI<br>9205 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <u>C Series Module Properties</u> dialog box                                                                        |

| LSB Weight (±1 V range)    | Returns the LSB weight in pV/LSB for the ±1 V ra<br>nge. Use this value to convert and calibrate NI 9<br>205 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox.      |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±200 mV range) | Returns the LSB weight in pV/LSB for the ±200 m<br>V range. Use this value to convert and calibrate<br>NI 9205 data if you set the <b>Calibration Mode</b> t<br>o <b>Raw</b> in the <b>C Series Module Properties</b> dia<br>log box.           |
| LSB Weight (±5 V range)    | Returns the LSB weight in pV/LSB for the ±5 V ra<br>nge. Use this value to convert and calibrate NI 9<br>205 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox.      |
| Module ID                  | Returns the module ID, 0x712A (NI 9205 with DS UB) or 0x71EA (NI 9205 with spring terminal).                                                                                                                                                    |
| Offset (±10 V range)       | Returns the calibration offset in nV for the ±10 V<br>range. Use this value to <u>convert and calibrate</u> NI<br>9205 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <u>C Series Module Properties</u> dialog box |
| Offset (±1 V range)        | Returns the calibration offset in nV for the ±1 V r<br>ange. Use this value to convert and calibrate NI<br>9205 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <b>C Series Module Properties</b> dialog<br>box.    |
| Offset (±200 mV range)     | Returns the calibration offset in nV for the ±200 mV range. Use this value to convert and calibrat e NI 9205 data if you set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Series Module Properties</b> di alog box.                    |
| Offset (±5 V range)        | Returns the calibration offset in nV for the ±5 V r<br>ange. Use this value to convert and calibrate NI<br>9205 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <b>C Series Module Properties</b> dialog<br>box.    |

| Serial Number | Returns the unique serial number of the module . |
|---------------|--------------------------------------------------|
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9205/9206 (FPGA Interface)

Right-click an <u>NI 9205</u> or <u>NI 9206</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 26 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• Channel Configuration—Specifies the input range for each channel.

• **Channels**—Specifies the channel(s) for which you want to select the input range.

 Input Range—Specifies the input range for the selected channel(s) as ±10 V, ±5 V, ±1 V, or ±200 mV.

• **Terminal Mode**—Specifies the terminal mode for the selected channel(s) as RSE (referenced single-ended), NRSE (non-referenced single-ended ), or DIFF (differential).

 Minimum Time Between Conversions—Specifies the <u>minimum time</u> between conversions in µs.

• Enable Advanced Self-Calibration Nodes—Place a checkmark in this checkbox if you want to enable <u>Self-Calibration</u> support in the FPGA for this module.

#### IO Sample Method (FPGA Interface)

This module method acquires a single sample from the module. The channel number, terminal mode, and voltage range are all configurable at run time. You use this module method by selecting it in an <u>FPGA I/O Method Node</u> that is configured for the appropriate device and/or channel. <u>Details Examples</u>

**Note** NI suggests that you do not configure the VI to run an IO Sample method and another FPGA I/O Method Node in parallel when both are targeted to the same C Series module. Similarly, NI suggests that you do not configure the VI to run multiple IO Sample methods in parallel when the IO Sample methods are targeted to the same C Series module. U16 | Configuration [i+2] contains encoded configuration information that gets loaded into the module conversion pipeline. This configuration information controls the data to be sampled two iterations into the future. Refer to the Conversion Timing topic for more information. Refer to the Configuration Encoding table below for an example of how the configuration information is encoded. 116 Data [i] Returns the data from the current sample.

error in describes error conditions that occur before this VI or function runs. The default is no error. If an error occurred before this VI or function runs, the VI or function passes the error in value to error out. This VI or function runs normally only if no error occurred before this VI or function runs. If an error occurs while this VI or function runs, it runs normally and sets its own error status in error out. Use error in and error out to check errors and to specify execution order by wiring error out from one node to error in of the next node.

#### TFI

132

abc

status is TRUE (X) if an error occurred before this VI or function ran or FALSE (checkmark) to indicate a warning or that no error occurred before this VI or function ran. The default is FALSE.

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

**source** always contains an empty string because strings are not supported in LabVIEW FPGA.

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the



same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the **error out** indicator on the front panel and select **Explain Error** from the shortcut menu for more information about the error.



## **Configuration Encoding Table**

The following table describes how to construct the Configuration [i+2] value to write to the IO Sample method to perform a particular operation. The **Operation** column lists the types of operations that can be performed using the IO Sample method. The **Configuration Bit Fields** column lists the bit positions within the **Configuration** [i+2] number that need to be set. The **Values** column specifies the binary value to apply to the specified **Configuration Bit Fields**.

| Operation | Configuration Bit Fields | Values |
|-----------|--------------------------|--------|
| AI Read   | 15:13                    | 001b   |

| 12:11<br>10:8 | 12:11 | 01b for channels 0-15<br>10b for channels 16-31                                                                                                                |
|---------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 10:8  | 000b for channels 0, 8, 16, or 24<br>001b for channels 1, 9, 17, or 25<br><br>110b for channels 6, 14, 22, or 3<br>0<br>111b for channels 7, 15, 23, or 3<br>1 |
|               | 7:6   | 00b                                                                                                                                                            |
|               | 5:4   | 00b for NRSE mode<br>11b for RSE or DIFF modes                                                                                                                 |
| 3:2           | 3:2   | 11b for channels 8-15 or 24-31<br>01b for DIFF mode on channels<br>0-7 or 16-23<br>10b for RSE or NRSE mode on c<br>hannels 0-7 or 16-23                       |
|               | 1:0   | 00b for ±10 V<br>01b for ±5 V<br>10b for ±1 V<br>11b for ±200 mV                                                                                               |
| DI0 Read      | 15:0  | 000000000000000b                                                                                                                                               |
| DO0 Write     | 15:1  | 01000000000000b                                                                                                                                                |
|               | 0     | Binary value to write to DO0                                                                                                                                   |

## **Using This Method**

The IO Sample method provides an efficient and flexible interface to the module. You can use this method to acquire a single sample from any of the channels on the module, at any range, and with any available input mode.

When this method is executed, the module performs a single conversion on the next channel present in the conversion pipeline on the module. The data from this conversion is returned via the **Data** [i] method output. At the same time that the conversion data is read from the module, the new configuration information specified by the **Configuration** [i+2] input is loaded into the configuration pipeline on the module. The pipeline is two samples deep. So, the configuration information specified on one execution of the IO Sample method determines which channel will

be sampled by the IO Sample method two iterations into the future. Refer to the <u>Conversion Timing</u> topic for more details.

### **Examples**

Refer to the NI 9205 Basic IO VI and the NI 9205 Advanced IO VI in the labview\ex amples\CompactRIO\Module Specific\NI 9205\NI 9205 Basic IO \NI 9205 Basic IO.lvproj and labview\examples\CompactRIO\M odule Specific\NI 9205\NI 9205 Advanced IO\NI 9205 Advance d IO.lvproj for examples of the IO concepts discussed above.

Open example (NI 9205 Basic IO)

Open example (NI 9205 Advanced IO)

#### Set Terminal Mode Method (FPGA Interface)

Overrides the default setting provided in the <u>C Series Module Properties</u> dialog box. You use this module method by selecting it in an <u>FPGA I/O Method Node</u> that is configured for the appropriate device and/or channel.

U8 |

Al Channel is the channel you want to set the terminal mode for.

**Terminal Mode** is an enumeration of the following trigger modes:

- **RSE** is a single-ended measurement between any of the 32 individual channels and the module ground.
- **NRSE** is a single-ended measurement between any of the 32 individual channels and the AISENSE line into the module.
- **DIFF** is a differential measurement between two of the 32 individual channels, with the name of the differential channel matching the channel tied to the positive side of the differential measurement. Channels AI0 to AI7, and

Al16 to Al23 may be set to DIFF configuration.

error in describes error conditions that occur before this VI or function runs. The default is no error. If an error occurred before this VI or function runs, the VI or function passes the error in value to error out. This VI or function runs normally only if no error occurred before this VI or function runs. If an error occurs while this VI or function runs, it runs normally and sets its own error status in error out. Use error in and error out to check errors and to specify execution order by wiring error out from one node to error in of the next node.

TF

status is TRUE (X) if an error occurred before this VI or function ran or FALSE (checkmark) to indicate a warning or that no error occurred before this VI or function ran. The default is FALSE. code is the error or warning code. The default is 0. If status is

TRUE, **code** is a nonzero <u>error code</u>. If **status** is FALSE, **code** is 0 or a warning code.

**source** always contains an empty string because strings are not supported in LabVIEW FPGA.



abc

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the error out indicator on the front panel and select Explain Error from the shortcut menu for more information about the error.

TF status is TRUE (X) if an error occurred or FALSE (checkmark) to indicate a warning or that no error occurred. 132 code is the error or warning code. If status is TRUE, code is a nonzero error code. If **status** is FALSE, code is 0 or a warning code. abc source always contains an empty string because strings are not supported in LabVIEW FPGA.

#### Set Triggers Method (FPGA Interface)

This module method controls the data returned by the trigger digital input line. You use this module method by selecting it in an <u>FPGA I/O Method Node</u> that is configured for the appropriate device and/or channel. <u>Details Examples</u>

**Trigger Mode** is an enumeration of the following trigger mode options:

• None disables the trigger function.

• Al Below Low detects when the analog signal is below the low threshold you specify.

• Al Above High detects when the analog signal is above the high threshold you specify.

• Al Inside Region detects when the analog signal is between the high and low thresholds you specify.

• Al Below Low with Hysteresis asserts the trigger when the signal starts above the high threshold you specify and then crosses below the low threshold you specify. The trigger deasserts when the signal crosses above the high threshold you specify.

Al Above High with Hysteresis
 asserts the trigger when the signal starts
 below the low threshold you specify and
 then crosses above the high threshold you
 specify. The trigger deasserts when the
 signal crosses below the low threshold
 you specify.

• **DI Trigger** detects when the digital signal on PFI0 is logic high.

|     | - | - | -   |    |
|-----|---|---|-----|----|
|     |   |   |     |    |
|     | - | - | -   | æ  |
|     |   |   | -   |    |
| . 1 |   | - | -   | Б. |
|     |   |   | - 3 | а. |
|     |   | - | 45  |    |
|     |   |   |     | _  |
|     |   |   | ~   |    |
|     |   |   |     |    |

Note The onboard NI 9205 on <u>Single-Board</u> <u>RIO</u> (sbRIO) devices does not support DI triggering.

Al High Threshold defines the upper threshold for the analog trigger circuit.

AI Low Threshold defines the lower threshold for the analog trigger circuit.



**I16** 

error in describes error conditions that occur before this VI or function runs. The default is no error. If an error occurred before this VI or function runs, the VI or function passes the error in value to error out. This VI or function runs normally only if no error occurred before this VI or function runs. If an error occurs while this VI or function runs, it runs normally and sets its own error status in error out. Use error in and error out to check errors and to specify execution order by wiring error out from one node to error in of the next node.

TF

132

abc

**status** is TRUE if an error occurred. If **status** is TRUE, the VI does not perform any operations.

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

source always contains an empty string because strings are not supported in LabVIEW FPGA.

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the error out indicator on



[57]

the front panel and select **Explain Error** from the shortcut menu for more information about the error.



## Using This Method

Use the Set Triggers Method to configure the trigger circuit on the module. Once the trigger circuit is configured, use an FPGA I/O Node configured to access the Trig channel to monitor the output of the trigger circuit. The trigger circuit does not automatically initiate any conversions on the module. It is up to the FPGA VI to monitor the Trig line, and then initiate a conversion using an FPGA I/O Node or the IO Sample method when the appropriate trigger event occurs.

Perform the following steps to trigger an acquisition using the Set Triggers Method:

1. Ensure that the module pipeline is primed with the next two channels that you want to sample after the trigger event. This step will minimize the delay between the trigger event and the AI channels getting sampled. For analog triggering modes, this step also configures the analog trigger circuitry to monitor the desired channel. The AI trigger circuit monitors the channel waiting in the module pipeline for the next conversion.

If you are using FPGA I/O Nodes to perform the acquisition, this step can be accomplished by executing an FPGA I/O Node configured to match the FPGA I/O Node that you will be executing after the trigger event. If you are using one of the analog triggering modes along with the FPGA I/O Nodes, the AI trigger circuit will operate on the lowest numbered channel present in the FPGA I/O Node.

Refer to the <u>IO Sample</u> method and <u>Conversion Timing</u> topics for more information on managing the module pipeline using the IO Sample method. If you are using one of the analog trigger modes along with the IO Sample method, the AI trigger circuit will operate on the channel waiting in the pipeline to be converted by the next IO Sample method.

- 2. Execute the <u>Set Triggers</u> method with the appropriate trigger mode selected. The trigger mode circuitry is implemented in the hardware as you specify in this method. Refer to the NI 9205 and NI 9206 hardware documentation on ni.com/manuals for more information about the trigger modes.
- 3. Monitor the Trig channel in a loop until you see the appropriate trigger condition occur.
- 4. Execute an FPGA I/O Node or IO Sample method function to acquire data in response to the trigger event.

### **Examples**

Refer to the NI 9205 Basic Triggering VI and the NI 9205 Advanced Triggering VI in the labview\examples\CompactRIO\Module Specific\NI 9205\NI 920 5 Basic Triggering.lvproj and lab view\examples\CompactRIO\Module Specific\NI 9205\NI 9205 A dvanced Triggering\NI 9205 Advanced Triggering.lvproj for examples of the triggering concepts discussed above.

Open example (NI 9205 Basic Triggering)

Open example (NI 9205 Advanced Triggering)

#### Set Voltage Range Method (FPGA Interface)

This module method overrides the default setting provided in the <u>C Series Module</u> <u>Properties</u> dialog box. You use this module method by selecting it in an <u>FPGA I/O</u> <u>Method Node</u> that is configured for the appropriate device and/or channel.

Al Channel is the channel you want to set the voltage range for.

**Voltage Range** is an enumeration of the following voltage ranges:

- ±10 V
- ±5 V
- ±1 V
- ±200 mV

error in describes error conditions that occur before this VI or function runs. The default is no error. If an error occurred before this VI or function runs, the VI or function passes the error in value to error out. This VI or function runs normally only if no error occurred before this VI or function runs. If an error occurs while this VI or function runs, it runs normally and sets its own error status in error out. Use error in and error out to check errors and to specify execution order by wiring error out from one node to error in of the next node.

TF

132

**status** is TRUE if an error occurred. If **status** is TRUE, the VI does not perform any operations.

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u>

[55]

U8 |

<u>code</u>. If status is FALSE, code is 0 or a warning code.

**source** always contains an empty string because strings are not supported in LabVIEW FPGA.

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the error out indicator on the front panel and select Explain Error from the shortcut menu for more information about the error.

TF

132

abc

status is TRUE if an error occurred. If status is TRUE, the VI does not perform any operations.

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

**source** always contains an empty string because strings are not supported in LabVIEW FPGA.

abc



Conversion Timing for the NI 9205/9206 (FPGA Interface)

#### <u>Example</u>

The <u>NI 9205</u> and <u>NI 9206</u> modules implement a two-element deep pipeline for access to the AI, DIO, and DOO channels. This pipeline results in maximum sample rate and maximum sample quality. The Trig channel has a parallel data path that bypasses the pipeline.

When using the <u>FPGA I/O Node</u> to sample channels, the pipeline is automatically managed by the FPGA I/O Node, and the channels within the FPGA I/O Node are sampled in numerical order regardless of the order they appear in the node.

If the first two channel requests in the FPGA I/O Node do not match the two channel requests stored in the module pipeline, there will be a delay before the first channel sample occurs. This delay is caused by the FPGA I/O Node automatically updating the module channel sample pipeline, which takes two channel sample cycles.

To minimize the need for the pipeline updates, each FPGA I/O Node leaves the module pipeline primed to repeat itself. If you use only one FPGA I/O Node in a looping structure, only the first iteration of the loop will incur the two-cycle time delay. All subsequent iterations operate with no delay.

When using the <u>IO Sample</u> method, you must take steps to manage this pipeline in the VIs.

To read one channel, that channel configuration must be requested two cycles before the time it is to be sampled. The U16 configuration value for an AI channel sample contains the channel number, channel input range, and terminal mode. The U16 configuration value also can represent an access to the DIO or DOO channels, which is treated the same as an AI operation.

The following diagram illustrates how the pipeline works within a sequence structure. A typical application would use a loop structure to iterate through a scan list, which is a predefined list of configurations, continuously. The sequence structure and art elements show how data moves into the NI 9205/9206 pipeline and then is converted. Note that the IO Sample method first converts the configuration that is in the ADC, and then shifts the configuration values through the pipeline to prepare for the next time LabVIEW calls the IO Sample method.



The simplest form of pipeline management is to force the pipeline on every set of samples. This assumes that the pipeline is always wrong at the first sample, and sends all IO Sample requests in order. The last two data points need some configuration to be requested, but it does not matter, in this use case, what configuration that is.

A better form of pipeline management emulates the behavior of the FPGA I/O Node. Instead of always assuming that the pipeline is wrong, you choose the last two configuration values based on the first two samples you want to include in the next iteration. This pipeline management system can be accomplished in two parts: initialization and sample iteration.

ନ୍ତୁ

Тір

NI recommends you use the IO Sample method for the following reasons:

> Smaller on FPGA—With large channel count, the IO Sample method is more efficient with FPGA resources, and thus requires less space on the FPGA for the same application.

 Sample flexibility—The IO Sample method gives you more flexibility to change channel range, terminal mode, and

channel order at run time and at full sample rate.

 Application timing flexibility—The IO Sample method returns all sample data as soon as it is available. The FPGA I/O Node will gather data for all requested samples and then return all at once.

The **Minimum Time Between Conversions** control you can set in the <u>C Series</u> <u>Module Properties</u> dialog box determines the shortest possible time between any two conversions. For channels sampled within the same FPGA I/O Node, the time you set determines the exact time between conversions. For channels sampled within separate FPGA I/O Nodes or for conversions caused by looping on an FPGA I/O Node, the time you set may be less than the actual time between conversions. However, the minimum time you set is never greater than the time between conversions. If the application tries to execute an FPGA I/O Node or IO Sample method faster than the specified minimum time between conversions, the conversion is delayed until the minimum time you set is satisfied.

The default minimum time between conversions for the NI 9205/9206 is 8  $\mu$ s. The accuracy specifications in the NI 9205 and NI 9206 hardware documentation on ni.com/manuals are based on this default value. If you set the minimum time between conversions to at least 8  $\mu$ s, the accuracy of the module is not affected. If you set the minimum time between conversions to less than 8  $\mu$ s, the accuracy of the module degrades if you sample data from multiple channels.

#### Example

Refer to the NI 9205 Advanced IO VI in the labview\examples\CompactRIO\ Module Specific\NI 9205\NI 9205 Advanced IO\NI 9205 Advanc ed IO.lvproj for an example of conversion timing on the NI 9205 and NI 9206 C Series Modules. Self-Calibration for the NI 9205/9206 (FPGA Interface)

Self-Calibration adjusts the calibration constants stored onboard the module. You can perform a self-calibration at any time to account for changes in environmental conditions. You can enable self-calibration on the <u>C Series Module Properties</u> dialog box.

Enabling Self-Calibration on the <u>NI 9205</u> or <u>NI 9206</u> allows access to the <u>Write Self-Calibration Constants</u> and <u>Restore Last External Calibration Constants</u> module methods.



**Caution** The Write Self-Calibration Constants and Restore Last External Calibration Constants method nodes must be used with the example VI to prevent damaging the module.

Refer to the NI 9205 Self-Calibration VI in the labview\examples\CompactRI O\Module Specific\NI 9205\NI 9205 Self Calibration\NI 9205 Self Calibration.lvproj for an example of self-calibration.

## NI 9205 (Scan Interface)

CompactRIO 32-Channel Single-Ended/16-Channel Differential, ±200 mV to ±10 V, 16-Bit Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9205 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9205, <b>x</b> is 0 to 31. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9205. Right-click the NI 9205 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

• Channel Configuration—You can specify the input range for each channel.

• **Channels**—Specifies the channel(s) for which you want to select the input range.

• Input Range—Specifies the input range for the selected channel(s) as ±10 V, ±5 V, ±1 V, or ±200 mV.

• **Terminal Mode**—Specifies the terminal mode for the selected channel(s) as RSE (referenced single-ended), NRSE (non-referenced single-ended), or DIFF (differential).

• Minimum Time between Conversions—Specifies the time (in uSec) between channel samples. The Scan Engine samples all channels of the module sequentially. The default time between sampling one channel and the next is 8 µs. If you connect all unused channels to ground, you should not have to increase this setting. If for some reason you cannot connect unused channels to ground, you can reduce noise by increasing the minimum time between conversions.

#### NI 9206

CompactRIO 32-Channel Single-Ended/16-Channel Differential, ±200 mV to ±10 V, 16-Bit Analog Input Module

#### Software Reference (?)

FPGA Interface | Scan Interface

## NI 9206 Pinout



# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels IO Sample Method Set Terminal Mode Method Set Triggers Method Set Voltage Range Method Conversion Timing for the NI 9205/9206 Self-Calibration for the NI 9205/9206

## NI 9206 (FPGA Interface)

CompactRIO 32-Channel Single-Ended/16-Channel Differential, ±200 mV to ±10 V, 16-Bit Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9206 has AI channels 0 to<br>31. The channel is sampled using the currently c<br>onfigured terminal mode and voltage range. Yo<br>u can configure these settings at edit time using<br>the <u>C Series Module Properties</u> dialog box or at r<br>un time using the <u>Set Terminal Mode</u> or <u>Set Volt</u><br><u>age Range</u> methods. |
| D10      | Digital input channel used to access the module digital line, which is labeled PFI0.                                                                                                                                                                                                                                                                                                                                                 |
| Trig     | Returns the output of the module trigger circuit<br>ry. Use the <u>Set Triggers</u> method to configure the<br>trigger circuit.                                                                                                                                                                                                                                                                                                      |
| DO0      | Digital output channel 0.                                                                                                                                                                                                                                                                                                                                                                                                            |

Refer to the <u>Conversion Timing</u> topic for information about the order and timing of conversions for these I/O channels.

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method           | Description                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <u>IO Sample</u> | Acquires a single sample from the module. The<br>channel number, terminal mode, and voltage r<br>nge are all configurable at run time.                                                                                                                                                                                                                                                                         |  |
|                  | Note NI suggests that<br>you do not configure th<br>e VI to run an IO Sampl<br>e method and another<br>FPGA I/O Method Node<br>in parallel when both a<br>re targeted to the same<br>C Series module. Simil<br>arly, NI suggests that y<br>ou do not configure th<br>e VI to run multiple IO<br>Sample methods in par<br>allel when the IO Samp<br>le methods are targete<br>d to the same C Series<br>module. |  |
|                  | Refer to the NI 9206 Basic IO VI and the NI 9206<br>Advanced IO VI in the labview\examples\C<br>ompactRIO\Module Specific\NI 9206<br>\NI 9206 Basic IO\NI 9206 Basic<br>IO.lvproj and labview\examples\Com<br>pactRIO\Module Specific\NI 9206\N<br>I 9206 Advanced IO\NI 9206 Advan<br>ced IO.lvproj for examples related to this<br>method.                                                                   |  |
|                  | 🔊 Open example (NI 9206 Basic IO)                                                                                                                                                                                                                                                                                                                                                                              |  |
|                  | 浸 Open example (NI 9206 Advanced IO)                                                                                                                                                                                                                                                                                                                                                                           |  |

| <u>Set Terminal Mode</u> | Sets the terminal mode for a channel as RSE (ref<br>erenced single-ended), NRSE (non-referenced si<br>ngle-ended), or DIFF (differential). This method<br>overwrites the value you configure in the <b>C Seri</b><br><b>es Module Properties</b> dialog box.                                                                                                                                                                                                                                    |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>Set Triggers</u>      | Sets the trigger output to one of the following v alues:                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                          | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                          | <ul> <li>AI Below Low</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                          | <ul> <li>Al Above High</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                          | <ul> <li>Al Inside Region</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                          | <ul> <li>AI Below Low with Hysteresis</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                          | <ul> <li>AI Above High with Hysteresis</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                          | <ul> <li>DI Trigger</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                          | Refer to the NI 9206 Basic Triggering VI and the<br>NI 9206 Advanced Triggering VI in the labview<br>\examples\CompactRIO\Module Spec<br>ific\NI 9206\NI 9206 Basic Trigge<br>ring\NI 9206 Basic Triggering.lv<br>proj and labview\examples\CompactR<br>IO\Module Specific\NI 9206\NI 920<br>6 Advanced Triggering\NI 9206 Ad<br>vanced Triggering.lvproj for example<br>s related to this method.<br>Open example (NI 9206 Basic Triggering)<br>Open example (NI 9206 Advanced Triggering<br>) |
| <u>Set Voltage Range</u> | Sets the input range for a channel as ±10 V, ±5 V,<br>±1 V, or ±200 mV. This method overwrites the val<br>ue you configure in the <b>C Series Module Prop</b><br><b>erties</b> dialog box.                                                                                                                                                                                                                                                                                                      |

## I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Linearization Coefficient x | <ul> <li>(Optional) NI-MCal linearization coefficient x, w<br/>here x is the number of the linearization coefficients 3 t<br/>o 0. You can use these coefficients in calibration<br/>to compensate for some types of measurement<br/>nonlinearity inherent in this device.</li> <li>When returning calibrated data from the FPGA I/<br/>O Node, the Linearization Coefficients are not us<br/>ed to calculate the calibrated data. This means t<br/>hat calibrated data returned in FPGA does not c<br/>ompensate for the measurement nonlinearities<br/>in the device.</li> <li>Refer to the NI 9206 Advanced IO VI in the labv<br/>iew\examples\CompactRIO\Module S<br/>pecific\NI 9206 Advanced IO.lvproj for a<br/>n example of this concept.</li> <li>Open example</li> </ul> |
| LSB Weight (±10 V range)    | Returns the LSB weight in pV/LSB for the ±10 V r<br>ange. Use this value to <u>convert and calibrate</u> NI<br>9206 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <u>C Series Module Properties</u> dialog box                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| LSB Weight (±1 V range)     | Returns the LSB weight in pV/LSB for the ±1 V ra<br>nge. Use this value to convert and calibrate NI 9<br>206 data if you set the <b>Calibration Mode</b> to <b>Ra</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|                            | <b>w</b> in the <b>C Series Module Properties</b> dialog b ox.                                                                                                                                                                                  |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±200 mV range) | Returns the LSB weight in pV/LSB for the ±200 m<br>V range. Use this value to convert and calibrate<br>NI 9206 data if you set the <b>Calibration Mode</b> t<br>o <b>Raw</b> in the <b>C Series Module Properties</b> dia<br>log box.           |
| LSB Weight (±5 V range)    | Returns the LSB weight in pV/LSB for the ±5 V ra<br>nge. Use this value to convert and calibrate NI 9<br>206 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox.      |
| Module ID                  | Returns the module ID, 0x71EB.                                                                                                                                                                                                                  |
| Offset (±10 V range)       | Returns the calibration offset in nV for the ±10 V<br>range. Use this value to <u>convert and calibrate</u> NI<br>9206 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <u>C Series Module Properties</u> dialog box |
| Offset (±1 V range)        | Returns the calibration offset in nV for the ±1 V r<br>ange. Use this value to convert and calibrate NI<br>9206 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <b>C Series Module Properties</b> dialog<br>box.    |
| Offset (±200 mV range)     | Returns the calibration offset in nV for the ±200 mV range. Use this value to convert and calibrat e NI 9206 data if you set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Series Module Properties</b> di alog box.                    |
| Offset (±5 V range)        | Returns the calibration offset in nV for the ±5 V r<br>ange. Use this value to convert and calibrate NI<br>9206 data if you set the <b>Calibration Mode</b> to <b>R</b><br><b>aw</b> in the <b>C Series Module Properties</b> dialog<br>box.    |
| Serial Number              | Returns the unique serial number of the module .                                                                                                                                                                                                |
| Vendor ID                  | Returns the NI vendor ID, 0x1093.                                                                                                                                                                                                               |
|                            |                                                                                                                                                                                                                                                 |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9205/9206 (FPGA Interface)

Right-click an <u>NI 9205</u> or <u>NI 9206</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 26 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• Channel Configuration—Specifies the input range for each channel.

• **Channels**—Specifies the channel(s) for which you want to select the input range.

• Input Range—Specifies the input range for the selected channel(s) as ±10 V, ±5 V, ±1 V, or ±200 mV.

• **Terminal Mode**—Specifies the terminal mode for the selected channel(s) as RSE (referenced single-ended), NRSE (non-referenced single-ended ), or DIFF (differential).

 Minimum Time Between Conversions—Specifies the <u>minimum time</u> between conversions in μs.

• Enable Advanced Self-Calibration Nodes—Place a checkmark in this checkbox if you want to enable <u>Self-Calibration</u> support in the FPGA for this module.

#### IO Sample Method (FPGA Interface)

This module method acquires a single sample from the module. The channel number, terminal mode, and voltage range are all configurable at run time. You use this module method by selecting it in an <u>FPGA I/O Method Node</u> that is configured for the appropriate device and/or channel. <u>Details Examples</u>

|             | <b>Note</b> NI suggests that you do not configure the<br>VI to run an IO Sample method and another<br>FPGA I/O Method Node in parallel when both are<br>targeted to the same C Series module. Similarly,<br>NI suggests that you do not configure the VI to<br>run multiple IO Sample methods in parallel<br>when the IO Sample methods are targeted to<br>the same C Series module.                                                               |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| U16 }       | <b>Configuration</b> [i+2] contains encoded<br>configuration information that gets loaded into<br>the module conversion pipeline. This<br>configuration information controls the data to<br>be sampled two iterations into the future. Refer<br>to the <u>Conversion Timing</u> topic for more<br>information. Refer to the <u>Configuration</u><br><u>Encoding</u> table below for an example of how the<br>configuration information is encoded. |
| <b>NI16</b> | <b>Data</b> [i] Returns the data from the current sample.                                                                                                                                                                                                                                                                                                                                                                                          |
|             | error in describes error conditions that occur<br>before this VI or function runs. The default is no<br>error. If an error occurred before this VI or<br>function runs, the VI or function passes the<br>error in value to error out. This VI or function<br>runs normally only if no error occurred before                                                                                                                                        |

this VI or function runs. If an error occurs while this VI or function runs, it runs normally and sets its own error status in **error out**. Use **error in** and **error out** to check errors and to specify execution order by wiring **error out** from one node to **error in** of the next node.

TFI

132

abc

**status** is TRUE (X) if an error occurred before this VI or function ran or FALSE (checkmark) to indicate a warning or that no error occurred before this VI or function ran. The default is FALSE.

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

**source** always contains an empty string because strings are not supported in LabVIEW FPGA.

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the error out indicator on the front panel and select Explain Error from the shortcut menu for more information about the error.



## **Configuration Encoding Table**

The following table describes how to construct the Configuration [i+2] value to write to the IO Sample method to perform a particular operation. The **Operation** column lists the types of operations that can be performed using the IO Sample method. The **Configuration Bit Fields** column lists the bit positions within the **Configuration** [i+2] number that need to be set. The **Values** column specifies the binary value to apply to the specified **Configuration Bit Fields**.

| Operation | Configuration Bit Fields | Values                                                                 |
|-----------|--------------------------|------------------------------------------------------------------------|
| AI Read   | 15:13                    | 001b                                                                   |
|           | 12:11                    | 01b for channels 0-15<br>10b for channels 16-31                        |
|           | 10:8                     | 000b for channels 0, 8, 16, or 24<br>001b for channels 1, 9, 17, or 25 |
|           |                          | <br>110b for channels 6, 14, 22, or 3<br>0                             |
|           |                          |                                                                        |

|           |      | 111b for channels 7, 15, 23, or 3<br>1                                                                                                   |
|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------|
|           | 7:6  | 00b                                                                                                                                      |
|           | 5:4  | 00b for NRSE mode<br>11b for RSE or DIFF modes                                                                                           |
|           | 3:2  | 11b for channels 8-15 or 24-31<br>01b for DIFF mode on channels<br>0-7 or 16-23<br>10b for RSE or NRSE mode on c<br>hannels 0-7 or 16-23 |
|           | 1:0  | 00b for ±10 V<br>01b for ±5 V<br>10b for ±1 V<br>11b for ±200 mV                                                                         |
| DI0 Read  | 15:0 | 00000000000000b                                                                                                                          |
| DO0 Write | 15:1 | 0100000000000b                                                                                                                           |
|           | 0    | Binary value to write to DO0                                                                                                             |

## Using This Method

The IO Sample method provides an efficient and flexible interface to the module. You can use this method to acquire a single sample from any of the channels on the module, at any range, and with any available input mode.

When this method is executed, the module performs a single conversion on the next channel present in the conversion pipeline on the module. The data from this conversion is returned via the **Data** [i] method output. At the same time that the conversion data is read from the module, the new configuration information specified by the **Configuration** [i+2] input is loaded into the configuration pipeline on the module. The pipeline is two samples deep. So, the configuration information specified on one execution of the IO Sample method determines which channel will be sampled by the IO Sample method two iterations into the future. Refer to the <u>Conversion Timing</u> topic for more details.

## **Examples**

Refer to the NI 9205 Basic IO VI and the NI 9205 Advanced IO VI in the labview\ex amples\CompactRIO\Module Specific\NI 9205\NI 9205 Basic IO

\NI 9205 Basic IO.lvprojandlabview\examples\CompactRIO\M odule Specific\NI 9205\NI 9205 Advanced IO\NI 9205 Advance d IO.lvproj for examples of the IO concepts discussed above.

Open example (NI 9205 Basic IO)

Open example (NI 9205 Advanced IO)

#### Set Terminal Mode Method (FPGA Interface)

Overrides the default setting provided in the <u>C Series Module Properties</u> dialog box. You use this module method by selecting it in an <u>FPGA I/O Method Node</u> that is configured for the appropriate device and/or channel.

U8 |

Al Channel is the channel you want to set the terminal mode for.

**Terminal Mode** is an enumeration of the following trigger modes:

- **RSE** is a single-ended measurement between any of the 32 individual channels and the module ground.
- NRSE is a single-ended measurement between any of the 32 individual channels and the AISENSE line into the module.
- **DIFF** is a differential measurement between two of the 32 individual channels, with the name of the differential channel matching the channel tied to the positive side of the differential measurement. Channels AI0 to AI7, and AI16 to AI23 may be set to DIFF configuration.

error in describes error conditions that occur before this VI or function runs. The default is no error. If an error occurred before this VI or function runs, the VI or function passes the error in value to error out. This VI or function

runs normally only if no error occurred before this VI or function runs. If an error occurs while this VI or function runs, it runs normally and sets its own error status in **error out**. Use **error in** and **error out** to check errors and to specify execution order by wiring **error out** from one node to **error in** of the next node.

TF

132

abc

| status is TRUE (X) if an<br>error occurred before<br>this VI or function ran<br>or FALSE (checkmark)<br>to indicate a warning<br>or that no error<br>occurred before this VI<br>or function ran. The<br>default is FALSE. |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>code</b> is the error or<br>warning code. The<br>default is 0. If <b>status</b> is<br>TRUE, <b>code</b> is a<br>nonzero <u>error code</u> . If<br><b>status</b> is FALSE, <b>code</b><br>is 0 or a warning code.       |
| <b>source</b> always<br>contains an empty<br>string because strings<br>are not supported in<br>LabVIEW FPGA.                                                                                                              |

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the error out indicator on the front panel and select Explain Error from

the shortcut menu for more information about the error.

| FTF         | <b>status</b> is TRUE (X) if an<br>error occurred or<br>FALSE (checkmark) to<br>indicate a warning or<br>that no error occurred. |
|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 132         | <b>code</b> is the error or<br>warning code. If<br><b>status</b> is TRUE, <b>code</b><br>is a nonzero <u>error</u>               |
|             | <u>code</u> . If <b>status</b> is<br>FALSE, <b>code</b> is 0 or a<br>warning code.                                               |
| <b>Labc</b> | <b>source</b> always<br>contains an empty<br>string because strings<br>are not supported in<br>LabVIEW FPGA.                     |

#### Set Triggers Method (FPGA Interface)

This module method controls the data returned by the trigger digital input line. You use this module method by selecting it in an <u>FPGA I/O Method Node</u> that is configured for the appropriate device and/or channel. <u>Details Examples</u>

**Trigger Mode** is an enumeration of the following trigger mode options:

- None disables the trigger function.
- Al Below Low detects when the analog signal is below the low threshold you specify.

• Al Above High detects when the analog signal is above the high threshold you specify.
• Al Inside Region detects when the analog signal is between the high and low thresholds you specify.

 Al Below Low with Hysteresis asserts the trigger when the signal starts above the high threshold you specify and then crosses below the low threshold you specify. The trigger deasserts when the signal crosses above the high threshold you specify.

Al Above High with Hysteresis
 asserts the trigger when the signal starts
 below the low threshold you specify and
 then crosses above the high threshold you
 specify. The trigger deasserts when the
 signal crosses below the low threshold
 you specify.

• **DI Trigger** detects when the digital signal on PFI0 is logic high.



I16

**I16** 

[574]

Note The onboard NI 9205 on <u>Single-Board</u> <u>RIO</u> (sbRIO) devices does not support DI triggering.

Al High Threshold defines the upper threshold for the analog trigger circuit.

AI Low Threshold defines the lower threshold for the analog trigger circuit.

error in describes error conditions that occur before this VI or function runs. The default is no error. If an error occurred before this VI or function runs, the VI or function passes the error in value to error out. This VI or function runs normally only if no error occurred before this VI or function runs. If an error occurs while this VI or function runs, it runs normally and

sets its own error status in **error out**. Use **error in** and **error out** to check errors and to specify execution order by wiring **error out** from one node to **error in** of the next node.

> **status** is TRUE if an error occurred. If **status** is TRUE, the VI does not perform any operations.

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

source always contains an empty string because strings are not supported in LabVIEW FPGA.

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the error out indicator on the front panel and select Explain Error from the shortcut menu for more information about the error.



TFI

132

abc

status is TRUE if an error occurred. If status is TRUE, the VI does not perform any operations.

abc

132

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

source always contains an empty string because strings are not supported in LabVIEW FPGA.

## Using This Method

Use the Set Triggers Method to configure the trigger circuit on the module. Once the trigger circuit is configured, use an FPGA I/O Node configured to access the Trig channel to monitor the output of the trigger circuit. The trigger circuit does not automatically initiate any conversions on the module. It is up to the FPGA VI to monitor the Trig line, and then initiate a conversion using an FPGA I/O Node or the IO Sample method when the appropriate trigger event occurs.

Perform the following steps to trigger an acquisition using the Set Triggers Method:

1. Ensure that the module pipeline is primed with the next two channels that you want to sample after the trigger event. This step will minimize the delay between the trigger event and the AI channels getting sampled. For analog triggering modes, this step also configures the analog trigger circuitry to monitor the desired channel. The AI trigger circuit monitors the channel waiting in the module pipeline for the next conversion.

If you are using FPGA I/O Nodes to perform the acquisition, this step can be accomplished by executing an FPGA I/O Node configured to match the FPGA I/O Node that you will be executing after the trigger event. If you are using one of the analog triggering modes along with the FPGA I/O Nodes, the AI trigger circuit will operate on the lowest numbered channel present in the FPGA I/O Node. Refer to the <u>IO Sample</u> method and <u>Conversion Timing</u> topics for more information on managing the module pipeline using the IO Sample method. If you are using one of the analog trigger modes along with the IO Sample method, the AI trigger circuit will operate on the channel waiting in the pipeline to be converted by the next IO Sample method.

- 2. Execute the <u>Set Triggers</u> method with the appropriate trigger mode selected. The trigger mode circuitry is implemented in the hardware as you specify in this method. Refer to the NI 9205 and NI 9206 hardware documentation on ni.com/manuals for more information about the trigger modes.
- 3. Monitor the Trig channel in a loop until you see the appropriate trigger condition occur.
- 4. Execute an FPGA I/O Node or IO Sample method function to acquire data in response to the trigger event.

## **Examples**

Refer to the NI 9205 Basic Triggering VI and the NI 9205 Advanced Triggering VI in the labview\examples\CompactRIO\Module Specific\NI 9205\NI 920 5 Basic Triggering\NI 9205 Basic Triggering.lvproj and lab view\examples\CompactRIO\Module Specific\NI 9205\NI 9205 A dvanced Triggering\NI 9205 Advanced Triggering.lvproj for examples of the triggering concepts discussed above.

Open example (NI 9205 Basic Triggering)

Open example (NI 9205 Advanced Triggering)

### Set Voltage Range Method (FPGA Interface)

This module method overrides the default setting provided in the <u>C Series Module</u> <u>Properties</u> dialog box. You use this module method by selecting it in an <u>FPGA I/O</u> <u>Method Node</u> that is configured for the appropriate device and/or channel.



AI Channel is the channel you want to set the voltage range for.

**Voltage Range** is an enumeration of the following voltage ranges:

- ±10 V
- ±5 V
- ±1 V

TFI

132

abc

±200 mV

error in describes error conditions that occur before this VI or function runs. The default is no error. If an error occurred before this VI or function runs, the VI or function passes the error in value to error out. This VI or function runs normally only if no error occurred before this VI or function runs. If an error occurs while this VI or function runs, it runs normally and sets its own error status in error out. Use error in and error out to check errors and to specify execution order by wiring error out from one node to error in of the next node.

> status is TRUE if an error occurred. If status is TRUE, the VI does not perform any operations.

**code** is the error code number identifying an error. The default is 0. If status is TRUE, code is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

**source** always contains an empty string because strings are not supported in LabVIEW FPGA.

error out contains error information. If error in indicates that an error occurred before this VI or function ran, error out contains the same error information. Otherwise, it describes the error status that this VI or function produces. Right-click the error out indicator on the front panel and select Explain Error from the shortcut menu for more information about the error.

▶I32 ▶I32

error occurred. If status is TRUE, the VI does not perform any operations. code is the error code number identifying an error. The default is 0. If status is TRUE, code

status is TRUE if an

is a nonzero <u>error</u> <u>code</u>. If status is FALSE, code is 0 or a warning code.

source always contains an empty string because strings are not supported in LabVIEW FPGA.

Conversion Timing for the NI 9205/9206 (FPGA Interface)

#### **Example**

2.1

The <u>NI 9205</u> and <u>NI 9206</u> modules implement a two-element deep pipeline for access to the AI, DIO, and DOO channels. This pipeline results in maximum sample rate and maximum sample quality. The Trig channel has a parallel data path that bypasses the pipeline.

When using the <u>FPGA I/O Node</u> to sample channels, the pipeline is automatically managed by the FPGA I/O Node, and the channels within the FPGA I/O Node are sampled in numerical order regardless of the order they appear in the node.

If the first two channel requests in the FPGA I/O Node do not match the two channel requests stored in the module pipeline, there will be a delay before the first channel sample occurs. This delay is caused by the FPGA I/O Node automatically updating the module channel sample pipeline, which takes two channel sample cycles.

To minimize the need for the pipeline updates, each FPGA I/O Node leaves the module pipeline primed to repeat itself. If you use only one FPGA I/O Node in a looping structure, only the first iteration of the loop will incur the two-cycle time delay. All subsequent iterations operate with no delay.

When using the <u>IO Sample</u> method, you must take steps to manage this pipeline in the VIs.

To read one channel, that channel configuration must be requested two cycles before the time it is to be sampled. The U16 configuration value for an AI channel sample contains the channel number, channel input range, and terminal mode. The U16 configuration value also can represent an access to the DIO or DOO channels, which is treated the same as an AI operation.

The following diagram illustrates how the pipeline works within a sequence structure. A typical application would use a loop structure to iterate through a scan list, which is a predefined list of configurations, continuously. The sequence structure and art elements show how data moves into the NI 9205/9206 pipeline and then is converted. Note that the IO Sample method first converts the configuration that is in the ADC, and then shifts the configuration values through the pipeline to prepare for the next time LabVIEW calls the IO Sample method.



The simplest form of pipeline management is to force the pipeline on every set of samples. This assumes that the pipeline is always wrong at the first sample, and sends all IO Sample requests in order. The last two data points need some configuration to be requested, but it does not matter, in this use case, what configuration that is.

A better form of pipeline management emulates the behavior of the FPGA I/O Node. Instead of always assuming that the pipeline is wrong, you choose the last two configuration values based on the first two samples you want to include in the next iteration. This pipeline management system can be accomplished in two parts: initialization and sample iteration.

ବ୍ର

Тір

NI recommends you use the IO Sample method for the following reasons:

> Smaller on FPGA—With large channel count, the IO Sample method is more efficient with FPGA resources, and thus requires less space on the FPGA for the same application.

 Sample flexibility—The IO Sample method gives you more flexibility to change channel range, terminal mode, and

channel order at run time and at full sample rate.

 Application timing flexibility—The IO Sample method returns all sample data as soon as it is available. The FPGA I/O Node will gather data for all requested samples and then return all at once.

The **Minimum Time Between Conversions** control you can set in the <u>C Series</u> <u>Module Properties</u> dialog box determines the shortest possible time between any two conversions. For channels sampled within the same FPGA I/O Node, the time you set determines the exact time between conversions. For channels sampled within separate FPGA I/O Nodes or for conversions caused by looping on an FPGA I/O Node, the time you set may be less than the actual time between conversions. However, the minimum time you set is never greater than the time between conversions. If the application tries to execute an FPGA I/O Node or IO Sample method faster than the specified minimum time between conversions, the conversion is delayed until the minimum time you set is satisfied.

The default minimum time between conversions for the NI 9205/9206 is 8  $\mu$ s. The accuracy specifications in the NI 9205 and NI 9206 hardware documentation on ni.com/manuals are based on this default value. If you set the minimum time between conversions to at least 8  $\mu$ s, the accuracy of the module is not affected. If you set the minimum time between conversions to less than 8  $\mu$ s, the accuracy of the module degrades if you sample data from multiple channels.

#### Example

Refer to the NI 9205 Advanced IO VI in the labview\examples\CompactRIO\ Module Specific\NI 9205\NI 9205 Advanced IO\NI 9205 Advanc ed IO.lvproj for an example of conversion timing on the NI 9205 and NI 9206 C Series Modules. Self-Calibration for the NI 9205/9206 (FPGA Interface)

Self-Calibration adjusts the calibration constants stored onboard the module. You can perform a self-calibration at any time to account for changes in environmental conditions. You can enable self-calibration on the <u>C Series Module Properties</u> dialog box.

Enabling Self-Calibration on the <u>NI 9205</u> or <u>NI 9206</u> allows access to the <u>Write Self-Calibration Constants</u> and <u>Restore Last External Calibration Constants</u> module methods.



**Caution** The Write Self-Calibration Constants and Restore Last External Calibration Constants method nodes must be used with the example VI to prevent damaging the module.

Refer to the NI 9205 Self-Calibration VI in the labview\examples\CompactRI O\Module Specific\NI 9205\NI 9205 Self Calibration\NI 9205 Self Calibration.lvproj for an example of self-calibration.

## NI 9206 (Scan Interface)

CompactRIO 32-Channel Single-Ended/16-Channel Differential, ±200 mV to ±10 V, 16-Bit Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9206 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9206, <b>x</b> is 0 to 31. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9206. Right-click the NI 9206 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

• Channel Configuration—You can specify the input range for each channel.

• **Channels**—Specifies the channel(s) for which you want to select the input range.

• Input Range—Specifies the input range for the selected channel(s) as ±10 V, ±5 V, ±1 V, or ±200 mV.

• **Terminal Mode**—Specifies the terminal mode for the selected channel(s) as RSE (referenced single-ended), NRSE (non-referenced single-ended), or DIFF (differential).

• Minimum Time between Conversions—Specifies the time between channel samples. The Scan Engine samples all channels of the module sequentially. The default time between sampling one channel and the next is 8 µs. If you connect all unused channels to ground, you should not have to increase this setting. If for some reason you cannot connect unused channels to ground, you can reduce noise by increasing the minimum time between conversions.

#### NI 9207

CompactRIO 16-Channel, ±20 mA/±10 V, 24-Bit Isolated Analog Input Module

#### Software Reference (?)

FPGA Interface | Scan Interface

## NI 9207 Pinout

| AI0+ | F01000       | Al0- |
|------|--------------|------|
| Al1+ | 62200        | Al1- |
| Al2+ | 0320         | Al2- |
| Al3+ | 20020        | Al3- |
| Al4+ | 0520         | Al4- |
| AI5+ | <u>-0620</u> | AI5- |
| Al6+ | 0720         | Al6- |
| AI7+ | 0320         | Al7- |
| Al8  | 09200        | Vsup |
| Al9  | 010280       | Vsup |
| Al10 | 0120         | Vsup |
| Al11 | D12300       | Vsup |
| Al12 | 01331-0      | Vsup |
| Al13 | 214320       | Vsup |
| Al14 | 01530        | Vsup |
| Al15 | 016340       | Vsup |
| COM  | 21730        | Vsup |
| COM  | 018360       | Vsup |
|      |              |      |
|      |              |      |
|      |              |      |
|      |              |      |



# **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Converting NI 9207 Data</u>

## NI 9207 (FPGA Interface)

CompactRIO 16-Channel, ±20 mA/±10 V, 24-Bit Isolated Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                             |
|----------|-------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9207 has AI channels 0 to<br>15. |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

## **Module Methods**

This device does not support any module methods.

## I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed</b> or <b>High Re</b><br><b>solution</b> . Refer to the NI 9207 hardware docum<br>entation on ni.com/manuals for more informati<br>on about the <b>High Speed</b> and <b>High Resolutio</b><br><b>n</b> conversion times. This property overwrites th<br>e value you configure in the <u>C Series Module Pro</u> |

|               | <u>perties</u> dialog box.                                   |
|---------------|--------------------------------------------------------------|
|               | Returns the conversion time setting when configured to read. |
| Module ID     | Returns the module ID, 0x74AD.                               |
| Serial Number | Returns the unique serial number of the module .             |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                            |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9207 (FPGA Interface)

Right-click an <u>NI 9207</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Refer to the table below for information about the units and encoding of the fixed-point data depending on the channel type.
 Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must <u>convert</u> the binary values to engineering units. The default is Calibrated.

| Channel Type | Units of Fixed-<br>Point Data | IntegerType | Word Length | Integer Word<br>Length |
|--------------|-------------------------------|-------------|-------------|------------------------|
| Voltage      | Volts                         | Signed      | 24 bits     | 5 bits                 |
| Current      | Amps                          | Signed      | 24 bits     | –4 bits                |

 Conversion Time—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select High Speed or High Resolution. The default is High Resolution. Refer to the NI 9207 hardware documentation on ni.com/manuals for more information about the High Speed and High Resolution conversion times.

#### Converting NI 9207 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9207</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

#### Using an Equation to Convert Binary Current Values to Amperes

You can use the following equation in the host VI to convert binary current values to amperes:

#### Amps = Binary Value × 0.022 A ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

Using an Equation to Convert Binary Voltage Values to Volts

You can use the following equation in the host VI to convert binary voltage values to volts:

#### **Volts = Binary Value** × 10.4 V ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

## NI 9207 (Scan Interface)

CompactRIO 8-Channel ±10 V, 8-Channel ±20 mA, 24-Bit Isolated Analog Input Module

👰 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for channels AIO– AI7 return calibrated floating-point data in volts, and the I/O variables for channels AI8–AI15 return calibrated floating-point data in amps.

## **Module Channels**

The NI 9207 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9207, <b>x</b> is 0 to 15. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9207. Right-click the NI 9207 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select High Speed or High

**Resolution**. Refer to the NI 9207 hardware documentation on ni.com/ manuals for more information about the **High Speed** and **High Resolution** conversion times.

#### NI 9208

CompactRIO 16-Channel, ±20 mA, 24-Bit Isolated Analog Input Module

#### Software Reference (?)

🔁 FPGA Interface | 🞯 Scan Interface

## NI 9208 Pinout





# **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Converting NI 9208 Data</u>

## NI 9208 (FPGA Interface)

CompactRIO 16-Channel, ±20 mA, 24-Bit Isolated Analog Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an FPGA I/O Node, configured for reading, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                             |
|----------|-------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9208 has AI channels 0 to<br>15. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

## **Module Methods**

This device does not support any module methods.

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed</b> or <b>High Re</b><br><b>solution</b> . Refer to the NI 9208 hardware docum<br>entation on ni.com/manuals for more informati<br>on about the <b>High Speed</b> and <b>High Resolutio</b><br><b>n</b> conversion times. This property overwrites th<br>e value you configure in the <u>C Series Module Pro</u><br><u>perties</u> dialog box.<br>Returns the conversion time setting when confi<br>gured to read. |
| Module ID       | Returns the module ID, 0x74AC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Serial Number   | Returns the unique serial number of the module .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Vendor ID       | Returns the NI vendor ID, 0x1093.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9208 (FPGA Interface)

Right-click an <u>NI 9208</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of amps. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –4 bits. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must <u>convert</u> the binary current values to amps. The default is Calibrated.

Conversion Time—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select High Speed or High Resolution. The default is High Resolution. Refer to the NI 9208 hardware documentation on ni.com/manuals for more information about the High Speed and High Resolution conversion times.

Converting NI 9208 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9208</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of amps. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary current values to amps. You must convert these values in the host VI.

You can use the following equation in the host VI to convert binary current values to amperes:

Amps = Binary Value × 0.022 A ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

## NI 9208 (Scan Interface)

CompactRIO 16-Channel, ±20 mA, 24-Bit Isolated Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in amps.

## **Module Channels**

The NI 9208 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9208, <b>x</b> is 0 to 15. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9208. Right-click the NI 9208 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

 Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select High Speed or High Resolution. Refer to the NI 9208 hardware documentation on ni.com/ manuals for more information about the High Speed and High Resolution conversion times.

#### NI 9209

CompactRIO 16-Channel Differential, 32-Channel Single-Ended, ±10 V, 24-Bit Analog Input Module

AI0

Al1

Al2

AI3

AI4

AI5

AI6

AI7

COM

COM

AI16

Al17

Al18

Al19

AI20

AI21

AI22

AI23

NC

1

2

3

4

Б

6

7

8

9

10

11

12

13

14

15

16

17

18

### Software Reference (?)

#### 这 <u>FPGA Interface</u>

## NI 9209 Pinout



# **Related Topics**

FPGA Interface **Detecting Out-of-Range Channels** Converting NI 9209 Data

## NI 9209 (FPGA Interface)

CompactRIO 16-Channel Differential, 32-Channel Single-Ended, ±10 V, 24-Bit Analog **Input Module** 

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                             |
|----------|-------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9209 has AI channels 0 to<br>31. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method            | Description                                                                                                                                                                                                   |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Terminal Mode | Sets the terminal mode for a channel as RSE (ref<br>erenced single-ended) or DIFF (differential). Thi<br>s method overwrites the value you configure in t<br>he <b>C Series Module Properties</b> dialog box. |

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed</b> or <b>High Re<br/>solution</b> . Refer to the NI 9209 hardware docum<br>entation on ni.com/manuals for more informati<br>on about the <b>High Speed</b> and <b>High Resolutio</b><br><b>n</b> conversion times. This property overwrites th<br>e value you configure in the <u>C Series Module Pro</u><br><u>perties</u> dialog box.<br>Returns the conversion time setting when confi<br>gured to read. |
| Module ID       | Returns the module ID, 0x77F3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Serial Number   | Returns the unique serial number of the module .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Vendor ID       | Returns the NI vendor ID, 0x1093.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9209 (FPGA Interface)

Right-click an <u>NI 9209</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated <u>fixed</u>-<u>point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the binary current values to amps. The default is **Calibrated**.

Conversion Time—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select High Speed or High Resolution. The default is High Resolution. Refer to the NI 9209 hardware documentation on ni.com/manuals for more information about the High Speed and High Resolution conversion times.

- Channels—Specifies which channels you want to configure settings for.
- **Terminal Mode**—Specifies the terminal mode for the selected channels as RSE (referenced single-ended) or DIFF (differential).

Converting NI 9209 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9209</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

#### Using an Equation to Convert Binary Voltage Values to Volts

You can use the following equation in the host VI to convert binary voltage values to volts:

#### **Volts = Binary Value** × 10.4 V ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

## NI 9209 (Scan Interface)

CompactRIO 16-Channel Differential, 32-Channel Single-Ended, ±10 V, 24-Bit Analog Input Module

🔊 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9209 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9209, <b>x</b> is 0 to 31. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9209. Right-click the NI 9209 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

 Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select High Speed or High Resolution.

• **Terminal Mode**—Specifies the terminal mode for one or more selected channels as referenced, single-ended (RSE) or differential (DIFF).

NI 9210

CompactRIO 4-Channel, ±80 mV, 24-Bit Thermocouple Input Module

#### Software Reference (?)

FPGA Interface

### NI 9210 Pinout



## **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Converting NI 9210 Data</u>

## NI 9210 (FPGA Interface)

CompactRIO 4-Channel, ±80 mV, 24-Bit Thermocouple Input Module

闷 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                                                                                       |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TCx      | Thermocouple input channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9210 has TC chann<br>els 0 to 3.                                                                                    |
| CJC      | Cold-junction compensation channel. For the b<br>est accuracy, read the CJC channel in the same<br>FPGA I/O Node as the thermocouple input chan<br>nels. You must <u>convert the CJC data</u> to temperat<br>ure. |
| Autozero | Autozero channel. For the best accuracy, read th<br>e Autozero channel in the same FPGA I/O Node a<br>s the thermocouple input channels.                                                                          |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

## I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9210 (FPGA Interface)

Right-click an <u>NI 9210</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –2 bits. If you select Calibrated, you must convert the fixed-point CJC data to binary CJC data and then convert the binary CJC data to temperature. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must convert the binary thermocouple values to voltage and convert the binary CJC data to temperature. The default is Calibrated.

#### Converting NI 9210 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9210</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. If you set the **Calibration Mode** to **Calibrated**, you must convert the fixed-point CJC data to binary CJC data and then convert the binary CJC data to temperature. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary thermocouple values to voltage and convert the binary CJC data to temperature. You must convert these values in the host VI.

#### Using a VI to Convert Data to Temperature

Refer to the Convert to Temperature (NI 9210) polymorphic VI in the labview\exa mples\CompactRIO\Module Specific\NI 9210\NI 9210 Support F iles.llb for an example of converting calibrated or raw data to temperature. You can use the Convert to Temperature (NI 9210) VI as a subVI in the host VI.

#### Using an Equation to Convert Binary Thermocouple Values to Voltage

You can use the following equation in the host VI to convert binary thermocouple values to voltage:

#### Voltage = Binary Value × 80 mV ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

Using an Equation to Convert Fixed-Point CJC Data to Binary CJC Data

You can use the following equation in the host VI to convert fixed-point CJC data to binary CJC data:

**Binary CJC Data** = (**Fixed-Point CJC Data**)  $\div$  (0.160  $\div$  (2<sup>24</sup> – 1))

where

**Fixed-Point CJC Data** is the value returned by the FPGA I/O Node.

Using Equations to Convert Binary CJC Data to Temperature

You can use the following equations in the host VI to convert binary CJC data to temperature:

Calculate the resistance of the thermistor:

 $\mathbf{R}_{\mathbf{T}} = (10000 \times \mathbf{Binary CJC Data}) \div (2^{23} - \mathbf{Binary CJC Data})$ 

Calculate the CJC temperature:

 $T = [1 \div [A + B(ln(R_T)) + C(ln(R_T))^3]] - (273.15 + OffsetConstant)$ 

where

**T** = temperature in °C **A** = 1.2873851 × 10<sup>-3</sup> **B** = 2.3575235 × 10<sup>-4</sup> **C** = 9.4978060 × 10<sup>-8</sup> **R**<sub>T</sub> = thermistor resistance reading **OffsetConstant**<sup>\*</sup> = 0.1

<sup>\*</sup>The **OffsetConstant** is the typical temperature gradient between the CJC sensor and the thermocouple cold junction.

Refer to the National Institute of Standards and Technology (NIST) Monograph 175 thermocouple reference tables for more information about converting and adjusting thermocouple values.

## NI 9210 (Scan Interface)

CompactRIO 4-Channel, ±80 mV, 24-Bit Thermocouple Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.



**Note** The Scan Interface applies Autozero and cold-junction compensation to NI 9210 data returned in temperature units.

## **Module Channels**

The NI 9210 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9210, <b>x</b> is 0 to 3. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9210. Right-click the NI 9210 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

• **Thermocouple Type**—Specifies the type of thermocouple connected to the channel.

 Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Volts, Degrees Kelvin, Degrees Celsius, Degrees Fahrenheit, or Degrees Rankine.

#### NI 9211

CompactRIO 4-Channel, ±80 mV, 24-Bit Thermocouple Input Module

#### Software Reference (?)

😰 FPGA Interface | 🕝 Scan Interface

### NI 9211 Pinout



## **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Converting NI 9211 Data</u>

## NI 9211 (FPGA Interface)

CompactRIO 4-Channel, ±80 mV, 24-Bit Thermocouple Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an FPGA I/O Node, configured for reading, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal    | Description                                                                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TC <b>x</b> | Thermocouple input channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9211 has TC chann<br>els 0 to 3.                                                                                    |
| CJC         | Cold-junction compensation channel. For the b<br>est accuracy, read the CJC channel in the same<br>FPGA I/O Node as the thermocouple input chan<br>nels. You must <u>convert the CJC data</u> to temperat<br>ure. |
| Autozero    | Autozero channel. For the best accuracy, read th<br>e Autozero channel in the same FPGA I/O Node a<br>s the thermocouple input channels.                                                                          |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x70A3.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9211 (FPGA Interface)

Right-click an <u>NI 9211</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –2 bits. If you select Calibrated, you must <u>convert</u> the fixed-point CJC data to binary CJC data and then convert the binary CJC data to temperature. Select Raw if you

want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the binary thermocouple values to voltage and convert the binary CJC data to temperature. The default is **Calibrated**.

Converting NI 9211 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9211</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. If you set the **Calibration Mode** to **Calibrated**, you must convert the fixed-point CJC data to binary CJC data and then convert the binary CJC data to temperature. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary thermocouple values to voltage and convert the binary CJC data to temperature. You must convert these values in the host VI.



**Note** The equations below apply only to the NI 9211. If you are using the NI 9211E board-only module, refer to the KnowledgeBase for the correct equations.

#### Using a VI to Convert Data to Temperature

Refer to the Convert to Temperature (NI 9211) polymorphic VI in the labview\exa mples\CompactRIO\Module Specific\NI 9211\NI 9211 Support F iles.llb for an example of converting calibrated or raw data to temperature. You can use the Convert to Temperature (NI 9211) VI as a subVI in the host VI.

Using an Equation to Convert Binary Thermocouple Values to Voltage

You can use the following equation in the host VI to convert binary thermocouple values to voltage:

#### Voltage = Binary Value × 80 mV ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.
#### Using an Equation to Convert Fixed-Point CJC Data to Binary CJC Data

You can use the following equation in the host VI to convert fixed-point CJC data to binary CJC data:

**Binary CJC Data** = (**Fixed-Point CJC Data**)  $\div$  (0.160  $\div$  (2<sup>24</sup> – 1))

where

**Fixed-Point CJC Data** is the value returned by the FPGA I/O Node.

Using Equations to Convert Binary CJC Data to Temperature

You can use the following equations in the host VI to convert binary CJC data to temperature:

Calculate the resistance of the thermistor:

 $\mathbf{R}_{\mathbf{T}} = (10000 \times \mathbf{Binary CJC Data}) \div (2^{23} - \mathbf{Binary CJC Data})$ 

Calculate the CJC temperature:

 $T = [1 \div [A + B(ln(R_T)) + C(ln(R_T))^3]] - (273.15 + OffsetConstant)$ 

where

**T** = temperature in °C **A** =  $1.2873851 \times 10^{-3}$  **B** =  $2.3575235 \times 10^{-4}$  **C** =  $9.4978060 \times 10^{-8}$  **R**<sub>T</sub> = thermistor resistance reading **OffsetConstant**<sup>\*</sup> = 0.7

<sup>\*</sup>The **OffsetConstant** is the typical temperature gradient between the CJC sensor and the thermocouple cold junction.

Refer to the National Institute of Standards and Technology (NIST) Monograph 175 thermocouple reference tables for more information about converting and adjusting thermocouple values.

# NI 9211 (Scan Interface)

CompactRIO 4-Channel, ±80 mV, 24-Bit Thermocouple Input Module

📄 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.



**Note** The Scan Interface applies Autozero and cold-junction compensation to NI 9211 data returned in temperature units.

### **Module Channels**

The NI 9211 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9211, <b>x</b> is 0 to 3. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9211. Right-click the NI 9211 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

• **Thermocouple Type**—Specifies the type of thermocouple connected to the channel.

 Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Volts, Degrees Kelvin, Degrees
 Celsius, Degrees Fahrenheit, or Degrees Rankine.

NI 9212

CompactRIO 8-Channel, ±78 mV, 24-Bit Channel-to-Channel Isolated Thermocouple Input Module

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

#### NI 9212 Pinout



### NI TB-9212 Pinout

The NI TB-9212 provides connections for eight thermocouple channels on the NI 9212.



# **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Converting NI 9212 Data</u>

## NI 9212 (FPGA Interface)

CompactRIO 8-Channel, ±78 mV, 24-Bit, Channel-to-Channel Isolated Thermocouple Input Module

🔊 Open example

🔍 Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal Description

| TC <b>x</b> | Thermocouple input channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9212 has TC chann<br>els 0 to 7.                                                                                                                                                                                                |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CJCx        | Cold-junction compensation channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9212 has C JC channels 0 to 1. For the best accuracy, read t he appropriate CJC channel in the same FPGA I/ O Node as the corresponding thermocouple inp ut channels. You must <u>convert the CJC data</u> to t emperature. |
|             | <ul> <li>CJC 0—corresponds to thermocouple i nput channels TC0, TC1, TC2, and TC3.</li> <li>CJC 1—corresponds to thermocouple i nput channels TC4, TC5, TC6, and TC7.</li> </ul>                                                                                                                                              |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                                |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | Returns Booleans for each channel that indicate<br>whether the channel was out of range or had an<br>open thermocouple since the last execution of t<br>he Check Cached Status method. When the FPG<br>A I/O Node reads the channels, the FPGA VI dete<br>rmines the state of the channels and caches any<br>TRUE value until the Check Cached Status meth<br>od executes. |

• Force Status Read—When the value o f this input is FALSE, the method returns t he cached status information since the las t time that the Check Cached Status meth od executed. When the value is TRUE, the method forces the FPGA I/O Node to read all channels and update the status inform ation. Forcing a status read can introduce jitter into an analog input loop.

• **Open**—Returns an array of Boolean val ues. A value of TRUE in any index indicate s that the channel sharing a number with that index detected an open thermocoupl e on the channel at some point after the l ast time that the Check Cached Status me thod executed.

### I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed</b> , <b>Best 60 H</b><br><b>z Rejection</b> , <b>Best 50 Hz Rejection</b> , or <b>High R</b><br><b>esolution</b> . Refer to the <b>NI 9212 with NI TB-921</b><br><b>2 Datasheet</b> for more information about the <b>Hi</b><br><b>gh Speed</b> , <b>Best 60 Hz Rejection</b> , <b>Best 50 Hz</b><br><b>Rejection</b> , and <b>High Resolution</b> conversion ti<br>mes. This property overwrites the value you con<br>figure in the <u>C Series Module Properties</u> dialog b<br>ox. |

|               | Returns the conversion time setting when configured to read. |
|---------------|--------------------------------------------------------------|
| Module ID     | Returns the module ID, 0x7705.                               |
| Serial Number | Returns the unique serial number of the module .             |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                            |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9212 (FPGA Interface)

Right-click an <u>NI 9212</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –2 bits. If you select Calibrated, you must convert the CJC data from voltage to temperature. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must convert the CJC data from voltage to the temperature. The default is Calibrated.

Conversion Time—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select High Speed, Best 60 Hz Rejection, Best 50 Hz Rejection, or High Resolution. The default is High Resolution. Refer to the NI 9212 with NI TB-9212 Datasheet for more information about the High Speed, Best 60 Hz Rejection, Best 50 Hz Rejection, and High Resolution conversion times.

Converting NI 9212 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9212</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. If you set the **Calibration Mode** to **Calibrated**, you must convert the CJC data from voltage to temperature. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary thermocouple and CJC values to voltage and then convert the CJC data from voltage to temperature. You must convert these values in the host VI.

#### Using a VI to Convert Data to Temperature

Refer to the NI 9212 Convert to Temperature polymorphic VI in the labview\exam ples\CompactRIO\Module Specific\NI 9212\NI 9212 Getting St arted\NI 9212 Getting Started.lvproj for an example of converting calibrated or raw data to temperature. You can use the NI 9212 Convert to Temperature VI as a subVI in the host VI.

#### Using an Equation to Convert Binary Values to Voltage

You can use the following equation in the host VI to convert the binary thermocouple and CJC values to voltage:

#### **Voltage = Binary Value** × 78.125 mV ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

#### Converting CJC Data from Voltage to Temperature

The NI 9212 Convert Thermistor Reading VI is a subVI in the NI 9212 Convert to Temperature polymorphic VI that converts CJC data from voltage to temperature.

The VI uses the following equation to calculate the resistance of the thermistor:

 $R_{T} = [(CJC Data \div 0.078125) \div (1 - (CJC Data \div 0.078125))] \times 28,000$ 

Using the resistance of the thermistor, the VI references a look-up table to interpolate the CJC temperature.

Refer to the National Institute of Standards and Technology (NIST) Monograph 175 thermocouple reference tables for more information about converting and adjusting thermocouple values.

# NI 9212 (Scan Interface)

CompactRIO 8-Channel, ±78 mV, 24-Bit Channel-to-Channel Isolated Thermocouple Input Module

👰 Open example

e/

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

**Note** The Scan Interface applies cold-junction compensation to NI 9212 data returned in temperature units.

### **Module Channels**

The NI 9212 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| TCx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9212, <b>x</b> is 0 to 7. |

## **Module-Specific Errors**

The NI 9212 can return the following module-specific error.

| ErrorCode | Description                        |
|-----------|------------------------------------|
| -65582    | An open thermocouple was detected. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9212. Right-click the NI 9212 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

 Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select High Speed, Best 60 Hz Rejection, Best 50 Hz Rejection, or High Resolution. Refer to the NI 9212 with NI TB-9212 Datasheet for more information about the High Speed, Best 60 Hz Rejection, Best 50 Hz Rejection, and High Resolution conversion times.

• **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Thermocouple Type**—Specifies the type of thermocouple connected to the channel.

 Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Volts, Degrees Kelvin, Degrees Celsius, Degrees Fahrenheit, or Degrees Rankine. • Enable Open Thermocouple Detection—If this box is checked, the NI 9212 returns a zero value and reports an error if it detects an open thermocouple on any channel. This box is checked by default. If you do not check this box, each channel of the NI 9212 independently returns full-scale data and the NI 9212 does not report an error if an open thermocouple is detected



**Note** Enabling or disabling open thermocouple detection on the NI 9212 has no effect on the accuracy of the measurement because this option on the module is implemented entirely from software.

NI 9213

CompactRIO 16-Channel, ±78 mV, 24-Bit Thermocouple Input Module

#### Software Reference (?)

这 FPGA Interface 🛛 📀 Scan Interface

| 6     |               | 7     |       |            |       |
|-------|---------------|-------|-------|------------|-------|
| Г     |               | 7     |       |            |       |
|       |               |       |       |            |       |
| 10    |               | NO    |       |            | NO    |
| NC    | 10 H H M      | NC    | NC    |            | NC    |
| TC0+  | 2             | TC0-  | TC0+  | F-02/2010  | TC0-  |
| TC1+  | II 3 🗆 🗆 20 🔤 | TC1-  | TC1+  | 103210     | TC1-  |
| TC2+  | 4             | TC2-  | TC2+  | 24220      | TC2-  |
| TC3+  | 5 23          | TC3-  | TC3+  | -523-      | TC3-  |
| TC4+  | 60024         | TC4-  | TC4+  | 26240      | TC4-  |
| TC5+  | 0000          | TC5-  | TC5+  | 07250      | TC5-  |
| TC6+  | 8             | TC6-  | TC6+  | 08260      | TC6-  |
| TC7+  | 9002          | TC7-  | TC7+  | <u></u>    | TC7-  |
| TC8+  | 10            | TC8-  | TC8+  | 010280     | TC8-  |
| TC9+  | 10            | TC9-  | TC9+  | 011290     | TC9-  |
| TC10+ | 12            | TC10- | TC10+ | 12300      | TC10- |
| TC11+ | 13            | TC11- | TC11+ |            | TC11- |
| TC12+ | 19 🗆 🗆 😵 📗    | TC12- | TC12+ | 21432      | TC12- |
| TC13+ | 15            | TC13- | TC13+ | -1533-     | TC13- |
| TC14+ | 16 🗆 🗆 34     | TC14- | TC14+ | -1634-     | TC14- |
| TC15+ | 10113         | TC15- | TC15+ | 1735-      | TC15- |
| COM   | 18 🗆 🗆 36     | COM   | COM   |            | COM   |
|       |               |       |       |            |       |
|       |               |       |       |            |       |
|       |               | 4     |       |            |       |
| C     |               | 7     |       | ι <i>)</i> |       |

# NI 9213 Pinout

# **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Converting NI 9213 Data</u>

# NI 9213 (FPGA Interface)

CompactRIO 16-Channel, ±78 mV, 24-Bit Thermocouple Input Module

😥 Open example

Find related examples

# FPGA I/O Node

You can use an FPGA I/O Node, configured for reading, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| TC <b>x</b> | Thermocouple input channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9213 has TC chann<br>els 0 to 15.                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Autozero    | Autozero channel. For the best accuracy, read th<br>e Autozero channel in the same FPGA I/O Node a<br>s the thermocouple input channels.                                                                          |
| CJC         | Cold-junction compensation channel. For the b<br>est accuracy, read the CJC channel in the same<br>FPGA I/O Node as the thermocouple input chan<br>nels. You must <u>convert the CJC data</u> to temperat<br>ure. |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                                |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | Returns Booleans for each channel that indicate<br>whether the channel was out of range or had an<br>open thermocouple since the last execution of t<br>he Check Cached Status method. When the FPG<br>A I/O Node reads the channels, the FPGA VI dete<br>rmines the state of the channels and caches any<br>TRUE value until the Check Cached Status meth<br>od executes. |
|                     | • Force Status Read—When the value o<br>f this input is FALSE, the method returns t<br>he cached status information since the las<br>t time that the Check Cached Status meth<br>od executed. When the value is TRUE, the                                                                                                                                                  |

method forces the FPGA I/O Node to read all channels and update the status inform ation. Forcing a status read can introduce jitter into an analog input loop.

• Out of Range—Returns an array of Bo olean values. A value of TRUE in any index indicates that the channel sharing a numb er with that index exceeded the commonmode voltage range at some point after th e last time that the Check Cached Status method executed.

• **Open**—Returns an array of Boolean val ues. A value of TRUE in any index indicate s that the channel sharing a number with that index detected an open thermocoupl e on the channel at some point after the l ast time that the Check Cached Status me thod executed.

### I/O Properties

This device does not support any I/O properties.

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed</b> or <b>High Re</b><br><b>solution</b> . Refer to the NI 9213 hardware docum<br>entation on ni.com/manuals for more informati<br>on about the <b>High Speed</b> and <b>High Resolutio</b><br><b>n</b> conversion times. This property overwrites th<br>e value you configure in the <u>C Series Module Pro</u><br><u>perties</u> dialog box. |

|               | Returns the conversion time setting when configured to read. |
|---------------|--------------------------------------------------------------|
| Module ID     | Returns the module ID, 0x7449.                               |
| Serial Number | Returns the unique serial number of the module .             |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                            |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9213 (FPGA Interface)

Right-click an <u>NI 9213</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –2 bits. If you select Calibrated, you must <u>convert</u> the CJC data from voltage to temperature. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must <u>convert</u> the binary thermocouple and CJC values to voltage and then convert the CJC data from voltage to temperature. The default is Calibrated.

 Conversion Time—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select High Speed or High Resolution. The default is High Resolution. Refer to the NI 9213 hardware documentation on ni.com/manuals for more information about the High Speed and High Resolution conversion times.

#### Converting NI 9213 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9213</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. If you set the **Calibration Mode** to **Calibrated**, you must convert the CJC data from voltage to temperature. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary thermocouple and CJC values to voltage and then convert the CJC data from voltage to temperature. You must convert these values in the host VI.



**Note** The equations below apply only to the NI 9213. If you are using the NI 9213E board-only module, refer to the KnowledgeBase for the correct equations.

#### Using a VI to Convert Data to Temperature

Refer to the NI 9213 Convert to Temperature polymorphic VI in the labview\exam ples\CompactRIO\Module Specific\NI 9213\NI 9213 Getting St arted\NI 9213 Getting Started.lvproj for an example of converting calibrated or raw data to temperature. You can use the NI 9213 Convert to Temperature VI as a subVI in the host VI.

#### Using an Equation to Convert Binary Values to Voltage

You can use the following equation in the host VI to convert the binary thermocouple and CJC values to voltage:

#### **Voltage = Binary Value** × 78.125 mV ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

Using Equations to Convert CJC Data from Voltage to Temperature

You can use the following equations in the host VI to convert CJC data from volts to temperature:

Calculate the resistance of the thermistor:

 $\mathbf{R}_{\mathbf{T}} = (10000 \times \mathbf{CJC} \, \mathbf{Data} \times 32) \div (2.5 - \mathbf{CJC} \, \mathbf{Data} \times 32)$ 

Calculate the CJC temperature:

 $T = [1 \div [A + B(ln(R_T)) + C(ln(R_T))^3]] - (273.15 + OffsetConstant)$ 

where

**T** = temperature in °C **A** = 1.2873851 × 10<sup>-3</sup> **B** = 2.3575235 × 10<sup>-4</sup> **C** = 9.4978060 × 10<sup>-8</sup> **R**<sub>T</sub> = thermistor resistance reading **OffsetConstant**<sup>\*</sup> = 1

<sup>\*</sup>The **OffsetConstant** is the typical temperature gradient between the CJC sensor and the thermocouple cold junction.

Refer to the National Institute of Standards and Technology (NIST) Monograph 175 thermocouple reference tables for more information about converting and adjusting thermocouple values.

# NI 9213 (Scan Interface)

CompactRIO 16-Channel, ±78 mV, 24-Bit Thermocouple Input Module

🔊 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

**Note** The Scan Interface applies Autozero and cold-junction compensation to NI 9213 data returned in temperature units.

#### **Module Channels**

E/

The NI 9213 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| TCx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9213, <b>x</b> is 0 to 15. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9213. Right-click the NI 9213 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.
- Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select High Speed or High Resolution. Refer to the NI 9213 hardware documentation on ni.com/ manuals for more information about the High Speed and High Resolution conversion times.
- **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Thermocouple Type**—Specifies the type of thermocouple connected to the channel.

 Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Volts, Degrees Kelvin, Degrees Celsius, Degrees Fahrenheit, or Degrees Rankine.

• Enable Open Thermocouple Detection—If this box is checked, the NI 9213 returns a zero value and reports an error if it detects an open thermocouple on any channel. This box is checked by default. If you do not check this box, each channel of the NI 9213 independently returns full-scale data and the NI 9213 does not report an error if an open thermocouple is detected.



Note Enabling or disabling open thermocouple detection on the NI 9213 has no effect on the accuracy of the measurement because this option on the module is implemented entirely from software.

NI 9214

CompactRIO 16-Channel, ±78 mV, 24-Bit Thermocouple Input Module

#### Software Reference (?)

😰 FPGA Interface | 🕑 Scan Interface

### NI TB-9214 Pinout

The NI TB-9214 provides connections for the 16 thermocouple channels of the NI 9214.



# **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Converting NI 9214 Data</u>

## NI 9214 (FPGA Interface)

CompactRIO 16-Channel, ±78 mV, 24-Bit Thermocouple Input Module

😥 Open example

🔍 Find related examples

## FPGA I/O Node

You can use an FPGA I/O Node, configured for reading, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| TC <b>x</b> | Thermocouple input channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9214 has TC chann<br>els 0 to 15.                                                                                                                                                                                               |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Autozero    | Autozero channel. For the best accuracy, read th<br>e Autozero channel in the same FPGA I/O Node a<br>s the thermocouple input channels.                                                                                                                                                                                      |
| CJCx        | Cold-junction compensation channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9214 has C JC channels 0 to 2. For the best accuracy, read t he appropriate CJC channel in the same FPGA I/ O Node as the corresponding thermocouple inp ut channels. You must <u>convert the CJC data</u> to t emperature. |
|             | <ul> <li>CJC 0—corresponds to thermocouple i<br/>nput channels TC2, TC3, TC4, TC7, TC8, an<br/>d TC9.</li> </ul>                                                                                                                                                                                                              |
|             | <ul> <li>CJC 1—corresponds to thermocouple i<br/>nput channels TC10, TC11, TC12, TC13, TC<br/>14, and TC15.</li> </ul>                                                                                                                                                                                                        |
|             | <ul> <li>CJC 2—corresponds to thermocouple i<br/>nput channels TC0, TC1, TC5, and TC6.</li> </ul>                                                                                                                                                                                                                             |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Check | Cached | Status |
|-------|--------|--------|
|-------|--------|--------|

Returns Booleans for each channel that indicate whether the channel was out of range or had an open thermocouple since the last execution of t he Check Cached Status method. When the FPG A I/O Node reads the channels, the FPGA VI dete rmines the state of the channels and caches any TRUE value until the Check Cached Status meth od executes.

> • Force Status Read—When the value o f this input is FALSE, the method returns t he cached status information since the las t time that the Check Cached Status meth od executed. When the value is TRUE, the method forces the FPGA I/O Node to read all channels and update the status inform ation. Forcing a status read can introduce jitter into an analog input loop.

> • Out of Range—Returns an array of Bo olean values. A value of TRUE in any index indicates that the channel sharing a numb er with that index exceeded the commonmode voltage range at some point after th e last time that the Check Cached Status method executed.

> • **Open**—Returns an array of Boolean val ues. A value of TRUE in any index indicate s that the channel sharing a number with that index detected an open thermocoupl e on the channel at some point after the l ast time that the Check Cached Status me thod executed.

### I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time          | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed</b> or <b>High Re</b><br><b>solution</b> . Refer to the <b>NI 9214 with NI TB-9214</b><br><b>Operating Instructions and Specifications</b> for<br>more information about the <b>High Speed</b> and <b>H</b><br><b>igh Resolution</b> conversion times. This propert<br>y overwrites the value you configure in the <u>C Ser</u><br><u>ies Module Properties</u> dialog box.<br>Returns the conversion time setting when confi<br>gured to read. |
| Open TC Detection Enable | <ul> <li>Enables open thermocouple detection on the m odule. When this property is enabled, the NI 921 4 returns an error if it detects an open thermocouple on any TCx channel. This property overwrit es the value you configure in the <u>C Series Modul</u> <u>e Properties</u> dialog box.</li> <li>Note Enabling open t hermocouple detection n on the NI 9214 result s in a small current lea kage in the thermocouple measurement. Referr to the Overview of Op en Thermocouple Detection support docume nt for more information n about compensating</li> </ul>                      |
|                          | Returns open thermocouple detection setting w<br>hen configured to read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Module ID     | Returns the module ID, 0x74EE.                   |
|---------------|--------------------------------------------------|
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9214 (FPGA Interface)

Right-click an <u>NI 9214</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –2 bits. If you select Calibrated, you must convert the CJC data from voltage to temperature. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must convert the CJC data from voltage to the temperature. The default is Calibrated.

• **Conversion Time**—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select **High** 

**Speed** or **High Resolution**. The default is **High Resolution**. Refer to the **NI 9214 with NI TB-9214 Operating Instructions and Specifications** for more information about the **High Speed** and **High Resolution** conversion times.

• Enable Open Thermocouple Detection—Place a checkmark in this checkbox if you want to enable <u>open thermocouple detection</u> on the module.



**Note** Enabling open thermocouple detection on the NI 9214 results in a small current leakage in the thermocouple measurement. Refer to the Overview of Open Thermocouple Detection support document for more information about compensating for this error.

Converting NI 9214 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9214</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. If you set the **Calibration Mode** to **Calibrated**, you must convert the CJC data from voltage to temperature. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary thermocouple and CJC values to voltage and then convert the CJC data from voltage to temperature. You must convert these values in the host VI.

#### Using a VI to Convert Data to Temperature

Refer to the NI 9214 Convert to Temperature polymorphic VI in the labview\exam ples\CompactRIO\Module Specific\NI 9214\NI 9214 Getting St arted\NI 9214 Getting Started.lvproj for an example of converting calibrated or raw data to temperature. You can use the NI 9214 Convert to Temperature VI as a subVI in the host VI.

#### Using an Equation to Convert Binary Values to Voltage

You can use the following equation in the host VI to convert the binary thermocouple and CJC values to voltage:

#### **Voltage** = **Binary Value** × 78.125 mV ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

Converting CJC Data from Voltage to Temperature

The NI 9214 Convert Thermistor Reading VI is a subVI in the NI 9214 Convert to Temperature polymorphic VI that converts CJC data from voltage to temperature.

The VI uses the following equation to calculate the resistance of the thermistor:

 $R_{T} = [(CJC Data \div 0.078125) \div (1 - (CJC Data \div 0.078125))] \times 20,000$ 

Using the resistance of the thermistor, the VI references a look-up table to interpolate the CJC temperature.

Refer to the National Institute of Standards and Technology (NIST) Monograph 175 thermocouple reference tables for more information about converting and adjusting thermocouple values.

## NI 9214 (Scan Interface)

CompactRIO 16-Channel, ±78 mV, 24-Bit Thermocouple Input Module

🔊 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

ŧ

**Note** The Scan Interface applies Autozero and cold-junction compensation to NI 9214 data returned in temperature units.

# **Module Channels**

The NI 9214 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| TCx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9214, <b>x</b> is 0 to 15. |

#### Module-Specific Errors

The NI 9214 can return the following module-specific errors.

| Error Code | Description                             |
|------------|-----------------------------------------|
| -65582     | An open thermocouple was detected.      |
| -65583     | A common-mode range error was detected. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9214. Right-click the NI 9214 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

 Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select High Speed or High Resolution. Refer to the NI 9214 hardware documentation on ni.com/ manuals for more information about the High Speed and High Resolution conversion times.

• **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Thermocouple Type**—Specifies the type of thermocouple connected to the channel.

 Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Volts, Degrees Kelvin, Degrees Celsius, Degrees Fahrenheit, or Degrees Rankine.

• Enable Open Thermocouple Detection—If this box is checked, the NI 9214 returns a zero value and reports an error if it detects an open thermocouple on any channel. This box is checked by default. If you do not check this box, the Open Thermocouple Detection Circuit is disabled and the NI 9214 does not report an error or go to full-scale when an open thermocouple is detected.



**Note** Enabling open thermocouple detection on the NI 9214 results in a small current leakage in the thermocouple measurement. Refer to the Overview of Open Thermocouple Detection support document for more information about compensating for this error.

### NI 9214 OTD Compensation Example VI

Refer to the NI 9214 OTD Compensation VI in the labview\examples\Compact RIO\NI Scan Engine\Module Specific\Analog Input\NI 9214 -Compensation - Scan Mode\NI 9214 OTD Compensation - Scan Mode.lvproj for an example that compensates for the error introduced by enabling open thermocouple detection on the NI 9214.

### NI 9215

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Analog Input Module

#### Software Reference (?)

😂 FPGA Interface | 🎯 Scan Interface

#### NI 9215 Pinout





# **Related Topics**

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> Detecting Out-of-Range Channels

# NI 9215 (FPGA Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Analog Input Module

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>simultaneously read from</u> multiple channels on the NI 9215.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9215 has AI channels 0 to<br>3. |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9215<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>15 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property  | Description                                                                                   |
|-----------|-----------------------------------------------------------------------------------------------|
| Module ID | Returns the module ID, 0x7135 (NI 9215 with BN<br>C) or 0x70A6 (NI 9215 with screw terminal). |

| Serial Number | Returns the unique serial number of the module . |
|---------------|--------------------------------------------------|
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9215 (FPGA Interface)

Right-click an <u>NI 9215</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module in units of volts. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data for the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

### NI 9215 (Scan Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Analog Input Module

📄 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

### **Module Channels**

The NI 9215 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9215, <b>x</b> is 0 to 3. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9215. Right-click the NI 9215 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9216

CompactRIO 8-Channel, 24-Bit, 100  $\Omega$  RTD Analog Input Module

#### Software Reference (?)

#### FPGA Interface

#### NI 9216 Pinout

| NC<br>EX0+<br>RTD0+<br>RTD0-<br>COM<br>EX1+<br>RTD1+<br>RTD1+<br>RTD1+<br>RTD2+<br>RTD2+<br>RTD2+<br>RTD2+<br>RTD3+<br>RTD3+<br>RTD3-<br>COM<br>NC | 0         1         19         0           0         2         20         0           0         3         21         0           0         4         22         0           0         5         23         0           0         6         24         0           0         7         25         0           0         9         27         0           0         10         28         0           0         11         29         0           0         12         30         0           0         13         31         0           0         14         32         0           0         17         35         0           0         18         36         0 | NC<br>EX4+<br>ATD4+<br>RTD4-<br>COM<br>EX5+<br>RTD5+<br>RTD5+<br>RTD5+<br>RTD5+<br>RTD6+<br>RTD6+<br>RTD6+<br>RTD6+<br>RTD6+<br>RTD6+<br>RTD7+<br>RTD7+<br>RTD7+<br>RTD7-<br>COM<br>NC | NC<br>EX0+<br>ATD0+<br>ATD0-<br>COM<br>EX1+<br>ATD1+<br>ATD1-<br>COM<br>EX2+<br>ATD2+<br>ATD2+<br>ATD2+<br>ATD2+<br>ATD3+<br>ATD3+<br>ATD3-<br>COM<br>NC |           | NC<br>EX4+<br>RTD4+<br>RTD4+<br>COM<br>EX5+<br>RTD5+<br>RTD5-<br>COM<br>EX6+<br>RTD6+<br>RTD6+<br>RTD6+<br>RTD6+<br>RTD6+<br>RTD7+<br>RTD7+<br>RTD7-<br>COM<br>NC | RTD0+<br>COM0<br>RTD1+<br>COM1<br>RTD2+<br>COM3<br>NC<br>RTD3+<br>COM3<br>NC<br>RTD4+<br>COM4<br>RTD5+<br>COM5<br>RTD6+<br>COM5<br>RTD6+<br>COM5 | 20<br>1<br>22<br>1<br>22<br>1<br>22<br>23<br>4<br>5<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>6<br>7<br>8<br>22<br>22<br>23<br>4<br>5<br>6<br>6<br>7<br>8<br>22<br>22<br>23<br>24<br>5<br>6<br>6<br>7<br>8<br>22<br>22<br>23<br>24<br>5<br>6<br>6<br>7<br>8<br>22<br>22<br>7<br>8<br>9<br>22<br>23<br>24<br>5<br>6<br>6<br>7<br>8<br>9<br>22<br>23<br>24<br>5<br>6<br>6<br>7<br>8<br>9<br>22<br>23<br>24<br>11<br>12<br>13<br>33<br>14<br>15<br>5<br>5<br>6<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>11<br>12<br>13<br>33<br>14<br>15<br>5<br>5<br>6<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>8<br>9<br>22<br>7<br>7<br>8<br>9<br>22<br>7<br>7<br>8<br>9<br>22<br>7<br>7<br>8<br>9<br>23<br>7<br>7<br>7<br>8<br>9<br>23<br>7<br>7<br>7<br>7<br>9<br>23<br>7<br>7<br>7<br>9<br>23<br>7<br>7<br>7<br>9<br>23<br>7<br>7<br>7<br>7<br>7<br>9<br>23<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>9<br>2<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | EX0+<br>RTD0<br>EX1+<br>RTD1<br>EX2+<br>RTD2<br>EX3+<br>RTD3<br>NC<br>EX4+<br>RTD4<br>EX4+<br>RTD5<br>EX6+<br>RTD6<br>EX7+<br>RTD6<br>EX7+<br>RTD7<br>NC |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| C                                                                                                                                                  | J                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 7                                                                                                                                                                                      |                                                                                                                                                          | $\square$ | /                                                                                                                                                                 | 7                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ,                                                                                                                                                        |

# **Related Topics**

😰 FPGA Interface

<u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u> Converting Nominal Values to Temperature Values for the NI 9216

### NI 9216 (FPGA Interface)

CompactRIO 8-Channel, 24-Bit, 100 Ω RTD Analog Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| RTD <b>x</b> | RTD input channel <b>x</b> , where <b>x</b> is the number of t<br>he channel. The NI 9216 has RTD channels 0 to 7 |
|--------------|-------------------------------------------------------------------------------------------------------------------|
|              |                                                                                                                   |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

### Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pΩ/LSB for the chann<br>el. Use this value to <u>convert and calibrate</u> NI 921<br>6 data if you set the <b>Calibration Mode</b> to <b>Raw</b><br>in the <u>C Series Module Properties</u> dialog box.                   |
| Offset     | Returns the calibration offset in $\mu\Omega$ for the chan<br>nel. Use this value to convert and calibrate NI 92<br>16 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

## Module Properties

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time in milliseconds it takes to acquire<br>conversion data. This property overwrites the va<br>lue you configure in the <u>C Series Module Propert</u><br><u>ies</u> dialog box. |

| Module ID     | Returns the module ID, 0x77C4 (NI 9216 with spr<br>ing terminal) or 0x77DF (NI 9216 with DSUB). |
|---------------|-------------------------------------------------------------------------------------------------|
| Serial Number | Returns the unique serial number of the module .                                                |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                                                               |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9216 (FPGA Interface)

Right-click an <u>NI 9216</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of ohms. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 10 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• **Conversion Time**—Specifies the time it takes to acquire one point of data from all channels. You can select **200 ms** or **2.5 ms**.

Converting Nominal Values to Temperature Values for the NI 9216 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9216</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module in units of ohms. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node returns uncalibrated, binary values for the module. After you <u>convert</u> <u>these binary values to nominal values</u>, you can convert the nominal resistance values into temperature values. You must convert these values in the host VI.

#### Using a VI to Convert Values

Refer to the RTD to Temp VI in the labview\examples\CompactRIO\Module Specific\NI 9216\NI 9216 Getting Started\NI 9216 Getting S tarted.lvproj for an example of converting nominal resistance values to temperature. You can use the RTD to Temp VI as a subVI in the host VI to convert nominal resistance values to temperature.

#### Using an Equation to Measure Temperature

You can use a linearization curve known as the <u>Callendar-Van Dusen equation</u> in the host VI to measure the temperature of RTDs.

#### NI 9216 (Scan Interface)

CompactRIO 8-Channel, 24-Bit, 100 Ω RTD Analog Input Module

🔊 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

#### **Module Channels**

The NI 9216 has the following channels.
| Channel      | Description                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------|
| RTD <b>x</b> | RTD input channel <b>x</b> , where <b>x</b> is the number of t he channel. The NI 9216 has RTD channels 0 to 7. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9216. Right-click the NI 9216 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Conversion Time**—Specifies the time it takes to acquire one point of data from all channels. You can select **200 ms** or **2.5 ms**.
- **Channels**—Specifies the channel(s) for which you want to configure settings.
- Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Ohms, Degrees Kelvin, Degrees Celsius, Degrees Fahrenheit, or Degrees Rankine.

• **RTD Type**—Specifies the type of RTD connected to the channel by temperature coefficient of resistance (TCR). If you select **Custom**, you must enter the **Callendar-Van Dusen Coefficients** below.

• **Callendar-Van Dusen Coefficients**—Specifies the coefficients to use in the <u>Callendar-Van Dusen equation</u>, a linearization curve for measuring the temperature of an RTD.

#### NI 9217

CompactRIO 4-Channel, 24-Bit, 100  $\Omega$  RTD Analog Input Module

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

## NI 9217 Pinout



# **Related Topics**

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u> <u>Converting Nominal Values to Temperature Values for the NI 9217</u>

# NI 9217 (FPGA Interface)

CompactRIO 4-Channel, 24-Bit, 100Ω RTD Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal     | Description                                                                                                      |
|--------------|------------------------------------------------------------------------------------------------------------------|
| RTD <b>x</b> | RTD input channel <b>x</b> , where <b>x</b> is the number of t he channel. The NI 9217 has RTD channels 0 to 3 . |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pΩ/LSB for the chann<br>el. Use this value to <u>convert and calibrate</u> NI 921<br>7 data if you set the <b>Calibration Mode</b> to <b>Raw</b><br>in the <u>C Series Module Properties</u> dialog box.                   |
| Offset     | Returns the calibration offset in $\mu\Omega$ for the chan<br>nel. Use this value to convert and calibrate NI 92<br>17 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time in milliseconds it takes to acquire<br>conversion data. This property overwrites the va<br>lue you configure in the <u>C Series Module Propert</u><br><u>ies</u> dialog box. |
| Module ID       | Returns the module ID, 0x712B.                                                                                                                                                             |
| Serial Number   | Returns the unique serial number of the module .                                                                                                                                           |
| Vendor ID       | Returns the NI vendor ID, 0x1093.                                                                                                                                                          |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9217 (FPGA Interface)

Right-click an <u>NI 9217</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• **Calibration Mode**—Sets the calibration mode for the C Series module. Select **Calibrated** if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed</u>-<u>point</u> data from the module in units of ohms. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 10 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• **Conversion Time**—Specifies the time it takes to acquire one point of data from all channels. You can select **200 ms** or **2.5 ms**.

Converting Nominal Values to Temperature Values for the NI 9217 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9217</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module in units of ohms. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node returns uncalibrated, binary values for the module. After you <u>convert</u> <u>these binary values to nominal values</u>, you can convert the nominal resistance values into temperature values. You must convert these values in the host VI.

#### Using a VI to Convert Values

Refer to the RTD to Temp VI in the labview\examples\CompactRIO\Module Specific\NI 9217\NI 9217 Getting Started\NI 9217 Getting S tarted.lvproj for an example of converting nominal resistance values to temperature. You can use the RTD to Temp VI as a subVI in the host VI to convert nominal resistance values to temperature.

#### Using an Equation to Measure Temperature

You can use a linearization curve known as the <u>Callendar-Van Dusen equation</u> in the host VI to measure the temperature of RTDs.

# NI 9217 (Scan Interface)

CompactRIO 4-Channel, 24-Bit, 100Ω RTD Analog Input Module

📄 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

## **Module Channels**

The NI 9217 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9217, <b>x</b> is 0 to 3. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9217. Right-click the NI 9217 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.
- **Conversion Time**—Specifies the time it takes to acquire one point of data from all channels. You can select **200 ms** or **2.5 ms**.
- **Channels**—Specifies the channel(s) for which you want to configure settings.
- Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Ohms, Degrees Kelvin, Degrees Celsius, Degrees Fahrenheit, or Degrees Rankine.

• **RTD Type**—Specifies the type of RTD connected to the channel by temperature coefficient of resistance (TCR). If you select **Custom**, you must enter the **Callendar-Van Dusen Coefficients** below.

• **Callendar-Van Dusen Coefficients**—Specifies the coefficients to use in the <u>Callendar-Van Dusen equation</u>, a linearization curve for measuring the temperature of an RTD.

NI 9218

CompactRIO 2-Channel, 24-Bit Dynamic Universal Analog Input Module

#### Software Reference (?)

😂 FPGA Interface | 🞯 Scan Interface

## NI 9218

# NI 9218 Pinout



# NI 9218 Pin Assignments by Mode

| Pin | Mode    |                  |                  |      |         |
|-----|---------|------------------|------------------|------|---------|
|     | Bridge  | Volt             | age              | IEPE | TEDS    |
|     | ±22mV/V | ±65 mV           | ±16V             | ±5V  | Class 1 |
| 1   | EX+     | EX+ <sup>*</sup> | EX+ <sup>*</sup> | _    | _       |
| 2   |         |                  |                  | AI+  | TEDS+   |

| 3                           | EX- | EX-*             | AI-, EX- <sup>*</sup> | AI- | TEDS- |
|-----------------------------|-----|------------------|-----------------------|-----|-------|
| 4                           | RS+ |                  |                       |     |       |
| 5                           | RS- |                  |                       |     |       |
| 6                           | AI+ | AI+              | AI+                   |     | _     |
| 7                           | AI- | AI- <sup>†</sup> |                       |     | _     |
| 8                           | SC  |                  |                       |     |       |
| 9                           | SC  |                  |                       |     |       |
| *Ontional sensor excitation |     |                  |                       |     |       |

Optional sensor excitation.

<sup>†</sup>In ±65 mV mode, you must tie pin 7 (AI-) to pin 3 (EX-).

#### **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Accessing TEDS Information from a Module (FPGA Interface) Acquiring Data from a Module (FPGA Interface) NI 9218 Data Rates Configuring the Data Rate for a Module (FPGA Interface) Understanding Loop Timing for the NI 9218 Synchronizing Multiple C Series Modules

#### NI 9218 (FPGA Interface)

CompactRIO 2-Channel, 24-Bit Dynamic Universal Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

Ľ

**Note** You can <u>synchronize</u> an NI 9218 module with other modules that have a <u>selectable</u> <u>timebase source</u>.

# Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | channel <b>x</b> , where <b>x</b> is the number of the channel<br>. The NI 9218 has channels 0 to 1.                                                                                                                                                                                                                                                                                       |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 13.1072 MHz. Use the FPGA I/O Node in a <u>singl</u><br><u>e-cycle Timed Loop</u> to access this channel. You<br>must <u>export the Onboard Clock of the NI 9218</u> to<br>access this channel.                                                                                      |
| Start         | Channel that controls when the NI 9218 starts a cquiring data. If TRUE is written to the <b>Start</b> cha nnel, the NI 9218 starts acquiring data. When th e NI 9218 is acquiring data, you must write TRUE to the <b>Stop</b> channel before you can access prop erties for the module. If FALSE is written to the <b>S</b> tart channel, no operation is performed.                      |
| Stop          | Channel that controls when the NI 9218 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9218 stops acquiring data. When the<br>NI 9218 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |

You can <u>read TEDS information</u> from the NI 9218.

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | Returns Booleans for each channel that indicate<br>whether there was an excitation fault or open lo<br>op on the channel since the last execution of the<br>Check Cached Status method. When the FPGA I/<br>O Node reads the channels, the FPGA VI determi<br>nes the state of the channels and caches any TR<br>UE value until the Check Cached Status method<br>executes. |
|                     | • Excitation Fault—Returns an array of<br>Boolean values. A value of TRUE in any ind<br>ex indicates that the channel sharing a nu<br>mber with that index detected an excitati<br>on fault on the channel at some point afte<br>r the last time that the Check Cached Stat<br>us method executed.                                                                          |
|                     | • <b>Open Loop</b> —Returns an array of Boole<br>an values. A value of TRUE in any index in<br>dicates that the channel sharing a numbe<br>r with that index detected an open loop o<br>n the channel at some point after the last<br>time that the Check Cached Status metho<br>d executed.                                                                                |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property                  | Description                                                                                                                                                                                                                                                |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Configuration       | Sets the input configuration of the correspondin<br>g channel to one of ten modes: ±60 V; ±16 V; ±16<br>V, 12 V Ex.; ±65 mV; ±65 mV, 12 V Ex.; ±20 mA; ±20<br>mA, 12 V Ex.; ±22 mV/V Bridge, 2 V Ex.; ±22 mV/V<br>Bridge, 3.3 V Ex.; ±5 V IEPE AC Coupled. |
| LSB Weight (±16 V range)  | Returns the LSB weight in pV/LSB for the $\pm 16$ V r ange.                                                                                                                                                                                                |
| LSB Weight (±20 mA range) | Returns the LSB weight in fV/LSB for the $\pm 20\ \text{mA}$ range.                                                                                                                                                                                        |

| LSB Weight (±22 mV/V range)  | Returns the LSB weight in fV/LSB for the ±22 mV<br>/V range.                                                                             |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±5 V IEPE range) | Returns the LSB weight in pV/LSB for the ±5 V IE PE range.                                                                               |
| LSB Weight (±65 mV range)    | Returns the LSB weight in fV/LSB for the $\pm 65 \mbox{ mV}$ range.                                                                      |
| LSB Weight (±60 V range)     | Returns the LSB weight in pV/LSB for the $\pm 60$ V r ange.                                                                              |
| Offset (±16 V range)         | Returns the calibration offset in nV for the $\pm 16~\text{V}$ range.                                                                    |
| Offset (±20 mA range)        | Returns the calibration offset in nV for the $\pm 20~\text{m}$ A range.                                                                  |
| Offset (±22 mV/V range)      | Returns the calibration offset in nV for the $\pm 22$ m V/V range.                                                                       |
| Offset (±5 V IEPE range)     | Returns the calibration offset in nV for the $\pm 5$ V I EPE range.                                                                      |
| Offset (±65 mV range)        | Returns the calibration offset in nV for the $\pm 65~\text{m}$ V range.                                                                  |
| Offset (±60 V range)         | Returns the calibration offset in nV for the $\pm 60$ V range.                                                                           |
| Offset Cal Enable            | Enables offset calibration. This disconnects bot<br>h signal input pins and internally connects a sho<br>rt to the ADC driver circuitry. |
| Shunt Cal Enable             | Controls the shunt calibration switch for each c hannel.                                                                                 |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                       |
|---------------|---------------------------------------------------|
| Data Rate     | Sets the rate at which the NI 9218 acquires data. |
| Module ID     | Returns the module ID, 0x7757.                    |
| Serial Number | Returns the unique serial number of the module .  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                 |

# **Excitation Protection**

The NI 9218 excitation circuit is protected from overcurrent and overvoltage fault conditions. A fault condition also occurs if the voltage supplied to the external power connector on the NI 9218 is below the minimum required voltage, if the excitation pins on the NI 9218 are shorted together, or if the connected load exceeds the powered sensor output current limit. The circuit is automatically disabled in the event of a fault condition. Whenever possible, a channel automatically recovers after the fault is removed.

You must wire error terminals on the FPGA I/O Property Nodes to receive notification of overcurrent and overvoltage faults. LabVIEW returns <u>error 65654</u> if there is an overcurrent or overvoltage fault on at least one channel. If a warning occurs, only the channel(s) with the fault are affected and all other channels on the module continue to function properly without interruption. If an error occurs, the module is unable to recover from the fault condition and you must restart the module after the fault is removed.

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9218 (FPGA Interface)

Right-click an <u>NI 9218</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Refer to the table below for information about the units and encoding of the fixed-point data depending on the channel mode. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the analog input values in the host VI. The default is **Calibrated**.

| Channel Mode        | Units of Fixed-<br>Point Data | IntegerType | Word Length | Integer Word<br>Length | Typical<br>Measurement<br>Range |
|---------------------|-------------------------------|-------------|-------------|------------------------|---------------------------------|
| ±16 V               | Volts                         | Signed      | 35 bits     | 7 bits                 | ±16.3 V                         |
| ±20 mA              | Amps                          | Signed      | 35 bits     | 7 bits                 | 24.4 mA                         |
| ±22 mV/V Brid<br>ge | Volts/volt                    | Signed      | 35 bits     | 7 bits                 | 22.1 mV/V                       |
| ±5 V IEPE           | Volts                         | Signed      | 35 bits     | 7 bits                 | 5.33 V                          |
| ±60 V               | Volts                         | Signed      | 35 bits     | 7 bits                 | ±62.1 V                         |
| ±65 mV              | Volts                         | Signed      | 35 bits     | 7 bits                 | 73.5 mV                         |

• Data Rate—Specifies the rate at which the module acquires data.

• Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.

• **Channels**—Specifies the channel(s) for which you want to select the mode and range.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Selected Channel(s) Settings—Specifies the mode and range for each channel.

• Input Configuration—Sets the mode for the selected channel(s).

**Note** The following channel modes require a connection accessory.

| Channel Mode    | Connection Accessory                   |          |
|-----------------|----------------------------------------|----------|
| ±20 mA          | NI 9983D                               |          |
| ±22 mV/V Bridge | 120 $\Omega$ Quarter-Bridge Completion | NI 9984D |
|                 | $350 \Omega$ Quarter-Bridge Completion | NI 9985D |
|                 | Half-Bridge Completion                 | NI 9986D |
| ±60 V           | NI 9987D                               |          |

#### NI 9218 Data Rates

The frequency of a master timebase ( $\mathbf{f}_{M}$ ) controls the data rate ( $\mathbf{f}_{s}$ ) of the NI 9218. The NI 9218 includes an internal master timebase with a frequency of 13.1072 MHz, but the module can also accept an external master timebase or export its own master timebase.

#### Internal Master Timebase

The following equation provides the available data rates for the NI 9218 with the internal master timebase.

$$f_s = \frac{f_M \div 256}{n}$$

where n is any integer from 1 to 31.

Refer to the following table for the available data rates with the internal master timebase.

| NI 9218 Data Rates (kS/s) |       |       |       |
|---------------------------|-------|-------|-------|
| 51.200                    | 5.689 | 3.012 | 2.048 |
| 25.600                    | 5.120 | 2.845 | 1.969 |
| 17.067                    | 4.654 | 2.695 | 1.896 |
| 12.800                    | 4.267 | 2.560 | 1.829 |
| 10.240                    | 3.938 | 2.438 | 1.765 |

| 8.533 | 3.657 | 2.328 | 1.707 |
|-------|-------|-------|-------|
| 7.314 | 3.413 | 2.226 | 1.652 |
| 6.400 | 3.200 | 2.133 |       |

#### External Master Timebase

The NI 9218 has a different set of data rates when using an external master timebase with a frequency other than 13.1072 MHz. To synchronize the data rate of an NI 9218 with other modules that use master timebases to control sampling, all of the modules must share a single master timebase source.

#### Related Topics

#### FPGA Interface

<u>Synchronizing Multiple C Series Modules</u> <u>Configuring the Data Rate for a Module</u> (FPGA Interface)

Loop Timing for the NI 9218 (FPGA Interface)

The NI 9218 uses an internal master timebase. When creating a loop with an I/O Node that acquires data from the NI 9218, do not use the Loop Timer or Wait functions. If the loop execution time is slower than the data rate of the NI 9218, the FPGA I/O Node returns an overrun warning and continues to read from the module.

The overrun warning means that the data the FPGA I/O Node returns is valid, but the function missed one or more data points since the last time it read data from the NI 9218. The function returns the overrun warning when all of the following conditions are true:

- The NI 9218 is in acquisition mode.
- An FPGA I/O Node that is acquiring data from the module executes at least once after you put the module in acquisition mode.
- The FPGA I/O Node did not read one or more data points since the previous time the function executed.

#### Avoiding Overrun Warnings with the NI 9218

Follow these guidelines when developing an FPGA VI to avoid overrun warnings.

 Ensure that the loop does not execute slower than the data rate of the NI 9218.

• When reading from the NI 9218 and an additional internally timed module in the same loop, use one FPGA I/O Node to read all module channels. You also must synchronize the NI 9218 and the additional internally timed module.

• You can read from an NI 9218 and a non-internally timed analog input module in the same loop if the other module can acquire data as fast or faster than the data rate of the NI 9218. If you use the same FPGA I/O Node to read data from the modules, the FPGA I/O Node does not return data for the other module until the NI 9218 acquires data.

• Use different loops for the NI 9218 and another analog input module that acquires data slower than the NI 9218.

**Note** If your application acquires multiple buffers of data from an internally timed module and the timing relationship between them is not important, you can ignore the overrun warning returned with the first point of each buffer.

Related Topics

FPGA Interface Synchronizing Multiple C Series Modules Configuring the Data Rate for a Module (FPGA Interface)

## NI 9218 (Scan Interface)

CompactRIO 2-Channel, 24-Bit Dynamic Universal Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

## **Module Channels**

The NI 9218 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9218, <b>x</b> is 0 to 1. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9218. Right-click the NI 9218 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to configure settings.
- Input Configuration—Sets the input configuration of the corresponding channel to one of ten modes: ±60 V; ±16 V; ±16 V, 12 V Ex.; ±65 mV; ±65 mV, 12 V Ex.; ±20 mA; ±20 mA, 12 V Ex.; ±22 mV/V Bridge, 2 V Ex.; ±22 mV/V Bridge, 3.3 V Ex.; ±5 V IEPE AC Coupled.

#### NI 9219

CompactRIO 4-Channel, 24-Bit Universal Analog Input Module

#### Software Reference (?)

FPGA Interface | Scan Interface

| Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Terminal | Signal Name         | Signal Description                   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------|--------------------------------------|
| <b></b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1        | T+                  | TEDS Data                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 2        | T-                  | TEDS COM                             |
| Ch 0 0140<br>0250<br>0360                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3        | EX+/HI <sup>1</sup> | Positive excitation or in put signal |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4        | HI                  | Positive input signal                |
| Ch 1 0140<br>0250<br>0360                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 5        | EX-/LO <sup>1</sup> | Negative excitation or i nput signal |
| Ch 2<br>Ch 2<br>Ch 3<br>Ch 3 | 6        | LO                  | Negative input signal                |

## NI 9219 Pinout

<sup>1</sup> Depending on the mode, terminals 3 and 5 are either the excitation or input signals.

# NI 9219 Pin Assignments by Mode

| Mode                  | Terminal |    |     |    |     |    |
|-----------------------|----------|----|-----|----|-----|----|
|                       | 1        | 2  | 3   | 4  | 5   | 6  |
| Voltage               | T+       | T- | —   | HI | LO  |    |
| Current               | T+       | T- | HI  |    | LO  |    |
| 4-Wire Resist<br>ance | T+       | T- | EX+ | HI | EX- | LO |
| 2-Wire Resist<br>ance | T+       | T- | HI  | _  | LO  | _  |
| Thermocoup<br>le      | T+       | T- | _   | HI | LO  | _  |
| 4-Wire RTD            | T+       | T- | EX+ | HI | EX- | LO |
| 3-Wire RTD            | T+       | T- | EX+ |    | EX- | LO |
| Quarter-Brid<br>ge    | T+       | T- | HI  | _  | LO  | _  |

| Half-Bridge | T+ | T- | EX+ | HI | EX- | —  |
|-------------|----|----|-----|----|-----|----|
| Full-Bridge | T+ | T- | EX+ | HI | EX- | LO |
| Digital In  | T+ | T- |     | HI | LO  | _  |
| Contact     | T+ | T- | HI  |    | LO  |    |

## **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Accessing TEDS Information from a Module (FPGA Interface)</u> <u>Converting NI 9219 Data</u> <u>Configuring Modes and Ranges for the NI 9219</u> <u>Configuring the Digital In Threshold for the NI 9219</u>

## NI 9219 (FPGA Interface)

CompactRIO 4-Channel, 24-Bit Universal Analog Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal     | Description                                                                                                                                                                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CHx          | channel <b>x</b> , where <b>x</b> is the number of the channel<br>. The NI 9219 has channels 0 to 3.                                                                                                                                                                  |
| CJC <b>x</b> | Cold-junction compensation channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9219 has C JC channels 0 to 3. If a channel is in Thermocou ple mode, you can read CJC data for the channe l. You must <u>convert the CJC data</u> to temperature . |

You can <u>read TEDS information</u> from the NI 9219.

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property             | Description                                                 |
|----------------------|-------------------------------------------------------------|
| Voltage Range        | <u>Sets the range</u> of a channel in Voltage mode.         |
| Resistance Range     | Sets the range of a channel in Resistance mode.             |
| RTD Range            | Sets the range of a channel in RTD mode.                    |
| Quarter Bridge Range | Sets the range of a channel in Quarter Bridge m ode.        |
| Full Bridge Range    | Sets the range of a channel in Full Bridge mode.            |
| Digital Threshold    | <u>Sets the threshold</u> of a channel in Digital In mod e. |

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from all channels. You can select <b>High Speed</b><br>, <b>Best 60 Hz Rejection</b> , <b>Best 50 Hz Rejectio</b><br><b>n</b> , or <b>High Resolution</b> . Refer to the NI 9219 har<br>dware documentation on ni.com/manuals for m<br>ore information about these conversion times. T<br>his property overwrites the value you configure i<br>n the <u>C Series Module Properties</u> dialog box. |

| Module ID     | Returns the module ID, 0x730C.                   |
|---------------|--------------------------------------------------|
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# **Excitation Protection**

The NI 9219 excitation circuit is protected from overcurrent and overvoltage fault conditions. The circuit is automatically disabled in the event of a fault condition. Whenever possible, a channel automatically recovers after the fault is removed. You must wire error terminals on the FPGA I/O Property Nodes to receive notification of overcurrent and overvoltage faults. LabVIEW returns <u>error 65544 or 65548</u> if there is an overcurrent or overvoltage fault on at least one channel. If a warning occurs, only the channel(s) with the fault are affected and all other channels on the module continue to function properly without interruption. If an error occurs, the module is unable to recover from the fault condition and you must restart the module after the fault is removed.

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9219 (FPGA Interface)

Right-click an <u>NI 9219</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the FPGA I/O Node to return calibrated, fixedpoint data from the module. Refer to the table below for information about the units and encoding of the fixed-point data depending on the channel mode. If you select Calibrated and an NI 9219 channel is in Thermocouple mode, you must <u>convert</u> the CJC data in the host VI. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the analog input values in the host VI. The default is Calibrated.

| Channel Mode           | Units of Fixed-<br>Point Data | IntegerType | Word Length | IntegerWord<br>Length |
|------------------------|-------------------------------|-------------|-------------|-----------------------|
| Voltage                | Volts                         | Signed      | 32 bits     | 7 bits                |
| Current                | Amps                          | Signed      | 32 bits     | –1 bits               |
| Resistance and R<br>TD | Ohms                          | Unsigned    | 32 bits     | 14 bits               |
| Thermocouple           | Volts                         | Signed      | 32 bits     | –1 bits               |
| Quarter Bridge         | Volts/volt                    | Unsigned    | 32 bits     | 14 bits               |
| Half Bridge            | Volts/volt                    | Signed      | 32 bits     | 7 bits                |
| Full Bridge            | Volts/volt                    | Signed      | 32 bits     | -1 bits               |

• **Channels**—Specifies the channel(s) for which you want to select the mode and range.

Selected Channel(s) Settings—Specifies the mode and range for each channel.

- **Channel Mode**—Sets the mode for the selected channel(s).
- **Range**—Sets the range for the selected channel(s).
- **Threshold**—<u>Sets the Digital In threshold</u> for the selected channel(s). This option is available only if you select **Digital In** for the channel mode.

Conversion Time—Specifies the time it takes to acquire one point of data from all channels. You can select High Speed, Best 60 Hz Rejection, Best 50 Hz Rejection, or High Resolution. Refer to the NI 9207 hardware

documentation on ni.com/manuals for more information about these conversion times.

• Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.

#### Converting NI 9219 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9219</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. If you set the **Calibration Mode** to **Calibrated** and an NI 9219 channel is in Thermocouple mode, you must convert the fixed-point CJC data to binary CJC data and then convert the binary CJC data to temperature. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return binary values from the module that are calibrated based on the <u>range</u> of the selected mode. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to meaningful engineering units. If you set the **Calibration Mode** to **Raw** and an NI 9219 channel is in Thermocouple mode, you also must convert the binary CJC data to temperature. You must convert these values in the host VI.



**Note** The equations below apply only to the NI 9219. If you are using the NI 9219E board-only module, refer to the KnowledgeBase for the correct equations.

#### Using a VI to Convert and Adjust Binary Values

Refer to the NI 9219 Binary to Nominal VI in the labview\examples\CompactR IO\Module Specific\NI 9219\NI 9219 Scaling Utility directory for an example of converting and adjusting binary input values. You can use the polymorphic NI 9219 Binary to Nominal VI as a subVI in the host VI to convert and adjust binary input values.

#### Using an Equation to Convert Binary Values

You can use the following equation in the host VI to convert the binary input values to engineering units for each channel:

#### Engineering Units<sup>\*</sup> = Binary Value × (Range High – Range Low) $\div 2^{24}$

where

**Binary Value** is the value returned by the FPGA I/O Node

**Range High** is the upper value of the input range <sup>†</sup>

**Range Low** is the lower value of the input range.

<sup>\*</sup>Engineering units are equivalent to the units of the mode input range listed in the NI 9219 hardware documentation on ni.com/manuals.

<sup>†</sup>Refer to the NI 9219 hardware documentation on ni.com/manuals for the input ranges for each mode. For modes that have only one input range value, use 0 as the lower value of the input range.

#### **Digital In**

Digital In mode returns a Boolean value, where FALSE is equivalent to any voltage below the specified <u>threshold</u> and TRUE is equivalent to any voltage above the specified threshold.

#### **Open Contact**

Open Contact mode returns a Boolean value, where FALSE indicates a closed circuit and TRUE indicates a open circuit.

#### Using an Equation to Convert Fixed-Point CJC Data

You can use the following equation in the host VI to convert fixed-point CJC data to binary CJC data:

**Binary CJC Data** = (**Fixed-Point CJC Data**)  $\div$  (0.250  $\div$  (2<sup>24</sup> – 1))

Using Equations to Convert Binary CJC Data

You can use the following equations in the host VI to convert binary CJC data to temperature:

Calculate the resistance of the thermistor:

#### $R_{T} = 10000 \div [(2^{16} \div Binary CJC Data) - 1]$

Calculate the CJC temperature:

 $T = [1 \div [A + B(ln(R_T)) + C(ln(R_T))^3]] - (273.15 + OffsetConstant)$ 

where

T = temperature in °C A =  $1.2873851 \times 10^{-3}$ B =  $2.3575235 \times 10^{-4}$ C =  $9.4978060 \times 10^{-8}$ R<sub>T</sub> = thermistor resistance reading OffsetConstant<sup>\*</sup> = 1.5

<sup>\*</sup>The **OffsetConstant** is the typical temperature gradient between the CJC sensor and the thermocouple cold junction.

Refer to the National Institute of Standards and Technology (NIST) Monograph 175 thermocouple reference tables for more information about converting and adjusting thermocouple values.

Configuring Modes and Ranges for the NI 9219 (FPGA Interface)

You can configure the mode and range for each channel on the NI 9219 at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the range for each channel at run time using the <u>FPGA I/O Property Node</u>. The execution of an I/O Property Node that is configured with a **Range** property overwrites the value you configured in the **C Series Module Properties** dialog box.

Configuring Modes and Ranges Using the C Series Module Properties Dialog Box

Complete the following steps to configure the channel(s) mode and range using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an NI 9219.
- 2. Right-click the NI 9219 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.

- 3. Select the channel(s) for which you want to configure the mode and range from the **Channels** table. You can select more than one channel by holding the <Ctrl> or <Shift> key when selecting channels.
- 4. Select the mode for the channel(s) from the **Channel Mode** pull-down menu. If you select **Digital In** mode, skip the following steps and <u>set the threshold</u>. If you select **Open Contact** mode, skip the following step.
- 5. Select the range from the **Range** pull-down menu for the selected channel(s).
- 6. Click the **OK** button.
- 7. Select File»Save All in the Project Explorer window.

#### Configuring Ranges Using the FPGA I/O Property Node

Complete the following steps to configure the channel range using the FPGA I/O Property Node.

- 1. <u>Create FPGA I/O items</u> for the channel of the NI 9219 for which you want to configure a **Range** property. The channel must be set to Voltage mode, Resistance mode, RTD mode, Quarter Bridge mode, or Full Bridge mode.
- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the NI 9219 channel for which you want to configure the range.
- 3. Click the **Property** section and select the **Range** property from the shortcut menu.
- 4. Right-click the **Range** input and select **Create**»**Control** from the shortcut menu.
- 5. On the front panel of the VI, select a rate from the **Range** pull-down menu.

You can change the channel range at run time by writing to the control from the host VI. Refer to the NI 9219 Getting Started VI in the labview\examples\CompactR IO\Module Specific\NI 9219\NI 9219 Getting Started\NI 9219 Getting Started.lvproj for an example of changing a channel range using the FPGA I/O Property Node.

#### Configuring the Digital In Threshold for the NI 9219 (FPGA Interface)

Channels in Digital In mode on the NI 9219 have a 0–60 V unipolar threshold. The default value of the Digital In mode threshold is 1.5 V. You can configure the threshold at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the threshold at run time using the <u>FPGA I/O Property</u> <u>Node</u>. The execution of an I/O Property Node that is configured with a **Digital Threshold** property overwrites the value you configured in the **C Series Module Properties** dialog box.

Configuring the Digital In Threshold Using the C Series Module Properties Dialog Box

Complete the following steps to configure the Digital In threshold for the NI 9219 using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an NI 9219.
- 2. Right-click the NI 9219 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the Digital In threshold from the **Channels** table. You can select more than one channel by holding the <Ctrl> or <Shift> key when selecting channels.
- 4. Select **Digital In** from the **Channel Mode** pull-down menu.
- 5. Enter a value between 0 and 60 in the **Threshold** text box for the selected channel(s).
- 6. Click the **OK** button.
- 7. Select File»Save All in the Project Explorer window.

Configuring the Digital In Threshold Using the FPGA I/O Property Node

Complete the following steps to configure the Digital In threshold using the FPGA I/O Property Node.

- 1. <u>Create FPGA I/O items</u> for the channel of the NI 9219 for which you want to configure the **Digital Threshold** property. The channel must be set to Digital In mode.
- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the NI 9219 channel for which you want to configure the Digital In threshold.
- 3. Click the **Property** section and select **Digital Threshold** from the shortcut menu.
- 4. Right-click the **Digital Threshold** input and select **Create**»**Control** from the shortcut menu.
- 5. On the front panel of the VI, enter a binary value in the **Digital Threshold** control. You can use the following equation in the host VI to calculate the threshold value:

Threshold (binary) = Threshold (volts)  $\times 2^{24} \div 60$ 

You can change the Digital In threshold at run time by writing to the control from the host VI. Refer to the NI 9219 Digital Threshold VI in the labview\examples\Com pactRIO\Module Specific\NI 9219\NI 9219 Digital Threshold\ NI 9219 Digital Threshold.lvproj for an example of configuring the NI 9219 Digital In threshold using the FPGA I/O Property Node.

## NI 9219 (Scan Interface)

CompactRIO 4-Channel, 24-Bit Universal Analog Input Module

👰 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data or Boolean data in units determined by the measurement mode you select on the **C Series Module Properties** dialog box. The following table shows the units for the different modes.

| Mode    | Data Units |
|---------|------------|
| Voltage | Volts      |

| Current      | Amps                                         |
|--------------|----------------------------------------------|
| Resistance   | Ohms                                         |
| Thermocouple | Volts or Temperature Units                   |
| RTD          | Ohms or Temperature Units                    |
| Bridge       | Volts/Volt                                   |
| Digital In   | Boolean                                      |
| Open Contact | Boolean                                      |
| EV.          | Note The Scan Interface applies Autozero and |

**Note** The Scan Interface applies Autozero and cold-junction compensation to NI 9219 data on channels configured for thermocouple mode.

## Module Channels

The NI 9219 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| СНх     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9219, <b>x</b> is 0 to 3. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9219. Right-click the NI 9219 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to configure settings.
- Mode—Specifies the measurement mode for the selected channel(s).

• **Range**—Specifies the range for the selected channel(s).

• **Thermocouple Type**—Specifies the type of thermocouple connected to a channel in thermocouple mode.

• **Measurement Units**—Specifies the units for data to be returned from the selected channel(s) configured for thermocouple or RTD mode.

 RTD Type—Specifies the type of RTD connected to the channel by temperature coefficient of resistance (TCR). If you select Custom, you must enter the Callendar-Van Dusen Coefficients below.

• **Callendar-Van Dusen Coefficients**—Specifies the coefficients to use in the <u>Callendar-Van Dusen equation</u>, a linearization curve for measuring the temperature of an RTD.

• **Threshold**—Specifies the minimum high level in volts for the selected channel(s) configured for Digital In mode. The range of valid threshold values is 0–60.

Conversion Time—Determines the time it takes to read all channels of the module. You can select High Speed, Best 60 Hz Rejection, Best 50 Hz Rejection, or High Resolution. Refer to the NI 9219 hardware documentation on ni.com/manuals for more information about these conversion times.

#### NI 9220

CompactRIO 16-Channel, ±10 V, 16-Bit Simultaneous Analog Input Module

#### Software Reference (?)

FPGA Interface

| Al0+ 0 13 Al0- Al0+ Al0- Al0-   Al1+ 2 2 Al1- Al1- Al1- Al1-   Al2+ 3 2 Al2- Al2- Al2- Al2-   Al3+ 3 2 Al3- Al3- Al2- Al1- Al2-   Al4+ Al4- Al4- Al2- Al3- Al3- Al2- Al1-   Al4+ Al4- Al4- Al4- Al4- Al4- Al4- Al4-   Al5- Al5- Al5- Al5- Al5- Al6- Al5- Al6-   Al7+ 3 3 Al7- Al7+ 2 8 0 COM 28 1 Al6+   Al9+ 3 Al9- Al9- Al9- Al9- Al9- Al9- Al6+ Al7- Al6+ Al6+ Al7- Al6+ Al7+ Al6+ Al7+ Al6+ Al7+ |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

# NI 9220 Pinout

# **Related Topics**

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u>

# NI 9220 (FPGA Interface)

CompactRIO 16-Channel, ±10 V, 16-Bit Simultaneous Analog Input Module

🔊 Open example

Sind related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>simultaneously read from</u> multiple channels on the NI 9220.

# User-Controlled I/O Sampling

You can use the following User-Controlled I/O Sampling functions to perform I/O with more specific control over the I/O hardware on the FPGA.

| Function                         | Туре            |
|----------------------------------|-----------------|
| Generate I/O Sample Pulse Method | Module function |
| Get I/O Read Status Method       | I/O function    |
| Read I/O Method                  | I/O function    |
| Reset I/O Method                 | Module function |



**Note** You must call the Reset I/O Method function first to prepare the NI 9220 to use the other User-Controlled I/O Sampling functions.

#### **Terminals in Software**

Use the FPGA I/O Node or User-Controlled I/O Sampling functions to access the following terminals for this device.

| Terminal | Description                                                                                                             |
|----------|-------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9220 has AI channels 0 to<br>15. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                               |
|------------|-----------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe           |
|            | l. Use this value to <u>convert and calibrate</u> NI 9220 |

|        | data if you set the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series Module Properties</u> dialog box.                                                                                                                              |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>20 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID.                           |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9220 (FPGA Interface)

Right-click an <u>NI 9220</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module in units of volts. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data for the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

## NI 9220 (Scan Interface)

CompactRIO 16-Channel, ±10 V, 16-Bit Simultaneous Analog Input Module

📄 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9220 has the following channels.

| Channel | Description                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9220 has AI channels 0 to<br>15. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9220. Right-click the NI 9220 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

COM NC

CON

CON

CON

co

COM NC

COM

#### NI 9221

CompactRIO 8-Channel, ±60 V, 12-Bit Analog Input Module

#### Software Reference (?)

😰 FPGA Interface | 🕝 Scan Interface

#### NI 9221 Pinout



# Related Topics

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u> <u>Configuring the Minimum Time Between Conversions for the NI 9201/9221</u> <u>Understanding NI 9201/9221 Scanning</u>
## NI 9221 (FPGA Interface)

CompactRIO 8-Channel, ±60 V, 12-Bit Analog Input Module

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9221 has AI channels 0 to<br>7. |

You can <u>configure the minimum time between conversions</u> and <u>understand</u> <u>scanning</u> for these channels.

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9221<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box. |

| Offset | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92            |
|--------|--------------------------------------------------------------------------------------------------------------------|
|        | 21 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br>w in the <b>C Series Module Properties</b> dialog b |
|        | ox.                                                                                                                |

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x70A5.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9201/9221 (FPGA Interface)

Right-click an <u>NI 9201</u> or <u>NI 9221</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 16 bits and an integer word length of 5 bits for the NI 9201 and 7 bits for the NI 9221. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

 Minimum Time Between Conversions—Specifies the <u>minimum time</u> between conversions in μs.

Configuring the Minimum Time Between Conversions for the NI 9201/9221 (FPGA Interface)

You can configure the minimum time between conversions for the <u>NI 9201/9221</u> in the <u>C Series Module Properties</u> dialog box.

Complete the following steps to configure the minimum time between conversions for the NI 9201/9221.

- 1. <u>Configure</u> the CompactRIO system, and add an NI 9201/9221.
- 2. Right-click the NI 9201/9221 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Enter a value between 0 and 10 μs in increments of 25 ns in the **Minimum Time Between Conversions** text box.
- 4. Click the **OK** button.
- 5. Select File»Save All in the Project Explorer window.

Ľ

**Note** The default minimum time between conversions for the NI 9201 is 2 µs, and the default minimum time between conversions for the NI 9221 is 1.25 µs. The accuracy specifications in the NI 9201 and NI 9221 hardware documentation on ni.com/manuals are based on these default values. Refer to the

following tables for examples of how the value you enter in the

Minimum Time Between Conversions text

box affects the actual time between conversions and the accuracy of the module.

Refer to the following table if you are using a chassis other than the NI 9151 R Series Expansion chassis.

| Module   | Sampling Data<br>from a Single<br>or Multiple Channel<br>s? | Minimum Time<br>Between Conversio<br>ns <sup>*</sup> | Able to Achieve<br>Specified Time<br>Between Conversio<br>ns? <sup>**</sup> | Module Accuracy               |
|----------|-------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------|-------------------------------|
| NI 9201  | Single                                                      | ≥ 1.25 µs                                            | Yes                                                                         | Module accuracy n ot affected |
|          |                                                             | < 1.25 µs                                            | No                                                                          | Module accuracy n ot affected |
| Multiple | ≥2 µs                                                       | Yes                                                  | Module accuracy n ot affected                                               |                               |
|          |                                                             | < 2 µs                                               | No                                                                          | Module accuracy d<br>egrades  |
| NI 9221  | Single                                                      | ≥ 1.25 µs                                            | Yes                                                                         | Module accuracy n ot affected |
|          |                                                             | < 1.25 µs                                            | No                                                                          | Module accuracy n ot affected |
| Multiple | ≥ 1.25 µs                                                   | Yes                                                  | Module accuracy n ot affected                                               |                               |
|          |                                                             | < 1.25 µs                                            | No                                                                          | Module accuracy d<br>egrades  |

Refer to the following table if you are using the NI 9151 R Series Expansion chassis.

| Module  | Sampling Data<br>from a Single<br>or Multiple Channel<br>s? | Minimum Time<br>Between Conversio<br>ns <sup>*</sup> | Able to Achieve<br>Specified Time<br>Between Conversio<br>ns? <sup>**</sup> | Module Accuracy               |
|---------|-------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------|-------------------------------|
| NI 9201 | Single                                                      | ≥2.1 µs                                              | Yes                                                                         | Module accuracy n ot affected |

|         |                           | < 2.1 µs                      | No                               | Module accuracy n<br>ot affected |
|---------|---------------------------|-------------------------------|----------------------------------|----------------------------------|
|         | Multiple                  | ≥2.1 µs                       | Yes                              | Module accuracy n<br>ot affected |
|         |                           | < 2.1 $\mu$ s and ≥ 2 $\mu$ s | No                               | Module accuracy n<br>ot affected |
|         |                           | < 2 µs                        | No                               | Module accuracy d<br>egrades     |
| NI 9221 | NI 9221 Single            | ≥ 2.1 µs                      | Yes                              | Module accuracy n<br>ot affected |
|         |                           | < 2.1 µs                      | No                               | Module accuracy n<br>ot affected |
|         | Multiple                  | ≥2.1 µs                       | Yes                              | Module accuracy n<br>ot affected |
|         | < 2.1 µs and ≥ 1.25<br>µs | No                            | Module accuracy n<br>ot affected |                                  |
|         |                           | < 1.25 µs                     | No                               | Module accuracy d<br>egrades     |

<sup>\*</sup> The value you set in the **C Series Module Properties** dialog box.

<sup>\*\*</sup> The actual time between conversions depends on how you develop the FPGA VI. Y es indicates that it is possible to write an FPGA VI that can sustain the minimum time between conversions specified in the **C Series Module Properties** dialog box. No indicates that the minimum time between conversions specified in the **C Series Module Properties** dialog box is too low and you may not be able to write an FPGA VI that can sustain the specified time.

#### Understanding NI 9201/9221 Scanning (FPGA Interface)

To scan the channels of the <u>NI 9201/9221</u>, configure an <u>FPGA I/O Node</u> with the channels you want to acquire from the module. The module implements a pipeline that is automatically managed by the FPGA I/O Node. Channels within the FPGA I/O Node are sampled in numerical order regardless of the order they appear in the node.

The first time an FPGA I/O Node configured with channels on an NI 9201/9221 module executes, the module performs two setup conversions before converting

the first channel. The two setup conversions prime the pipeline for subsequent FPGA I/O Node reads. The module does not repeat the setup conversions unless the FPGA I/O Node channel configuration changes and the pipeline needs to be primed again.

## NI 9221 (Scan Interface)

CompactRIO 8-Channel, ±60 V, 12-Bit Analog Input Module

应 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9221 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9221, <b>x</b> is 0 to 7. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9221. Right-click the NI 9221 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

NI 9222

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous, Channel-to-Channel Isolated Analog Input Module

Software Reference (?)

FPGA Interface

### NI 9222 Pinout



# **Related Topics**

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u>

# NI 9222 (FPGA Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous, Channel-to-Channel Isolated Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>simultaneously read from</u> multiple channels on the NI 9222.

# User-Controlled I/O Sampling

You can use the following User-Controlled I/O Sampling functions to perform I/O with more specific control over the I/O hardware on the FPGA.

| Function                         | Туре            |
|----------------------------------|-----------------|
| Generate I/O Sample Pulse Method | Module function |
| Get I/O Read Status Method       | I/O function    |
| Read I/O Method                  | I/O function    |
| Reset I/O Method                 | Module function |



**Note** You must call the Reset I/O Method function first to prepare the NI 9222 to use the other User-Controlled I/O Sampling functions.

## **Terminals in Software**

Use the FPGA I/O Node or User-Controlled I/O Sampling functions to access the following terminals for this device.

Terminal

Description

| Analog input channel <b>x</b> , where <b>x</b> is the number |
|--------------------------------------------------------------|
| of the channel. The NI 9222 has AI channels 0 to             |
| 3.                                                           |

## Arbitration

Alx

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9222<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>22 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x7445.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9222/9223 (FPGA Interface)

Right-click an <u>NI 9222</u> or <u>NI 9223</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data for the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

## NI 9222 (Scan Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous, Channel-to-Channel Isolated Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9222 has the following channels.

| Channel | Description                                                                                                            |
|---------|------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9222 has AI channels 0 to<br>3. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9222. Right-click the NI 9222 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9223

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous, Channel-to-Channel Isolated Analog Input Module

Software Reference (?)

#### FPGA Interface

### NI 9223 Pinout



# **Related Topics**

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u>

## NI 9223 (FPGA Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous, Channel-to-Channel Isolated Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from</u> multiple channels on the NI 9223.

# User-Controlled I/O Sampling

You can use the following User-Controlled I/O Sampling functions to perform I/O with more specific control over the I/O hardware on the FPGA.

| Function                         | Туре            |
|----------------------------------|-----------------|
| Generate I/O Sample Pulse Method | Module function |
| Get I/O Read Status Method       | I/O function    |
| Read I/O Method                  | I/O function    |
| Reset I/O Method                 | Module function |



**Note** You must call the Reset I/O Method function first to prepare the NI 9223 to use the other User-Controlled I/O Sampling functions.

#### Terminals in Software

Use the FPGA I/O Node or User-Controlled I/O Sampling functions to access the following terminals for this device.

| Terminal | Description                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9223 has AI channels 0 to<br>3. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9223<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>23 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x74EC.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9222/9223 (FPGA Interface)

Right-click an <u>NI 9222</u> or <u>NI 9223</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data for the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

## NI 9223 (Scan Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous, Channel-to-Channel Isolated Analog Input Module

🔊 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9223 has the following channels.

| Channel | Description                                                                                                            |
|---------|------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9223 has AI channels 0 to<br>3. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9223. Right-click the NI 9223 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9224

CompactRIO 8-Channel, ±10V 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

FPGA Interface

#### NI 9224 Pinout



# **Related Topics**

FPGA Interface Converting NI 9224 Data

## NI 9224 (FPGA Interface)

CompactRIO 8-Channel, ±10V 24-Bit Simultaneous Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9224 has AI channels 0 to<br>7. |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

## **Module Methods**

This device does not support any module methods.

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed (1k S/s)</b> ,<br><b>Medium Speed (100 S/s)</b> , <b>Medium Resoluti</b><br>on (50/60Hz rejection – 12 S/s), or High Re<br>solution (50/60Hz rejection – 2 S/s). This pr<br>operty overwrites the value you configure in the<br><u>C Series Module Properties</u> dialog box. |

|               | Returns the conversion time setting when configured to read. |
|---------------|--------------------------------------------------------------|
| Module ID     | Returns the module ID, 0x780D.                               |
| Serial Number | Returns the unique serial number of the module .             |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                            |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9224 (FPGA Interface)

Right-click an <u>NI 9224</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the binary values to engineering units. The default is **Calibrated**. Conversion Time—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select High Speed (1k S/s), Medium Speed (100 S/s), Medium Resolution (50/60Hz rejection – 12 S/s), or High Resolution (50/60Hz rejection – 2 S/s). The default is High Resolution (50/60Hz rejection – 2 S/s).

Converting NI 9224 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9224</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

Using an Equation to Convert Binary Values to Voltage

You can use the following equation in the host VI to convert binary voltage values to volts:

#### Voltage = Binary Value × 1257533 pV/LSB

where

**Binary Value** is the value returned by the FPGA I/O Node.

## NI 9224 (Scan Interface)

CompactRIO 8-Channel, ±10V 24-Bit Simultaneous Analog Input Module

🔊 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

## **Module Channels**

The NI 9224 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9224, <b>x</b> is 0 to 7. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9224. Right-click the NI 9224 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

 Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select Medium Speed, High Speed, Medium Resolution, or High Resolution. Refer to the NI 9224 hardware documentation on ni.com/manuals for more information about the Medium Speed, High Speed, Medium Resolution, or High Resolution conversion times.

#### NI 9225

CompactRIO 3-Channel, 300 V<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

📴 FPGA Interface | 🕝 Scan Interface

### NI 9225 Pinout



# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Acquiring Data from a Module (FPGA Interface) Configuring the Master Timebase Source for a Module (FPGA Interface) Configuring the Data Rate for a Module (FPGA Interface) Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules Understanding Loop Timing (FPGA Interface)

# NI 9225 (FPGA Interface)

CompactRIO 3-Channel, 300 V<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

🔊 Open example

🔍 Find related examples

# FPGA I/O Node

You can use an FPGA I/O Node, configured for reading, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9225. You can also <u>synchronize</u> an NI 9225 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

### **Terminals in Software**

E

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9225 has AI channels 0 to<br>2. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                                                                             |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 12.8 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9225</u> to ac<br>cess this channel.                                                                                                                                                                                                                                                                                                                        |
| Start         | Channel that controls when the NI 9225 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9225 starts acquiring data. When th<br>e NI 9225 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.<br>Refer to the NI 9225 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9225 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels. |

| Stop | Channel that controls when the NI 9225 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9225 stops acquiring data. When the<br>NI 9225 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Refer to the NI 9225 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9225\NI 9225 Getting<br>Started\NI 9225 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                              |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pV/LSB for the channe<br>l. Use this value to <u>convert and calibrate</u> NI 9225<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box. |
| Offset     | Returns the calibration offset in μV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>25 data if you set the <b>Calibration Mode</b> to <b>Ra</b>                                                             |

**w** in the **C Series Module Properties** dialog b ox.

## Module Properties

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9225 acquires data. |
| Module ID     | Returns the module ID, 0x7383.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

## Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9225 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)

Right-click an <u>NI 9225/NI 9227/NI 9229/NI 9238/NI 9239/NI 9246/NI 9247</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module.

• Select **Calibrated**, which is the default, if you want the <u>FPGA I/O Node</u> to return calibrated, signed, <u>fixed-point</u> data from the module. The following table describes the units and integer word length of the returned data:

| Module  | Units | Word Length (bits) | Integer Word Length<br>(bits) |
|---------|-------|--------------------|-------------------------------|
| NI 9225 | V     | 24                 | 10                            |
| NI 9227 | A     | 24                 | 5                             |
| NI 9229 | V     | 24                 | 7                             |
| NI 9238 | V     | 24                 | 1                             |
| NI 9239 | V     | 24                 | 5                             |
| NI 9246 | A     | 24                 | 7                             |
| NI 9247 | A     | 24                 | 9                             |

• Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

#### NI 9225 (Scan Interface)

CompactRIO 3-Channel, 300 V<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9225 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9225, <b>x</b> is 0 to 2. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9225. Right-click the NI 9225 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9226

CompactRIO 8-Channel, 24-Bit, 1000 Ω RTD Analog Input Module

#### Software Reference (?)

FPGA Interface

#### NI 9226 Pinout

| NC 1 190 NC   EX0+ 2 200 EX4   RTD0+ 3 210 RTD   RTD0- 4 220 RTD   RTD0- 4 220 RTD   COM 5 230 COM   EX1+ 0 6 240 EX5   RTD1+ 7 250 RTD   COM 9 270 COM   EX2+ 010 280 EX6   RTD2- 012300 RTD   COM 013310 COM   EX3+ 014 320 EX7   RTD3+ 016 340 RTD   COM 017 350 COM   NC 018 360 NC | NC Q1199 NC   4+ EX0+ Q2200 EX   04+ RTD0+ Q3212 RT   04- RTD0- Q4220 RT   M COM Q5200 EX   5+ EX1+ Q62400 EX   05- RTD1+ Q7250 RT   05- RTD1- Q8200 RT   05- RTD1- Q8200 RT   05- RTD2- Q12300 EX   06- RTD2- Q12300 EX   06- RTD2- Q12300 EX   06- RTD2- Q13200 EX   06- RTD2- Q13200 EX   07- RTD3+ Q13200 EX   07- RTD3- <th>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C<br/>C</th> | C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|

## **Related Topics**

😰 FPGA Interface

<u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u> <u>Converting Nominal Values to Temperature Values for the NI 9226</u>

## NI 9226 (FPGA Interface)

CompactRIO 8-Channel, 24-Bit, 1000 Ω RTD Analog Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| RTD <b>x</b> | RTD input channel <b>x</b> , where <b>x</b> is the number of t he channel. The NI 9226 has RTD channels 0 to 7 |
|--------------|----------------------------------------------------------------------------------------------------------------|
|              | •                                                                                                              |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pΩ/LSB for the chann<br>el. Use this value to <u>convert and calibrate</u> NI 922<br>6 data if you set the <b>Calibration Mode</b> to <b>Raw</b><br>in the <u>C Series Module Properties</u> dialog box.                   |
| Offset     | Returns the calibration offset in $\mu\Omega$ for the chan<br>nel. Use this value to convert and calibrate NI 92<br>26 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                                       |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time in milliseconds it takes to acquire conversion data. This property overwrites the va lue you configure in the <u>C Series Module Propert</u> <u>ies</u> dialog box. |

| Module ID     | Returns the module ID, 0x77C8 (NI 9226 with spr<br>ing terminal) or 0x77E0 (NI 9226 with DSUB). |
|---------------|-------------------------------------------------------------------------------------------------|
| Serial Number | Returns the unique serial number of the module .                                                |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                                                               |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9226 (FPGA Interface)

Right-click an <u>NI 9226</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of ohms. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 14 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• **Conversion Time**—Specifies the time it takes to acquire one point of data from all channels. You can select **200 ms** or **2.5 ms**.

Converting Nominal Values to Temperature Values for the NI 9226 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9226</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module in units of ohms. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node returns uncalibrated, binary values for the module. After you <u>convert</u> <u>these binary values to nominal values</u>, you can convert the nominal resistance values into temperature values. You must convert these values in the host VI.

#### Using a VI to Convert Values

Refer to the RTD to Temp VI in the labview\examples\CompactRIO\Module Specific\NI 9226\NI 9226 Getting Started\NI 9226 Getting S tarted.lvproj for an example of converting nominal resistance values to temperature. You can use the RTD to Temp VI as a subVI in the host VI to convert nominal resistance values to temperature.

#### Using an Equation to Measure Temperature

You can use a linearization curve known as the <u>Callendar-Van Dusen equation</u> in the host VI to measure the temperature of RTDs.

#### NI 9226 (Scan Interface)

CompactRIO 8-Channel, 24-Bit, 1000 Ω RTD Analog Input Module

🔊 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

#### **Module Channels**

The NI 9226 has the following channels.

| Channel      | Description                                                                                                       |
|--------------|-------------------------------------------------------------------------------------------------------------------|
| RTD <b>x</b> | RTD input channel <b>x</b> , where <b>x</b> is the number of t<br>he channel. The NI 9226 has RTD channels 0 to 7 |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9226. Right-click the NI 9226 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Conversion Time**—Specifies the time it takes to acquire one point of data from all channels. You can select **200 ms** or **2.5 ms**.
- **Channels**—Specifies the channel(s) for which you want to configure settings.
- Measurement Units—Specifies the units you want data to be returned in for the channel. You can select Raw Ohms, Degrees Kelvin, Degrees Celsius, Degrees Fahrenheit, or Degrees Rankine.

• **RTD Type**—Specifies the type of RTD connected to the channel by temperature coefficient of resistance (TCR). If you select **Custom**, you must enter the **Callendar-Van Dusen Coefficients** below.

• **Callendar-Van Dusen Coefficients**—Specifies the coefficients to use in the <u>Callendar-Van Dusen equation</u>, a linearization curve for measuring the temperature of an RTD.

#### NI 9227

CompactRIO 4-Channel, 5 A<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

😂 FPGA Interface 🛛 🞯 Scan Interface

#### NI 9227 Pinout



# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Acquiring Data from a Module (FPGA Interface) Configuring the Master Timebase Source for a Module (FPGA Interface) Configuring the Data Rate for a Module (FPGA Interface) Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules Understanding Loop Timing (FPGA Interface)

# NI 9227 (FPGA Interface)

CompactRIO 4-Channel, 5 A<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

Ľ

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9227. You can also <u>synchronize</u> an NI 9227 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9227 has AI channels 0 to<br>3. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                               |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 12.8 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9227</u> to ac<br>cess this channel.                                                                                                          |
| Start         | Channel that controls when the NI 9227 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9227 starts acquiring data. When th<br>e NI 9227 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed. |

|      | Refer to the NI 9227 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9227\NI 9227 Getting<br>Started\NI 9227 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                              |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop | Channel that controls when the NI 9227 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9227 stops acquiring data. When the<br>NI 9227 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |
|      | Refer to the NI 9227 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9227\NI 9227 Getting<br>Started\NI 9227 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                              |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## Methods

This device does not support any methods.

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

Property

Description

| LSB Weight | Returns the LSB weight in pA/LSB for the chann<br>el. Use this value to <u>convert and calibrate</u> NI 922<br>7 data if you set the <b>Calibration Mode</b> to <b>Raw</b><br>in the <u>C Series Module Properties</u> dialog box.          |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset     | Returns the calibration offset in nA for the chan<br>nel. Use this value to convert and calibrate NI 92<br>27 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9227 acquires data. |
| Module ID     | Returns the module ID, 0x7416.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9227 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)

Right-click an <u>NI 9225/NI 9227/NI 9229/NI 9238/NI 9239/NI 9246/NI 9247</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:
• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module.

• Select **Calibrated**, which is the default, if you want the <u>FPGA I/O Node</u> to return calibrated, signed, <u>fixed-point</u> data from the module. The following table describes the units and integer word length of the returned data:

| Module  | Units | Word Length (bits) | Integer Word Length<br>(bits) |
|---------|-------|--------------------|-------------------------------|
| NI 9225 | V     | 24                 | 10                            |
| NI 9227 | A     | 24                 | 5                             |
| NI 9229 | V     | 24                 | 7                             |
| NI 9238 | V     | 24                 | 1                             |
| NI 9239 | V     | 24                 | 5                             |
| NI 9246 | A     | 24                 | 7                             |
| NI 9247 | A     | 24                 | 9                             |

• Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

# NI 9227 (Scan Interface)

CompactRIO 4-Channel, 5 A<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in amps.

### **Module Channels**

The NI 9227 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9227, <b>x</b> is 0 to 3. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9227. Right-click the NI 9227 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

NI 9228

CompactRIO 8-Channel, ±60V 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

FPGA Interface

### NI 9228 Pinout



# **Related Topics**

FPGA Interface Converting NI 9228 Data

# NI 9228 (FPGA Interface)

CompactRIO 8-Channel, ±60V 24-Bit Simultaneous Analog Input Module

📄 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9228 has AI channels 0 to<br>7. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

This device does not support any module methods.

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property        | Description                                                                                                                                                  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conversion Time | Sets the time it takes to acquire one point of dat<br>a from one or more channels in a single FPGA I/<br>O Node. You can select <b>High Speed (1k S/s)</b> , |

|               | Medium Speed (100 S/s), Medium Resoluti<br>on (50/60Hz rejection – 12 S/s), or High Re<br>solution (50/60Hz rejection – 2 S/s). This pr<br>operty overwrites the value you configure in the<br><u>C Series Module Properties</u> dialog box.<br>Returns the conversion time setting when confi<br>gured to read. |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module ID     | Returns the module ID, 0x780E.                                                                                                                                                                                                                                                                                   |
| Serial Number | Returns the unique serial number of the module .                                                                                                                                                                                                                                                                 |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                                                                                                                                                                                                                                                                                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9228 (FPGA Interface)

Right-click an <u>NI 9228</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 7 bits. Select Raw

if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the binary values to engineering units. The default is **Calibrated**.

Conversion Time—Specifies the time it takes to acquire one point of data from one or more channels in a single FPGA I/O Node. You can select High Speed (1k S/s), Medium Speed (100 S/s), Medium Resolution (50/60Hz rejection – 12 S/s), or High Resolution (50/60Hz rejection – 2 S/s). The default is High Resolution (50/60Hz rejection – 2 S/s).

Converting NI 9228 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9228</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

Using an Equation to Convert Binary Values to Voltage

You can use the following equation in the host VI to convert binary voltage values to volts:

#### Voltage = Binary Value × 7602677 pV/LSB

where

**Binary Value** is the value returned by the FPGA I/O Node.

#### NI 9228 (Scan Interface)

CompactRIO 8-Channel, ±60V 24-Bit Simultaneous Analog Input Module

📄 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in units as specified on the **C Series Module Properties** dialog box.

### **Module Channels**

The NI 9228 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9228, <b>x</b> is 0 to 7. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9228. Right-click the NI 9228 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

 Conversion Time—Determines the time it takes to acquire one point of data from one or more channels. You can select Medium Speed, High Speed, Medium Resolution, or High Resolution. Refer to the NI 9228 hardware documentation on ni.com/manuals for more information about the Medium Speed, High Speed, Medium Resolution, or High Resolution conversion times.

#### NI 9229

CompactRIO 4-Channel, ±60 V, 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

😂 FPGA Interface | 🞯 Scan Interface

## NI 9229 Pinout





# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Acquiring Data from a Module (FPGA Interface) Configuring the Master Timebase Source for a Module (FPGA Interface) Configuring the Data Rate for a Module (FPGA Interface) Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules Understanding Loop Timing (FPGA Interface)

# NI 9229 (FPGA Interface)

CompactRIO 4-Channel, ±60 V, 24-Bit Simultaneous Analog Input Module

🔊 Open example

Sind related examples

## FPGA I/O Node

E

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9229. You also can <u>synchronize</u> an NI 9229 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9229 has AI channels 0 to<br>3. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                                                                                   |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 12.8 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9229</u> to ac<br>cess this channel.                                                                                                                                                                                                                                                                                                                              |
| Start         | Channel that controls when the NI 9229 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> channel, the NI 9229 starts acquiring data. When th<br>e NI 9229 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.<br>Refer to the NI 9229 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9229\NI 9229 Getting<br>Started\NI 9229 Getting Started.<br>lvproj for an example of using the <b>Start</b> and |

|      | Stop channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|      | 📄 Open example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Stop | Channel that controls when the NI 9229 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9229 stops acquiring data. When the<br>NI 9229 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed.<br>Refer to the NI 9229 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9229\NI 9229 Getting<br>Started\NI 9229 Getting Started. |  |
|      | lvproj for an example of using the <b>Start</b> and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|      | Stop channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|      | 📄 Open example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9229<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box. |

| Offset | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>29 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br>w in the <b>C Series Module Properties</b> dialog b |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | w in the C Series Module Properties dialog b                                                                                                                                                                                  |
|        | OX.                                                                                                                                                                                                                           |

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9229 acquires data. |
| Module ID     | Returns the <u>module ID</u> .                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9229 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)

Right-click an <u>NI 9225/NI 9227/NI 9229/NI 9238/NI 9239/NI 9246/NI 9247</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module.

• Select **Calibrated**, which is the default, if you want the <u>FPGA I/O Node</u> to return calibrated, signed, <u>fixed-point</u> data from the module. The following table describes the units and integer word length of the returned data:

| Module  | Units | Word Length (bits) | Integer Word Length<br>(bits) |
|---------|-------|--------------------|-------------------------------|
| NI 9225 | V     | 24                 | 10                            |
| NI 9227 | A     | 24                 | 5                             |
| NI 9229 | V     | 24                 | 7                             |
| NI 9238 | V     | 24                 | 1                             |
| NI 9239 | V     | 24                 | 5                             |
| NI 9246 | A     | 24                 | 7                             |
| NI 9247 | A     | 24                 | 9                             |

• Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Data Rate**—Specifies the rate at which the module acquires data.

# NI 9229 (Scan Interface)

CompactRIO 4-Channel, ±60 V, 24-Bit Simultaneous Analog Input Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

### **Module Channels**

The NI 9229 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9229, <b>x</b> is 0 to 3. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9229. Right-click the NI 9229 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9230

CompactRIO 3-Channel, ±30 V, 12.8 kS/s, 24-Bit Software Selectable IEPE and AC/DC Analog Input Module

#### Software Reference (?)

这 <u>FPGA Interface</u>

## NI 9230 Pinout



# **Related Topics**

FPGA Interface
 <u>Converting and Calibrating CompactRIO Analog Input Values</u>
 <u>Detecting Out-of-Range Channels</u>
 <u>Accessing TEDS Information from a Module (FPGA Interface)</u>
 <u>Acquiring Data from a Module (FPGA Interface)</u>
 <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u>
 <u>Configuring the NI 9230/9232/9234 Channel Input Modes</u>
 <u>Configuring the Data Rate for a Module (FPGA Interface)</u>
 <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u>
 <u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9230 (FPGA Interface)

CompactRIO 3-Channel, ±30 V, 12.8 kS/s, 24-Bit Software Selectable IEPE and AC/DC Analog Input Module

🔊 Open example

Find examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>synchronize</u> an NI 9230 with other modules that have a <u>selectable timebase</u> <u>source</u>.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9230 has AI channels 0 to<br>2. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                     |
| Onboard Clock | 13.1072 MHz internal clock of the NI 9230. Use t<br>he FPGA I/O Node in a <u>single-cycle Timed Loop</u> t<br>o access this channel. You must <u>export the onbo</u><br><u>ard clock of the NI 9230</u> to access this channel. If<br>you do not export the onboard clock and try to<br>access the <b>Onboard Clock</b> channel, LabVIEW r<br>eturns a code generation error when you try to c<br>ompile the FPGA VI.                                                                                                                                               |
| Start         | Channel that controls when the NI 9230 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9230 starts acquiring data. When th<br>e NI 9230 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties or <u>TEDS information</u> for the module. If FA<br>LSE is written to the <b>Start</b> channel, no operatio<br>n is performed.<br>Refer to the NI 9230 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9230 Getting Started. |

|      | lvproj for an example of using the <b>Start</b> and                                                                                                                                                                                                                                                                                                                                                         |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Stop channets.                                                                                                                                                                                                                                                                                                                                                                                              |
|      | 😥 Open example                                                                                                                                                                                                                                                                                                                                                                                              |
| Stop | Channel that controls when the NI 9230 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9230 stops acquiring data. When the<br>NI 9230 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties or TEDS information for the module. If FAL<br>SE is written to the <b>Stop</b> channel, no operation i<br>s performed. |
|      | Refer to the NI 9230 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9230\NI 9230 Getting<br>Started\NI 9230 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                                               |

# Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                   |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | Returns Booleans for each channel that indicate<br>whether there was a short circuit or open loop o<br>n the channel since the last execution of the Che<br>ck Cached Status method. When the FPGA I/O N<br>ode reads the channels, the FPGA VI determines<br>the state of the channels and caches any TRUE v |

alue until the Check Cached Status method exec utes. Short Circuit—Returns an array of Boo lean values. A value of TRUE in any index i ndicates that the channel sharing a numb er with that index detected a short circuit on the channel at some point after the las t time that the Check Cached Status meth od executed. Open Loop—Returns an array of Boole an values. A value of TRUE in any index in dicates that the channel sharing a numbe r with that index detected an open loop o n the channel at some point after the last time that the Check Cached Status metho d executed.

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property            | Description                                                                                                                                                                                                                                 |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Configuration | <u>Sets the input configuration</u> of the correspondin<br>g channel to one of three modes: AC coupled, D<br>C coupled, or IEPE AC coupled.                                                                                                 |
| LSB Weight          | Returns the LSB weight in pV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9230<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset              | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>30 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9230 acquires data. |
| Module ID     | Returns the module ID, 0x77CC.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9230 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9230/9232/9234 (FPGA Interface)

Right-click an <u>NI 9230</u>, <u>NI 9232</u>, or <u>NI 9234</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-</u>

point data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 7 bits for the NI 9230/9232 and 4 bits for the NI 9234. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

- Data Rate—Specifies the rate at which the module acquires data.
- Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.
- **Channels**—Specifies the channel(s) for which you want to select the input configuration.

• Selected Channel(s) Settings—Specifies the input configuration for each channel.

 Input Configuration—<u>Sets the input configuration</u> for the selected channel(s). Select AC Coupled for AC coupling with IEPE excitation off, DC Coupled for DC coupling with IEPE excitation off, or IEPE AC Coupled for AC coupling with IEPE excitation on.

Configuring the NI 9230/9232/9234 Channel Input Modes (FPGA Interface)

You can configure the input mode for each channel of the <u>NI 9230</u>, <u>NI 9232</u>, or <u>NI 9234</u> at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the input mode for each channel at run time using the <u>FPGA I/O Property Node</u>. The execution of an FPGA I/O Property Node that is configured with an **Input Configuration** property overwrites the value you configured in the **C Series Module Properties** dialog box for the corresponding channel.

Configuring the Channel Input Modes Using the C Series Module Properties Dialog Box

Complete the following steps to configure the channel input modes using the **C** Series Module Properties dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the input mode from the Channels table. You can select more than one channel by holding the <Ctrl>> or <Shift> key when selecting channels.
- 4. Select the input mode for the selected channel(s) from the **Input Configuration** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring the Channel Input Modes Using the FPGA I/O Property Node

Complete the following steps to configure the channel input modes using the FPGA I/O Property Node.

- 1. <u>Create FPGA I/O items</u> for the channels of the module for which you want to configure the **Input Configuration** property.
- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the module channel for which you want to configure the input mode.
- 3. Click the **Property** section and select **Input Configuration** from the shortcut menu.
- 4. Right-click the **Input Configuration** input and select **Create»Control** from the shortcut menu.
- 5. On the front panel of the VI, select an input mode for the channel from the **Input Configuration** pull-down menu.

You can change the channel input modes at run time by writing to the control from the host VI. Refer to the following getting started VIs for examples of how to configure the input modes using the FPGA I/O Property Node.

| Module  | Example File Path                                                                                                                         | Open Example                    |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| NI 9230 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9230\NI 9230 Gett<br/>ing Started\NI 9230 G<br/>etting Started.lvproj</pre> | Dpen example (NI 9230)          |
| NI 9232 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9232\NI 9232 Gett<br/>ing Started\NI 9232 G<br/>etting Started.lvproj</pre> | 🔊 Open example (NI 9232)        |
| NI 9234 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9234\NI 9234 Gett<br/>ing Started\NI 9234 G<br/>etting Started.lvproj</pre> | <i>թ</i> Open example (NI 9234) |

E

**Note** The **Input Configuration** property returns <u>error 65538</u> if the module is acquiring data. You must use the <u>Stop channel</u> to stop acquiring data before you can write properties to the modules.

#### NI 9231

8 AI, ±5 V, 24 Bit, 51.2 kS/s/ch Simultaneous, AC/DC Coupling, IEPE AC Coupling

#### Software Reference (?)

FPGA Interface

#### NI 9231

## NI 9231 Pinout



# **Related Topics**

FPGA Interface
<u>C Series Module Properties Dialog Box</u>
<u>Converting and Calibrating CompactRIO Analog Input Values</u>
<u>Detecting Out-of-Range Channels for CompactRIO Analog Input Channels</u>
<u>Acquiring Data from an NI 9231</u>
<u>Configuring the Data Rate for a Module (FPGA Interface)</u>
<u>Converting NI 9231 Data</u>
<u>Synchronizing Multiple Modules</u>
<u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9231 (FPGA Interface)

8 AI, ±5 V, 24 Bit, 51.2 kS/s/ch Simultaneous, AC/DC Coupling, IEPE AC Coupling

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

Ľ

**Note** You can <u>synchronize</u> an NI 9231 module with other modules that have a <u>selectable</u> <u>timebase source</u>.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                           |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9231 has channels 0 to 7.                                                                                                                                                                                                                                                         |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The onboard clock frequency i<br>s 13.1072 MHz. Use the FPGA I/O Node in a <u>singl</u><br><u>e-cycle timed loop</u> to access this channel. You m<br>ust <u>export the onboard clock of the NI 9231</u> to a<br>ccess this channel.                                                              |
| Start         | Channel that controls when the NI 9231 starts a cquiring data. If TRUE is written to the <b>Start</b> cha nnel, the NI 9231 starts acquiring data. When th e NI 9231 is acquiring data, you must write TRUE to the <b>Stop</b> channel before you can access prop erties for the module. If FALSE is written to the <b>S tart</b> channel, no operation is performed. |
| Stop          | Channel that controls when the NI 9231 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9231 stops acquiring data. When the<br>NI 9231 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope                                                                                           |

rties for the module. If FALSE is written to the **St op** channel, no operation is performed.

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                              |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | Returns Booleans for each channel that indicate<br>whether there was a short circuit or open loop o<br>n the channel since the last execution of the Che<br>ck Cached Status method. When the FPGA I/O N<br>ode reads the channels, the FPGA VI determines<br>the state of the channels and caches any TRUE v<br>alue until the Check Cached Status method exec<br>utes. |
|                     | • Short Circuit—Returns an array of Boo<br>lean values. A value of TRUE in any index i<br>ndicates that the channel sharing a numb<br>er with that index detected a short circuit<br>on the channel at some point after the las<br>t time that the Check Cached Status meth<br>od executed.                                                                              |
|                     | • <b>Open Loop</b> —Returns an array of Boole<br>an values. A value of TRUE in any index in<br>dicates that the channel sharing a numbe<br>r with that index detected an open loop o<br>n the channel at some point after the last<br>time that the Check Cached Status metho<br>d executed.                                                                             |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property            | Description                                                                                                                       |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Input Configuration | Sets the input configuration of the correspondin<br>g channel to one of three modes: AC Coupled, D<br>C Coupled, IEPE AC Coupled. |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                       |
|---------------|---------------------------------------------------|
| Data Rate     | Sets the rate at which the NI 9231 acquires data. |
| Module ID     | Returns the module ID, 0x7930.                    |
| Serial Number | Returns the unique serial number of the module .  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                 |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9231 (FPGA Interface)

Right-click an <u>NI 9231</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module. The fixed-point data is signed, with 24-bits word length and 4-bits integer word length. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must convert the binary data to the actual analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

- Data Rate—Specifies the rate at which the module acquires data.
- Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.
- **Channels**—Specifies the channel(s) for which you want to select the input configuration.

• Selected Channel(s) Settings—Specifies the input configuration for each channel.

• Input Configuration—<u>Sets the input configuration</u> for the selected channel(s). Select AC Coupled for AC coupling, DC Coupled for DC coupling, IEPE AC Coupled for AC coupling with IEPE enabled.

#### Configuring the NI 9231 Channel Input Modes (FPGA Interface)

You can configure the input mode for each channel of the <u>NI 9231</u> at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the input mode for each channel at run time using the <u>FPGA I/O Property Node</u>. The execution of an FPGA I/O Property Node that is configured with an **Input**  **Configuration** property overwrites the value you configured in the **C Series Module Properties** dialog box for the corresponding channel.

Configuring the Channel Input Modes Using the C Series Module Properties Dialog Box

Complete the following steps to configure the channel input modes using the **C** Series Module Properties dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the input mode from the Channels table. You can select more than one channel by holding the <Ctrl>> or <Shift> key when selecting channels.
- 4. Select the input mode for the selected channel(s) from the **Input Configuration** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring the Channel Input Modes Using the FPGA I/O Property Node

Complete the following steps to configure the channel input modes using the FPGA I/O Property Node.

- 1. <u>Create FPGA I/O items</u> for the channels of the module for which you want to configure the **Input Configuration** property.
- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the module channel for which you want to configure the input mode.
- 3. Click the **Property** section and select **Input Configuration** from the shortcut menu.
- 4. Right-click the **Input Configuration** input and select **Create»Control** from the shortcut menu.

5. On the front panel of the VI, select an input mode for the channel from the **Input Configuration** pull-down menu.

You can change the channel input modes at run time by writing to the control from the host VI. Refer to the following getting started VIs for examples of how to configure the input modes using the FPGA I/O Property Node.

| Module  | Example File Path                                                                                                                         | Open Example             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| NI 9231 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9231\NI 9231 Gett<br/>ing Started\NI 9231 G<br/>etting Started.lvproj</pre> | 🔊 Open example (NI 9231) |

**Note** The **Input Configuration** property returns <u>error 65538</u> if the module is acquiring data. You must use the <u>Stop channel</u> to stop acquiring data before you can write properties to the modules.

Converting NI 9231 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9231</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

You can use the following equations in the host VI to convert binary voltage values to volts:

#### Volts = Binary Value × 610714.8 pV/LSB

where

**Binary Value** is the value returned by the FPGA I/O Node.

NI 9232

CompactRIO 3-Channel, ±30 V, 102.4 kS/s, 24-Bit Software Selectable IEPE and AC/DC Analog Input Module

#### Software Reference (?)

FPGA Interface

### NI 9232 Pinout



# **Related Topics**

😰 FPGA Interface

Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Accessing TEDS Information from a Module (FPGA Interface) Acquiring Data from a Module (FPGA Interface) Configuring the Master Timebase Source for a Module (FPGA Interface) Configuring the NI 9230/9232/9234 Channel Input Modes Configuring the Data Rate for a Module (FPGA Interface) Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules Understanding Loop Timing (FPGA Interface)

# NI 9232 (FPGA Interface)

CompactRIO 3-Channel, ±30 V, 102.4 kS/s, 24-Bit Software Selectable IEPE and AC/DC Analog Input Module

😥 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>synchronize</u> an NI 9232 with other modules that have a <u>selectable timebase</u> <u>source</u>.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9232 has AI channels 0 to<br>2. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                       |  |
| Onboard Clock | 13.1072 MHz internal clock of the NI 9232. Use t<br>he FPGA I/O Node in a <u>single-cycle Timed Loop</u> t<br>o access this channel. You must <u>export the onbo</u><br><u>ard clock of the NI 9232</u> to access this channel. If<br>you do not export the onboard clock and try to<br>access the <b>Onboard Clock</b> channel, LabVIEW r<br>eturns a code generation error when you try to c<br>ompile the FPGA VI. |  |
| Start         | Channel that controls when the NI 9232 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9232 starts acquiring data. When th<br>e NI 9232 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties or <u>TEDS information</u> for the module. If FA<br>LSE is written to the <b>Start</b> channel, no operatio    |  |

|      | n is performed.                                                                                                                                                                                                                                                                                                                                                                                             |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|      | Refer to the NI 9232 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9232\NI 9232 Getting<br>Started\NI 9232 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                                               |  |
|      | 🔊 Open example                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Stop | Channel that controls when the NI 9232 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9232 stops acquiring data. When the<br>NI 9232 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties or TEDS information for the module. If FAL<br>SE is written to the <b>Stop</b> channel, no operation i<br>s performed. |  |
|      | Refer to the NI 9232 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9232\NI 9232 Getting<br>Started\NI 9232 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                                               |  |
|      | 📄 Open example                                                                                                                                                                                                                                                                                                                                                                                              |  |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

Method

Description

| Check Cached Status | Returns Booleans for each channel that indicate<br>whether there was a short circuit or open loop o<br>n the channel since the last execution of the Che<br>ck Cached Status method. When the FPGA I/O N<br>ode reads the channels, the FPGA VI determines<br>the state of the channels and caches any TRUE v<br>alue until the Check Cached Status method exec<br>utes. |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                     | • Short Circuit—Returns an array of Boo<br>lean values. A value of TRUE in any index i<br>ndicates that the channel sharing a numb<br>er with that index detected a short circuit<br>on the channel at some point after the las<br>t time that the Check Cached Status meth<br>od executed.                                                                              |  |
|                     | • <b>Open Loop</b> —Returns an array of Boole<br>an values. A value of TRUE in any index in<br>dicates that the channel sharing a numbe<br>r with that index detected an open loop o<br>n the channel at some point after the last<br>time that the Check Cached Status metho<br>d executed.                                                                             |  |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property            | Description                                                                                                                                                                                                                        |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Input Configuration | Sets the input configuration of the correspon<br>g channel to one of three modes: AC coupled<br>C coupled, or IEPE AC coupled.                                                                                                     |  |
| LSB Weight          | Returns the LSB weight in pV/LSB for the channe<br>l. Use this value to <u>convert and calibrate</u> NI 9232<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box. |  |
| Offset              | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>32 data if you set the <b>Calibration Mode</b> to <b>Ra</b>                                                             |  |

**w** in the **C Series Module Properties** dialog b ox.

## Module Properties

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |  |
|---------------|----------------------------------------------------------|--|
| Data Rate     | <u>Sets the rate</u> at which the NI 9232 acquires data. |  |
| Module ID     | Returns the module ID, 0x753F.                           |  |
| Serial Number | Returns the unique serial number of the module           |  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |  |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9232 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9230/9232/9234 (FPGA Interface)

Right-click an <u>NI 9230</u>, <u>NI 9232</u>, or <u>NI 9234</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the FPGA I/O Node to return calibrated, fixedpoint data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 7 bits for the NI 9230/9232 and 4 bits for the NI 9234. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is **Calibrated**.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Data Rate**—Specifies the rate at which the module acquires data.

• Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.

• **Channels**—Specifies the channel(s) for which you want to select the input configuration.

• Selected Channel(s) Settings—Specifies the input configuration for each channel.

 Input Configuration—<u>Sets the input configuration</u> for the selected channel(s). Select AC Coupled for AC coupling with IEPE excitation off, DC Coupled for DC coupling with IEPE excitation off, or IEPE AC Coupled for AC coupling with IEPE excitation on.

Configuring the NI 9230/9232/9234 Channel Input Modes (FPGA Interface)

You can configure the input mode for each channel of the <u>NI 9230</u>, <u>NI 9232</u>, or <u>NI 9234</u> at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the input mode for each channel at run time using the <u>FPGA I/O Property Node</u>. The execution of an FPGA I/O Property Node that is configured with an **Input Configuration** property overwrites the value you

configured in the **C Series Module Properties** dialog box for the corresponding channel.

Configuring the Channel Input Modes Using the C Series Module Properties Dialog Box

Complete the following steps to configure the channel input modes using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the input mode from the Channels table. You can select more than one channel by holding the <Ctrl>> or <Shift> key when selecting channels.
- 4. Select the input mode for the selected channel(s) from the **Input Configuration** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring the Channel Input Modes Using the FPGA I/O Property Node

Complete the following steps to configure the channel input modes using the FPGA I/O Property Node.

- 1. <u>Create FPGA I/O items</u> for the channels of the module for which you want to configure the **Input Configuration** property.
- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the module channel for which you want to configure the input mode.
- 3. Click the **Property** section and select **Input Configuration** from the shortcut menu.
- 4. Right-click the **Input Configuration** input and select **Create**»**Control** from the shortcut menu.

5. On the front panel of the VI, select an input mode for the channel from the **Input Configuration** pull-down menu.

You can change the channel input modes at run time by writing to the control from the host VI. Refer to the following getting started VIs for examples of how to configure the input modes using the FPGA I/O Property Node.

| Module  | Example File Path                                                                                                                         | Open Example             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| NI 9230 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9230\NI 9230 Gett<br/>ing Started\NI 9230 G<br/>etting Started.lvproj</pre> | Dpen example (NI 9230)   |
| NI 9232 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9232\NI 9232 Gett<br/>ing Started\NI 9232 G<br/>etting Started.lvproj</pre> | 🔊 Open example (NI 9232) |
| NI 9234 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9234\NI 9234 Gett<br/>ing Started\NI 9234 G<br/>etting Started.lvproj</pre> | Dpen example (NI 9234)   |

**I** 

**Note** The **Input Configuration** property returns <u>error 65538</u> if the module is acquiring data. You must use the <u>Stop channel</u> to stop acquiring data before you can write properties to the modules.

#### NI 9234

CompactRIO 4-Channel, ±5 V, 51.2 KS/s, 24-Bit Software Selectable IEPE and AC/DC Analog Input Module

#### Software Reference (?)

🔁 FPGA Interface | 😉 Scan Interface
#### NI 9234 Pinout



# **Related Topics**

FPGA Interface
 <u>Converting and Calibrating CompactRIO Analog Input Values</u>
 <u>Detecting Out-of-Range Channels</u>
 <u>Accessing TEDS Information from a Module (FPGA Interface)</u>
 <u>Acquiring Data from a Module (FPGA Interface)</u>
 <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u>
 <u>Configuring the NI 9230/9232/9234 Channel Input Modes</u>
 <u>Configuring the Data Rate for a Module (FPGA Interface)</u>
 <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u>
 <u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9234 (FPGA Interface)

CompactRIO 4-Channel, ±5 V, 51.2 KS/s, 24-Bit Software Selectable IEPE and AC/DC Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>synchronize</u> an NI 9234 with other modules that have a <u>selectable timebase</u> <u>source</u>.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9234 has AI channels 0 to<br>3. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                     |
| Onboard Clock | 13.1072 MHz internal clock of the NI 9234. Use t<br>he FPGA I/O Node in a <u>single-cycle Timed Loop</u> t<br>o access this channel. You must <u>export the onbo</u><br><u>ard clock of the NI 9234</u> to access this channel. If<br>you do not export the onboard clock and try to<br>access the <b>Onboard Clock</b> channel, LabVIEW r<br>eturns a code generation error when you try to c<br>ompile the FPGA VI.                                                                                                                                               |
| Start         | Channel that controls when the NI 9234 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9234 starts acquiring data. When th<br>e NI 9234 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties or <u>TEDS information</u> for the module. If FA<br>LSE is written to the <b>Start</b> channel, no operatio<br>n is performed.<br>Refer to the NI 9234 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9234 Getting Started. |

|      | <pre>lvproj for an example of using the Start and<br/>Stop channels.</pre> Open example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop | Channel that controls when the NI 9234 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9234 stops acquiring data. When the<br>NI 9234 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties or TEDS information for the module. If FAL<br>SE is written to the <b>Stop</b> channel, no operation i<br>s performed.<br>Refer to the NI 9234 Getting Started VI in the 1a<br>bview\examples\CompactRIO\Module<br>Specific\NI 9234 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels. |
|      | 📄 Open example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property            | Description                                                                                                                                 |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Input Configuration | <u>Sets the input configuration</u> of the correspondin<br>g channel to one of three modes: AC coupled, D<br>C coupled, or IEPE AC coupled. |

| LSB Weight | Returns the LSB weight in pV/LSB for the channe<br>l. Use this value to <u>convert and calibrate</u> NI 9234<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>34 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9234 acquires data. |
| Module ID     | Returns the module ID, 0x72B5.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9234 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9230/9232/9234 (FPGA Interface)

Right-click an <u>NI 9230</u>, <u>NI 9232</u>, or <u>NI 9234</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 7 bits for the NI 9230/9232 and 4 bits for the NI 9234. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

- **Data Rate**—Specifies the rate at which the module acquires data.
- Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.

• **Channels**—Specifies the channel(s) for which you want to select the input configuration.

• Selected Channel(s) Settings—Specifies the input configuration for each channel.

 Input Configuration—<u>Sets the input configuration</u> for the selected channel(s). Select AC Coupled for AC coupling with IEPE excitation off, DC Coupled for DC coupling with IEPE excitation off, or IEPE AC Coupled for AC coupling with IEPE excitation on.

#### Configuring the NI 9230/9232/9234 Channel Input Modes (FPGA Interface)

You can configure the input mode for each channel of the <u>NI 9230</u>, <u>NI 9232</u>, or <u>NI 9234</u> at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the input mode for each channel at run time using the <u>FPGA I/O Property Node</u>. The execution of an FPGA I/O Property Node that is configured with an **Input Configuration** property overwrites the value you configured in the **C Series Module Properties** dialog box for the corresponding channel.

Configuring the Channel Input Modes Using the C Series Module Properties Dialog Box

Complete the following steps to configure the channel input modes using the **C** Series Module Properties dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the input mode from the **Channels** table. You can select more than one channel by holding the <Ctrl>> or <Shift> key when selecting channels.
- 4. Select the input mode for the selected channel(s) from the **Input Configuration** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring the Channel Input Modes Using the FPGA I/O Property Node

Complete the following steps to configure the channel input modes using the FPGA I/O Property Node.

1. <u>Create FPGA I/O items</u> for the channels of the module for which you want to configure the **Input Configuration** property.

- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the module channel for which you want to configure the input mode.
- 3. Click the **Property** section and select **Input Configuration** from the shortcut menu.
- 4. Right-click the **Input Configuration** input and select **Create»Control** from the shortcut menu.
- 5. On the front panel of the VI, select an input mode for the channel from the **Input Configuration** pull-down menu.

You can change the channel input modes at run time by writing to the control from the host VI. Refer to the following getting started VIs for examples of how to configure the input modes using the FPGA I/O Property Node.

| Module  | Example File Path                                                                                                                         | Open Example             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| NI 9230 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9230\NI 9230 Gett<br/>ing Started\NI 9230 G<br/>etting Started.lvproj</pre> | 🔊 Open example (NI 9230) |
| NI 9232 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9232\NI 9232 Gett<br/>ing Started\NI 9232 G<br/>etting Started.lvproj</pre> | Dpen example (NI 9232)   |
| NI 9234 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9234\NI 9234 Gett<br/>ing Started\NI 9234 G<br/>etting Started.lvproj</pre> | 🔊 Open example (NI 9234) |

E

**Note** The **Input Configuration** property returns <u>error 65538</u> if the module is acquiring data. You must use the <u>Stop channel</u> to stop acquiring data before you can write properties to the modules.

# NI 9234 (Scan Interface)

CompactRIO 4-Channel, ±5 V, 51.2 KS/s, 24-Bit Software Selectable IEPE and AC/DC Analog Input Module

👰 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9234 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9234, <b>x</b> is 0 to 3. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9234. Right-click the NI 9234 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to select the input configuration.

• Input Configuration—Specifies the input configuration for the selected channel(s). You can select one of three modes: AC coupled, DC coupled, or IEPE AC coupled.

NI 9235

CompactRIO 8-Channel, 24-Bit Quarter-Bridge Analog Input Module

Software Reference (?)

这 FPGA Interface 🛛 📀 Scan Interface

#### NI 9235 Pinout



# **Related Topics**

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u> <u>Acquiring Data from a Module (FPGA Interface)</u> <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Configuring the Data Rate for a Module (FPGA Interface)</u> <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u> <u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9235 (FPGA Interface)

CompactRIO 8-Channel, 24-Bit Quarter-Bridge Analog Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>synchronize</u> an NI 9235 module with other modules that have a <u>selectable</u> <u>timebase source</u>.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9235 has AI channels 0 to<br>7. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                               |
| Onboard Clock | 12.8 MHz internal clock of the NI 9235. Use the F<br>PGA I/O Node in a <u>single-cycle Timed Loop</u> to ac<br>cess this channel. You must <u>export the Onboard</u><br><u>Clock of the NI 9235</u> to access this channel.                                                                                                                                                                                   |
| Start         | Channel that controls when the NI 9235 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9235 starts acquiring data. When th<br>e NI 9235 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed. |

|      | Refer to the NI 9235 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9235\NI 9235 Getting<br>Started\NI 9235 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                              |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop | Channel that controls when the NI 9235 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9235 stops acquiring data. When the<br>NI 9235 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |
|      | Refer to the NI 9235 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9235\NI 9235 Getting<br>Started\NI 9235 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                              |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property         | Description                                                                                                                                                                                                                                                                                          |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight       | Returns the LSB weight in units of 100 fV/V per L<br>SB for the channel. 100 fV is equal to 10 <sup>-13</sup> volts.<br>Use this value to <u>convert and calibrate</u> NI 9235 d<br>ata if you set the <b>Calibration Mode</b> to <b>Raw</b> in<br>the <u>C Series Module Properties</u> dialog box. |
| Offset           | Returns the calibration offset in units of 100 nV/<br>V for the channel. Use this value to convert and<br>calibrate NI 9235 data if you set the <b>Calibratio</b><br><b>n Mode</b> to <b>Raw</b> in the <b>C Series Module Prop</b><br><b>erties</b> dialog box.                                     |
| Shunt Cal Enable | Controls the shunt calibration switch for each c<br>hannel.<br>Refer to the NI 9235 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9235\NI 9235 Getting<br>Started\NI 9235 Getting Started.<br>lvproj for an example of using the Shunt Cal<br>Enable property.     |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                       |
|---------------|---------------------------------------------------|
| Data Rate     | Sets the rate at which the NI 9235 acquires data. |
| Module ID     | Returns the module ID, 0x732A.                    |
| Serial Number | Returns the unique serial number of the module .  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                 |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9235 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9235/9236 (FPGA Interface)

Right-click an <u>NI 9235</u> or <u>NI 9236</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts/volt. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –4 bits.
 Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

### NI 9235 (Scan Interface)

CompactRIO 8-Channel, 24-Bit Quarter-Bridge Analog Input Module

🔊 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts/volts (channel voltage/excitation voltage).

#### **Module Channels**

The NI 9235 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9235, <b>x</b> is 0 to 7. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9235. Right-click the NI 9235 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9236

CompactRIO 8-Channel, 24-Bit Quarter-Bridge Analog Input Module

#### Software Reference (?)

🔁 FPGA Interface | 😉 Scan Interface

### NI 9236 Pinout



# **Related Topics**

这 FPGA Interface

Converting and Calibrating CompactRIO Analog Input Values

**Detecting Out-of-Range Channels** 

Acquiring Data from a Module (FPGA Interface)

Configuring the Master Timebase Source for a Module (FPGA Interface)

Configuring the Data Rate for a Module (FPGA Interface)

Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules

<u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9236 (FPGA Interface)

CompactRIO 8-Channel, 24-Bit Quarter-Bridge Analog Input Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

Ľ

**Note** You can <u>synchronize</u> an NI 9236 module with other modules that have a <u>selectable</u> <u>timebase source</u>.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9236 has AI channels 0 to<br>7. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                             |
| Onboard Clock | 12.8 MHz internal clock of the NI 9236. Use the F<br>PGA I/O Node in a <u>single-cycle Timed Loop</u> to ac<br>cess this channel. You must <u>export the Onboard</u><br><u>Clock of the NI 9236</u> to access this channel.                                                                                                                                                                                                                                                                                                                 |
| Start         | Channel that controls when the NI 9236 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9236 starts acquiring data. When th<br>e NI 9236 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.<br>Refer to the NI 9236 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9236 Getting Started. |

|      | <pre>lvproj for an example of using the Start and</pre>                                                                                                                                                                                                                                |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Stop channels.                                                                                                                                                                                                                                                                         |
|      | 📄 Open example                                                                                                                                                                                                                                                                         |
| Stop | Channel that controls when the NI 9236 stops ac                                                                                                                                                                                                                                        |
|      | quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9236 stops acquiring data. When the<br>NI 9236 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b> |
|      | <b>op</b> channel, no operation is performed.                                                                                                                                                                                                                                          |
|      | Refer to the NI 9236 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9236\NI 9236 Getting<br>Started\NI 9236 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                          |
|      | 📄 Open example                                                                                                                                                                                                                                                                         |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                      |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in units of 100 fV/V per L<br>SB for the channel. 100 fV is equal to 10 <sup>-13</sup> volts.<br>Use this value to <u>convert and calibrate</u> NI 9236 d |

|                  | ata if you set the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series Module Properties</u> dialog box.                                                                                                                                                                                    |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset           | Returns the calibration offset in units of 100 nV/<br>V for the channel. Use this value to convert and<br>calibrate NI 9236 data if you set the <b>Calibratio</b><br><b>n Mode</b> to <b>Raw</b> in the <b>C Series Module Prop</b><br><b>erties</b> dialog box.                                 |
| Shunt Cal Enable | Controls the shunt calibration switch for each c<br>hannel.<br>Refer to the NI 9236 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9236\NI 9236 Getting<br>Started\NI 9236 Getting Started.<br>lvproj for an example of using the Shunt Cal<br>Enable property. |
|                  | 😥 Open example                                                                                                                                                                                                                                                                                   |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9236 acquires data. |
| Module ID     | Returns the module ID, 0x732B.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9236 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9235/9236 (FPGA Interface)

Right-click an <u>NI 9235</u> or <u>NI 9236</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts/volt. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –4 bits.
 Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select Raw, you must <u>convert and calibrate</u> the analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

### NI 9236 (Scan Interface)

CompactRIO 8-Channel, 24-Bit Quarter-Bridge Analog Input Module

🔊 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts/volts (channel voltage/excitation voltage).

## **Module Channels**

The NI 9236 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9236, <b>x</b> is 0 to 7. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9236. Right-click the NI 9236 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9237

CompactRIO 4-Channel, 24-Bit Half/Full-Bridge Analog Input Module

#### Software Reference (?)

🔁 FPGA Interface | 🞯 Scan Interface

#### NI 9237 Pinout





# **Related Topics**

这 FPGA Interface

<u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u> <u>Acquiring Data from a Module (FPGA Interface)</u> <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Configuring the Data Rate for a Module (FPGA Interface)</u> <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u> <u>Understanding Loop Timing (FPGA Interface)</u>

### NI 9237 (FPGA Interface)

CompactRIO 4-Channel, 24-Bit Half/Full-Bridge Analog Input Module

📄 Open example

Find related examples

### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>synchronize</u> an NI 9237 module with other modules that have a <u>selectable</u> <u>timebase source</u>.

### **Terminals in Software**

E

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9237 has AI channels 0 to<br>3. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                                                                                                     |
| Onboard Clock | 12.8 MHz internal clock of the NI 9237. Use the F<br>PGA I/O Node in a <u>single-cycle Timed Loop</u> to ac<br>cess this channel. You must <u>export the Onboard</u><br><u>Clock of the NI 9237</u> to access this channel.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Start         | Channel that controls when the NI 9237 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9237 starts acquiring data. When th<br>e NI 9237 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties or <u>TEDS information</u> for the module. If FA<br>LSE is written to the <b>Start</b> channel, no operatio<br>n is performed.<br>Refer to the NI 9237 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9237 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels. |
| Stop          | Channel that controls when the NI 9237 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9237 stops acquiring data. When the<br>NI 9237 is acquiring data, you must write TRUE t                                                                                                                                                                                                                                                                                                                                                                                                                                  |

o the **Stop** channel before you can access prope rties or TEDS information for the module. If FAL SE is written to the **Stop** channel, no operation i s performed.

Refer to the NI 9237 Getting Started VI in the la bview\examples\CompactRIO\Module Specific\NI 9237\NI 9237 Getting Started\NI 9237 Getting Started. lvproj for an example of using the **Start** and **Stop** channels.

🔊 Open example

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property           | Description                                                                                                                                                                                                                                                                                          |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Half-Bridge Enable | Controls the half-bridge completion option for e ach channel.                                                                                                                                                                                                                                        |
| LSB Weight         | Returns the LSB weight in units of 100 fV/V per L<br>SB for the channel. 100 fV is equal to 10 <sup>-13</sup> volts.<br>Use this value to <u>convert and calibrate</u> NI 9237 d<br>ata if you set the <b>Calibration Mode</b> to <b>Raw</b> in<br>the <u>C Series Module Properties</u> dialog box. |
| Offset             | Returns the calibration offset in units of 10 nV/V<br>for the channel. Use this value to convert and ca<br>librate NI 9237 data if you set the <b>Calibration</b>                                                                                                                                    |

|                   | Mode to Raw in the C Series Module Proper ties dialog box.                                                         |
|-------------------|--------------------------------------------------------------------------------------------------------------------|
| Offset Cal Enable | Enables offset calibration. This disconnects bot<br>h signal input pins and forces the channel input<br>s to zero. |
| Shunt Cal Enable  | Controls the shunt calibration switch for each c hannel.                                                           |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property           | Description                                                                         |
|--------------------|-------------------------------------------------------------------------------------|
| Data Rate          | <u>Sets the rate</u> at which the NI 9237 acquires data.                            |
| Excitation Voltage | Sets the excitation voltage level. All channels sh are the same excitation voltage. |
| Module ID          | Returns the module ID, 0x73A4 (NI 9237 with DS UB) or 0x71C3 (NI 9237 with RJ-50).  |
| Serial Number      | Returns the unique serial number of the module .                                    |
| Vendor ID          | Returns the NI vendor ID, 0x1093.                                                   |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9237 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9237 (FPGA Interface)

Right-click an <u>NI 9237</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts/volt. The fixed-point data is signed, with a word length of 24 bits and an integer word length of –4 bits.
 Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Data Rate**—Specifies the rate at which the module acquires data.

• Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.

• **Excitation Voltage**—Specifies the excitation voltage for the module to output to bridges, or specifies external excitation.

• Enable Half-Bridge Completion—Enables half-bridge completion for individual channels.

# NI 9237 (Scan Interface)

CompactRIO 4-Channel, 24-Bit Half/Full-Bridge Analog Input Module

🔊 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts/volts (channel voltage/excitation voltage).

# **Module Channels**

The NI 9237 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9237, <b>x</b> is 0 to 3. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9237. Right-click the NI 9237 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- Excitation Voltage—Specifies the excitation voltage for the module to output to bridges, or specifies external excitation.
- Enable Half-Bridge Completion—Enables half-bridge completion for individual channels.

### NI 9238

CompactRIO 4-Channel, ±0.5 V, 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

FPGA Interface

#### NI 9238 Pinout



# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Acquiring Data from a Module (FPGA Interface) Configuring the Master Timebase Source for a Module (FPGA Interface) Configuring the Data Rate for a Module (FPGA Interface) Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules Understanding Loop Timing (FPGA Interface)

# NI 9238 (FPGA Interface)

CompactRIO 4-Channel, ±0.5 V, 24-Bit Simultaneous Analog Input Module

📄 Open example

Find related examples

### FPGA I/O Node

E/

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9238. You can also <u>synchronize</u> an NI 9238 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9238 has AI channels 0 to<br>3. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                               |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 12.8 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9238</u> to ac<br>cess this channel.                                                                                                          |
| Start         | Channel that controls when the NI 9238 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9238 starts acquiring data. When th<br>e NI 9238 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed. |
| Stop          | Channel that controls when the NI 9238 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9238 stops acquiring data. When the<br>NI 9238 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope                                                                                                                                   |

rties for the module. If FALSE is written to the **St op** channel, no operation is performed.

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in fV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9238<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>38 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9238 acquires data. |
| Module ID     | Returns the module ID, 0x7750.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9238 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)

Right-click an <u>NI 9225/NI 9227/NI 9229/NI 9238/NI 9239/NI 9246/NI 9247</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module.

• Select **Calibrated**, which is the default, if you want the <u>FPGA I/O Node</u> to return calibrated, signed, <u>fixed-point</u> data from the module. The following table describes the units and integer word length of the returned data:

| Module  | Units | Word Length (bits) | Integer Word Length<br>(bits) |
|---------|-------|--------------------|-------------------------------|
| NI 9225 | V     | 24                 | 10                            |
| NI 9227 | A     | 24                 | 5                             |
| NI 9229 | V     | 24                 | 7                             |

| NI 9238 | V | 24 | 1 |
|---------|---|----|---|
| NI 9239 | V | 24 | 5 |
| NI 9246 | A | 24 | 7 |
| NI 9247 | A | 24 | 9 |

• Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Data Rate**—Specifies the rate at which the module acquires data.

NI 9239

CompactRIO 4-Channel, ±10 V, 24-Bit Simultaneous Analog Input Module

Software Reference (?)

FPGA Interface | Scan Interface

#### NI 9239 Pinout





# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Acquiring Data from a Module (FPGA Interface) Configuring the Master Timebase Source for a Module (FPGA Interface) Configuring the Data Rate for a Module (FPGA Interface) Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules Understanding Loop Timing (FPGA Interface)

# NI 9239 (FPGA Interface)

CompactRIO 4-Channel, ±10 V, 24-Bit Simultaneous Analog Input Module

📄 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9239. You also can <u>synchronize</u> an NI 9239 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

### **Terminals in Software**

E

Use the FPGA I/O Node to access the following terminals for this device.

| P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9239 has AI channels 0 to<br>3. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                                                                             |
| Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 12.8 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9239</u> to ac<br>cess this channel.                                                                                                                                                                                                                                                                                                                        |
| Channel that controls when the NI 9239 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9239 starts acquiring data. When th<br>e NI 9239 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.<br>Refer to the NI 9239 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9239 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels. |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Stop | Channel that controls when the NI 9239 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9239 stops acquiring data. When the<br>NI 9239 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Refer to the NI 9239 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9239\NI 9239 Getting<br>Started\NI 9239 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                                                                              |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pV/LSB for the channe<br>l. Use this value to <u>convert and calibrate</u> NI 9239<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box. |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>39 data if you set the <b>Calibration Mode</b> to <b>Ra</b>                                                             |

**w** in the **C Series Module Properties** dialog b ox.

### Module Properties

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9239 acquires data. |
| Module ID     | Returns the module ID, 0x71C2.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9239 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)

Right-click an <u>NI 9225/NI 9227/NI 9229/NI 9238/NI 9239/NI 9246/NI 9247</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module.

• Select **Calibrated**, which is the default, if you want the <u>FPGA I/O Node</u> to return calibrated, signed, <u>fixed-point</u> data from the module. The following table describes the units and integer word length of the returned data:

| Module  | Units | Word Length (bits) | Integer Word Length<br>(bits) |
|---------|-------|--------------------|-------------------------------|
| NI 9225 | V     | 24                 | 10                            |
| NI 9227 | A     | 24                 | 5                             |
| NI 9229 | V     | 24                 | 7                             |
| NI 9238 | V     | 24                 | 1                             |
| NI 9239 | V     | 24                 | 5                             |
| NI 9246 | A     | 24                 | 7                             |
| NI 9247 | A     | 24                 | 9                             |

• Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

#### NI 9239 (Scan Interface)

CompactRIO 4-Channel, ±10 V, 24-Bit Simultaneous Analog Input Module

🔊 Open example
### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

#### **Module Channels**

The NI 9239 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9239, <b>x</b> is 0 to 3. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9239. Right-click the NI 9239 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### Hardware Documentation

Refer to the NI 9239 hardware documentation on ni.com/manuals for information about module specifications and how to use the module. Refer to the <u>CompactRIO</u> <u>Related Documentation</u> topic for additional CompactRIO documentation resources.

#### NI 9242

CompactRIO 4-Channel, 250 V<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

FPGA Interface

### NI 9242 Pinout



# **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Acquiring Data from a Module (FPGA Interface)</u> <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Configuring the Data Rate for a Module (FPGA Interface)</u> <u>Converting NI 9242 and NI 9244 Data</u> <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u> <u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9242 (FPGA Interface)

CompactRIO 4-Channel, 250 V<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

### FPGA I/O Node

E/

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9242. You can also <u>synchronize</u> an NI 9242 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9242 has AI channels 0 to<br>2. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                               |
| Neutral       | Neutral input channel. Do not access Neutral ch<br>annels on multiple modules in the same FPGA I/<br>O Node if the modules are not synchronized or d<br>o not use the same data rate.                                                                                                                                                                                                                         |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 12.8 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9242</u> to ac<br>cess this channel.                                                                                                          |
| Start         | Channel that controls when the NI 9242 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9242 starts acquiring data. When th<br>e NI 9242 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed. |
| Stop          | Channel that controls when the NI 9242 stops ac quiring data. If TRUE is written to the <b>Stop</b> chan                                                                                                                                                                                                                                                                                                      |

nel, the NI 9242 stops acquiring data. When the NI 9242 is acquiring data, you must write TRUE t o the **Stop** channel before you can access prope rties for the module. If FALSE is written to the **St op** channel, no operation is performed.

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

### Methods

This device does not support any methods.

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                       |
|---------------|---------------------------------------------------|
| Data Rate     | Sets the rate at which the NI 9242 acquires data. |
| Module ID     | Returns the module ID, 0x772A.                    |
| Serial Number | Returns the unique serial number of the module .  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                 |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9242 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9242/9244 (FPGA Interface)

Right-click an <u>NI 9242</u> or <u>NI 9244</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 10 bits. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>scale</u> the analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

Converting NI 9242 and NI 9244 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9242</u> and the <u>NI 9244</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

You can use the following equations in the host VI to convert binary voltage values to volts:

NI 9242

#### **Volts = Binary Value** × 500 V ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

NI 9244

Volts = Binary Value × 997.5 V ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

### NI 9242 (Scan Interface)

CompactRIO 4-Channel, 250 V<sub>rms</sub>, 24-Bit Simultaneous Analog Input Module

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

### **Module Channels**

The NI 9242 has the following channels.

| Channel | Description                                                                                                            |
|---------|------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9242 has AI channels 0 to<br>2. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9242. Right-click the NI 9242 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Data Rate**—Specifies the rate at which the NI 9242 acquires and returns data. The data rate must remain within the appropriate data rate range listed in the NI 9242 hardware documentation on ni.com/manuals.

#### NI 9244

CompactRIO 4-Channel, 400 V<sub>rms</sub> L-N, 800 V<sub>rms</sub> L-L, 24-Bit Simultaneous Analog Input Module

#### Software Reference (?)

FPGA Interface

#### NI 9244 Pinout



### **Related Topics**

FPGA Interface <u>Detecting Out-of-Range Channels</u> <u>Acquiring Data from a Module (FPGA Interface)</u> <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Configuring the Data Rate for a Module (FPGA Interface)</u> <u>Converting NI 9242 and NI 9244 Data</u> <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u> <u>Understanding Loop Timing (FPGA Interface)</u>

## NI 9244 (FPGA Interface)

CompactRIO 4-Channel, 400 V<sub>rms</sub> L-N, 800 V<sub>rms</sub> L-L, 24-Bit Simultaneous Analog Input Module

### FPGA I/O Node

E/

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9244. You can also <u>synchronize</u> an NI 9244 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9244 has AI channels 0 to<br>2. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                               |
| Neutral       | Neutral input channel. Do not access Neutral ch<br>annels on multiple modules in the same FPGA I/<br>O Node if the modules are not synchronized or d<br>o not use the same data rate.                                                                                                                                                                                                                         |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 12.8 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9244</u> to ac<br>cess this channel.                                                                                                          |
| Start         | Channel that controls when the NI 9244 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9244 starts acquiring data. When th<br>e NI 9244 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed. |
| Stop          | Channel that controls when the NI 9244 stops ac quiring data. If TRUE is written to the <b>Stop</b> chan                                                                                                                                                                                                                                                                                                      |

nel, the NI 9244 stops acquiring data. When the NI 9244 is acquiring data, you must write TRUE t o the **Stop** channel before you can access prope rties for the module. If FALSE is written to the **St op** channel, no operation is performed.

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

### Methods

This device does not support any methods.

## I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9244 acquires data. |
| Module ID     | Returns the module ID, 0x76E8.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9244 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9242/9244 (FPGA Interface)

Right-click an <u>NI 9242</u> or <u>NI 9244</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module in units of volts. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 10 bits. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>scale</u> the analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

Converting NI 9242 and NI 9244 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9242</u> and the <u>NI 9244</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

You can use the following equations in the host VI to convert binary voltage values to volts:

NI 9242

#### Volts = Binary Value × 500 V ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

NI 9244

**Volts = Binary Value** × 997.5 V ÷ 8,388,607

where

**Binary Value** is the value returned by the FPGA I/O Node.

### NI 9244 (Scan Interface)

CompactRIO 4-Channel, 400 V<sub>rms</sub> L-N, 800 V<sub>rms</sub> L-L, 24-Bit Simultaneous Analog Input Module

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

### **Module Channels**

The NI 9244 has the following channels.

| Channel | Description                                                                                                            |
|---------|------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9244 has AI channels 0 to<br>2. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9244. Right-click the NI 9244 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Data Rate**—Specifies the rate at which the NI 9244 acquires and returns data. The data rate must remain within the appropriate data rate range listed in the NI 9244 hardware documentation on ni.com/manuals.

NI 9246

CompactRIO 3-Channel, 20 A<sub>rms</sub> Continuous, 24-Bit, Analog Input Module

#### Software Reference (?)

FPGA Interface

#### NI 9246 Pinout



## **Related Topics**

FPGA Interface <u>Converting and Calibrating CompactRIO Analog Input Values</u> <u>Detecting Out-of-Range Channels</u> <u>Acquiring Data from a Module (FPGA Interface)</u> <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Configuring the Data Rate for a Module (FPGA Interface)</u> <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u> <u>Understanding Loop Timing (FPGA Interface)</u>

### NI 9246 (FPGA Interface)

CompactRIO 3-Channel, 20 A<sub>rms</sub> Continuous, 24-Bit, Analog Input Module

📄 Open example

Find related examples

### FPGA I/O Node

E/

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9246. You can also <u>synchronize</u> an NI 9246 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9246 has AI channels 0 to<br>2. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                                                    |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 13.1 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9246</u> to ac<br>cess this channel.                                                                                                                                                                                                                                                                                               |
| Start         | Channel that controls when the NI 9246 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9246 starts acquiring data. When th<br>e NI 9246 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.<br>Refer to the NI 9246 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9246 Getting Started.<br>lvproj for an example of using the <b>Start</b> and |

|      | Stop channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 📄 Open example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Stop | Channel that controls when the NI 9246 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9246 stops acquiring data. When the<br>NI 9246 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed.<br>Refer to the NI 9246 Getting Started VI in the 1a<br>bview\examples\CompactRIO\Module<br>Specific\NI 9246 Getting Started.<br>1vproj for an example of using the <b>Start</b> and |
|      | Stop channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      | 🔊 Open example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

### Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9246<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box. |

| Offset | Returns the calibration offset in $\mu$ V for the chan<br>nel. Use this value to convert and calibrate NI 92<br>46 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br>w in the <b>C Series Module Properties</b> dialog b |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | w in the C Series Module Properties dialog b                                                                                                                                                                                       |
|        | OX.                                                                                                                                                                                                                                |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9246 acquires data. |
| Module ID     | Returns the module ID, 0x77E3.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

## Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9246 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)

Right-click an <u>NI 9225/NI 9227/NI 9229/NI 9238/NI 9239/NI 9246/NI 9247</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module.

• Select **Calibrated**, which is the default, if you want the <u>FPGA I/O Node</u> to return calibrated, signed, <u>fixed-point</u> data from the module. The following table describes the units and integer word length of the returned data:

| Module  | Units | Word Length (bits) | Integer Word Length<br>(bits) |
|---------|-------|--------------------|-------------------------------|
| NI 9225 | V     | 24                 | 10                            |
| NI 9227 | A     | 24                 | 5                             |
| NI 9229 | V     | 24                 | 7                             |
| NI 9238 | V     | 24                 | 1                             |
| NI 9239 | V     | 24                 | 5                             |
| NI 9246 | A     | 24                 | 7                             |
| NI 9247 | A     | 24                 | 9                             |

• Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI.

- Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.
- **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.
- **Data Rate**—Specifies the rate at which the module acquires data.

#### NI 9247

CompactRIO 3-Channel, 50 A<sub>rms</sub> Continuous, 24-Bit, Analog Input Module

#### Software Reference (?)

FPGA Interface

#### NI 9247 Pinout



## **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Acquiring Data from a Module (FPGA Interface) Configuring the Master Timebase Source for a Module (FPGA Interface) Configuring the Data Rate for a Module (FPGA Interface) Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules Understanding Loop Timing (FPGA Interface)

## NI 9247 (FPGA Interface)

CompactRIO 3-Channel, 50 A<sub>rms</sub> Continuous, 24-Bit, Analog Input Module

🔊 Open example

E

Find related examples

### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

**Note** You can <u>simultaneously read from or</u> <u>write to</u> multiple channels on the NI 9247. You can also <u>synchronize</u> an NI 9247 module with other modules that have a <u>selectable timebase</u> <u>source</u>.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9247 has AI channels 0 to<br>2. Do not access AI channels on multiple module<br>s in the same FPGA I/O Node if the modules are<br>not synchronized or do not use the same data ra<br>te.                                                                                                                                                                                                                                                                                                |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The Onboard Clock frequency<br>is 13.1 MHz. Use the FPGA I/O Node in a <u>single-c</u><br><u>ycle Timed Loop</u> to access this channel. You mu<br>st <u>export the Onboard Clock of the NI 9247</u> to ac<br>cess this channel.                                                                                                                                                                                                                                                                           |
| Start         | Channel that controls when the NI 9247 starts <u>a</u><br><u>cquiring data</u> . If TRUE is written to the <b>Start</b> cha<br>nnel, the NI 9247 starts acquiring data. When th<br>e NI 9247 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.<br>Refer to the NI 9247 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9247 NI 9247 Getting<br>Started\NI 9247 Getting Started. |

|      | lvproj for an example of using the <b>Start</b> and                                                                                                                                                                                                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Stop channels.                                                                                                                                                                                                                                                                                                                          |
|      | 📄 Open example                                                                                                                                                                                                                                                                                                                          |
| Stop | Channel that controls when the NI 9247 stops ac                                                                                                                                                                                                                                                                                         |
|      | quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9247 stops acquiring data. When the<br>NI 9247 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |
|      | Refer to the NI 9247 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9247\NI 9247 Getting<br>Started\NI 9247 Getting Started.<br>lvproj for an example of using the <b>Start</b> and<br><b>Stop</b> channels.                                                                                           |
|      | 📄 Open example                                                                                                                                                                                                                                                                                                                          |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

### Methods

This device does not support any methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                  |
|------------|--------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9247 |

|        | data if you set the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series Module Properties</u> dialog box.                                                                                                                              |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset | Returns the calibration offset in μV for the chan<br>nel. Use this value to convert and calibrate NI 92<br>47 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                              |
|---------------|----------------------------------------------------------|
| Data Rate     | <u>Sets the rate</u> at which the NI 9247 acquires data. |
| Module ID     | Returns the module ID, 0x77B8.                           |
| Serial Number | Returns the unique serial number of the module .         |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                        |

### Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9247 with the single-cycle Timed Loop. Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9225/9227/9229/9238/9239/9246/9247 (FPGA Interface)

Right-click an <u>NI 9225/NI 9227/NI 9229/NI 9238/NI 9239/NI 9246/NI 9247</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module.

• Select **Calibrated**, which is the default, if you want the <u>FPGA I/O Node</u> to return calibrated, signed, <u>fixed-point</u> data from the module. The following table describes the units and integer word length of the returned data:

| Module  | Units | Word Length (bits) | Integer Word Length<br>(bits) |
|---------|-------|--------------------|-------------------------------|
| NI 9225 | V     | 24                 | 10                            |
| NI 9227 | A     | 24                 | 5                             |
| NI 9229 | V     | 24                 | 7                             |
| NI 9238 | V     | 24                 | 1                             |
| NI 9239 | V     | 24                 | 5                             |
| NI 9246 | A     | 24                 | 7                             |
| NI 9247 | A     | 24                 | 9                             |

• Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select **Raw**, you must <u>convert and calibrate</u> the analog input values in the host VI.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• Data Rate—Specifies the rate at which the module acquires data.

#### NI 9250

CompactRIO 2-Ch, ±5 V, 24-Bit, Analog Input Software Selectable IEPE & AC/DC

### Software Reference (?)

#### FPGA Interface

NI 9250

### NI 9250 Pinout



### **Related Topics**

FPGA Interface
<u>C Series Module Properties Dialog Box</u>
<u>Converting and Calibrating CompactRIO Analog Input Values</u>
<u>Detecting Out-of-Range Channels for CompactRIO Analog Input Channels</u>
<u>Acquiring Data from an NI 9250</u>
<u>Configuring the Data Rate for a Module (FPGA Interface)</u>
<u>Converting NI 9250 Data</u>
<u>Synchronizing Multiple Modules</u>
Understanding Loop Timing (FPGA Interface)

### NI 9250 (FPGA Interface)

CompactRIO 2-Ch, ±5 V, 24-Bit, Analog Input Software Selectable IEPE & AC/DC

🔊 Open example

🔍 Find related examples

### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.



**Note** You can <u>synchronize</u> an NI 9250 module with other modules that have a <u>selectable</u> <u>timebase source</u>.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                            |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9250 has channels 0 to 1.                                                                                                          |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The onboard clock frequency i<br>s 13.1072 MHz. Use the FPGA I/O Node in a <u>singl</u><br><u>e-cycle timed loop</u> to access this channel. You m |

|       | ust <u>export the onboard clock of the NI 9250</u> to a ccess this channel.                                                                                                                                                                                                                                                                                                                |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start | Channel that controls when the NI 9250 starts a cquiring data. If TRUE is written to the <b>Start</b> cha nnel, the NI 9250 starts acquiring data. When th e NI 9250 is acquiring data, you must write TRUE to the <b>Stop</b> channel before you can access prop erties for the module. If FALSE is written to the <b>S</b> tart channel, no operation is performed.                      |
| Stop  | Channel that controls when the NI 9250 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9250 stops acquiring data. When the<br>NI 9250 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property            | Description                                                                                                                       |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Input Configuration | Sets the input configuration of the correspondin<br>g channel to one of three modes: AC Coupled, D<br>C Coupled, IEPE AC Coupled. |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property  | Description                                       |
|-----------|---------------------------------------------------|
| Data Rate | Sets the rate at which the NI 9250 acquires data. |

| Module ID     | Returns the module ID, 0x77EA.                   |
|---------------|--------------------------------------------------|
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9250 (FPGA Interface)

Right-click an <u>NI 9250</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. The fixed-point data is signed, with 24-bits word length and 4-bits integer word length. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must <u>convert</u> the binary data to the actual analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

- Data Rate—Specifies the rate at which the module acquires data.
- Enable TEDS Support—Place a checkmark in this checkbox if you want to enable <u>TEDS support</u> in the FPGA and host VIs for this module.
- **Channels**—Specifies the channel(s) for which you want to select the input configuration.
- Selected Channel(s) Settings—Specifies the input configuration for each channel.
  - Input Configuration—<u>Sets the input configuration</u> for the selected channel(s). Select AC Coupled for AC coupling, DC Coupled for DC coupling, IEPE AC Coupled for AC coupling with IEPE enabled.

Configuring the NI 9250 Channel Input Modes (FPGA Interface)

You can configure the input mode for each channel of the <u>NI 9250</u> at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the input mode for each channel at run time using the <u>FPGA I/O Property Node</u>. The execution of an FPGA I/O Property Node that is configured with an **Input Configuration** property overwrites the value you configured in the **C Series Module Properties** dialog box for the corresponding channel.

Configuring the Channel Input Modes Using the C Series Module Properties Dialog Box

Complete the following steps to configure the channel input modes using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to display the **C Series Module Properties** dialog box.

- 3. Select the channel(s) for which you want to configure the input mode from the Channels table. You can select more than one channel by holding the <Ctrl>> or <Shift> key when selecting channels.
- 4. Select the input mode for the selected channel(s) from the **Input Configuration** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring the Channel Input Modes Using the FPGA I/O Property Node

Complete the following steps to configure the channel input modes using the FPGA I/O Property Node.

- 1. <u>Create FPGA I/O items</u> for the channels of the module for which you want to configure the **Input Configuration** property.
- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the module channel for which you want to configure the input mode.
- 3. Click the **Property** section and select **Input Configuration** from the shortcut menu.
- 4. Right-click the **Input Configuration** input and select **Create»Control** from the shortcut menu.
- 5. On the front panel of the VI, select an input mode for the channel from the **Input Configuration** pull-down menu.

You can change the channel input modes at run time by writing to the control from the host VI. Refer to the following getting started VIs for examples of how to configure the input modes using the FPGA I/O Property Node.

| Module  | Example File Path                                                                                                                         | Open Example             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| NI 9250 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9250\NI 9250 Gett<br/>ing Started\NI 9250 G<br/>etting Started.lvproj</pre> | 🔊 Open example (NI 9250) |

**Note** The **Input Configuration** property returns <u>error 65538</u> if the module is acquiring data. You must use the <u>Stop channel</u> to stop acquiring data before you can write properties to the modules.

Converting NI 9250 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9250</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

You can use the following equations in the host VI to convert binary voltage values to volts:

#### Volts = Binary Value × 608896 pV/LSB

where

E/

**Binary Value** is the value returned by the FPGA I/O Node.

NI 9251

CompactRIO 2-Channel, 3 Vrms, 24-Bit Differential Analog Input Module

#### Software Reference (?)

FPGA Interface

#### NI 9251

### NI 9251 Pinout



## **Related Topics**

FPGA Interface
<u>C Series Module Properties Dialog Box</u>
<u>Converting and Calibrating CompactRIO Analog Input Values</u>
<u>Detecting Out-of-Range Channels for CompactRIO Analog Input Channels</u>
<u>Acquiring Data from a Module</u>
<u>Configuring the Data Rate for a Module (FPGA Interface)</u>
<u>Converting NI 9251 Data</u>
<u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u>
<u>Understanding Loop Timing (FPGA Interface)</u>

### NI 9251 (FPGA Interface)

CompactRIO 2-Channel, 3 Vrms, 24-Bit Differential Analog Input Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

Ľ

**Note** You can <u>synchronize</u> an NI 9251 module with other modules that have a <u>selectable</u> <u>timebase source</u>.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                                                                                           |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9251 has channels 0 to 1.                                                                                                                                                                                                                                                         |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The onboard clock frequency i<br>s 13.1072 MHz. Use the FPGA I/O Node in a <u>singl</u><br><u>e-cycle timed loop</u> to access this channel. You m<br>ust <u>export the onboard clock of the NI 9251</u> to a<br>ccess this channel.                                                              |
| Start         | Channel that controls when the NI 9251 starts a cquiring data. If TRUE is written to the <b>Start</b> cha nnel, the NI 9251 starts acquiring data. When th e NI 9251 is acquiring data, you must write TRUE to the <b>Stop</b> channel before you can access prop erties for the module. If FALSE is written to the <b>S</b> tart channel, no operation is performed. |
| Stop          | Channel that controls when the NI 9251 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9251 stops acquiring data. When the<br>NI 9251 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope                                                                                           |

rties for the module. If FALSE is written to the **St op** channel, no operation is performed.

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property            | Description                                                                                                   |
|---------------------|---------------------------------------------------------------------------------------------------------------|
| Input Configuration | Sets the input configuration of the correspondin<br>g channel to one of two modes: AC Coupled; DC<br>Coupled. |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                       |  |
|---------------|---------------------------------------------------|--|
| Data Rate     | Sets the rate at which the NI 9251 acquires data. |  |
| Module ID     | Returns the module ID, 0x77E9.                    |  |
| Serial Number | Returns the unique serial number of the module .  |  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                 |  |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9251 (FPGA Interface)

Right-click an <u>NI 9251</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. The fixed-point data is signed, with 24-bits word length and 4-bits integer word length. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the binary data to the actual analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

- Data Rate—Specifies the rate at which the module acquires data.
- **Channels**—Specifies the channel(s) for which you want to select the input configuration.

• Selected Channel(s) Settings—Specifies the input configuration for each channel.

• Input Configuration—<u>Sets the input configuration</u> for the selected channel(s). Select **AC Coupled** for AC coupling, **DC Coupled** for DC coupling.

#### Configuring the NI 9251 Channel Input Modes (FPGA Interface)

You can configure the input mode for each channel of the <u>NI 9251</u> at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the input mode for each channel at run time using the <u>FPGA I/O Property Node</u>. The execution of an FPGA I/O Property Node that is configured with an **Input Configuration** property overwrites the value you configured in the **C Series Module Properties** dialog box for the corresponding channel.

Configuring the Channel Input Modes Using the C Series Module Properties Dialog Box

Complete the following steps to configure the channel input modes using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an module.
- 2. Right-click the module in the **Project Explorer** window and select **Properties** to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the input mode from the **Channels** table. You can select more than one channel by holding the <Ctrl>> or <Shift> key when selecting channels.
- 4. Select the input mode for the selected channel(s) from the **Input Configuration** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring the Channel Input Modes Using the FPGA I/O Property Node

Complete the following steps to configure the channel input modes using the FPGA I/O Property Node.

- 1. <u>Create FPGA I/O items</u> for the channels of the module for which you want to configure the **Input Configuration** property.
- 2. Place an FPGA I/O Property Node on the block diagram and <u>configure</u> it for the module channel for which you want to configure the input mode.

- 3. Click the **Property** section and select **Input Configuration** from the shortcut menu.
- 4. Right-click the **Input Configuration** input and select **Create»Control** from the shortcut menu.
- 5. On the front panel of the VI, select an input mode for the channel from the **Input Configuration** pull-down menu.

You can change the channel input modes at run time by writing to the control from the host VI. Refer to the following getting started VIs for examples of how to configure the input modes using the FPGA I/O Property Node.

| Module  | Example File Path                                                                                                                         | Open Example           |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| NI 9251 | <pre>labview\examples\Comp<br/>actRIO\Module Specific<br/>\NI 9251\NI 9251 Gett<br/>ing Started\NI 9251 G<br/>etting Started.lvproj</pre> | Dpen example (NI 9251) |
|         |                                                                                                                                           |                        |

**Note** The **Input Configuration** property returns <u>error 65538</u> if the module is acquiring data. You must use the <u>Stop channel</u> to stop acquiring data before you can write properties to the modules.

Converting NI 9251 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9251</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

You can use the following equations in the host VI to convert binary voltage values to volts:

#### Volts = Binary Value × 515589 pV/LSB

₹
where

**Binary Value** is the value returned by the FPGA I/O Node.

AI0+

AI1+

AI2+

AI3+

AI4+

AI5+

AI6+

AI7+

COM

COM

NC

NC

NC

NC

NC

NC

NC

NC NC

NI 9252

CompactRIO 8-Channel, ±10 V, 24-Bit Differential Analog Input Module

### Software Reference (?)

FPGA Interface

NI 9252

# NI 9252 Pinout



## **Related Topics**

FPGA Interface
<u>C Series Module Properties Dialog Box</u>
<u>Converting and Calibrating CompactRIO Analog Input Values</u>
<u>Detecting Out-of-Range Channels for CompactRIO Analog Input Channels</u>
<u>Acquiring Data from a Module</u>
<u>Configuring the Data Rate for a Module (FPGA Interface)</u>
<u>Converting NI 9252 Data</u>
<u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9202/9260 Modules</u>
<u>Understanding Loop Timing (FPGA Interface)</u>

# NI 9252 (FPGA Interface)

CompactRIO 8-Channel, ±10 V, 24-Bit Differential Analog Input Module

🔊 Open example

🔍 Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9252 has channels 0 to 7.                                                                                                                                                                                        |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The onboard clock frequency i<br>s 12.8 MHz. Use the FPGA I/O Node in a <u>single-cy</u><br><u>cle timed loop</u> to access this channel. You must<br><u>export the onboard clock of the NI 9252</u> to acces<br>s this channel. |
| Start         | Channel that controls when the NI 9252 starts a cquiring data. If TRUE is written to the <b>Start</b> cha                                                                                                                                                                                            |

|      | nnel, the NI 9252 starts acquiring data. When th<br>e NI 9252 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.                                                                                                             |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop | Channel that controls when the NI 9252 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9252 stops acquiring data. When the<br>NI 9252 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property         | Description                                                                                                                                                    |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Rate        | Sets the rate at which the NI 9252 acquires data.                                                                                                              |
| Module ID        | Returns the <u>module ID</u> .                                                                                                                                 |
| Serial Number    | Returns the unique serial number of the module .                                                                                                               |
| Vendor ID        | Returns the NI vendor ID, 0x1093.                                                                                                                              |
| Filter Response  | Sets the AI filter types supported by the device.<br>The filters supported by this module are the Co<br>mb (default) and Butterworth filter.                   |
| Filter Order     | Sets the Filter Order for the Butterworth filter. T<br>his setting would only take effect if the module i<br>s currently configured to the Butterworth filter. |
| Filter Frequency | Sets the AI filter's cutoff frequency.                                                                                                                         |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9252 (FPGA Interface)

Right-click an <u>NI 9252</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. The fixed-point data is signed, with 24-bits word length and 4-bits integer word length. Select **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select **Raw**, you must <u>convert</u> the binary data to the actual analog input values in the host VI. The default is **Calibrated**.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Data Rate**—Specifies the rate at which the module acquires data.

 Filter Response—Sets the AI digital filter types supported by the device. Filters supported by this module are the Comb (default) and Butterworth filter.

• Filter Order—Sets the Filter Order for the Butterworth filter. This setting would only take effect if the module is currently configured to the Butterworth filter.

• Filter Frequency—Configures the cut-off frequency of the filter. It is dependent on the data rate. Available values:

| Filter Settings      | Cut-off Frequency |             |          |
|----------------------|-------------------|-------------|----------|
|                      | Comb              | Butterworth |          |
|                      |                   | 12.8 MHz    | 13.1 MHz |
| Filter Frequency - 1 | Data Rate/1       | 4000 Hz     | 4096 Hz  |
| Filter Frequency - 2 | Data Rate/2       | 2000 Hz     | 2048 Hz  |
| Filter Frequency - 3 | Data Rate/4       | 1000 Hz     | 1024 Hz  |
| Filter Frequency - 4 | Data Rate/8       | 500 Hz      | 512 Hz   |
| Filter Frequency - 5 | Data Rate/16      | 250 Hz      | 256 Hz   |
| Filter Frequency - 6 | Data Rate/16      | 125 Hz      | 128 Hz   |
| Notes:               |                   | ·           |          |

When the module is configured to the Comb filter, Filter Frequency - 5 and Filter Frequency - 6 sets the Notch Frequency at Data Rate/16.

Converting NI 9252 Data (FPGA Interface)

Set the Calibration Mode to Calibrated in the C Series Module Properties dialog box for the NI 9252 if you want the FPGA I/O Node to return calibrated, fixed-point data from the module. Set the Calibration Mode to Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the Calibration Mode to Raw, you must convert the binary values to engineering units. You must convert these values in the host VI.

You can use the following equations in the host VI to convert binary voltage values to volts:

#### Volts = Binary Value × 1261243 pV/LSB

where

**Binary Value** is the value returned by the FPGA I/O Node.

NI 9253

CompactRIO 8-Channel, ±20 mA, 24-Bit Differential Analog Input Module

### Software Reference (?)

FPGA Interface

NI 9253

# NI 9253 Pinout



## **Related Topics**

FPGA Interface
<u>C Series Module Properties Dialog Box</u>
<u>Converting and Calibrating CompactRIO Analog Input Values</u>
<u>Detecting Out-of-Range Channels for CompactRIO Analog Input Channels</u>
<u>Acquiring Data from a Module</u>
<u>Configuring the Data Rate for a Module (FPGA Interface)</u>
<u>Converting NI 9253 Data</u>
<u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9202/9260 Modules</u>
<u>Understanding Loop Timing (FPGA Interface)</u>

## NI 9253 (FPGA Interface)

CompactRIO 8-Channel, ±20 mA, 24-Bit Single-ended Analog Input Module

🔊 Open example

Sind related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal      | Description                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alx           | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9253 has channels 0 to 7.                                                                                                                                                                                        |
| Onboard Clock | Gives access to the onboard clock in the LabVIE<br>W block diagram. The onboard clock frequency i<br>s 12.8 MHz. Use the FPGA I/O Node in a <u>single-cy</u><br><u>cle timed loop</u> to access this channel. You must<br><u>export the onboard clock of the NI 9253</u> to acces<br>s this channel. |
| Start         | Channel that controls when the NI 9253 starts a cquiring data. If TRUE is written to the <b>Start</b> cha                                                                                                                                                                                            |

|      | nnel, the NI 9253 starts acquiring data. When th<br>e NI 9253 is acquiring data, you must write TRUE<br>to the <b>Stop</b> channel before you can access prop<br>erties for the module. If FALSE is written to the <b>S</b><br><b>tart</b> channel, no operation is performed.                                                                                                             |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop | Channel that controls when the NI 9253 stops ac<br>quiring data. If TRUE is written to the <b>Stop</b> chan<br>nel, the NI 9253 stops acquiring data. When the<br>NI 9253 is acquiring data, you must write TRUE t<br>o the <b>Stop</b> channel before you can access prope<br>rties for the module. If FALSE is written to the <b>St</b><br><b>op</b> channel, no operation is performed. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | <ul> <li>Returns Booleans for each channel that indicate whether there was a input limits fault, overcurre nt, or field side power fault on the channel since the last execution of the Check Cached Status m ethod. When the FPGA I/O Node reads the chan nels, the FPGA VI determines the state of the cha nnels and caches any TRUE value until the Chec k Cached Status method executes.</li> <li>Channel Input Limits Fault—Return s an array of Boolean values. A value of TR UE in any index indicates that the channel sharing a number with that index detecte d the channel input is out of range of Low er Fault Detection Limit and Upper Fault D etection Limit on the channel at some poi</li> </ul> |

nt after the last time that the Check Cache d Status method executed.

• Channel Overcurrent—Returns an ar ray of Boolean values. A value of TRUE in a ny index indicates that the channel sharin g a number with that index detected an ov ercurrent on the channel at some point af ter the last time that the Check Cached St atus method executed.

• Field-Side Power Fault—Returns a si ngle Boolean value. A value of TRUE indic ates that the module detected Field-Side Power Fault on the module at some point after the last time that the Check Cached Status method executed.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property                            | Description                                                                                                                                                                            |
|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Limits Fault Detection Enable | Enable the module to detect Input Limit Fault o<br>n the corresponding channel. Set the input to T<br>RUE to enable and FALSE (default) to disable the<br>Input Limit Fault Detection. |
| Lower Fault Detection Limit         | Sets the Channel's Lower Fault Detection Limit<br>of the corresponding channel. The range of vali<br>d current limit values is 0—0.0219 A (default val<br>ue is 0.0 A).                |
| Upper Fault Detection Limit         | Sets the Channel's Upper Fault Detection Limit<br>of the corresponding channel. The range of vali<br>d current limit values is 0—0.0219 A (default val<br>ue is 0.0219 A).             |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property                                | Description                                                                                                                                                                          |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Rate                               | Sets the rate at which the NI 9253 acquires data.                                                                                                                                    |
| Module ID                               | Returns the <u>module ID</u> .                                                                                                                                                       |
| Serial Number                           | Returns the unique serial number of the module .                                                                                                                                     |
| Vendor ID                               | Returns the NI vendor ID, 0x1093.                                                                                                                                                    |
| Filter Response                         | Sets the AI filter types supported by the device.<br>The filters supported by this module are the Co<br>mb (default) and Butterworth filter.                                         |
| Filter Order                            | Sets the Filter Order for the Butterworth filter. T<br>his setting would only take effect if the module i<br>s currently configured to the Butterworth filter.                       |
| Filter Frequency                        | Sets the AI filter's cutoff frequency.                                                                                                                                               |
| Field-Side Power Fault Detection Enable | Enable the module to detect Field-Side Power S<br>upplied to the module. Set the input to TRUE to<br>enable and FALSE (default) to disable the Field-<br>Side Power Fault Detection. |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9253 (FPGA Interface)

Right-click an <u>NI 9253</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. The fixed-point data is signed, with 24-bits word length and -4-bits integer word length. Select Raw if you want the FPGA I/O Node to return calibrated, binary data from the module. If you select Raw, you must <u>convert</u> the binary data to the actual analog input values in the host VI. The default is Calibrated.

• Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Data Rate**—Specifies the rate at which the module acquires data.

• **Filter Response**—Sets the AI digital filter types supported by the device. Filters supported by this module are the Comb (default) and Butterworth filter.

• **Filter Order**—Sets the Filter Order for the Butterworth filter. This setting would only take effect if the module is currently configured to the Butterworth filter.

| <ul> <li>Filter Frequency—Configures the cut-off frequency of the filter. It is</li> </ul> |
|--------------------------------------------------------------------------------------------|
| dependent on the data rate. Available values:                                              |

| Filter Settings      | Cut-off Frequency |             |          |
|----------------------|-------------------|-------------|----------|
|                      | Comb              | Butterworth |          |
|                      |                   | 12.8 MHz    | 13.1 MHz |
| Filter Frequency - 1 | Data Rate/1       | 4000 Hz     | 4096 Hz  |
| Filter Frequency - 2 | Data Rate/2       | 2000 Hz     | 2048 Hz  |
| Filter Frequency - 3 | Data Rate/4       | 1000 Hz     | 1024 Hz  |
| Filter Frequency - 4 | Data Rate/8       | 500 Hz      | 512 Hz   |
| Filter Frequency - 5 | Data Rate/16      | 250 Hz      | 256 Hz   |
| Filter Frequency - 6 | Data Rate/16      | 125 Hz      | 128 Hz   |

#### Notes:

When the module is configured to the Comb filter, Filter Frequency - 5 and Filter Frequency - 6 sets the Notch Frequency at Data Rate/16.

• **Diagnostic Settings**—Clicking on this button brings up a new dialog box which allows the diagnostics of the module to be selected.

• Field-Side Power Fault Detection Enable—Placing a checkmark in the checkbox will enable the module to detect field-side power fault.

• Input Limits Fault Detection Enable—Placing a checkmark in the checkbox enables the module to detect if the readings are within the set limits. It will also bring up the option to set the upper limit and the lower limit.

• Lower Fault Detection Limit—Sets the Channel's Lower Fault Detection Limit of the corresponding channel. The range of valid current limit values is 0—0.0219 A (default value is 0.0 A).

• **Upper Fault Detection Limit**—Sets the Channel's Upper Fault Detection Limit of the corresponding channel. The range of valid current limit values is 0—0.0219 A (default value is 0.0219 A).

Converting NI 9253 Data (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9253</u> if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data from the module. Set the **Calibration Mode** to **Raw** if you want the FPGA I/O Node to return calibrated, binary data from the module. If you set the **Calibration Mode** to **Raw**, you must convert the binary values to engineering units. You must convert these values in the host VI.

You can use the following equations in the host VI to convert binary current values to amperes:

#### Current = Binary Value × 2615.02 pA/LSB

where

**Binary Value** is the value returned by the FPGA I/O Node.

# NI 9253 (Scan Interface)

CompactRIO 8-Channel, ±20 mA, 24-Bit Single-ended Analog Input Module

🔊 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in amps.

## **Module Channels**

The NI 9253 has the following channels.

| Channel | Description                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9253, <b>x</b> is 0 to 7. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9253. Right-click the NI 9253 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- Data Rate—Sets the rate at which the module acquires data.

• **Filter Response**—Sets the AI filter types supported by the device. The filters supported by this module are the Comb (default) and Butterworth filter.

• **Filter Order**—Sets the Filter Order for the Butterworth filter. This setting would only take effect if the module is currently configured to the Butterworth filter.

- Filter Frequency—Sets the AI filter's cutoff frequency.
- Diagnostic Settings—You can set diagnostic functions for the module.
  - Module Settings

• Field-side Power Fault Detection Enable—Enable the module to detect Field-Side Power Supplied to the module. Select the checkbox to enable and unselect (default) to disable the Field-Side Power Fault Detection.

#### Channel Configuration

• Input Limits Fault Detection Enable—Enable the module to detect Input Limit Fault on the corresponding channel. Select the checkbox to enable and unselect (default) to disable the Input Limits Fault Detection.

• Lower Fault Detection Limit—Sets the Channel's Lower Fault Detection Limit of the corresponding channel. The range of valid current limit values is 0—0.0219 A (default value is 0.0 A).

• Upper Fault Detection Limit—Sets the Channel's Upper Fault Detection Limit of the corresponding channel. The range of valid current limit values is 0—0.0219 A (default value is 0.0219 A).

#### **Module Methods**

Use the Invoke Node to access the following module properties for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | Returns Booleans for each channel that indicate<br>whether there was an input limits fault, overcurr<br>ent, or field side power fault on the channel sinc<br>e the last execution of the Check Cached Status<br>method. When I/O variables or shared variables<br>read the channels, the scan driver determines t<br>he state of the channels and caches any TRUE v |

alue until the Check Cached Status method exec utes.

- Channel Input Limits Fault—Return s an array of Boolean values. A value of TR UE in any index indicates that the channel sharing a number with that index detecte d the channel input is out of range of Low er Fault Detection Limit and Upper Fault D etection Limit on the channel at some poi nt after the last time that the Check Cache d Status method executed.
- Channel Overcurrent—Returns an ar ray of Boolean values. A value of TRUE in a ny index indicates that the channel sharin g a number with that index detected an ov ercurrent on the channel at some point af ter the last time that the Check Cached St atus method executed.
- Field-Side Power Fault—Returns a si ngle Boolean value. A value of TRUE indic ates that the module detected Field-Side Power Fault on the module at some point after the last time that the Check Cached Status method executed.

### NI 9381

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

Software Reference (?)

😂 FPGA Interface 🛛 📀 Scan Interface

### NI 9381 Pinout



# Running AI and AO Operations Concurrently on the NI 9381

AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information.

# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Avoiding Timing Uncertainty with the NI 9381 Converting Voltage Values to Binary Values for the NI 9381

# NI 9381 (FPGA Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

🔍 Find NI 9381 examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

| Terminal | Description                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AI channels 0 to<br>7.            |
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AO channels 0 t<br>o 3.          |
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9381 has DIO chan<br>nels 0 to 3. |
| DIO3:0   | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

 $\triangle$ 

**Caution** AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding</u> <u>Timing Uncertainty</u> topic for more information.

# Arbitration

Analog input and analog output channels of this device support only the <u>Arbitrate if</u> <u>Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for analog input and analog output channels of this device.

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for the DIO channels of this device.

| Method            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Method Node (FPGA Modu</u><br><u>le)</u> topic for a description of this method.<br>This method is available only when you set the                                                                                                                                                                                                                                                                                                                                       |
|                   | DIO line direction to output. You can set the DIO line direction in the <u>C Series Module Properties</u> dialog box.                                                                                                                                                                                                                                                                                                                                                                             |
| Set Output Enable | Sets the line direction of the digital channel or t<br>he DIO3:0 digital port. Refer to the FPGA I/O Met<br>hod Node (FPGA Module) topic for more informa<br>tion on this method. This method can introduce<br>jitter in an analog input or analog output loop.<br>This method is available only when you enable<br>programmable DIO line changes on the module.<br>You can enable programmable DIO line changes<br>on the module in the <u>C Series Module Properties</u><br>dialog box.         |
| Wait on Any Edge  | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
|                   | Notes This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   | For the first two secon<br>ds after resetting the F                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|                      | PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out. |
|                      | Notes This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                                                                                                                                                                                                                                                                 |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                      |
|                      | Notes This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil                                                                                                                                                                                                                                                                                                                                                                                                 |

|                     |                                                                                                                                                                                                                                                                         | l not start counting unt<br>il the module is identifi<br>ed.                                                                                                                                                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Low Level   | Pauses the execution of t<br>til the digital signal is low<br>pecifies in FPGA clock tic<br>n Low Level method wait<br>A value of 0 causes the m<br>ediately, a negative value<br>wait indefinitely, and a per<br>method to wait for that n<br>fore timing out.         | the I/O Method Node un<br>W. The <b>Timeout</b> input s<br>ks how long the Wait o<br>is for the next low level.<br>Nethod to time out imm<br>e causes the method to<br>ositive value causes the<br>number of clock ticks be              |
|                     | E.                                                                                                                                                                                                                                                                      | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                     |
|                     |                                                                                                                                                                                                                                                                         | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                          |
| Wait on Rising Edge | Pauses the execution of t<br>til the next rising edge of<br><b>Timeout</b> input specifies<br>w long the Wait on Rising<br>the next rising edge. A va<br>hod to time out immedia<br>auses the method to wait<br>itive value causes the me<br>mber of clock ticks before | the I/O Method Node un<br>the digital signal. The<br>in FPGA clock ticks ho<br>g Edge method waits for<br>lue of 0 causes the met<br>tely, a negative value c<br>t indefinitely, and a pos<br>ethod to wait for that nu<br>e timing out. |
|                     | E.                                                                                                                                                                                                                                                                      | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                     |
|                     |                                                                                                                                                                                                                                                                         | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt                                                                                                                              |

il the module is identifi ed.

## Module Method

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for AI and AO channels of this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9381<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 93<br>81 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

This device supports the Number of Synchronizing Registers for Output Data synchronizing register option when used in SCTL output. This option supports the same functionality as the **Number of Synchronizing Registers for Output Data** option described in the <u>Advanced Code Generation FPGA I/O Properties Page</u> (FPGA Module) topic, with the exception that you can use this option only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the device is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the digital is performing digital I/O within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into AI node, AO Node, DO Node, and Set Output Data method calls. Additionally, failing to follow

these guidelines may result in lost data points for DO Node calls or Set Output Data method calls when either of them are made from inside a single-cycle Timed Loop.

- Use a single I/O Node to access AI and AO operations to ensure proper sequencing.
- Do not run the Set Output Enable method when an AI, AO, or DO subsystems is active.
- Do not perform the following operations concurrently:
  - AI Node call
  - AO Node call
  - Set Output Enable method call

Automatic line direction change when a DO call is made under the following conditions:

• The call is made from outside of a single-cycle Timed Loop.

Allow programmatic DIO line The direction

checkbox is checked in the <u>C Series</u> <u>Module Properties</u> dialog box.

• The DIO channel is configured as an input at the time when the DO node is called.

Refer to the NI 9381 Advanced IO VI in the labview\examples\CompactRIO\ Module Specific\NI 9381\NI 9381 Advanced IO\NI 9381 Advanc ed IO.lvproj for an example of the recommended way to use the AI, AO, and DIO subsystems.

C Series Module Properties Dialog Box for the NI 9381 (FPGA Interface)

Right-click an <u>NI 9381</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is unsigned, with a word length of 18 bits and an integer word length of 3 bits for the analog input channels and a word length of 16 bits and an integer word length of 3 bits for the analog output channels. Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is Calibrated.

• **Channels**—Specifies the channel(s) for which you want to select the direction.

• Selected Channel(s) Settings—Specifies the direction for each channel.

• Hot Swap Behavior (Analog Output)—Specifies the state of the analog output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

• Allow Programmatic DIO Line Direction Change—Place a checkmark in this checkbox if you want to enable programmable DIO line changes on the module.



**Caution** Performing a DIO line direction change will affect the timing of any concurrent AI, AO, and DO operations. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information. Converting Voltage Values to Binary Values for the NI 9381 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9381</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value - Offset) ÷ LSB Weight

where

**Binary Value** is the value you write to the FPGA I/O Node

**Current Value** is the voltage in V that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

**Offset** = -5249

LSB Weight =  $5.105 \text{ V} \div 2^{\text{DAC Resolution}}$ 

where

**DAC Resolution** is the DAC resolution value in the **NI 9381 Operating Instructions and Specifications**.

# NI 9381 (Scan Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the AI channels return floating-point data in volts. The I/O variables for the AO channels write floating-point data in volts. The I/O variables for the DIO channels read and write boolean values.

## **Module Channels**

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.            |
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.           |
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9381, <b>x</b> is 0 to 3 |

The NI 9381 has the following channels.

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9381. Right-click the NI 9381 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

• **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Direction**—Specifies the initial line direction of the selected channel(s) as input or output.

**Note** If you are using <u>direct access</u> to read from or write to AI or AO channels of the NI 9381, the conversion time is somewhat longer than 50 µs.

# Analog Output Modules

Use this book as a reference for the following information:

- FPGA I/O functions, I/O resources, arbitration options, methods, and properties each C Series analog output module supports in FPGA Interface mode
- I/O variables and properties each C Series analog output module supports in Scan Interface mode
- Instructions for using LabVIEW with CompactRIO analog output devices

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

#### NI 9260

\*

CompactRIO 2-Channel, 3 Vrms, 24-Bit Single-Ended Analog Output Module

Software Reference (?)

FPGA Interface

### NI 9260 Pinout



# **Related Topics**

FPGA Interface
 <u>9260 Properties Dialog Box</u>
 <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u>
 <u>Configuring the Data Rate for a Module (FPGA Interface)</u>
 <u>Outputting Data from the NI 9260</u>
 <u>Converting Voltage Values to Binary Values for the NI 9260</u>
 <u>Synchronizing Multiple NI 9225/9227/9229/923x/924x/9251/9260 Modules</u>

# NI 9260 (FPGA Interface)

CompactRIO 2-Channel, 3 Vrms, 24-Bit Single-Ended Analog Output Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9260 has channels 0 to 1.<br>Do not access AO channels on multiple modules<br>in the same FPGA I/O Node if the modules are n<br>ot synchronized or do not use the same data rat<br>e.                                                                                                                                                                               |
| Start    | Channel that controls when the NI 9260 starts o<br>utputting data. If TRUE is written to the <b>Start</b> ch<br>annel, the NI 9260 starts outputting data. The A<br>Ox will be reset to 0 volts every time this I/O nod<br>e is executed. When the NI 9260 is outputting da<br>ta, you must write TRUE to the <b>Stop</b> channel be<br>fore you can access properties. If FALSE is writte<br>n to the <b>Start</b> channel, no operation is perform<br>ed. |
| Stop     | Channel that controls when the NI 9260 stops o<br>utputting data. If TRUE is written to the <b>Stop</b> ch<br>annel, the NI 9260 stops outputting data. When t<br>he NI 9260 is outputting data, you must write TR<br>UE to the <b>Stop</b> channel before you can access p<br>roperties. If FALSE is written to the <b>Stop</b> channe<br>l, no operation is performed.                                                                                    |

# Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device contains no I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following I/O properties for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                            |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Status | Returns Booleans for each channel that indicate<br>s whether there was underflow or overvoltage o<br>n the channel since the last execution of the Che<br>ck Cached Status method. When the FPGA I/O N<br>ode reads the channels, the FPGA VI determines<br>the state of the channels and caches any TRUE v<br>alue until the Check Cached Status method exec<br>utes. |
|                     | • Underflow—Returns an array of Boole<br>an values. A value of TRUE in any index in<br>dicates that the channel sharing a numbe<br>r with that index has missed one or more<br>output samples at some point after the la<br>st time that the Check Cached Status met<br>hod executed.                                                                                  |
|                     | • Overvoltage—Returns an array of Boo<br>lean values. A value of TRUE in any index i<br>ndicates that the channel sharing a numb<br>er with that index detected an overvoltag<br>e on the channel at some point after the l<br>ast time that the Check Cached Status me<br>thod executed.                                                                              |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property | Description |
|----------|-------------|
|----------|-------------|

| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>l. Use this value to <u>convert NI 9260 data</u> if you se<br>t the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series</u><br><u>Module Properties</u> dialog box. |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert NI 9264 data if you<br>set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Seri</b><br><b>es Module Properties</b> dialog box.    |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                                  |
|---------------|--------------------------------------------------------------|
| Data Rate     | Sets the rate at which the NI 9260 outputs data.             |
| Module ID     | Returns the module ID, 0x7786 for BNC, 0x778C f or mini-XLR. |
| Serial Number | Returns the unique serial number of the module .             |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                            |

# **Excitation Protection**

The NI 9260 excitation circuit is protected from overvoltage fault conditions. The circuit is automatically disabled in the event of a fault condition. Whenever possible, a channel automatically recovers after the fault is removed. You must wire error terminals on the FPGA I/O Property Nodes to receive notification of overvoltage faults. LabVIEW returns <u>warning 65548</u> if there is an overvoltage fault on at least one channel. Only the channel(s) with the fault are affected and all other channels on the module continue to function properly without interruption.

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9260 (FPGA Interface)

Right-click an <u>NI 9260</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. The fixed-point data is signed, with a word length of 24 bits and an integer word length of 4 bits. Select **Raw** if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select **Raw**, you must <u>convert</u> the analog output values in the host VI before you write them to the module. The default is **Calibrated**.

• Master Timebase Source—Specifies the master timebase source that the module uses.

• **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Data Rate**—Specifies the rate at which the module acquires data.

Converting Voltage Values to Binary Values for the NI 9260 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9260</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the Calibration Mode to Raw, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.



**Note** The equations below apply only to the NI 9260.

Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary:

#### Binary Value = (Voltage Value - (Offset $\times$ 10<sup>-9</sup>)) $\times$ (LSB Weight $\times$ 10<sup>-12</sup>)

where

**Binary Value** is the value you write to the FPGA I/O Node

**Voltage Value** is the voltage in V that you want the channel to output <sup>†</sup>

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property.

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

#### **Offset** = 0

LSB Weight = Typical Output Span  $\div 2^{\text{DAC Resolution}} \times 10^{12}$ 

where **Typical Output Span** is 8.71 V for the NI 9260 **DAC Resolution** is the DAC resolution value in the <u>hardware documentation for the module</u>.

Outputting Data from an NI 9260 (FPGA Interface)

The <u>NI 9260</u> has two analog output channels that simultaneously output at the <u>data</u> <u>rate</u> for which you have configured the module. Use the **Start** and **Stop** channels of

the NI 9260 to put the module in and out of data mode. In data mode, the NI 9260 can only output data. You can use the <u>FPGA I/O Node</u> to write the data to the module. You cannot access properties while the module is in data mode.

**Note** You must <u>create FPGA I/O items</u> for the NI 9260 before you can configure the items using the FPGA I/O Node.

#### Putting the Module in Data Mode

Configure an FPGA I/O Node with the **Start** channel of the NI 9260. Wire a Boolean constant set to TRUE to the **Start** input of the FPGA I/O Node to send a synchronization pulse to the module. The AO**x** will be reset to 0 volts every time the device is put back into data mode.

#### Writing Data to the Module

When the module is in data mode, you can use an FPGA I/O Node to write data to the module. You can connect the AO input of the FPGA I/O Node to various types of functions, including an FPGA Memory function or an FPGA FIFO function. If you write to multiple channels on the module, place the channels in the same FPGA I/O Node to ensure that the VI writes the data synchronously.

Because the NI 9260 internally outputs data at a specified rate, the FPGA I/O Node does not finish until new data has been written to the module. If the NI 9260 is not in data mode while an FPGA I/O Node is running, the FPGA I/O Node returns an I/O Not Started error.

#### Exiting Data Mode

Configure an FPGA I/O Node with the **Stop** channel of the NI 9260. Write a TRUE to the **Stop** input. The module is no longer in data mode and you can now access NI 9260 properties.

NI recommends you ramp down to 0 volts before exiting data mode to prevent overshooting and ringing of the outputs due to the **Start** behavior. See **Putting the Module in Data Mode** above for the **Start** behavior.

NI 9262

CompactRIO 1 MS/s/ch Simultaneous, ±10 V, 6-Channel C Series Voltage Output Module

#### Software Reference (?)

FPGA Interface

### NI 9262 Pinout



# **Related Topics**

😰 FPGA Interface

Converting Voltage Values to Binary Values for the NI 9262/9263/9264/9269

# NI 9262 (FPGA Interface)

CompactRIO 1 MS/s/ch Simultaneous, ±10 V, 6-Channel C Series Voltage Output Module

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>writing</u>, with this device.



**Note** You can <u>simultaneously write to</u> multiple channels on the NI 9262.

## User-Controlled I/O Sampling

You can use the following User-Controlled I/O Sampling functions to perform I/O with more specific control over the I/O hardware on the FPGA.

| Function                         | Туре            |
|----------------------------------|-----------------|
| Generate I/O Sample Pulse Method | Module function |
| Get I/O Write Status Method      | I/O function    |
| Write I/O Method                 | I/O function    |
| Reset I/O Method                 | Module function |



**Note** You must call the Reset I/O Method function first to prepare the NI 9262 to use the other User-Controlled I/O Sampling functions.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                              |
|----------|--------------------------------------------------------------------------------------------------------------------------|
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9262 has AO channels 0 t<br>o 5. |

# Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.
### Methods

This device does not support any methods.

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert</u> NI 9262 data if you se<br>t the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series</u><br><u>Module Properties</u> dialog box. |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert NI 9262 data if you<br>set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Seri</b><br><b>es Module Properties</b> dialog box.    |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9262/9263/9264/9269 (FPGA Interface)

Right-click an <u>NI 9262</u>, <u>NI 9263</u>, <u>NI 9264</u>, or <u>NI 9269</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select **Raw**, you must <u>convert</u> the analog output values in the host VI before you write them to the module. The default is **Calibrated**.

• Hot Swap Behavior—Specifies the state of the output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

Converting Voltage Values to Binary Values for the NI 9262/9263/9264/9269 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9262/NI 9263/NI 9264/NI 9269</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value $\times 10^9$ – Offset) $\div$ LSB Weight,

where

**Binary Value** is the value you write to the FPGA I/O Node

**Voltage Value** is the voltage in V that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property.

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

**Offset** = 0

#### LSB Weight = Typical Output Span $\div 2^{\text{DAC Resolution}} \times 10^9$

whereTypical Output Span is 21.4 V for the NI 9263,<br/>21 V for the NI 9264, and 20.98 V for the NI 9269DAC Resolution is the DAC resolution value in<br/>the hardware documentation for the module.

#### NI 9263

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Analog Output Module

#### Software Reference (?)

FPGA Interface | Scan Interface

#### NI 9263 Pinout



# **Related Topics**

FPGA Interface Converting Voltage Values to Binary Values for the NI 9263/9264/9269

## NI 9263 (FPGA Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Analog Output Module

## FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.

**Note** You can <u>simultaneously write to</u> multiple channels on the NI 9263.

E

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                              |
|----------|--------------------------------------------------------------------------------------------------------------------------|
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9263 has AO channels 0 t<br>o 3. |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

You should use these three methods in conjunction with each other. The Write Data method stores data values before writing the data to a channel, the Update method writes the stored data values to the output channel, and the Wait for Update method waits until the Update method updates the output channels.

Refer to the NI 9264 Advanced Write Methods VI in the labview\examples\Com pactRIO\Module Specific\NI 9264\NI 9264 Advanced Write Met hods\NI 9264 Advanced Write Methods.lvproj for an example of using these methods.

| Method | Description                                                                                                                                        |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Update | Writes stored data values to the output channel.                                                                                                   |
|        | <ul> <li>Overrun—Returns a Boolean value. A v<br/>alue of TRUE indicates an overrun warnin<br/>g. The overrun warning means that the Up</li> </ul> |

|                 | date method is trying to run while the Wri<br>te Data method is running, typically in a dif<br>ferent loop. Either the Write Data method<br>is writing data to the module too quickly o<br>r the Update method is running too slowly<br>• Underflow—Returns a Boolean value.<br>A value of TRUE indicates an underflow w<br>arning. The underflow warning means tha<br>t the Write Data method has not written n<br>ew data to the module since the last time<br>the Update method ran. Either the Write D<br>ata method is writing data to the module t<br>oo slowly or the Update method is runnin<br>g too quickly.                                                                                                                                                                                                                                                                                                                      |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait for Update | <ul> <li>Waits until the Update method updates the out put channels.</li> <li>Timeout (Ticks)—Specifies in FPGA cl ock ticks how long the Wait for Update me thod waits for the Update method to upda te the output channels. A value of 0 cause s the Wait for Update method to time out i mmediately, a negative value causes the Wait for Update method to wait indefinitel y, and a positive value causes the Wait for Update method to wait for Update method to update method to wait a positive value causes the Wait for Update method to wait for that number of clock ticks before timing out.</li> <li>Timeout Occurred?—Returns a Boole an value. A value of TRUE indicates that a timeout occurred.</li> </ul> |
| Write Data      | <ul> <li>Stores data values before writing the data to a c hannel.</li> <li>Channel—Specifies the channel to whi ch you want to write data.</li> <li>Data—Specifies the data you want to w rite to the channel.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>l. Use this value to <u>convert</u> NI 9263 data if you se<br>t the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series</u><br><u>Module Properties</u> dialog box. |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert NI 9263 data if you<br>set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Seri</b><br><b>es Module Properties</b> dialog box.    |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

### Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

Converting Voltage Values to Binary Values for the NI 9262/9263/9264/9269 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9262/NI 9263/NI 9264/NI 9269</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value $\times 10^9$ – Offset) ÷ LSB Weight,

where

**Binary Value** is the value you write to the FPGA I/O Node

**Voltage Value** is the voltage in V that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property.

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

**Offset** = 0

### LSB Weight = Typical Output Span $\div 2^{\text{DAC Resolution}} \times 10^9$

where

**Typical Output Span** is 21.4 V for the NI 9263, 21 V for the NI 9264, and 20.98 V for the NI 9269 **DAC Resolution** is the DAC resolution value in the <u>hardware documentation for the module</u>.

C Series Module Properties Dialog Box for the NI 9262/9263/9264/9269 (FPGA Interface)

Right-click an <u>NI 9262</u>, <u>NI 9263</u>, <u>NI 9264</u>, or <u>NI 9269</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box. Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• **Calibration Mode**—Sets the calibration mode for the C Series module. Select **Calibrated** if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select **Raw**, you must <u>convert</u> the analog output values in the host VI before you write them to the module. The default is **Calibrated**.

• Hot Swap Behavior—Specifies the state of the output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

### NI 9263 (Scan Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Analog Output Module

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write floatingpoint values to the channels in volts.

### **Module Channels**

The NI 9263 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9263, <b>x</b> is 0 to 3. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9263. Right-click the NI 9263 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

NI 9264

CompactRIO 16-Channel, ±10 V, 16-Bit Simultaneous Analog Voltage Output Module

#### Software Reference (?)

😰 FPGA Interface | 🕝 Scan Interface

| AO0       C       1       19       COM       AO0       AO1       192         AO1       C       2       20       COM       AO1       02       03       210         AO2       O       3       21       COM       AO2       03       212         AO3       O       4       22       COM       AO3       04       22       230         AO3       O       4       22       COM       AO3       04       22       230         AO4       O       5       23       COM       AO4       05       230         AO5       O       6       24       COM       AO5       06       24       250         AO6       O       7       25       COM       AO5       06       27       250         AO8       9       27       COM       AO7       08       282       AO9       010       282       AO8       09       27       AO8       09       27       280       AO10       011       22       280       AO10       011       22       280       AO11       012       23       31       AO12       A013       014       22< | COM         COM         COM         20         1         AO0           COM         COM         COM         21         3         AO2           COM         COM         COM         22         4         AO3           COM         COM         COM         22         4         AO3           COM         COM         COM         22         7         AO4           COM         COM         COM         22         7         AO4           COM         COM         COM         22         7         AO4           COM         COM         COM         22         7         AO6           COM         COM         28         10         NC         NC           COM         COM         331         13         AO10         AO11           COM         COM |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## NI 9264 Pinout

# **Related Topics**

FPGA Interface Converting Voltage Values to Binary Values for the NI 9263/9264/9269

# NI 9264 (FPGA Interface)

CompactRIO 16-Channel, ±10 V, 16-Bit Simultaneous Analog Voltage Output Module

## FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.



**Note** You can <u>simultaneously write to</u> multiple channels on the NI 9264.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

You should use these three methods in conjunction with each other. The Write Data method stores data values before writing the data to a channel, the Update method writes the stored data values to the output channel, and the Wait for Update method waits until the Update method updates the output channels.

Refer to the NI 9264 Advanced Write Methods VI in the labview\examples\Com pactRIO\Module Specific\NI 9264\NI 9264 Advanced Write Met hods\NI 9264 Advanced Write Methods.lvproj for an example of using these methods.

| Method | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Update | <ul> <li>Writes stored data values to the output channel.</li> <li>Overrun—Returns a Boolean value. A v alue of TRUE indicates an overrun warnin g. The overrun warning means that the Up date method is trying to run while the Wri te Data method is running, typically in a dif ferent loop. Either the Write Data method is writing data to the module too quickly o</li> </ul> |
|        |                                                                                                                                                                                                                                                                                                                                                                                     |

|                 | r the Update method is running too slowly                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | • Underflow—Returns a Boolean value.<br>A value of TRUE indicates an underflow w<br>arning. The underflow warning means tha<br>t the Write Data method has not written n<br>ew data to the module since the last time<br>the Update method ran. Either the Write D<br>ata method is writing data to the module t<br>oo slowly or the Update method is runnin<br>g too quickly.                                                                                               |
| Wait for Update | Waits until the Update method updates the out put channels.                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                 | <ul> <li>Timeout (Ticks)—Specifies in FPGA cl<br/>ock ticks how long the Wait for Update me<br/>thod waits for the Update method to upda<br/>te the output channels. A value of 0 cause<br/>s the Wait for Update method to time out i<br/>mmediately, a negative value causes the<br/>Wait for Update method to wait indefinitel<br/>y, and a positive value causes the Wait for<br/>Update method to wait for that number of<br/>clock ticks before timing out.</li> </ul> |
|                 | <ul> <li>Timeout Occurred?—Returns a Boole<br/>an value. A value of TRUE indicates that a<br/>timeout occurred.</li> </ul>                                                                                                                                                                                                                                                                                                                                                   |
| Write Data      | Stores data values before writing the data to a c hannel.                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 | <ul> <li>Channel—Specifies the channel to whi<br/>ch you want to write data.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | <ul> <li>Data—Specifies the data you want to w rite to the channel.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                               |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>l. Use this value to <u>convert</u> NI 9264 data if you se<br>t the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series</u><br><u>Module Properties</u> dialog box. |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert NI 9264 data if you<br>set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Seri</b><br><b>es Module Properties</b> dialog box.    |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9262/9263/9264/9269 (FPGA Interface)

Right-click an <u>NI 9262</u>, <u>NI 9263</u>, <u>NI 9264</u>, or <u>NI 9269</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Calibration Mode—Sets the calibration mode for the C Series module. Select Calibrated if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select **Raw**, you must <u>convert</u> the analog output values in the host VI before you write them to the module. The default is **Calibrated**.

• Hot Swap Behavior—Specifies the state of the output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

Converting Voltage Values to Binary Values for the NI 9262/9263/9264/9269 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9262/NI 9263/NI 9264/NI 9269</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value $\times 10^9$ – Offset) $\div$ LSB Weight,

where

**Binary Value** is the value you write to the FPGA I/O Node

**Voltage Value** is the voltage in V that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property.

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

**Offset** = 0

### LSB Weight = Typical Output Span $\div 2^{\text{DAC Resolution}} \times 10^9$

where

**Typical Output Span** is 21.4 V for the NI 9263, 21 V for the NI 9264, and 20.98 V for the NI 9269 **DAC Resolution** is the DAC resolution value in the hardware documentation for the module.

### NI 9264 (Scan Interface)

CompactRIO 16-Channel, ±10 V, 16-Bit Simultaneous Analog Voltage Output Module

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write floatingpoint values to the channels in volts.

### **Module Channels**

The NI 9264 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9264, <b>x</b> is 0 to 15. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9264. Right-click the NI 9264 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9265

CompactRIO 4-Channel, 0–20 mA, 16-Bit Simultaneous Analog Current Output Module

#### Software Reference (?)

FPGA Interface | 3 Scan Interface

#### NI 9265 Pinout



# **Related Topics**

FPGA Interface Converting Current Values to Binary Values for the NI 9265/9266

# NI 9265 (FPGA Interface)

CompactRIO 4-Channel, 0–20 mA, 16-Bit Simultaneous Analog Current Output Module

闷 Open example

Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>writing</u>, with this device.

E

**Note** You can <u>simultaneously write to</u> multiple channels on the NI 9265.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                              |
|----------|--------------------------------------------------------------------------------------------------------------------------|
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9265 has AO channels 0 t<br>o 3. |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

Refer to the NI 9265 Getting Started VI in the labview\examples\CompactRIO \Module Specific\NI 9265\NI 9265 Getting Started\NI 9265 G etting Started.lvproj for an example of using the Check Output Status methods.

You should use the Update, Wait for Update, and Write Data methods in conjunction with each other. The Write Data method stores data values before writing the data to a channel, the Update method writes the stored data values to the output channel, and the Wait for Update method waits until the Update method updates the output channels.

Refer to the NI 9264 Advanced Write Methods VI in the labview\examples\Com pactRIO\Module Specific\NI 9264\NI 9264 Advanced Write Met hods\NI 9264 Advanced Write Methods.lvproj for an example of using the Update, Wait for Update, and Write Data methods.

| Method                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Output Status | Returns Booleans that indicate whether the mo<br>dule or channels reported a power supply fault<br>or an open current loop since the last execution<br>of the Check Cached Output Status method. Wh<br>en the FPGA I/O Node communicates with the m<br>odule, the FPGA VI samples the states of the mo<br>dule and channels and caches any TRUE value u<br>ntil the Check Cached Output Status method ex<br>ecutes.          |
|                            | • Force Status Read—When the value o<br>f this input is FALSE, the method returns t<br>he cached status information since the las<br>t time that the Check Cached Output Stat<br>us method executed. When the value is TR<br>UE, the method forces the FPGA I/O Node<br>to communicate with the module and upd<br>ate the status information. Forcing a statu<br>s read can introduce jitter into an analog o<br>utput loop. |
|                            | <ul> <li>Any Fault—Returns a Boolean value. A<br/>value of TRUE indicates that the module h<br/>as a power supply fault or at least one cha<br/>nnel has an open current loop.</li> </ul>                                                                                                                                                                                                                                    |
|                            | <ul> <li>Power Supply Fault—Returns a Bool<br/>ean value. A value of TRUE indicates that t<br/>he external power supply is out of the exp<br/>ected range.</li> </ul>                                                                                                                                                                                                                                                        |
|                            | • Open Current Loop—Returns an arra<br>y of Boolean values. A value of TRUE in an<br>y index indicates that the channel sharing<br>a number with that index has an open cur<br>rent loop and is configured to output a no<br>nzero current value.                                                                                                                                                                            |
| Check Output Status        | Returns Booleans that indicate whether the mo<br>dule or channels reported a power supply fault<br>or an open current loop during the last time the<br>FPGA I/O Node communicated with the module.<br>When the FPGA I/O Node communicates with th                                                                                                                                                                            |

e module, the FPGA VI samples the states of the module and channels and overwrites the previo us output status with the latest state of the mod ule and channels.

| <ul> <li>Force Status Read—When the value o f this input is FALSE, the method returns t he status information from the last time t he FPGA I/O Node communicated with the module. When the value is TRUE, the met hod forces the FPGA I/O Node to communi cate with the module and update the stat us information. Forcing a status read can i ntroduce jitter into an analog output loop.</li> </ul>                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Any Fault—Returns a Boolean value. A<br/>value of TRUE indicates that the module h<br/>as a power supply fault or at least one cha<br/>nnel has an open current loop.</li> </ul>                                                                                                                                                                                                                                                                                                                         |
| <ul> <li>Power Supply Fault—Returns a Bool<br/>ean value. A value of TRUE indicates that t<br/>he external power supply is out of the exp<br/>ected range.</li> </ul>                                                                                                                                                                                                                                                                                                                                             |
| • Open Current Loop—Returns an arra<br>y of Boolean values. A value of TRUE in an<br>y index indicates that the channel sharing<br>a number with that index has an open cur<br>rent loop and is configured to output a no<br>nzero current value.                                                                                                                                                                                                                                                                 |
| Writes stored data values to the output channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| • <b>Overrun</b> —Returns a Boolean value. A v<br>alue of TRUE indicates an overrun warnin<br>g. The overrun warning means that the Up<br>date method is trying to run while the Che<br>ck Cached Output Status, Check Output St<br>atus, or Write Data method is running, typ<br>ically in a different loop. The Update meth<br>od cannot run while the Check Cached Ou<br>tput Status, Check Output Status, or Write<br>Data method is running. If the Update met<br>hod is running at the same time as the Wri |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|                 | <ul> <li>te Data method, then either the Write Dat<br/>a method is writing data to the module to<br/>o quickly or the Update method is runnin<br/>g too slowly.</li> <li>Underflow—Returns a Boolean value.<br/>A value of TRUE indicates an underflow w<br/>arning. The underflow warning means tha<br/>t the Write Data method has not written n<br/>ew data to the module since the last time<br/>the Update method ran. Either the Write D<br/>ata method is writing data to the module t<br/>oo slowly or the Update method is runnin<br/>g too quickly.</li> </ul>                                                                                                                                                                                                                                                                                                                  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait for Update | <ul> <li>Waits until the Update method updates the out put channels.</li> <li>Timeout (Ticks)—Specifies in FPGA cl ock ticks how long the Wait for Update me thod waits for the Update method to upda te the output channels. A value of 0 cause s the Wait for Update method to time out i mmediately, a negative value causes the Wait for Update method to wait indefinitel y, and a positive value causes the Wait for Update method to wait for that number of clock ticks before timing out.</li> <li>Timeout Occurred?—Returns a Boole an value. A value of TRUE indicates that a timeout occurred.</li> </ul> |
| Write Data      | <ul> <li>Stores data values before writing the data to a c hannel.</li> <li>Channel—Specifies the channel to whi ch you want to write data.</li> <li>Data—Specifies the data you want to w rite to the channel.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in pA/LSB for the chann<br>el. Use this value to <u>convert</u> NI 9265 data if you s<br>et the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Serie</u><br><u>s Module Properties</u> dialog box. |
| Offset     | Returns the calibration offset in pA for the chan<br>nel. Use this value to convert NI 9265 data if you<br>set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Seri</b><br><b>es Module Properties</b> dialog box.     |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9265 (FPGA Interface)

Right-click an <u>NI 9265</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of amps when writing to the module. The fixed-point data is unsigned, with a word length of 20 bits and an integer word length of –5 bits. Select Raw if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select Raw, you must <u>convert</u> the analog output values in the host VI before you write them to the module. The default is Calibrated.

• Hot Swap Behavior—Specifies the state of the output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

Converting Current Values to Binary Values for the NI 9265 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9265</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of amps when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output current values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Current to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Current Value $\times 10^{12}$ – Offset) ÷ LSB Weight

where

**Binary Value** is the value you write to the FPGA I/O Node

**Current Value** is the current in mA that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property.

NI recommends using calibrated values for analog output. To convert calibrated current values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated current values by using the following values for **Offset** and **LSB Weight**:

**Offset** = 0

LSB Weight =  $20.6 \text{ mA} \div 2^{\text{DAC Resolution}} \times 10^{12}$ 

where

**DAC Resolution** is the DAC resolution value listed in the NI 9265 hardware documentation on ni.com/manuals.

## NI 9265 (Scan Interface)

CompactRIO 4-Channel, 0–20 mA, 16-Bit Simultaneous Analog Current Output Module

闷 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write floatingpoint values to the channels in amps.

## Module Channels

The NI 9265 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9265, <b>x</b> is 0 to 3. |

#### **Module-Specific Errors**

The NI 9265 can return the following module-specific errors.

| Error Code | Description                                                                                            |
|------------|--------------------------------------------------------------------------------------------------------|
| 65542      | One or more channels have detected an open c<br>urrent loop. Check the module connections.             |
| 65543      | The power supply voltage level is out of range. C heck the supply voltage and the module connec tions. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9265. Right-click the NI 9265 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9266

CompactRIO 8 AO, 0-20 mA, 16-Bit Simultaneous Analog Current Output Module

#### Software Reference (?)

#### FPGA Interface

#### NI 9266 Pinout



# **Related Topics**

FPGA Interface Converting Current Values to Binary Values for the NI 9266

## NI 9266 (FPGA Interface)

CompactRIO 8 AO, 0-20 mA, 16-Bit Simultaneous Analog Current Output Module

AO0

AO1 AO2

AO3 AO4

AO5

AO6

AO7 NC

NC

NC

NC

NC

NC

NC

NC

NC

NC COM

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>writing</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| AOx | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9266 has AO channels 0 t |
|-----|------------------------------------------------------------------------------------------------------------------|
|     | o 7.                                                                                                             |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

Refer to the NI 9266 Getting Started VI in the labview\examples\CompactRIO \Module Specific\NI 9266\NI 9266 Getting Started\NI 9266 G etting Started.lvproj for an example of using the Check Output Status methods.

You should use the Update, Wait for Update, and Write Data methods in conjunction with each other. The Write Data method stores data values before writing the data to a channel, the Update method writes the stored data values to the output channel, and the Wait for Update method waits until the Update method updates the output channels.

Refer to the NI 9264 Advanced Write Methods VI in the labview\examples\Com pactRIO\Module Specific\NI 9264\NI 9264 Advanced Write Met hods\NI 9264 Advanced Write Methods.lvproj for an example of using the Update, Wait for Update, and Write Data methods.

| Method                     | Description                                                                                                                                                                                         |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Output Status | Returns Booleans that indicate whether the mo<br>dule or channels reported a power supply fault<br>or an open current loop since the last execution<br>of the Check Cached Output Status method. Wh |

en the FPGA I/O Node communicates with the m odule, the FPGA VI samples the states of the mo dule and channels and caches any TRUE value u ntil the Check Cached Output Status method ex ecutes.

|                     | <ul> <li>Force Status Read—When the value o f this input is FALSE, the method returns t he cached status information since the las t time that the Check Cached Output Stat us method executed. When the value is TR UE, the method forces the FPGA I/O Node to communicate with the module and upd ate the status information. Forcing a statu s read can introduce jitter into an analog o utput loop.</li> </ul>             |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | <ul> <li>Any Fault—Returns a Boolean value. A<br/>value of TRUE indicates that the module h<br/>as a power supply fault or at least one cha<br/>nnel has an open current loop.</li> </ul>                                                                                                                                                                                                                                       |
|                     | <ul> <li>Power Supply Fault—Returns a Bool<br/>ean value. A value of TRUE indicates that t<br/>he external power supply is out of the exp<br/>ected range.</li> </ul>                                                                                                                                                                                                                                                           |
|                     | • Open Current Loop—Returns an arra<br>y of Boolean values. A value of TRUE in an<br>y index indicates that the channel sharing<br>a number with that index has an open cur<br>rent loop and is configured to output a no<br>nzero current value.                                                                                                                                                                               |
| Check Output Status | Returns Booleans that indicate whether the mo<br>dule or channels reported a power supply fault<br>or an open current loop during the last time the<br>FPGA I/O Node communicated with the module.<br>When the FPGA I/O Node communicates with th<br>e module, the FPGA VI samples the states of the<br>module and channels and overwrites the previo<br>us output status with the latest state of the mod<br>ule and channels. |

|        | <ul> <li>Force Status Read—When the value o<br/>f this input is FALSE, the method returns t<br/>he status information from the last time t<br/>he FPGA I/O Node communicated with the<br/>module. When the value is TRUE, the met<br/>hod forces the FPGA I/O Node to communi<br/>cate with the module and update the stat<br/>us information. Forcing a status read can i<br/>ntroduce jitter into an analog output loop.</li> <li>Any Fault—Returns a Boolean value. A<br/>value of TRUE indicates that the module h<br/>as a power supply fault or at least one cha<br/>nnel has an open current loop.</li> <li>Power Supply Fault—Returns a Bool<br/>ean value. A value of TRUE indicates that t<br/>he external power supply is out of the exp<br/>ected range.</li> <li>Open Current Loop—Returns an arra<br/>y of Boolean values. A value of TRUE in an<br/>y index indicates that the channel sharing<br/>a number with that index has an open cur<br/>rent loop and is configured to output a no<br/>nzero current value.</li> </ul> |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Update | <ul> <li>Overrun—Returns a Boolean value. A v alue of TRUE indicates an overrun warnin g. The overrun warning means that the Up date method is trying to run while the Che ck Cached Output Status, Check Output St atus, or Write Data method is running, typ ically in a different loop. The Update meth od cannot run while the Check Cached Output Status, or Write Data method is running. If the Update meth hod is running at the same time as the Wri te Data method, then either the Write Dat a method is writing data to the module to o quickly or the Update method is running to slowly.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                             |

|                 | • Underflow—Returns a Boolean value.<br>A value of TRUE indicates an underflow w<br>arning. The underflow warning means tha<br>t the Write Data method has not written n<br>ew data to the module since the last time<br>the Update method ran. Either the Write D<br>ata method is writing data to the module t<br>oo slowly or the Update method is runnin<br>g too quickly.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait for Update | <ul> <li>Waits until the Update method updates the out put channels.</li> <li>Timeout (Ticks)—Specifies in FPGA cl ock ticks how long the Wait for Update me thod waits for the Update method to upda te the output channels. A value of 0 cause s the Wait for Update method to time out i mmediately, a negative value causes the Wait for Update method to wait indefinitel y, and a positive value causes the Wait for Update method to wait for Update method to the to wait for Update method to</li></ul> |
| Write Data      | <ul> <li>Stores data values before writing the data to a c hannel.</li> <li>Channel—Specifies the channel to whi ch you want to write data.</li> <li>Data—Specifies the data you want to w rite to the channel.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

Property

Description

| LSB Weight | Returns the LSB weight in pA/LSB for the chann<br>el. Use this value to <u>convert</u> NI 9266 data if you s<br>et the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Serie</u><br><u>s Module Properties</u> dialog box. |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset     | Returns the calibration offset in pA for the chan<br>nel. Use this value to convert NI 9266 data if you<br>set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>C Seri</b><br><b>es Module Properties</b> dialog box.     |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9266 (FPGA Interface)

Right-click an <u>NI 9266</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of amps when writing to the module. The fixed-point data is unsigned, with a word length of 20 bits and an integer word length of –5 bits. Select **Raw** if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select **Raw**, you must <u>convert</u> the analog output values in the host VI before you write them to the module. The default is **Calibrated**.

• Hot Swap Behavior—Specifies the state of the output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

Converting Current Values to Binary Values for the NI 9266 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9266</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of amps when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output current values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Current to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Current Value $\times 10^{12}$ – Offset) ÷ LSB Weight

| where | <b>Binary Value</b> is the value you write to the FPGA I/O Node               |
|-------|-------------------------------------------------------------------------------|
|       | <b>Current Value</b> is the current in mA that you want the channel to output |
|       | <b>Offset</b> is the value returned by the Offset property                    |
|       | <b>LSB Weight</b> is the value returned by the LSB Weight property.           |
|       |                                                                               |

NI recommends using calibrated values for analog output. To convert calibrated current values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated current values by using the following values for **Offset** and **LSB Weight**:

**Offset** = 0

LSB Weight =  $20.89 \text{ mA} \div 2^{\text{DAC Resolution}} \times 10^{12}$ 

where

**DAC Resolution** is the DAC resolution value listed in the NI 9266 hardware documentation on ni.com/manuals.

## NI 9266 (Scan Interface)

CompactRIO 8 AO, 0-20 mA, 16-Bit Simultaneous Analog Current Output Module

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write floatingpoint values to the channels in amps.

## **Module Channels**

The NI 9266 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9266, <b>x</b> is 0 to 7. |

## Module-Specific Errors

The NI 9266 can return the following module-specific errors.

| ErrorCode | Description |
|-----------|-------------|
|-----------|-------------|

| 65542 | One or more channels have detected an open c<br>urrent loop. Check the module connections.             |
|-------|--------------------------------------------------------------------------------------------------------|
| 65543 | The power supply voltage level is out of range. C heck the supply voltage and the module connec tions. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9266. Right-click the NI 9266 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9269

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Isolated Analog Output Module

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

#### NI 9269 Pinout



# **Related Topics**

FPGA Interface Converting Voltage Values to Binary Values for the NI 9263/9264/9269

# NI 9269 (FPGA Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Isolated Analog Output Module

## FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.



**Note** You can <u>simultaneously write to</u> multiple channels on the NI 9269.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description
| AOx | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9269 has AO channels 0 t |
|-----|---------------------------------------------------------------------------------------------------------------|
|     | o 3.                                                                                                          |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

Refer to the NI 9269 Status Methods VI in the labview\examples\CompactRI O\Module Specific\NI 9269\NI 9269 Status Methods\NI 9269 S tatus Methods.lvproj for an example of using the Check Cached Output Status and Check Output Status methods.

You should use the Update, Wait for Update, and Write Data methods in conjunction with each other. The Write Data method stores data values before writing the data to a channel, the Update method writes the stored data values to the output channel, and the Wait for Update method waits until the Update method updates the output channels.

Refer to the NI 9264 Advanced Write Methods VI in the labview\examples\Com pactRIO\Module Specific\NI 9264\NI 9264 Advanced Write Met hods\NI 9264 Advanced Write Methods.lvproj for an example of using the Update, Wait for Update, and Write Data methods.

| Method                     | Description                                                                                                                                                                                            |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Cached Output Status | Returns Booleans for the module and each chan<br>nel that indicate whether the module or channe<br>ls reported an overcurrent condition since the la<br>st execution of the Check Cached Output Status |

method. When the FPGA I/O Node communicate s with the module, the FPGA VI samples the over current states of the module and channels and c aches any TRUE value until the Check Cached O utput Status method executes.

|                     | <ul> <li>Force Status Read—When the value o f this input is FALSE, the method returns t he cached status information since the las t time that the Check Cached Output Stat us method executed. When the value is TR UE, the method forces the FPGA I/O Node to communicate with the module and upd ate the status information. Forcing a statu s read can introduce jitter into an analog o utput loop.</li> </ul>                                                       |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | <ul> <li>Any Fault—Returns a Boolean value. A<br/>value of TRUE indicates that the module o<br/>r at least one channel is in an overcurrent<br/>condition.</li> </ul>                                                                                                                                                                                                                                                                                                     |
|                     | <ul> <li>Module Overcurrent—Returns a Bool<br/>ean value. A value of TRUE indicates that t<br/>he module is in an overcurrent condition.</li> </ul>                                                                                                                                                                                                                                                                                                                       |
|                     | <ul> <li>Channel Overcurrent—Returns an ar<br/>ray of Boolean values. A value of TRUE in a<br/>ny index indicates that the channel sharin<br/>g a number with that index is in an overcu<br/>rrent condition.</li> </ul>                                                                                                                                                                                                                                                  |
| Check Output Status | Returns Booleans for the module and each chan<br>nel that indicate whether the module or channe<br>Is reported an overcurrent condition during the<br>last time the FPGA I/O Node communicated wit<br>h the module. When the FPGA I/O Node commu<br>nicates with the module, the FPGA VI samples th<br>e overcurrent states of the module and channel<br>s and overwrites the previous output status wit<br>h the latest overcurrent state of the module and<br>channels. |
|                     | <ul> <li>Force Status Read—When the value o<br/>f this input is FALSE, the method returns t</li> </ul>                                                                                                                                                                                                                                                                                                                                                                    |

|        | <ul> <li>he status information from the last time t<br/>he FPGA I/O Node communicated with the<br/>module. When the value is TRUE, the met<br/>hod forces the FPGA I/O Node to communi<br/>cate with the module and update the stat<br/>us information. Forcing a status read can i<br/>ntroduce jitter into an analog output loop.</li> <li>Any Fault—Returns a Boolean value. A<br/>value of TRUE indicates that the module o<br/>r at least one channel is in an overcurrent<br/>condition.</li> <li>Module Overcurrent—Returns a Bool<br/>ean value. A value of TRUE indicates that t<br/>he module is in an overcurrent condition.</li> <li>Channel Overcurrent—Returns an ar<br/>ray of Boolean values. A value of TRUE in a<br/>ny index indicates that the channel sharin<br/>g a number with that index is in an overcur</li> </ul> |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Undata | rrent condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|        | <ul> <li>Overrun—Returns a Boolean value. A v alue of TRUE indicates an overrun warnin g. The overrun warning means that the Up date method is trying to run while the Che ck Cached Output Status, Check Output St atus, or Write Data method is running, typ ically in a different loop. The Update meth od cannot run while the Check Cached Ou tput Status, Check Output Status, or Write Data method is running. If the Update meth hod is running at the same time as the Wri te Data method, then either the Write Data a method is writing data to the module to o quickly or the Update method is runnin g too slowly.</li> <li>Underflow—Returns a Boolean value. A value of TRUE indicates an underflow w</li> </ul>                                                                                                              |
|        | arning. The underflow warning means tha<br>t the Write Data method has not written n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|                 | ew data to the module since the last time<br>the Update method ran. Either the Write D<br>ata method is writing data to the module t<br>oo slowly or the Update method is runnin<br>g too quickly.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait for Update | <ul> <li>Waits until the Update method updates the out put channels.</li> <li>Timeout (Ticks)—Specifies in FPGA cl ock ticks how long the Wait for Update me thod waits for the Update method to upda te the output channels. A value of 0 cause s the Wait for Update method to time out i mmediately, a negative value causes the Wait for Update method to wait indefinitel y, and a positive value causes the Wait for Update method to wait for Update method to the to wait for Update method to wait for that number of clock ticks before timing out.</li> <li>Timeout Occurred?—Returns a Boole an value. A value of TRUE indicates that a timeout occurred.</li> </ul> |
| Write Data      | <ul> <li>Stores data values before writing the data to a c hannel.</li> <li>Channel—Specifies the channel to whi ch you want to write data.</li> <li>Data—Specifies the data you want to w rite to the channel.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property   | Description                                                                                                                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>l. Use this value to <u>convert</u> NI 9269 data if you se<br>t the <b>Calibration Mode</b> to <b>Raw</b> in the <u>C Series</u><br><u>Module Properties</u> dialog box. |

| Offset | Returns the calibration offset in nV for the chan                                                |
|--------|--------------------------------------------------------------------------------------------------|
|        | nel. Use this value to convert NI 9269 data if you set the Calibration Mode to Raw in the C Seri |
|        | es Module Properties dialog box.                                                                 |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9262/9263/9264/9269 (FPGA Interface)

Right-click an <u>NI 9262</u>, <u>NI 9263</u>, <u>NI 9264</u>, or <u>NI 9269</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• **Calibration Mode**—Sets the calibration mode for the C Series module. Select **Calibrated** if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select **Raw**, you must <u>convert</u> the analog output values in the host VI before you write them to the module. The default is **Calibrated**.

• Hot Swap Behavior—Specifies the state of the output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

Converting Voltage Values to Binary Values for the NI 9262/9263/9264/9269 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9262/NI 9263/NI 9264/NI 9269</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value $\times 10^9$ – Offset) $\div$ LSB Weight,

| <b>Binary Value</b> is the value you write to the FPGA I/O Node              |
|------------------------------------------------------------------------------|
| <b>Voltage Value</b> is the voltage in V that you want the channel to output |
| <b>Offset</b> is the value returned by the Offset property                   |
| <b>LSB Weight</b> is the value returned by the LSB Weight property.          |
|                                                                              |

where

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

#### **Offset** = 0

LSB Weight = Typical Output Span  $\div 2^{\text{DAC Resolution}} \times 10^9$ 

where

**Typical Output Span** is 21.4 V for the NI 9263, 21 V for the NI 9264, and 20.98 V for the NI 9269 **DAC Resolution** is the DAC resolution value in the <u>hardware documentation for the module</u>.

### NI 9269 (Scan Interface)

CompactRIO 4-Channel, ±10 V, 16-Bit Simultaneous Isolated Analog Output Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write floatingpoint values to the channels in volts.

## Module Channels

The NI 9269 has the following channels.

| Channel | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9269, <b>x</b> is 0 to 3. |

## Module-Specific Errors

The NI 9269 can return the following module-specific errors.

Error Code Description

| 65548 | One or more channels are in overcurrent or over<br>voltage protection mode. Check the terminals fo<br>r any fault condition that could be causing an ou<br>t-of-range voltage or current on the channels. |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65579 | The module is in overcurrent protection mode.<br>Check the terminals for any fault condition that<br>could be causing an out-of-range current.                                                            |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9269. Right-click the NI 9269 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

NI 9381

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

Software Reference (?)

FPGA Interface | Scan Interface

### NI 9381 Pinout



# Running AI and AO Operations Concurrently on the NI 9381

AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information.

# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Avoiding Timing Uncertainty with the NI 9381 Converting Voltage Values to Binary Values for the NI 9381

## NI 9381 (FPGA Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

Find NI 9381 examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

| Terminal | Description                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AI channels 0 to<br>7.            |
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AO channels 0 t<br>o 3.          |
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9381 has DIO chan<br>nels 0 to 3. |
| DIO3:0   | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

 $\triangle$ 

**Caution** AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding</u> <u>Timing Uncertainty</u> topic for more information.

## Arbitration

Analog input and analog output channels of this device support only the <u>Arbitrate if</u> <u>Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for analog input and analog output channels of this device.

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for the DIO channels of this device.

| Method            | Description                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Me</u><br><u>le</u> ) topic for a descriptio                                                                                                                                                                                                        | ethod Node (FPGA Modu<br>n of this method.                                                                                                                                                                                                                       |
|                   | This method is available<br>DIO line direction to out<br>line direction in the <u>C Se</u><br>dialog box.                                                                                                                                                                    | e only when you set the<br>put. You can set the DIO<br>eries Module Properties                                                                                                                                                                                   |
| Set Output Enable | Sets the line direction of<br>he DIO3:0 digital port. R<br>hod Node (FPGA Module<br>tion on this method. Thi<br>jitter in an analog input<br>This method is available<br>programmable DIO line<br>You can enable program<br>on the module in the <u>C S</u><br>dialog box.   | f the digital channel or t<br>efer to the <u>FPGA I/O Met</u><br><u>e)</u> topic for more informa<br>is method can introduce<br>or analog output loop.<br>e only when you enable<br>changes on the module.<br>mable DIO line changes<br>Series Module Properties |
| Wait on Any Edge  | Pauses the execution of<br>til the next falling or risin<br>nal. The <b>Timeout</b> input<br>ticks how long the Wait<br>its for the next falling or<br>causes the method to the<br>egative value causes the<br>tely, and a positive value<br>wait for that number of<br>out. | the I/O Method Node un<br>ng edge of the digital sig<br>t specifies in FPGA clock<br>on Any Edge method wa<br>rising edge. A value of 0<br>me out immediately, a n<br>e method to wait indefini<br>e causes the method to<br>clock ticks before timing           |
|                   | <b>B</b>                                                                                                                                                                                                                                                                     | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                             |
|                   |                                                                                                                                                                                                                                                                              | For the first two secon<br>ds after resetting the F                                                                                                                                                                                                              |

|                      |                                                                                                                                                                                                                                                           | PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                                                                                                  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Falling Edge | Pauses the execution of<br>til the next falling edge<br><b>Timeout</b> input specifie<br>w long the Wait on Falli<br>r the next falling edge. A<br>ethod to time out imme<br>causes the method to w<br>sitive value causes the<br>umber of clock ticks be | f the I/O Method Node un<br>of the digital signal. The<br>es in FPGA clock ticks ho<br>ng Edge method waits fo<br>A value of 0 causes the m<br>ediately, a negative value<br>vait indefinitely, and a po<br>method to wait for that n<br>fore timing out. |
|                      | E.                                                                                                                                                                                                                                                        | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                      |
|                      |                                                                                                                                                                                                                                                           | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                                           |
| Wait on High Level   | Pauses the execution of<br>til the digital signal is his<br>specifies in FPGA clock<br>n High Level method wa<br>l. A value of 0 causes the<br>mediately, a negative va<br>o wait indefinitely, and<br>he method to wait for the<br>before timing out.    | f the I/O Method Node un<br>igh. The <b>Timeout</b> input<br>ticks how long the Wait o<br>aits for the next high leve<br>e method to time out im<br>alue causes the method t<br>a positive value causes t<br>hat number of clock ticks                    |
|                      | ek                                                                                                                                                                                                                                                        | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                      |
|                      |                                                                                                                                                                                                                                                           | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil                                                                                                                                                                           |

|                     |                                                                                                                                                                                                                                                               | l not start counting unt<br>il the module is identifi<br>ed.                                                                                                                                                                                         |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Low Level   | Pauses the execution of<br>til the digital signal is lo<br>pecifies in FPGA clock ti<br>n Low Level method wa<br>A value of 0 causes the r<br>ediately, a negative valu<br>wait indefinitely, and a<br>method to wait for that<br>fore timing out.            | the I/O Method Node un<br>w. The <b>Timeout</b> input s<br>cks how long the Wait o<br>its for the next low level.<br>method to time out imm<br>is causes the method to<br>positive value causes the<br>number of clock ticks be                      |
|                     | E.                                                                                                                                                                                                                                                            | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                 |
|                     |                                                                                                                                                                                                                                                               | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                                      |
| Wait on Rising Edge | Pauses the execution of<br>til the next rising edge of<br><b>Timeout</b> input specifie<br>w long the Wait on Risin<br>the next rising edge. A v<br>hod to time out immedi<br>auses the method to wa<br>itive value causes the m<br>mber of clock ticks befor | the I/O Method Node un<br>of the digital signal. The<br>s in FPGA clock ticks ho<br>og Edge method waits for<br>alue of 0 causes the met<br>ately, a negative value c<br>hit indefinitely, and a pos<br>ethod to wait for that nu<br>ore timing out. |
|                     | <b>e</b>                                                                                                                                                                                                                                                      | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                 |
|                     |                                                                                                                                                                                                                                                               | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt                                                                                                                                          |

il the module is identifi ed.

## Module Method

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. |

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for AI and AO channels of this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9381<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 93<br>81 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

This device supports the Number of Synchronizing Registers for Output Data synchronizing register option when used in SCTL output. This option supports the same functionality as the **Number of Synchronizing Registers for Output Data** option described in the <u>Advanced Code Generation FPGA I/O Properties Page</u> (FPGA Module) topic, with the exception that you can use this option only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the device is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the digital is performing digital I/O within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into AI node, AO Node, DO Node, and Set Output Data method calls. Additionally, failing to follow

these guidelines may result in lost data points for DO Node calls or Set Output Data method calls when either of them are made from inside a single-cycle Timed Loop.

- Use a single I/O Node to access AI and AO operations to ensure proper sequencing.
- Do not run the Set Output Enable method when an AI, AO, or DO subsystems is active.
- Do not perform the following operations concurrently:
  - AI Node call
  - AO Node call
  - Set Output Enable method call

Automatic line direction change when a DO call is made under the following conditions:

• The call is made from outside of a single-cycle Timed Loop.

Allow programmatic DIO line The direction

checkbox is checked in the <u>C Series</u> <u>Module Properties</u> dialog box.

• The DIO channel is configured as an input at the time when the DO node is called.

Refer to the NI 9381 Advanced IO VI in the labview\examples\CompactRIO\ Module Specific\NI 9381\NI 9381 Advanced IO\NI 9381 Advanc ed IO.lvproj for an example of the recommended way to use the AI, AO, and DIO subsystems.

C Series Module Properties Dialog Box for the NI 9381 (FPGA Interface)

Right-click an <u>NI 9381</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
 Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is unsigned, with a word length of 18 bits and an integer word length of 3 bits for the analog input channels and a word length of 16 bits and an integer word length of 3 bits for the analog output channels. Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is Calibrated.

• **Channels**—Specifies the channel(s) for which you want to select the direction.

• Selected Channel(s) Settings—Specifies the direction for each channel.

• Hot Swap Behavior (Analog Output)—Specifies the state of the analog output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

• Allow Programmatic DIO Line Direction Change—Place a checkmark in this checkbox if you want to enable programmable DIO line changes on the module.

 $\triangle$ 

**Caution** Performing a DIO line direction change will affect the timing of any concurrent AI, AO, and DO operations. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information. Converting Voltage Values to Binary Values for the NI 9381 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9381</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value - Offset) ÷ LSB Weight

where

**Binary Value** is the value you write to the FPGA I/O Node

**Current Value** is the voltage in V that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

**Offset** = -5249

LSB Weight =  $5.105 \text{ V} \div 2^{\text{DAC Resolution}}$ 

where

**DAC Resolution** is the DAC resolution value in the **NI 9381 Operating Instructions and Specifications**.

## NI 9381 (Scan Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the AI channels return floating-point data in volts. The I/O variables for the AO channels write floating-point data in volts. The I/O variables for the DIO channels read and write boolean values.

## **Module Channels**

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.            |
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.           |
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9381, <b>x</b> is 0 to 3 |

The NI 9381 has the following channels.

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9381. Right-click the NI 9381 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

• **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Direction**—Specifies the initial line direction of the selected channel(s) as input or output.

**Note** If you are using <u>direct access</u> to read from or write to AI or AO channels of the NI 9381, the conversion time is somewhat longer than 50 µs.

### Counter Input Modules

Use this book as a reference for the following information:

- FPGA I/O functions, I/O resources, arbitration options, methods, and properties each C Series counter input module supports in FPGA Interface mode
- Instructions for using LabVIEW with CompactRIO counter input devices

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

NI 9326

.

CompactRIO 6-Channel, Frequency Input Module

Software Reference (?)

FPGA Interface

## NI 9326 Pinout



# **Related Topics**

这 FPGA Interface

Synchronizing Multiple NI 9326 Modules

# NI 9326 (FPGA Interface)

CompactRIO 6-Channel, Frequency Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTRx     | Counter input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The counter I/O node returns a c<br>luster of three items, consisting of two unsigned<br>32-bit integers called A and B as well as the cou<br>nter status enum. The <b>Start</b> input I/O node mus<br>t be executed before counter or DI data can be r<br>ead. The NI 9326 has counters 0 through 5.                                                                                                                                                                                                                                                                                                                                                                                                |
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9326 has DI channels 0 thr<br>ough 5. Supported in <u>Digital Input Mode</u> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Start    | Channel that controls when the counters begin<br>monitoring their input terminals. If TRUE is writt<br>en to the <b>Start</b> channel, the NI 9326 counters ar<br>e reset, armed, and begin monitoring their input<br>terminals to perform the currently configured m<br>easurement (such as Edge Counting). Once the<br>NI 9326 counters are armed, you may execute th<br>e <b>CTRx</b> and <b>DIx</b> I/O nodes to read the counter d<br>ata. You may not execute any NI 9326 I/O Metho<br>d or Property nodes while the counters are arm<br>ed. To disarm the counters, use the <b>Stop</b> chann<br>el. If FALSE is written to the <b>Start</b> channel, no o<br>peration is performed. The <b>Start</b> channel is also<br>used to <u>synchronize multiple NI 9326 modules</u> . |
| Stop     | Channel that controls when the counters are dis<br>armed. If TRUE is written to the <b>Stop</b> channel, t<br>he counters are stopped. When the counters are<br>stopped, you may change the counter configura<br>tion by executing I/O Method and Property node<br>s. If FALSE is written to the <b>Stop</b> channel, no op<br>eration is performed.                                                                                                                                                                                                                                                                                                                                                                                                                                  |

The definition of **A** and **B** values vary according to the measurement mode you select. The following table defines the **A** and **B** values for each measurement mode option.

| Measurement Mode | A | В | Status |
|------------------|---|---|--------|
|------------------|---|---|--------|

| Edge Counting | Number of edges.                                                                                                    | Unused. Always returns<br>0.                                                            | Not applicable. |
|---------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------|
| Period        | Amount of time elapse<br>d during <b>B</b> signal perio<br>ds, measured in units o<br>f counter timebase tick<br>s. | Scaling factor for A valu<br>e. Divide A by B to calc<br>ulate the measured per<br>iod. | Applicable.     |

Period measurements are returned based on ticks of the module's 100 MHz timebase. Each tick corresponds to 10 ns. The actual measured period is calculated as:

```
Measured Period = (Number of Ticks * Timebase)/Scaling Factor = (A * 10 ns)/B
```

Example measurement of 1 kHz input signal:

**A** = 3,200,000 **B** = 32

Measured Period = (3,200,000 \* 10 ns)/32 = 1 ms

Counter statuses are applicable for selected measurement modes. The following table describes the different statuses.

| Status    | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No Sample | The first measurement data is not ready yet for t<br>his <b>CTRx</b> channel. This occurs as a result of the f<br>ollowing factors: the amount of time elapsed sin<br>ce the counter was armed via the <b>Start</b> channel,<br>the current counter settings, and the input sign<br>al behavior. In this case, the <b>A</b> and <b>B</b> values will<br>each return a default value of 0. |
| New       | A new, valid measurement for this <b>CTRx</b> channe l.                                                                                                                                                                                                                                                                                                                                   |
| Repeated  | The same measurement returned the last time a read was performed on this <b>CTRx</b> channel. This measurement is valid, and occurs when the <b>CT Rx</b> I/O Node reads are performed faster than the counter can produce new measurements.                                                                                                                                              |
| Timeout   | A timeout has occurred.                                                                                                                                                                                                                                                                                                                                                                   |

| New and Missed     | A new, valid measurement for this <b>CTRx</b> channe<br>l. The counter also produced one or more new<br>measurements that were never read. This occur<br>s when the counter produces measurements fas<br>ter than the <b>CTRx</b> I/O Node reads are performe<br>d. |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timeout and Missed | A timeout has occurred. In addition, the counter<br>produced one or more new measurements that<br>were never read.                                                                                                                                                  |

Timeout is applicable for period measurement mode only, and the definition of Timeout varies according to the setting of the Butterworth filter. The following table defines Timeout for each option.

| Measurement Mode                     | Timeout Definition                                                                                                                                      |
|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Period (Butterworth filter enabled)  | Timeout occurs when the actual input signal period is greater than the internal counter limit at $2^{32}$ x 10 ns and the counter returns a value of 0. |
| Period (Butterworth filter disabled) | Timeout occurs when the actual input signal pe<br>riod is greater than the maximum measurable p<br>eriod and the counter returns a value of 0.          |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device. You can also use the <u>properties dialog box</u> to configure the measurement modes for this device.

**Configure Edge Counting**—Configures the corresponding counter for any edge counting application. The Method Node returns an error if invoked while the counters are armed. The Initial Count and Reset Count are in units of number of edges.

Parameters

Description

| Terminal           | Source input terminal of the counter.                                                                                                                                                                                        |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Initial Count      | Initial counter value once the counter is armed.                                                                                                                                                                             |
| Direction          | Sets the count direction to either count up, cou<br>nt down or to be externally controlled.                                                                                                                                  |
| Direction Terminal | Configures the terminal that is used to control t<br>he count direction. This needs to be set when Di<br>rection is configured to "Externally Controlled". I<br>f not set, the parameter value defaults to DIO ter<br>minal. |
| Reset Enable       | Enables or disables Hardware Reset.                                                                                                                                                                                          |
| Reset Terminal     | Configures the terminal that is used to reset the<br>counter. This needs to be set when Hardware Re<br>set is enabled. If not set, the parameter value de<br>faults to DI0 terminal.                                         |
| Reset Count        | Sets the count value to load to the counter upon reset. If not set, the parameter value defaults to zero.                                                                                                                    |
| Pause Enable       | Enables or disables the pause trigger.                                                                                                                                                                                       |
| Pause Terminal     | Configures the terminal that is used to pause th<br>e counter. This needs to be set when pause trigg<br>er is enabled. If not set, the parameter value def<br>aults to DIO terminal.                                         |

**Configure Edge Counting Simple**—Configures the corresponding counter for simple edge counting. The simple configuration for edge counting sets Direction to Count Up and disables both Reset and Pause. The Method Node returns an error if invoked while the counters are armed. The Initial Count is in units of number of edges.

| Parameters    | Description                                      |
|---------------|--------------------------------------------------|
| Terminal      | Source input terminal of the counter.            |
| Initial Count | Initial counter value once the counter is armed. |

**Configure Period**—Configures the corresponding counter for period measurement. The Method Node returns an error if invoked while the counters are armed.

| Parameters | Description |
|------------|-------------|
|            | •           |

| Terminal                  | Source input terminal of the counter.                                                                                                                                                                                                                                                                                                                           |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable Butterworth Filter | Enables or disables Butterworth filter. If Butterw<br>orth Filter is enabled, set the Filter Frequency p<br>arameter accordingly to filter out the higher freq<br>uency noise. If disabled, configure the counter s<br>ettings based on Divisor, Measurement Time an<br>d Maximum Measurable Period before the start<br>of an acquisition.                      |
| Filter Frequency          | Configures the Butterworth filter's <u>cut-off frequ</u><br><u>ency</u> to filter out variations in the period measur<br>ements.                                                                                                                                                                                                                                |
| Measurement Time          | Configures the amount of time over which to m<br>easure and average to determine the input sign<br>al period. This value is specified in units of coun<br>ter timebase ticks. Set to 0 to disable the <b>Meas</b><br><b>urement Time</b> , in which case the measuremen<br>t will be completed using only the <b>Divisor</b> setti<br>ng.                       |
| Divisor                   | Configures the number of periods of the input si<br>gnal to measure and average to determine the i<br>nput signal period. Set to 0 to disable the <b>Divis</b><br><b>or</b> , in which case the measurement will be com<br>pleted using only the <b>Measurement Time</b> sett<br>ing.                                                                           |
| Maximum Measurable Period | Configures the maximum (slowest) period of the<br>input signal that can be measured. If the actual i<br>nput signal period is longer than this value, the<br>measurement will timeout and the counter retu<br>rns a value of 0. This value is specified in units of<br>counter timebase ticks. Set this value to 0 to dis<br>able enforcing the maximum period. |
| E.                        | <b>Note</b> Setting both <b>Measurement Time</b> and <b>Divisor</b> to 0 is invalid, and will cause the counter to always return a value of 0.                                                                                                                                                                                                                  |

**Configure Period Simple**—Configures the corresponding counter for simple period measurement. The simple configuration for period measurement enables

the Butterworth filter. The Method Node returns an error if invoked while the counters are armed.

| Parameters       | Description                                                                                                        |
|------------------|--------------------------------------------------------------------------------------------------------------------|
| Terminal         | Source input terminal of the counter.                                                                              |
| Filter Frequency | Configures the Butterworth filter's cut-off frequ<br>ency to filter out variations in the period measur<br>ements. |

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method       | Description                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. Supported in <u>Digital Input</u> <u>Mode</u> . |

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property                            | Description                                                                                                                                       |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Digital Filter Enable               | Enables the digital glitch filter for the correspon ding digital line.                                                                            |
| Digital Filter Minimum Pulse Width* | Configures the minimum pulse width for the dig<br>ital glitch filter of the corresponding digital line i<br>n increments of 80 ns, up to 5.24 ms. |
| Digital Logic Threshold             | Configures the digital logic threshold for the cha nnel.                                                                                          |
| Hysteresis Value                    | Configures the hysteresis value for the channel.                                                                                                  |
| Active Edge**                       | Configures the triggering edge of the input sign al.                                                                                              |

\* Unit in ticks, whereby 1 tick = 80 ns.

Example: Minimum Pulse Width = 1 ms. Therefore, input to the Digital Filter Minimum Pulse Width property node is 1 ms / 80 ns = 12500 ticks.

\*\* The definition of Active Edge varies according to the measurement mode. The following table defines Active Edge for each option.

| MeasurementMode                     | Active Edge Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Edge Counting                       | <ul> <li>Input Terminal: Configures the trigge<br/>ring edge of the input signal. Rising indica<br/>tes the counter would count on every risin<br/>g edge and vice versa.</li> </ul>                                                                                                                                                                                                                                                                        |  |
|                                     | <ul> <li>Direction Terminal: Configures the terminal that is used to control the count direction. When set to rising edge, the count er counts up when signal on the direction terminal is high. This applies only when the Direction parameter is set to "Externally Controlled". If the Direction Terminal is not t set and the Direction parameter is set to "Externally Controlled", the default setting is to count up when signal is high.</li> </ul> |  |
|                                     | • <b>Reset Terminal:</b> Configures the trigge<br>ring edge of the reset signal. This applies<br>only when the Reset Enable parameter is s<br>et to true. If the Reset Terminal is not set a<br>nd the Reset Enable parameter is set to tr<br>ue, the default setting is to reset on the ris<br>ing edge of the signal.                                                                                                                                     |  |
|                                     | • Pause Terminal: Configures the termi<br>nal that is used to pause the counter. Whe<br>n set to rising edge, the counter pauses w<br>hen the signal on the pause terminal is hig<br>h. This applies only when the Pause Enabl<br>e parameter is set to true. If the Pause Ter<br>minal is not set and the Pause Enable para<br>meter is set to true, the default setting is t<br>o pause when signal is high.                                              |  |
| Period (Butterworth filter enabled) | <b>Input Terminal:</b> Configures the triggering edg e of the input signal.                                                                                                                                                                                                                                                                                                                                                                                 |  |

Period (Butterworth filter disabled)

**Input Terminal:** Configures the triggering edg e of the input signal.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x7A5E.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u> when Digital Input Mode is set in the <u>properties dialog box</u>. The input channels of this device are synchronized with two synchronizing registers.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return null data if the module is not ready.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and 160 MHz.

C Series Module Properties Dialog Box for the NI 9326 (FPGA Interface)

Right-click an <u>NI 9326</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to launch the **C Series Module Properties** dialog box, that includes the following components, which you can use to configure a C Series module.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. Use this field to assign a descriptive name to the module.

• **Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies the slot in the chassis used by the C Series module.

• **Digital Input Mode**—Specifies the mode of module. If this property is checked, only digital input channel, DIx will be supported.

- Digital Input Channels—Specifies the list of input channels available in the module, which you can select to configure.
- Active Edge—Sets the triggering edge of the input signal.
- Threshold (V)—Sets the threshold value for the input channel.
- Hysteresis Value (V)—Sets the hysteresis value for the input channel.



**Note** Changing this option will change the <u>FPGA interface</u>.

• **Channel**—Specifies the list of counters available in the module, which you can select to configure.

• **Measurement**—Specifies the selected measurement mode of the corresponding counter.

• **Terminals**—Specifies the selected terminal settings of the corresponding counter.

• **Settings**—Specifies the selected configuration of the corresponding counter.

• Measurement Mode—Sets the measurement mode of the corresponding counter.

| Measurement Mode | Configuration Type | Description                             |
|------------------|--------------------|-----------------------------------------|
| Edge Counting    | Initial Count      | Sets the initial counter value.         |
|                  | Pause              | Enables or disables the Paus e feature. |

|        | HW Reset                          | Enables or disables the Hard ware Reset.                                                                                                                            |
|--------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | Reset Count                       | Sets the value the counter res<br>ets to when HW Reset is trigg<br>ered.                                                                                            |
|        | Direction                         | Sets the count direction to C<br>ount Up, Count Down, or Exte<br>rnally Controlled.                                                                                 |
| Period | Enable Butterworth Filter         | Enables or disables Butterwo<br>rth filter.                                                                                                                         |
|        | Filter Frequency*                 | Sets the Butterworth filter's c<br>ut-off frequency.                                                                                                                |
|        | Sample Rate (Hz)                  | Specifies the rate at which da<br>ta is being sampled from the<br>counter. This value is used to<br>calculate the Measurement Ti<br>me and Divisor of the counter   |
|        | Maximum Measurable Period<br>(ms) | Specifies the maximum (slow<br>est) period of the input signal<br>that can be measured.                                                                             |
|        | Maximum Freq (Hz)                 | Specifies the maximum input<br>frequency. This value is used<br>along with the Sample Rate t<br>o calculate the Measurement<br>Time and Divisor of the count<br>er. |

\* The following table specifies the available cut-off frequecies.

| Filter Frequency   | Cut-off Frequency |
|--------------------|-------------------|
| Filter Frequency—1 | 6167 Hz           |
| Filter Frequency—2 | 2941 Hz           |
| Filter Frequency—3 | 1439 Hz           |
| Filter Frequency—4 | 712 Hz            |
| Filter Frequency—5 | 354 Hz            |
| Filter Frequency—6 | 177 Hz            |
| Filter Frequency—7 | 88 Hz             |

| Filter Frequency—8  | 44 Hz |
|---------------------|-------|
| Filter Frequency—9  | 22 Hz |
| Filter Frequency—10 | 11 Hz |
| Filter Frequency—11 | 6 Hz  |
| Filter Frequency—12 | 3 Hz  |
| Filter Frequency—13 | 1 Hz  |

Advanced Configuration—Launches the <u>Advanced Configuration</u> dialog box.

Advanced Configuration Dialog Box (FPGA Interface)

Click the **Advanced Configuration** button on the <u>C Series Module Properties</u> dialog box for the <u>NI 9326</u> to launch the **Advanced Configuration** dialog box, which you can use to configure the counter input terminals and each digital input line.

- Counters—Configures the corresponding counter terminal.
  - Measurement Mode—Displays the measurement mode of the selected counter.
  - Reset Terminals to Default—Reset the terminal settings to the factory defaults.
  - Terminals of the selected counters:
    - For Edge Counting, there are up to 4 terminals per counter (Input, Reset, Direction, and Pause).
    - For Period, there is only one terminal per counter.
- **Digital Inputs**—Configures the corresponding digital inputs lines.
  - Digital Input Channels—Selects the Digital Inputs to configure.
  - Active Edge—Sets the triggering edge of the input signal.
  - Digital Filter—Enables or disables the digital input filter.
  - Minimum Pulse Width (ms)—Configures the minimum pulse width of the digital input filter. Pulses that are shorter than the minimum pulse width will be filtered out (Applies only when Digital Filter is enabled).

- Threshold (V)—Sets the threshold value for the digital input.
- Hysteresis Value (V)—Sets the hysteresis value for the digital input.

Synchronizing Multiple NI 9326 Modules (FPGA Interface)

Complete the following steps to synchronize multiple NI 9326 modules that are connected to the same FPGA device.

- 1. <u>Create the FPGA I/O items</u> with all the I/O channels to be synchronized, within a single <u>FPGA I/O Node</u>. Otherwise, the FPGA I/O Node will not return synchronized data.
- 2. Configure an FPGA I/O Node with **Start** channels for the NI 9326 modules you want to synchronize.
- 3. Wire a Boolean constant set to TRUE to each **Start** channel.

NI 9361

CompactRIO 8-Channel, Counter Input Module

Software Reference (?)

FPGA Interface

### NI 9361 Pinout

# **Related Topics**

😰 FPGA Interface

Synchronizing Multiple NI 9361 Modules

## NI 9361 (FPGA Interface)

CompactRIO 8-Channel, Counter Input Module

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                    |
|----------|----------------------------------------------------------------------------------------------------------------|
| CTRx     | Counter input channel <b>x</b> , where <b>x</b> is the number of the channel. The counter I/O node returns a c |

|       | luster of three items, consisting of two unsigned<br>32-bit integers called A and B as well as the cou<br>nter status enum. The <b>Start</b> input I/O node mus<br>t be executed before counter or DI data can be r<br>ead. The NI 9361 has counters 0 through 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIx   | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9361 has DI channels 0 thr<br>ough 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DI7:0 | Digital Port consisting of channels 0 through 7.<br>Channel 7 is returned in the Most Significant Bit<br>(MSB), and channel 0 is returned in the Least Sig<br>nificant Bit (LSB).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Start | Channel that controls when the counters begin<br>monitoring their input terminals. If TRUE is writt<br>en to the <b>Start</b> channel, the NI 9361 counters ar<br>e reset, armed, and begin monitoring their input<br>terminals to perform the currently configured m<br>easurement (such as Edge Counting). Once the<br>NI 9361 counters are armed, you may execute th<br>e <b>CTRx</b> and <b>DIx</b> I/O nodes to read the counter d<br>ata. You may not execute any NI 9361 I/O Metho<br>d or Property nodes while the counters are arm<br>ed. To disarm the counters, use the <b>Stop</b> chann<br>el. If FALSE is written to the <b>Start</b> channel, no o<br>peration is performed. The <b>Start</b> channel is also<br>used to <u>synchronize multiple NI 9361 modules</u> . |
| Stop  | Channel that controls when the counters are dis<br>armed. If TRUE is written to the <b>Stop</b> channel, t<br>he counters are stopped. When the counters are<br>stopped, you may change the counter configura<br>tion by executing I/O Method and Property node<br>s. If FALSE is written to the <b>Stop</b> channel, no op<br>eration is performed.                                                                                                                                                                                                                                                                                                                                                                                                                                  |

The definition of **A** and **B** values vary according to the measurement mode you select. The following table defines the **A** and **B** values for each measurement mode option.

| Measurement Mode | A | В | Status |
|------------------|---|---|--------|
|------------------|---|---|--------|

| Edge Counting       | Number of edges.                                                                                                    | Unused. Always returns<br>0.                                                                                                                                                                                                                                                                                                                                                                                            | Not applicable. |
|---------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Period              | Amount of time elapse<br>d during <b>B</b> signal perio<br>ds, measured in units o<br>f counter timebase tick<br>s. | Number of signal perio<br>ds measured.                                                                                                                                                                                                                                                                                                                                                                                  | Applicable.     |
| Pulse               | Width of High portion o<br>f input signal period, m<br>easured in units of cou<br>nter timebase ticks.              | Width of Low portion of<br>input signal period, me<br>asured in units of count<br>er timebase ticks.                                                                                                                                                                                                                                                                                                                    | Applicable.     |
| Pulse Width         | Width of input pulse, m<br>easured in units of cou<br>nter timebase ticks.                                          | Unused. Always returns<br>0.                                                                                                                                                                                                                                                                                                                                                                                            | Applicable.     |
| Two Edge Separation | Amount of time betwee<br>n two input edges, mea<br>sured in units of counte<br>r timebase ticks.                    | Unused. Always returns<br>0.                                                                                                                                                                                                                                                                                                                                                                                            | Applicable.     |
| Encoder Position    | Number of encoder cou<br>nts.                                                                                       | Unused. Always returns<br>0.                                                                                                                                                                                                                                                                                                                                                                                            | Not applicable. |
| Encoder Velocity    | Amount of time elapse<br>d during <b>B</b> encoder cou<br>nts, measured in units<br>of counter timebase tic<br>ks.  | Signed number of coun<br>ter encoder counts and<br>direction. Positive valu<br>es indicate counting in<br>the positive direction, a<br>nd negative values indi<br>cate counting in the op<br>posite direction. You m<br>ust use the <b>To Long In</b><br><b>teger</b> function to conv<br>ert the unsigned <b>B</b> valu<br>e (U32) to a signed valu<br>e (I32) when performin<br>g an Encoder Velocity<br>measurement. | Applicable.     |

All values that are based on ticks use the module's timebase of 100 MHz. Each tick corresponds to 10 ns. The actual value is calculated as:
Actual = Number of ticks \* 10 ns Examples:

- Period Measurement Mode—A is 100000. B is 1. Measured period = (A \* 10 ns)/B = 1 ms.
- 2. Encoder Velocity Measurement Mode—A is 100000. B is 1. Measured Encoder Velocity = B/(A \* 10 ns) = 1000 count/s.
- 3. Pulse Width and Two Edge Separation Measurement Mode—A is 100000. Measured Pulse Width or Two Edge Separation = A \* 10 ns = 1 ms.
- 4. Pulse Measurement Mode—A is 100000. B is 100000. Measured High Pulse = A \* 10 ns = 1 ms. Measured Low Pulse = B \* 10 ns = 1 ms.

Counter statuses are applicable for selected measurement modes. The following table describes the different statuses.

| Status         | Description                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No Sample      | The first measurement data is not ready yet for t<br>his <b>CTRx</b> channel. This occurs as a result of the f<br>ollowing factors: the amount of time elapsed sin<br>ce the counter was armed via the <b>Start</b> channel,<br>the current counter settings, and the input sign<br>al behavior. In this case, the <b>A</b> and <b>B</b> values will<br>each return a default value of 0. |
| New            | A new, valid measurement for this <b>CTRx</b> channe l.                                                                                                                                                                                                                                                                                                                                   |
| Repeated       | The same measurement returned the last time a read was performed on this <b>CTRx</b> channel. This measurement is valid, and occurs when the <b>CT Rx</b> I/O Node reads are performed faster than the counter can produce new measurements.                                                                                                                                              |
| Timeout        | A timeout has occurred.                                                                                                                                                                                                                                                                                                                                                                   |
| New and Missed | A new, valid measurement for this <b>CTRx</b> channe<br>I. The counter also produced one or more new<br>measurements that were never read. This occur<br>s when the counter produces measurements fas<br>ter than the <b>CTRx</b> I/O Node reads are performe<br>d.                                                                                                                       |

| Timeout and Missed | A timeout has occurred. In addition, the counter |
|--------------------|--------------------------------------------------|
|                    | produced one or more new measurements that       |
|                    | were never read.                                 |

Timeout is applicable for selected measurement modes, and the definition of Timeout varies according to the measurement mode you select. The following table defines Timeout for each measurement mode option.

| MeasurementMode             | Timeout Definition                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Period                      | Timeout occurs when the actual input signal pe<br>riod is greater than the maximum measurable p<br>eriod and the counter returns a value of 0.                                                                                                                                                                                                                                                                                            |
| Pulse                       | Timeout occurs when the actual input signal period is greater than the maximum measurable period. If the input signal remains high when timeout occurs, the counter returns a non-zero value for the high pulse and a value of 0 for the low pulse. If the input signal remains low when time out occurs, the counter returns a non-zero value for the low pulse and a value of 0 for the high pulse and a value of 0 for the high pulse. |
| Pulse Width                 | Timeout occurs when the actual input signal pe<br>riod is greater than the maximum measurable p<br>eriod and the counter returns a value of 0.                                                                                                                                                                                                                                                                                            |
| Two Edge Separation         | Timeout occurs when the actual input signal pe<br>riod is greater than the maximum measurable s<br>eparation and the counter returns a value of 0.                                                                                                                                                                                                                                                                                        |
| Quadrature Encoder Velocity | Timeout occurs when the actual input signal pe<br>riod is greater than the maximum measurable c<br>ount period and the counter returns a value of 0                                                                                                                                                                                                                                                                                       |
| Two Pulse Encoder Velocity  | Timeout occurs when the actual input signal pe<br>riod is greater than the maximum measurable c<br>ount period and the counter returns a value of 0                                                                                                                                                                                                                                                                                       |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following <u>I/O methods</u> for this device. You can also use the <u>properties dialog box</u> to configure the measurement modes for this device.

#### **Module Methods**

This device does not support any module methods.

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property                            | Description                                                                                                                                |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Digital Filter Enable               | Enables the digital filter for the corresponding d igital line.                                                                            |
| Digital Filter Minimum Pulse Width* | Configures the minimum pulse width for the dig<br>ital filter of the corresponding digital line in incr<br>ements of 80 ns, up to 5.24 ms. |
| Terminal Mode                       | Configures the terminal mode of the correspond<br>ing digital line (Differential, Single-ended, and S<br>ingle-ended with Pull-up).        |

\* Unit in ticks, whereby 1 tick = 80 ns.

Example: Minimum Pulse Width = 1 ms. Therefore, input to the Digital Filter Minimum Pulse Width property node is 1 ms / 80 ns = 12500 ticks.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x777E.                   |
| Serial Number | Returns the unique serial number of the module . |

| Vendor ID               | Returns the NI vendor ID, 0x1093.                                                                                               |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Digital Logic Threshold | Configures the digital logic threshold for the mo<br>dule. Does not apply to terminals that are config<br>ured as Differential. |

# Single-Cycle Timed Loop

This device does not support any single-cycled timed loop.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and 160 MHz.

C Series Module Properties Dialog Box for the NI 9361 (FPGA Interface)

Right-click an <u>NI 9361</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to launch the **C Series Module Properties** dialog box, that includes the following components, which you can use to configure a C Series module.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. Use this field to assign a descriptive name to the module.
- **Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies the slot in the chassis used by the C Series module.
- **Channel**—Specifies the list of counters available in the module, which you can select to configure.
- **Measurement**—Specifies the selected measurement mode of the corresponding counter.
- **Terminals**—Specifies the selected terminal settings of the corresponding counter.

• **Settings**—Specifies the selected configuration of the corresponding counter.

• Measurement Mode—Sets the measurement mode of the corresponding counter.

| Measurement Mode | Configuration Type | Description                                                                                                                                                       |
|------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Edge Counting    | Initial Count      | Sets the initial counter value.                                                                                                                                   |
|                  | Active Edge        | Sets the active edge of the co<br>unter.                                                                                                                          |
|                  | Pause              | Enables or disables the Paus e feature.                                                                                                                           |
|                  | Pause When         | Configures the Pause trigger t<br>o Pause When High or Pause<br>When Low.                                                                                         |
|                  | HW Reset           | Enables or disables the Hard ware Reset.                                                                                                                          |
|                  | Reset Edge         | Configures the HW Reset to tr<br>igger on the rising or falling e<br>dge.                                                                                         |
|                  | Reset Count        | Sets the value the counter res<br>ets to when HW Reset is trigg<br>ered.                                                                                          |
|                  | Direction          | Sets the count direction to C<br>ount Up, Count Down, or Exte<br>rnally Controlled.                                                                               |
|                  | Count Up When      | Sets the counter to Count Up<br>when the external terminal is<br>high or low.                                                                                     |
| Period           | Starting Edge      | Configures the counter to sta<br>rt counting on the rising or fa<br>lling edge.                                                                                   |
|                  | Sample Rate (Hz)   | Specifies the rate at which da<br>ta is being sampled from the<br>counter. This value is used to<br>calculate the Measurement Ti<br>me and Divisor of the counter |

|                             | Maximum Measurable Period<br>(ms)      | Specifies the maximum (slow est) period input signal that c an be measured.                                                           |
|-----------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
|                             | Maximum Freq (Hz)                      | Specifies the maximum input<br>frequency. This value is used<br>to calculate the Measuremen<br>t Time and Divisor of the cou<br>nter. |
| Pulse                       | Starting Edge                          | Configures the counter to sta<br>rt counting on the rising or fa<br>lling edge.                                                       |
|                             | Maximum Measurable Period<br>(ms)      | Specifies the maximum (slow<br>est) period input signal that c<br>an be measured.                                                     |
| Pulse Width                 | Starting Edge                          | Configures the counter to sta<br>rt counting on the rising or fa<br>lling edge.                                                       |
|                             | Maximum Measurable Period<br>(ms)      | Specifies the maximum (slow<br>est) period input signal that c<br>an be measured.                                                     |
| Two Edge Separation         | First Edge                             | Configures the first edge to ei ther rising or falling.                                                                               |
|                             | Second Edge                            | Configures the second edge t o either rising or falling.                                                                              |
|                             | Maximum Measurable Separa<br>tion (ms) | Specifies the maximum separ<br>ation that can be measured b<br>etween the first input signal<br>and the second input signal.          |
| Quadrature Encoder Position | Initial Position                       | Sets the initial counter value.                                                                                                       |
|                             | Decoding Type                          | Configures the decoding type (x1, x2, or x4).                                                                                         |
|                             | Z Index Enable                         | Enables or disables the usage of the Z terminal.                                                                                      |
|                             | Z Index Value                          | Sets the value that is loaded t<br>o the counter when the Z ter<br>minal is triggered.                                                |
|                             | Z Index Phase                          | Configures the AB phase in w<br>hich the Z Index value is load                                                                        |

|                             |                                         | ed to the counter when the Z<br>Terminal is triggered.                                                                                                            |
|-----------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Two Pulse Encoder           | Initial Position                        | Sets the initial counter value.                                                                                                                                   |
|                             | HW Reset                                | Enables or disables the Hard ware Reset.                                                                                                                          |
|                             | Reset Edge                              | Configures the HW Reset to tr<br>igger on the rising or falling e<br>dge.                                                                                         |
|                             | Reset Position                          | Sets the value the counter res<br>ets to when HW Reset is trigg<br>ered.                                                                                          |
| Quadrature Encoder Velocity | Decoding Type                           | Configures the decoding type (x1, x2, and x4).                                                                                                                    |
|                             | Sample Rate (Hz)                        | Specifies the rate at which da<br>ta is being sampled from the<br>counter. This value is used to<br>calculate the Measurement Ti<br>me and Divisor of the counter |
|                             | Maximum Measurable Count<br>Period (ms) | Specifies the maximum (slow<br>est) period between encoder<br>input counts that can be mea<br>sured.                                                              |
|                             | Maximum Count Rate (Hz)                 | Specifies the maximum coun<br>t rate. This value is used to ca<br>lculate the Measurement Tim<br>e and Divisor of the counter.                                    |
| Two Pulse Encoder Velocity  | Sample Rate (Hz)                        | Specifies the rate at which da<br>ta is being sampled from the<br>counter. This value is used to<br>calculate the Measurement Ti<br>me and Divisor of the counter |
|                             | Maximum Measurable Count<br>Period (ms) | Specifies the maximum (slow<br>est) period between encoder<br>input counts that can be mea<br>sured.                                                              |
|                             | Maximum Count Rate (Hz)                 | Specifies the maximum coun t rate. This value is used to ca                                                                                                       |

lculate the Measurement Tim e and Divisor of the counter.

Advanced Configuration—Launches the <u>Advanced Configuration</u> dialog box.

NI 9361 I/O Method Parameters

Refer to the I/O Methods, that includes the following parameters, which you can use to configure the NI 9361 measurement modes.



**Note** The counters operate based on the module's timebase of 100 MHz. Each timebase tick corresponds to 10 ns.

• **Configure Edge Counting**—Configures the corresponding counter for any edge counting application. The Method Node returns an error if invoked while the module is in running state. The Initial Count and Reset Count are in edges.

| Parameters                       | Description                                                                                                                                                                                                                         |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal                         | Source input terminal of the counter.                                                                                                                                                                                               |
| Initial Count                    | Initial counter value once the counter is arm ed.                                                                                                                                                                                   |
| Active Edge                      | Sets the triggering edge of the input signal.<br>Rising indicates the counter would count on<br>every rising edge and vice versa.                                                                                                   |
| Direction                        | Sets the count direction to either count up, c<br>ount down or to be externally controlled.                                                                                                                                         |
| Direction Terminal               | Configures the external terminal that is used<br>to control the count direction. This needs to<br>be set when Direction is configured to "Exter<br>nally Controlled". If not set, the parameter va<br>lue defaults to DIO terminal. |
| External Direction Count Up When | Configures whether the counter would coun<br>t up when the Direction Terminal is 'HIGH' or<br>to count up when the Direction Terminal is 'L<br>OW'. If not set, the parameter value defaults<br>to count up when high.              |
| Reset Enable                     | Enables or disables Hardware Reset.                                                                                                                                                                                                 |

| Reset Terminal    | Configures the reset terminal that is used to<br>reset the counter. This needs to be set when<br>Hardware Reset is enabled. If not set, the par<br>ameter value defaults to DI0 terminal.  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset Count       | Sets the count value to load to the counter u pon reset. If not set, the parameter value def aults to zero.                                                                                |
| Reset Active Edge | Sets the triggering edge of the reset signal. If<br>not set, the parameter value defaults to rese<br>t on the rising edge.                                                                 |
| Pause Enable      | Enables or disables the pause trigger.                                                                                                                                                     |
| Pause Terminal    | Configures the pause terminal that is used t<br>o pause the counter. This needs to be set wh<br>en pause trigger is enabled. If not set, the pa<br>rameter value defaults to DI0 terminal. |
| Pause When        | Configures the pause trigger to either pause<br>the counter when the pause terminal is 'HIG<br>H' or 'LOW'. If not set, the parameter value d<br>efaults to pause when high.               |

• Configure Edge Counting Simple—Configures the corresponding counter for simple edge counting. The simple configuration for edge counting sets Direction to Count Up and disables both Reset and Pause. The Method Node returns an error if invoked while the module is in running state. The Initial Count is in edges.

| Parameters    | Description                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Terminal      | Source input terminal of the counter.                                                                                             |
| Initial Count | Initial counter value once the counter is arm ed.                                                                                 |
| Active Edge   | Sets the triggering edge of the input signal.<br>Rising indicates the counter would count on<br>every rising edge and vice versa. |

• **Configure Period**—Configures the corresponding counter for period measurement. The Method Node returns an error if invoked while the module is in running state.

| Parameters | Description                           |
|------------|---------------------------------------|
| Terminal   | Source input terminal of the counter. |

| Starting Edge             | Configures the triggering edge of the input si gnal.                                                                                                                                                                                                                                                                                                          |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Measurement Time          | Configures the amount of time over which to<br>measure and average the period of the input<br>signal. This value is specified in units of coun<br>ter timebase ticks. Set to 0 to disable the <b>Me</b><br><b>asurement Time</b> , in which case the measu<br>rement will be completed using only the <b>Div</b><br><b>isor</b> setting.                      |
| Divisor                   | Configures the number of periods of the inp<br>ut signal to measure and average to determi<br>ne the input signal period. Set to 0 to disable<br>the <b>Divisor</b> , in which case the measurement<br>will be completed using only the <b>Measure</b><br><b>ment Time</b> setting.                                                                           |
| Maximum Measurable Period | Configures the maximum (slowest) period in<br>put signal that can be measured. If the actua<br>l input signal period is longer than this value<br>, the measurement will timeout and the cou<br>nter returns a value of 0. This value is specifi<br>ed in units of counter timebase ticks. Set this<br>value to 0 to disable enforcing the maximum<br>period. |
|                           | <b>Note</b> Setting both <b>Measurement Time</b><br>and <b>Divisor</b> to 0 is invalid, and will cause<br>the counter to always return a value of 0.                                                                                                                                                                                                          |

 Configure Period Simple—Configures the corresponding counter for simple period measurement. The simple configuration for period measurement sets Measurement Time to 0 and Divisor to 1. The Method Node returns an error if invoked while the module is in running state.

| Parameters                | Description                                                                              |
|---------------------------|------------------------------------------------------------------------------------------|
| Terminal                  | Source input terminal of the counter.                                                    |
| Starting Edge             | Configures the triggering edge of the input si gnal.                                     |
| Maximum Measurable Period | Configures the maximum (slowest) period in put signal that can be measured. If the actua |

l input signal period is longer than this value , the measurement will timeout and the cou nter returns a value of 0. This value is specifi ed in units of counter timebase ticks. Set this value to 0 to disable enforcing the maximum period.

• **Configure Pulse**—Configures the corresponding counter for pulse measurement. The Method Node returns an error if invoked while the module is in running state.

| Parameters                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal                  | Source input terminal of the counter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Starting Edge             | Configures the triggering edge of the input si gnal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Maximum Measurable Period | Configures the maximum (slowest) period in<br>put signal that can be measured. If the actua<br>l input signal period is longer than this value<br>, the measurement will timeout and the cou<br>nter returns a non-zero value for the high pul<br>se and a value of 0 for the low pulse if the act<br>ual signal is high during timeout. The counte<br>r returns a non-zero value for the low pulse a<br>nd a value of 0 for the high pulse if the actual<br>signal is low during timeout. This value is sp<br>ecified in units of counter timebase ticks. Set<br>this value to 0 to disable enforcing the maxi<br>mum period. |

• **Configure Pulse Width**—Configures the corresponding counter for pulse width measurement. The Method Node returns an error if invoked while the module is in running state.

| Parameters                | Description                                                                                                                                                                                  |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal                  | Source input terminal of the counter.                                                                                                                                                        |
| Starting Edge             | Configures the triggering edge of the input si gnal.                                                                                                                                         |
| Maximum Measurable Period | Configures the maximum (slowest) period in<br>put signal that can be measured. If the actua<br>l input signal period is longer than this value<br>, the measurement will timeout and the cou |

• **Configure Two Edge Separation**—Configures the corresponding counter for two edge separation measurement. The Method Node returns an error if invoked while the module is in running state.

| Parameters                    | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| First Terminal                | First source input terminal of the counter.                                                                                                                                                                                                                                                                                                                                                                        |
| First Edge                    | Configures the triggering edge of the first sig nal.                                                                                                                                                                                                                                                                                                                                                               |
| Second Terminal               | Second source input terminal of the counter.                                                                                                                                                                                                                                                                                                                                                                       |
| Second Edge                   | Configures the triggering edge of the second signal.                                                                                                                                                                                                                                                                                                                                                               |
| Maximum Measurable Separation | Configures the maximum separation betwee<br>n the first input signal and the second input<br>signal that can be measured. If the actual in<br>put signal separation is longer than this valu<br>e, the measurement will timeout and the co<br>unter returns a value of 0. This value is specif<br>ied in units of counter timebase ticks. Set thi<br>s value to 0 to disable enforcing the maximu<br>m separation. |

• **Configure Quadrature Encoder Position**—Configure the corresponding counter for quadrature encoder measurement. Z indexing can be enabled or disabled. The Method Node returns an error if invoked while the module is in running state.

| Parameters        | Description                                          |
|-------------------|------------------------------------------------------|
| A Terminal        | A input terminal of the counter.                     |
| A Invert Polarity | Configures the module to invert the <b>A</b> signal. |
| B Terminal        | <b>B</b> input terminal of the counter.              |
| B Invert Polarity | Configures the module to invert the <b>B</b> signal. |
| Initial Position  | Initial counter value once the counter is arm ed.    |

| Decoding Type     | Configures the decoding type to either x1, x2 or x4.                                                                                                                          |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z Index Enable    | Enables or disables the <b>Z</b> Index.                                                                                                                                       |
| Z Terminal        | Configures the Z terminal for the Z index. Th<br>is needs to be set when Z Index is enabled. If<br>not set, the parameter value defaults to DI0 t<br>erminal.                 |
| Z Invert Polarity | Configures the module to invert the Z signal.<br>If not set, the parameter value defaults to no<br>t inverting the Z signal.                                                  |
| Z Index Value     | Configures the counter value to be loaded w<br>hen the <b>Z</b> Index is triggered. If not set, the pa<br>rameter value defaults to not zero.                                 |
| Z Index Phase     | Configures the Z Index phase in which the Z<br>index would be triggered. If not set, the para<br>meter value defaults to trigger when A signal<br>is low and B signal is low. |

• **Configure Two Pulse Encoder**—Configures the corresponding counter for any two pulse encoder measurement. The Method Node returns an error if invoked while the module is in running state. The Initial Position and Reset Position values are in encoder counts.

| Parameters        | Description                                                                                                                                                                              |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A Terminal        | A input terminal of the counter.                                                                                                                                                         |
| A Invert Polarity | Configures the module to invert the <b>A</b> signal.                                                                                                                                     |
| B Terminal        | B input terminal of the counter.                                                                                                                                                         |
| B Invert Polarity | Configures the module to invert the <b>B</b> signal.                                                                                                                                     |
| Initial Position  | Initial counter value once the counter is arm ed.                                                                                                                                        |
| Reset Enable      | Enables or disables Hardware Reset.                                                                                                                                                      |
| Reset Terminal    | Configures the reset terminal that is used to<br>reset the counter. This needs to be set when<br>Hardware Reset is enabled. If not set, the par<br>ameter value defaults to DI0 terminal |

| Reset Position    | Sets the count value that would be loaded to<br>the counter upon reset. If not set, the param<br>eter value defaults to zero. |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Reset Active Edge | Sets the triggering edge of the reset signal. If<br>not set, the parameter value defaults to rese<br>t on rising edge.        |

• Configure Two Pulse Encoder Simple—Configures the corresponding counter for any two pulse encoder measurement. The simple configuration for two pulse encoder measurement disables Reset. The Method Node returns an error if invoked while the module is in running state. The Initial Position value is in encoder counts.

| Parameters        | Description                                          |
|-------------------|------------------------------------------------------|
| A Terminal        | A input terminal of the counter.                     |
| A Invert Polarity | Configures the module to invert the <b>A</b> signal. |
| B Terminal        | B input terminal of the counter.                     |
| B Invert Polarity | Configures the module to invert the <b>B</b> signal. |
| Initial Position  | Initial counter value once the counter is arm ed.    |

# • **Configure Quadrature Encoder Velocity**—Configures the corresponding counter for quadrature encoder velocity measurement. The Method Node returns an error if invoked while the module is in running state.

| Parameters        | Description                                                                                                                                                                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A Terminal        | A input terminal of the counter.                                                                                                                                                                                                                           |
| A Invert Polarity | Configures the module to invert the <b>A</b> signal.                                                                                                                                                                                                       |
| B Terminal        | B input terminal of the counter.                                                                                                                                                                                                                           |
| B Invert Polarity | Configures the module to invert the <b>B</b> signal.                                                                                                                                                                                                       |
| Decoding Type     | Configures the decoding type to either x1, x2 or x4.                                                                                                                                                                                                       |
| Measurement Time  | Configures the amount of time over which to<br>measure and average the period of the input<br>signal. This value is specified in units of coun<br>ter timebase ticks. Set to 0 to disable the <b>Me</b><br><b>asurement Time</b> , in which case the measu |

|                                 | rement will be completed using only the <b>Div isor</b> setting.                                                                                                                                                                                                                                                                                                                      |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Divisor                         | Configures the number of encoder count per<br>iods to measure and average to determine t<br>he encoder input period (velocity). Set to 0 t<br>o disable the <b>Divisor</b> , in which case the mea<br>surement will be completed using only the<br><b>Measurement Time</b> setting.                                                                                                   |
| Maximum Measurable Count Period | Configures the maximum (slowest) period b<br>etween encoder input counts that can be me<br>asured. If the actual time between encoder c<br>ounts is longer than this value, the measure<br>ment will timeout and the counter returns a<br>value of 0. This value is specified in units of c<br>ounter timebase ticks. Set this value to 0 to<br>disable enforcing the maximum period. |
| E.                              | <b>Note</b> Setting both <b>Measurement Time</b><br>and <b>Divisor</b> to 0 is invalid, and will cause<br>the counter to always return a value of 0.                                                                                                                                                                                                                                  |

• **Configure Two Pulse Encoder Velocity**—Configures the corresponding counter for two pulse encoder velocity measurement. The Method Node returns an error if invoked while the module is in running state.

| Parameters        | Description                                                                                                                                                                                                                                                                                                                              |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A Terminal        | A input terminal of the counter.                                                                                                                                                                                                                                                                                                         |
| A Invert Polarity | Configures the module to invert the <b>A</b> signal.                                                                                                                                                                                                                                                                                     |
| B Terminal        | B input terminal of the counter.                                                                                                                                                                                                                                                                                                         |
| B Invert Polarity | Configures the module to invert the <b>B</b> signal.                                                                                                                                                                                                                                                                                     |
| Measurement Time  | Configures the amount of time over which to<br>measure and average the period of the input<br>signal. This value is specified in units of coun<br>ter timebase ticks. Set to 0 to disable the <b>Me</b><br><b>asurement Time</b> , in which case the measu<br>rement will be completed using only the <b>Div</b><br><b>isor</b> setting. |
| Divisor           | Configures the number of encoder count per<br>iods to measure and average to determine t                                                                                                                                                                                                                                                 |

|                                 | he encoder input period (velocity). Set to 0 t<br>o disable the <b>Divisor</b> , in which case the mea<br>surement will be completed using only the<br><b>Measurement Time</b> setting.                                                                                                                                                                                               |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Maximum Measurable Count Period | Configures the maximum (slowest) period b<br>etween encoder input counts that can be me<br>asured. If the actual time between encoder c<br>ounts is longer than this value, the measure<br>ment will timeout and the counter returns a<br>value of 0. This value is specified in units of c<br>ounter timebase ticks. Set this value to 0 to<br>disable enforcing the maximum period. |

Advanced Configuration Dialog Box (FPGA Interface)

Click the **Advanced Configuration** button on the <u>C Series Module Properties</u> dialog box for the <u>NI 9361</u> to launch the **Advanced Configuration** dialog box, which you can use to configure the counter input terminals and each digital input line.

- **Counters**—Configures the corresponding counter terminal.
  - Measurement Mode—Displays the measurement mode of the selected counter.
  - Reset Terminals to Default—Reset the terminal settings to the factory defaults.
  - Terminals of the selected counters:
    - For Edge Counting, there are up to 4 terminals per counter (Input, Reset, Direction, and Pause).
    - For Quadrature Encoder Position and Two Pulse Encoder, there are up to 3 terminals per counter (A Input, B Input, and Z or Reset).
    - For Two Edge Separation, there are two terminals per counter (First Input and Second Input).
    - For Quadrature Encoder Velocity and Two Pulse Encoder Velocity, there are two terminals per counter (A Input and B Input).

- For Period, Pulse, and Pulse Width, there is only one terminal per counter.
- **Digital Inputs**—Configures the corresponding digital inputs lines.
  - Digital Input Channels—Selects the Digital Inputs to configure.
  - Terminal Mode—Configures the terminal mode (Differential, Single-Ended, or Single-Ended with Pull-up) of the selected digital input.
  - Digital Filter—Enables or disables the digital input filter.
  - Minimum Pulse Width (ms)—Configures the minimum pulse width of the digital input filter. Pulses that are shorter than the minimum pulse width will be filtered out (Applies only when Digital Filter is enabled).
  - Threshold (V)—Sets the threshold value for the counter (Applies only to terminals that are not differential).

Synchronizing Multiple NI 9361 Modules (FPGA Interface)

Complete the following steps to synchronize multiple NI 9361 modules that are connected to the same FPGA device.

- 1. <u>Create the FPGA I/O items</u> with all the I/O channels to be synchronized, within a single <u>FPGA I/O Node</u>. Otherwise, the FPGA I/O Node will not return synchronized data.
- 2. Configure an FPGA I/O Node with **Start** channels for the NI 9361 modules you want to synchronize.
- 3. Wire a Boolean constant set to TRUE to each **Start** channel.

#### Digital Input Modules

Use this book as a reference for the following information:

- FPGA I/O functions, I/O resources, arbitration options, methods, and properties each C Series digital input module supports in FPGA Interface mode
- I/O variables and properties each C Series digital input module supports in Scan Interface mode
- Instructions for using LabVIEW with CompactRIO digital input devices

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

NI 9344

CompactRIO 4-Channel Switch Input and 4-Channel LED Output Module

#### Software Reference (?)

EPGA Interface

# NI 9344 Front Panel



# Related Topics

FPGA Interface

# NI 9344 (FPGA Interface)

CompactRIO 4-Channel Switch Input and 4-Channel LED Output Module

Find examples

#### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device. When you write to an NI 9344 channel, the FPGA I/O Node does not automatically enable the channel for output.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal          | Description                                                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| User LED <b>x</b> | LED output channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9344 has LED channels 0 to 3.                         |
| User Switch x     | Switch input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9344 has Switch channels<br>0 to 3.             |
| User LED 3:0      | Digital output port consisting of channels 0 thro<br>ugh 3. Channel 3 is returned in the MSB, and cha<br>nnel 0 is returned in the LSB. |
| User Switch 3:0   | Digital input port consisting of channels 0 throu<br>gh 3. Channel 3 is returned in the MSB, and chan<br>nel 0 is returned in the LSB.  |

#### Arbitration

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>. Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

Method Description

| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                                        |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                                            |
| Wait on Rising Edge  | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho                                                                                                                                                                                                                                                                                                                                    |

w long the Wait on Rising Edge method waits for the next rising edge. A value of 0 causes the met hod to time out immediately, a negative value c auses the method to wait indefinitely, and a pos itive value causes the method to wait for that nu mber of clock ticks before timing out.

#### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method       | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x77C5.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O</u> <u>Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the module is performing digital I/O within a single-cycle Timed Loop, do not perform property reads, use the Set Line Direction method, or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9344 (FPGA Interface)

Right-click an <u>NI 9344</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

#### NI 9344 (Scan Interface)

CompactRIO 4-Channel Switch Input and 4-Channel LED Output Module

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

#### **Module Channels**

The NI 9344 has the following channels.

| Channel              | Description                                                                                                                 |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------|
| User LED <b>x</b>    | LED output channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9344 has LED channels 0 to 3.             |
| User Switch <b>x</b> | Switch input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9344 has Switch channels<br>0 to 3. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9344. Right-click the NI 9375 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

DI0 DI1

DI2

DI4

DI5

DI6

DI7

NC

DO0

DO1

DO2

DO3

DO4

DO5 DO6

DO7

Vsup

DI COM

• Location—Specifies a slot in the chassis for the C Series module.

#### NI 9375

CompactRIO 16-Channel Digital Input and 16-Channel Digital Output

#### Software Reference (?)

#### 这 FPGA Interface 🛛 🕝 Scan Interface

#### NI 9375 Pinout



# **Related Topics**

FPGA Interface Avoiding Timing Uncertainty with the NI 9375

# NI 9375 (FPGA Interface)

CompactRIO 16-Channel Digital Input and 16-Channel Digital Output

Find NI 9375 examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> or <u>writing</u>, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal    | Description                                                                                                                                                                                                                                                          |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIx         | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9375 has DI channels 0 to 1<br>5.                                                                                                                                           |
| D17:0       | Digital port consisting of DI channels 0 through<br>7. Channel 7 is returned in the MSB, and channe<br>l 0 is returned in the LSB.                                                                                                                                   |
| DI15:8      | Digital port consisting of DI channels 8 through<br>15. Channel 15 is returned in the MSB, and chan<br>nel 8 is returned in the LSB.                                                                                                                                 |
| DI15:0      | Digital port consisting of DI channels 0 through 15. Channel 15 is returned in the MSB, and chan nel 0 is returned in the LSB.                                                                                                                                       |
| DOx         | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9375 has DO channels 0 t<br>o 15.                                                                                                                                           |
| DO7:0       | Digital port consisting of DO channels 0 through<br>7. Channel 7 is returned in the MSB, and channe<br>l 0 is returned in the LSB.                                                                                                                                   |
| DO15:8      | Digital port consisting of DO channels 8 through 15. Channel 15 is returned in the MSB, and chan nel 8 is returned in the LSB.                                                                                                                                       |
| DO15:0      | Digital port consisting of DO channels 0 through 15. Channel 15 is returned in the MSB, and chan nel 0 is returned in the LSB.                                                                                                                                       |
| $\triangle$ | <b>Caution</b> DI and DO operations that are run<br>concurrently may exhibit jitter. Access both<br>subsystems using a single I/O Node to avoid<br>jitter in your application. Refer to the <u>Avoiding</u><br><u>Timing Uncertainty</u> topic for more information. |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

This device does not support any module methods.

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

Avoiding Timing Uncertainty with the NI 9375 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into DI and DO Node calls.

 Use a single I/O Node to access DI and DO operations to ensure proper sequencing. • Do not perform the following operations concurrently:

– DI Node call – DO Node call

Refer to the NI 9375 Digital Port Input Output VI in the labview\examples\Com pactRIO\Module Specific\NI 9375\NI 9375 Digital Port Input Output\NI 9375 Digital Port Input Output.lvproj for an example of the recommended way to use the DIO subsystems.

C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9375 (Scan Interface)

CompactRIO 16-Channel Digital Input and 16-Channel Digital Output

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

# **Module Channels**

The NI 9375 has the following channels.

| Channel | Description                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. For the NI 9375, <b>x</b> is 0 to 15. |
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9375, <b>x</b> is 0 to 15.    |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9375. Right-click the NI 9375 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9381

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

#### Software Reference (?)

这 FPGA Interface 🛛 🕝 Scan Interface

#### NI 9381 Pinout



# Running AI and AO Operations Concurrently on the NI 9381

AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information.

# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Avoiding Timing Uncertainty with the NI 9381 Converting Voltage Values to Binary Values for the NI 9381

# NI 9381 (FPGA Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

Find NI 9381 examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

| Terminal | Description                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AI channels 0 to<br>7.            |
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AO channels 0 t<br>o 3.          |
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9381 has DIO chan<br>nels 0 to 3. |
| DIO3:0   | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

 $\triangle$ 

**Caution** AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding</u> <u>Timing Uncertainty</u> topic for more information.

# Arbitration

Analog input and analog output channels of this device support only the <u>Arbitrate if</u> <u>Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for analog input and analog output channels of this device.

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for the DIO channels of this device.

| Method            | Description                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Me</u><br><u>le</u> ) topic for a descriptio                                                                                                                                                                                                        | ethod Node (FPGA Modu<br>n of this method.                                                                                                                                                                                                                       |
|                   | This method is available<br>DIO line direction to out<br>line direction in the <u>C Se</u><br>dialog box.                                                                                                                                                                    | e only when you set the<br>put. You can set the DIO<br>eries Module Properties                                                                                                                                                                                   |
| Set Output Enable | Sets the line direction of<br>he DIO3:0 digital port. R<br>hod Node (FPGA Module<br>tion on this method. Thi<br>jitter in an analog input<br>This method is available<br>programmable DIO line<br>You can enable program<br>on the module in the <u>C S</u><br>dialog box.   | f the digital channel or t<br>efer to the <u>FPGA I/O Met</u><br><u>e)</u> topic for more informa<br>is method can introduce<br>or analog output loop.<br>e only when you enable<br>changes on the module.<br>mable DIO line changes<br>Series Module Properties |
| Wait on Any Edge  | Pauses the execution of<br>til the next falling or risin<br>nal. The <b>Timeout</b> input<br>ticks how long the Wait<br>its for the next falling or<br>causes the method to the<br>egative value causes the<br>tely, and a positive value<br>wait for that number of<br>out. | the I/O Method Node un<br>ng edge of the digital sig<br>t specifies in FPGA clock<br>on Any Edge method wa<br>rising edge. A value of 0<br>me out immediately, a n<br>e method to wait indefini<br>e causes the method to<br>clock ticks before timing           |
|                   | <b>B</b>                                                                                                                                                                                                                                                                     | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                             |
|                   |                                                                                                                                                                                                                                                                              | For the first two secon<br>ds after resetting the F                                                                                                                                                                                                              |

|                      | PGA VI, the time out w<br>l not start counting un<br>il the module is identi<br>ed.                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Falling Edge | Pauses the execution of the I/O Method Node u<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks he<br>w long the Wait on Falling Edge method waits for<br>r the next falling edge. A value of 0 causes the r<br>ethod to time out immediately, a negative valu<br>causes the method to wait indefinitely, and a p<br>sitive value causes the method to wait for that<br>umber of clock ticks before timing out. |
|                      | Notes This method is<br>not available on the D<br>O3:0 port.                                                                                                                                                                                                                                                                                                                                                                                                                |
|                      | For the first two secor<br>ds after resetting the F<br>PGA VI, the time out w<br>l not start counting ur<br>il the module is identi<br>ed.                                                                                                                                                                                                                                                                                                                                  |
| Wait on High Level   | Pauses the execution of the I/O Method Node u<br>til the digital signal is high. The <b>Timeout</b> inpu<br>specifies in FPGA clock ticks how long the Wait<br>n High Level method waits for the next high lev<br>l. A value of 0 causes the method to time out in<br>mediately, a negative value causes the method<br>o wait indefinitely, and a positive value causes<br>he method to wait for that number of clock tic<br>before timing out.                             |
|                      | Notes This method is<br>not available on the D<br>O3:0 port.                                                                                                                                                                                                                                                                                                                                                                                                                |
|                      | For the first two secor<br>ds after resetting the F<br>PGA VI, the time out w                                                                                                                                                                                                                                                                                                                                                                                               |

|                     |                                                                                                                                                                                                                                                               | l not start counting unt<br>il the module is identifi<br>ed.                                                                                                                                                                                     |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Low Level   | Pauses the execution of<br>til the digital signal is lo<br>pecifies in FPGA clock ti<br>n Low Level method wa<br>A value of 0 causes the r<br>ediately, a negative valu<br>wait indefinitely, and a<br>method to wait for that<br>fore timing out.            | the I/O Method Node un<br>w. The <b>Timeout</b> input s<br>cks how long the Wait o<br>its for the next low level.<br>nethod to time out imm<br>te causes the method to<br>positive value causes the<br>number of clock ticks be                  |
|                     | E.                                                                                                                                                                                                                                                            | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                             |
|                     |                                                                                                                                                                                                                                                               | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                                  |
| Wait on Rising Edge | Pauses the execution of<br>til the next rising edge of<br><b>Timeout</b> input specifie<br>w long the Wait on Risin<br>the next rising edge. A v<br>hod to time out immedi<br>auses the method to wa<br>itive value causes the m<br>mber of clock ticks befor | the I/O Method Node un<br>f the digital signal. The<br>s in FPGA clock ticks ho<br>g Edge method waits for<br>alue of 0 causes the met<br>ately, a negative value c<br>it indefinitely, and a pos<br>ethod to wait for that nu<br>re timing out. |
|                     | <b>e</b>                                                                                                                                                                                                                                                      | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                             |
|                     |                                                                                                                                                                                                                                                               | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt                                                                                                                                      |

il the module is identifi ed.

#### Module Method

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for AI and AO channels of this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9381<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 93<br>81 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

This device supports the Number of Synchronizing Registers for Output Data synchronizing register option when used in SCTL output. This option supports the same functionality as the **Number of Synchronizing Registers for Output Data** option described in the <u>Advanced Code Generation FPGA I/O Properties Page</u> (FPGA Module) topic, with the exception that you can use this option only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the device is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the digital is performing digital I/O within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into AI node, AO Node, DO Node, and Set Output Data method calls. Additionally, failing to follow

these guidelines may result in lost data points for DO Node calls or Set Output Data method calls when either of them are made from inside a single-cycle Timed Loop.

- Use a single I/O Node to access AI and AO operations to ensure proper sequencing.
- Do not run the Set Output Enable method when an AI, AO, or DO subsystems is active.
- Do not perform the following operations concurrently:
  - AI Node call
  - AO Node call
  - Set Output Enable method call

Automatic line direction change when a DO call is made under the following conditions:

• The call is made from outside of a single-cycle Timed Loop.

Allow programmatic DIO line The direction

checkbox is checked in the <u>C Series</u> <u>Module Properties</u> dialog box.

• The DIO channel is configured as an input at the time when the DO node is called.

Refer to the NI 9381 Advanced IO VI in the labview\examples\CompactRIO\ Module Specific\NI 9381\NI 9381 Advanced IO\NI 9381 Advanc ed IO.lvproj for an example of the recommended way to use the AI, AO, and DIO subsystems.

C Series Module Properties Dialog Box for the NI 9381 (FPGA Interface)

Right-click an <u>NI 9381</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:
• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is unsigned, with a word length of 18 bits and an integer word length of 3 bits for the analog input channels and a word length of 16 bits and an integer word length of 3 bits for the analog output channels. Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is Calibrated.

• **Channels**—Specifies the channel(s) for which you want to select the direction.

• Selected Channel(s) Settings—Specifies the direction for each channel.

• Hot Swap Behavior (Analog Output)—Specifies the state of the analog output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

• Allow Programmatic DIO Line Direction Change—Place a checkmark in this checkbox if you want to enable programmable DIO line changes on the module.

 $\triangle$ 

**Caution** Performing a DIO line direction change will affect the timing of any concurrent AI, AO, and DO operations. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information. Converting Voltage Values to Binary Values for the NI 9381 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9381</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value - Offset) ÷ LSB Weight

where

**Binary Value** is the value you write to the FPGA I/O Node

**Current Value** is the voltage in V that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

**Offset** = -5249

LSB Weight =  $5.105 \text{ V} \div 2^{\text{DAC Resolution}}$ 

where

**DAC Resolution** is the DAC resolution value in the **NI 9381 Operating Instructions and Specifications**.

## NI 9381 (Scan Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the AI channels return floating-point data in volts. The I/O variables for the AO channels write floating-point data in volts. The I/O variables for the DIO channels read and write boolean values.

#### **Module Channels**

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.            |
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.           |
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9381, <b>x</b> is 0 to 3 |

The NI 9381 has the following channels.

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9381. Right-click the NI 9381 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

• **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Direction**—Specifies the initial line direction of the selected channel(s) as input or output.

**Note** If you are using <u>direct access</u> to read from or write to AI or AO channels of the NI 9381, the conversion time is somewhat longer than 50 µs.

NI 9401

E

CompactRIO 8-Channel, TTL Digital Input/Output Module

#### Software Reference (?)

FPGA Interface | 3 Scan Interface

#### NI 9401 Pinout



## **Related Topics**

FPGA Interface Configuring the Initial Line Direction for the NI 9401

#### NI 9401 (FPGA Interface)

CompactRIO 8-Channel, TTL Digital Input/Output Module

Find examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device. When you write to an NI 9401 channel, the FPGA I/O Node does not automatically enable the channel for output.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9401 has DIO chan<br>nels 0 to 7. |
| DIO3:0   | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |
| DIO7:4   | Digital port consisting of channels 4 through 7.<br>Channel 7 is returned in the MSB, and channel 4<br>is returned in the LSB.    |
| DIO7:0   | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

## Arbitration

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>. Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                                        |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.                                                                                                                                                                                                                                                                               |

|                     | A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                                                                                                                                                                                                                                              |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

#### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method             | Description                                                                                                                                                             |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Check Status       | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |  |
|                    | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |  |
| Set Line Direction | <u>Sets the direction</u> of one port to input or output.                                                                                                               |  |

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O</u> <u>Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the module is performing digital I/O within a single-cycle Timed Loop, do not perform property reads, use the Set Line Direction method, or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on. C Series Module Properties Dialog Box for the NI 9401 (FPGA Interface)

Right-click an <u>NI 9401</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Initial Line Direction—Sets the <u>initial line direction</u> for each digital port to digital input or digital output. The default is digital input.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

Configuring the Initial Line Direction for the NI 9401 (FPGA Interface)

Each digital port on the <u>NI 9401</u> is initially configured as a digital input. You can configure the initial line direction for each port on the NI 9401 at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the line direction for each port at run time using the <u>FPGA I/O Method Node</u>. The execution of an I/O Method Node that is configured with a Set Line Direction method overwrites the value you configured in the **C Series Module Properties** dialog box.

Configuring Line Direction Using the C Series Module Properties Dialog Box

Complete the following steps to configure the line direction of each digital port using the **C Series Module Properties** dialog box.

1. <u>Configure</u> the CompactRIO system, and add an NI 9401.

- 2. Right-click the NI 9401 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the direction for each port from the **Initial Line Direction** pull-down menus.
- 4. Click the **OK** button.
- 5. Select File»Save All in the Project Explorer window.

Configuring Line Direction Using the FPGA I/O Method Node

Complete the following steps to configure the line direction of each digital port using the FPGA I/O Method Node.

- 1. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for the NI 9401.
- 2. Click the **Method** section and select the **Set Line Direction** method from the shortcut menu.
- 3. Right-click each digital port input and select **Create**»**Control** from the shortcut menu.
- 4. On the front panel of the VI, select the direction for each port from the digital port pull-down menus.

## NI 9401 (Scan Interface)

CompactRIO 8-Channel, TTL Digital Input/Output Module

🔊 Open digital input example 🛛 🛛 🐼 Open digital output example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

#### **Module Channels**

The NI 9401 has the following channels.

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9401, <b>x</b> is 0 to 7 |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9401. Right-click the NI 9401 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- Initial Line Direction—Specifies the initial line direction of each fourchannel port as input or output.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input, <u>counter-driven output</u>, <u>pulse-width modulation</u> output, or <u>quadrature</u> input.

NI 9402

CompactRIO 4-Channel, LVTTL Digital Input/Output Module

Software Reference (?)

FPGA Interface | Scan Interface

#### NI 9402 Pinout



# **Related Topics**

FPGA Interface Configuring the Line Direction for the NI 9402

# NI 9402 (FPGA Interface)

CompactRIO 4-Channel, LVTTL Digital Input/Output Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

# Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| DIOx   | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9402 has DIO chan<br>nels 0 to 3. |
|--------|-----------------------------------------------------------------------------------------------------------------------------------|
| DIO3:0 | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

#### Arbitration

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>. Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data      | Refer to the <u>FPGA I/O Method Node (FPGA Modu</u><br><u>le)</u> topic for a description of this method.                                                                                                                                                                                                                                                                                                                                                                                         |
| Set Output Enable    | <u>Sets the line direction</u> of the digital channel or t<br>he DIO3:0 digital port. Refer to the <u>FPGA I/O Met</u><br><u>hod Node (FPGA Module)</u> topic for more informa<br>tion on this method.                                                                                                                                                                                                                                                                                            |
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho                                                                                                                                                                                                                                                                                                                                   |

|                     | w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                                                                                                                                                                 |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on High Level  | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                   |
| Wait on Low Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                       |
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

#### Module Method

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

Method

Description



#### I/O Properties

This device does not support any I/O properties.

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

The NI 9402 supports the following output synchronizing register options:

Number of Synchronizing Registers for Output Data when used in SCTL

# Number of Synchronizing Registers for Output Enable when used in SCTL

These two options support the same functionality as the **Number of Synchronizing Registers for Output Data** and **Number of Synchronizing Registers for Output Enable** options described in the <u>Advanced Code Generation</u> <u>FPGA I/O Properties Page (FPGA Module)</u> topic, with the exception that you can use these options only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the module is performing digital I/O within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9402 (FPGA Interface)

Right-click an <u>NI 9402</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to select the line direction.

• Selected Channel(s) Settings—Specifies the line direction for each channel.

• **Direction**—<u>Sets the line direction</u> for the selected channel(s) to digital input or digital output. The default is digital input.

Configuring the Line Direction for the NI 9402 (FPGA Interface)

Each digital channel on the <u>NI 9402</u> is initially configured as a digital input. You can configure the initial line direction for each channel on the NI 9402 at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the line direction for each channel at run time using the <u>FPGA I/O Method Node</u>. The execution of an I/O Method Node that is configured with a Set Output Enable method overwrites the values you configured in the **C Series Module Properties** dialog box. In addition, the execution of an FPGA I/O Node configured for output automatically configures the line for output and overwrites the values you configured in the **C Series Module Properties** dialog box or using the **Set Output Enable** method.

Configuring Line Direction Using the C Series Module Properties Dialog Box

Complete the following steps to set the line direction of channels using the **C Series Module Properties** dialog box.

1. <u>Configure</u> the CompactRIO system, and add an NI 9402.

- 2. Right-click the NI 9402 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the line direction from the Channels table. You can select more than one channel by holding the <C trl> or <Shift> key when selecting channels.
- 4. Select the direction for the channel(s) from the **Direction** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring Line Direction of One Channel Using the FPGA I/O Method Node

Complete the following steps to set the line direction of a channel using the FPGA I/O Method Node.

- 1. <u>Create FPGA I/O items</u> for the channel of the NI 9402 for which you want to configure the line direction.
- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for this channel.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the **Enable** input and select **Create**»**Control** from the shortcut menu.
- 5. On the front panel of the VI, click the **Enable** Boolean control to set it to TRUE if you want to set the line direction of the channel to digital output.

Configuring Line Direction of Multiple Channels Using the FPGA I/O Method Node

Complete the following steps to set the line direction of multiple channels using the FPGA I/O Method Node.

1. <u>Create FPGA I/O items</u> for the DIO3:0 digital port of the NI 9402.

- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for the DIO3:0 digital port.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the **Enable** input and select **Create»Control** from the shortcut menu. The **Enable** control appears as an unsigned 8-bit integer. Each bit in the integer represents the line direction of one channel of the NI 9402.
- 5. On the front panel of the VI, use the **Enable** control to enter the line direction for each channel in the port. Change a bit to 1 to set the line direction of the corresponding channel to digital output. Leave a bit as 0 to set the line direction of the corresponding channel to digital input. Refer to the table below for examples of what to enter in the **Enable** control.

| Channel Line Direction<br>Configuration | Enable Control<br>(Floating Point) | Enable Control<br>(Binary) | Enable Control<br>(Hex) |
|-----------------------------------------|------------------------------------|----------------------------|-------------------------|
| Change all channels t<br>o input        | 0                                  | 0000                       | 0x00                    |
| Change all channels t<br>o output       | 15                                 | 1111                       | 0x0F                    |
| Change channel 0 to output              | 1                                  | 0001                       | 0x01                    |

## NI 9402 (Scan Interface)

CompactRIO 4-Channel, LVTTL Digital Input/Output Module

🔊 Open digital input example 🛛 🛛 🐼 Open digital output example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

## Module Channels

The NI 9402 has the following channels.

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9402, <b>x</b> is 0 to 3 |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9402. Right-click the NI 9402 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Direction**—Specifies the initial line direction of the selected channel(s) as input or output.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input, <u>counter-driven output</u>, <u>pulse-width modulation</u> output, or <u>quadrature</u> input.

#### NI 9403

CompactRIO 32-Channel, TTL Digital Input/Output Module

#### Software Reference (?)

FPGA Interface | 3 Scan Interface

#### NI 9403 Pinout



# **Related Topics**

FPGA Interface Configuring the Line Direction for the NI 9403

## NI 9403 (FPGA Interface)

CompactRIO 32-Channel, TTL Digital Input/Output Module

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                          |
|----------|--------------------------------------------------------------------------------------------------------------------------------------|
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9403 has DIO chan<br>nels 0 to 31.   |
| DIO7:0   | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB.       |
| DIO15:8  | Digital port consisting of channels 8 through 15.<br>Channel 15 is returned in the MSB, and channel<br>8 is returned in the LSB.     |
| DIO23:16 | Digital port consisting of channels 16 through 23<br>. Channel 23 is returned in the MSB, and channe<br>l 16 is returned in the LSB. |
| DIO31:24 | Digital port consisting of channels 24 through 31<br>. Channel 31 is returned in the MSB, and channe<br>l 24 is returned in the LSB. |
| DIO31:0  | Digital port consisting of channels 0 through 31.<br>Channel 31 is returned in the MSB, and channel<br>0 is returned in the LSB.     |

#### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> and <u>Never</u> <u>Arbitrate</u> options for arbitration. The default arbitration setting is **Arbitrate if Multiple Requestors Only**.

If you are sure that the design of the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels, you can place a checkmark in the **Disable Arbitration** checkbox on the <u>C Series Module Properties</u> dialog box to disable arbitration and reduce the amount of FPGA logic used by VIs. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

Method

Description

| Read and Set Output Data | First returns the data read from the digital line o<br>r port, then writes data to the line or port witho<br>ut enabling it. You can use the Read and Set Out<br>put Data method to optimize performance whe<br>n performing successive reads and writes on a D<br>IO resource. For the NI 9403, this method is faste<br>r than using a read FPGA I/O Node and a Set Out<br>put Data method. The data type of the output a<br>nd input depends on the I/O item. If the I/O item<br>is a digital line, <b>Data to Set</b> requires a Boolean<br>data type. If the I/O item is a digital port, <b>Data t</b><br><b>o Set</b> requires a numeric data type. |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data          | Refer to the <u>FPGA I/O Method Node (FPGA Modu</u><br><u>le)</u> topic for a description of this method.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Set Output Enable        | Sets the line direction of the digital channel or p<br>ort. Refer to the FPGA I/O Method Node (FPGA M<br>odule) topic for more information on this metho<br>d.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### **Module Methods**

This device does not support any module methods.

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

#### Hardware Documentation

Refer to the NI 9403 hardware documentation on ni.com/manuals for information about module specifications and how to use the module. Refer to the <u>CompactRIO</u> <u>Related Documentation</u> topic for additional CompactRIO documentation resources.

C Series Module Properties Dialog Box for the NI 9403 (FPGA Interface)

Right-click an <u>NI 9403</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to select the line direction.
- Selected Channel(s) Settings—Specifies the line direction for each channel.
  - **Direction**—<u>Sets the line direction</u> for the selected channel(s) to digital input or digital output. The default is digital input.
- **Disable Arbitration**—Place a checkmark in this checkbox if you want to change the arbitration setting to <u>Never Arbitrate</u> and reduce the amount of FPGA logic used by VIs. Check this box only if you are sure that the design of

the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked to keep the default <u>Arbitrate if Multiple Requestors Only</u> arbitration setting.

#### Configuring the Line Direction for the NI 9403 (FPGA Interface)

Each digital channel on the <u>NI 9403</u> is initially configured as a digital input. You can configure the initial line direction for each channel on the NI 9403 at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the line direction for each channel at run time using the <u>FPGA I/O Method Node</u>. The execution of an I/O Method Node that is configured with a Set Output Enable method overwrites the values you configured in the **C Series Module Properties** dialog box. In addition, the execution of an FPGA I/O Node configured for output automatically configures the line for output and overwrites the values you configured in the **C Series Module Properties** dialog box or using the **Set Output Enable** method.

#### Configuring Line Direction Using the C Series Module Properties Dialog Box

Complete the following steps to set the line direction of channels using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an NI 9403.
- 2. Right-click the NI 9403 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the line direction from the Channels table. You can select more than one channel by holding the <C trl> or <Shift> key when selecting channels.
- 4. Select the direction for the channel(s) from the **Direction** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring Line Direction of One Channel Using the FPGA I/O Method Node

Complete the following steps to set the line direction of a channel using the FPGA I/O Method Node.

- 1. <u>Create FPGA I/O items</u> for the channel of the NI 9403 for which you want to configure the line direction.
- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for this channel.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the **Enable** input and select **Create**»**Control** from the shortcut menu.
- 5. On the front panel of the VI, click the **Enable** Boolean control to set it to TRUE if you want to set the line direction of the channel to digital output.

Configuring Line Direction of Multiple Channels Using the FPGA I/O Method Node

Complete the following steps to set the line direction of multiple channels using the FPGA I/O Method Node.

- 1. <u>Create FPGA I/O items</u> for the digital port of the NI 9403 that contains the channels you want to configure.
- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for this digital port.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the Enable input and select Create»Control from the shortcut menu. If you configured the FPGA I/O Method Node for the DIO7:0, DIO15:8, DIO23:16, or DIO31:24 digital port, the Enable control appears as an unsigned 8-bit integer. If you configured the FPGA I/O Method Node for the DIO31:0 digital port, the Enable control appears as an unsigned 32-bit integer. Each bit in the integer represents the line direction of one channel of the NI 9403.

5. On the front panel of the VI, use the **Enable** control to enter the line direction for each channel in the port. Change a bit to 1 to set the line direction of the corresponding channel to digital output. Leave a bit as 0 to set the line direction of the corresponding channel to digital input. Refer to the table below for examples of what to enter in the **Enable** control if you configured the FPGA I/O Method Node for the DIO7:0 digital port.

| Channel Line Direction<br>Configuration | Enable Control (Hex) | Enable Control (Binary) |
|-----------------------------------------|----------------------|-------------------------|
| Change all channels to input            | 0x00                 | 0b0000000               |
| Change all channels to outpu<br>t       | 0xFF                 | 0b1111111               |
| Change channel 0 to output              | 0x01                 | 0b0000001               |
| Change channels 0 through 5 to output   | 0x3F                 | 0b00111111              |
| Change channels 3 and 7 to o utput      | 0x88                 | 0b10001000              |

Refer to the table below for examples of what to enter in the **Enable** control if you configured the FPGA I/O Method Node for the DIO31:0 digital port.

| Channel Line Direction<br>Configuration | Enable Control (Hex) | Enable Control (Binary)                |
|-----------------------------------------|----------------------|----------------------------------------|
| Change all channels to input            | 0x0000000            | 0b000000000000000000000000000000000000 |
| Change all channels to outpu<br>t       | 0xFFFFFFFF           | 0b111111111111111111111111111111111111 |
| Change channel 0 to output              | 0x0000001            | 0b000000000000000000000000000000000000 |
| Change channels 0 through 5 to output   | 0x000003F            | 0b000000000000000000000000000000000000 |
| Change channels 3 and 7 to o<br>utput   | 0x0000088            | 0b000000000000000000000000000000000000 |

#### NI 9403 (Scan Interface)

CompactRIO 32-Channel, TTL Digital Input/Output Module

🔊 Open digital input example 🛛 🔊 Open digital output example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

#### **Module Channels**

The NI 9403 has the following channels.

| Channel | Description                                                                                                                        |
|---------|------------------------------------------------------------------------------------------------------------------------------------|
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9403, <b>x</b> is 0 to 3<br>1. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9403. Right-click the NI 9403 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to configure settings.

• Initial Line Direction—Specifies the initial line direction of the selected channel(s) as input or output.

NI 9411

CompactRIO 6-Channel, Differential or TTL Digital Input Module

Software Reference (?)

这 FPGA Interface | 📀 Scan Interface

#### NI 9411 Pinout



# NI 9411 (FPGA Interface)

CompactRIO 6-Channel, Differential or TTL Digital Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                             |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9411 has DI channels 0 to 5                                    |
| DI5:0    | Digital port consisting of channels 0 through 5.<br>Channel 5 is returned in bit 5, and channel 0 is r<br>eturned in bit 0. Bits 6 and 7 return a zero. |

#### Arbitration

This device supports only the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po                                                                                                                   |

|                     | sitive value causes the method to wait for that n umber of clock ticks before timing out.                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on High Level  | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                   |
| Wait on Low Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                       |
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. |
|              | NoteDuring the first 2seconds after you reset                       |

the FPGA VI, the error t erminals on this metho d may not correctly rep ort certain types of err ors.

# I/O Properties

This device does not support any I/O properties.

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready.

While the module is performing digital input within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital input and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

## NI 9411 (Scan Interface)

CompactRIO 6-Channel, Differential or TTL Digital Input Module

🔊 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return data as Boolean values.

#### **Module Channels**

The NI 9411 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o f the channel. For the NI 9411, <b>x</b> is 0 to 5. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9411. Right-click the NI 9411 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input or <u>quadrature</u> input.

NI 9421

CompactRIO 8-Channel, 24 V, Sinking Digital Input Module

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

#### NI 9421 Pinout





## NI 9421 (FPGA Interface)

CompactRIO 8-Channel, 24 V, Sinking Digital Input Module

#### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9421 has DI channels 0 to 7           |
| DI7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |

#### Arbitration

This device supports only the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |

| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out. |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                      |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                          |
| Wait on Rising Edge  | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out.    |
# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of

the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready.

While the module is performing digital input within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital input and the **Ready** output of the Check Status method to return FALSE.

#### **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

### NI 9421 (Scan Interface)

CompactRIO 8-Channel, 24 V, Sinking Digital Input Module

🔊 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return data as Boolean values.

### **Module Channels**

The NI 9421 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o f the channel. For the NI 9421, <b>x</b> is 0 to 7. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9421. Right-click the NI 9421 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input or <u>quadrature</u> input.

#### NI 9422

CompactRIO 8-Channel, Differential or TTL Digital Input Module

Software Reference (?)

FPGA Interface | Scan Interface

#### NI 9422 Pinout



# NI 9422 (FPGA Interface)

CompactRIO 8-Channel, 24 V, Sinking/Sourcing Digital Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                          |
|----------|----------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9422 has DI channels 0 to 7 |

| DI7:0 | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
|-------|--------------------------------------------------------------------------------------------------------------------------------|

### Arbitration

This device supports only the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t                                                                                                                  |

|                     | he method to wait for that number of clock ticks before timing out.                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Low Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                       |
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                        |                                                                                                                                                                         |
|--------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value th<br>the module is ready. | hat indicates whether                                                                                                                                                   |
|              | N<br>Se<br>th<br>e<br>d<br>d<br>o<br>o             | <b>lote</b> During the first 2<br>econds after you reset<br>he FPGA VI, the error t<br>rminals on this metho<br>may not correctly rep<br>rt certain types of err<br>rs. |

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready.

While the module is performing digital input within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital input and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on. C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

#### NI 9422 (Scan Interface)

CompactRIO 8-Channel, 24 V, Sinking/Sourcing Digital Input Module

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return data as Boolean values.

# **Module Channels**

The NI 9422 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o f the channel. For the NI 9422, <b>x</b> is 0 to 7. |

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9422. Right-click the NI 9422 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

### **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input or <u>quadrature</u> input.

#### NI 9423

CompactRIO 8-Channel, 24 V, High-Speed Digital Input Module

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

#### NI 9423 Pinout



# NI 9423 (FPGA Interface)

CompactRIO 8-Channel, 24 V, High-Speed Digital Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                          |
|----------|----------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9423 has DI channels 0 to 7 |

| DI7:0 | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
|-------|--------------------------------------------------------------------------------------------------------------------------------|

### Arbitration

This device supports only the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t                                                                                                                  |

|                     | he method to wait for that number of clock ticks before timing out.                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Low Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                       |
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                        |                                                                                                                                                                         |
|--------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value th<br>the module is ready. | hat indicates whether                                                                                                                                                   |
|              | N<br>Se<br>th<br>e<br>d<br>d<br>o<br>o             | <b>lote</b> During the first 2<br>econds after you reset<br>he FPGA VI, the error t<br>rminals on this metho<br>may not correctly rep<br>rt certain types of err<br>rs. |

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready.

While the module is performing digital input within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital input and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on. C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

#### NI 9423 (Scan Interface)

CompactRIO 8-Channel, 24 V, High-Speed Digital Input Module

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return data as Boolean values.

# **Module Channels**

The NI 9423 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o f the channel. For the NI 9423, <b>x</b> is 0 to 7. |

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9423. Right-click the NI 9423 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input or <u>quadrature</u> input.

#### NI 9425

CompactRIO 32-Channel, 24 V, Sinking Digital Input Module

#### Software Reference (?)

😂 FPGA Interface | 🞯 Scan Interface

| DI3     O(4)220     DI19     DI17     121     3     DI2       DI4     O(5)230     DI20     DI19     DI18     222     4     DI3       DI5     O(6)240     DI21     DI20     DI9     235     DI4       DI6     O(7)250     DI22     DI21     256     7     DI6       DI7     O(8)260     DI23     DI22     26     7     DI6       DI7     O(8)260     DI23     DI23     27     9     COM       DI9     O(10)280     DI25     COM     28     10     COM       DI10     O(10)280     DI27     DI26     DI24     30     11     DI8       DI11     O(12)3000     DI27     DI25     31     13     DI10       DI112     O(3)3100     DI28     DI27     DI26     32     14     DI11       DI13     O(10)3300     DI29     DI28     34     15     DI12       DI14     O(15)3300     DI29     DI28     34     15     DI12       DI14     O(13)300     DI29     35     17     DI14       DI15     O(6)3400     DI31     DI30     36     17     DI14       O(11)3500     NC     < | DI0<br>DI1<br>DI2<br>DI2<br>DI3<br>DI4<br>DI5<br>DI5<br>DI6<br>DI7<br>DI6<br>DI7<br>DI6<br>DI7<br>DI8<br>DI9<br>DI10<br>DI10<br>DI10<br>DI11<br>DI12<br>DI3<br>DI4<br>DI5<br>DI6<br>DI7<br>DI8<br>DI9<br>DI7<br>DI8<br>DI9<br>DI10<br>DI10<br>DI10<br>DI10<br>DI10<br>DI10<br>DI10<br>DI10 | DI16<br>DI17<br>DI18<br>DI19<br>DI20<br>DI21<br>DI22<br>DI22<br>DI22<br>DI23<br>DI23<br>DI24<br>CO<br>DI25<br>CO<br>DI26<br>DI27<br>DI28<br>DI2<br>DI28<br>DI2<br>DI28<br>DI2<br>DI28<br>DI2<br>DI29<br>DI2<br>DI29<br>DI2<br>DI30<br>DI2<br>DI31<br>DI3<br>NC<br>DI3 | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | DI0<br>DI1<br>DI2<br>DI3<br>DI4<br>DI5<br>DI6<br>DO7<br>COM<br>COM<br>DI8<br>DI9<br>DI10<br>DI11<br>DI12<br>DI13<br>DI14<br>DI15<br>NC |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|

# NI 9425 Pinout

# NI 9425 (FPGA Interface)

CompactRIO 32-Channel, 24 V, Sinking Digital Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9425 has DI channels 0 to 3<br>1.     |
| DI7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |

| DI15:8  | Digital port consisting of channels 8 through 15.<br>Channel 15 is returned in the MSB, and channel<br>8 is returned in the LSB.     |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| DI23:16 | Digital port consisting of channels 16 through 23<br>. Channel 23 is returned in the MSB, and channe<br>l 16 is returned in the LSB. |
| DI31:24 | Digital port consisting of channels 24 through 31<br>. Channel 31 is returned in the MSB, and channe<br>l 24 is returned in the LSB. |
| DI31:0  | Digital port consisting of channels 0 through 31.<br>Channel 31 is returned in the MSB, and channel<br>0 is returned in the LSB.     |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9425 (Scan Interface)

CompactRIO 32-Channel, 24 V, Sinking Digital Input Module

👰 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return data as Boolean values.

### **Module Channels**

The NI 9425 has the following channels.

| Channel | Description                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. For the NI 9425, <b>x</b> is 0 to 31. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9425. Right-click the NI 9425 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

NI 9426

CompactRIO 32-Channel, 24 V, Sourcing Digital Input Module

Software Reference (?)

这 FPGA Interface 🛛 📀 Scan Interface

#### NI 9426 Pinout



# NI 9426 (FPGA Interface)

CompactRIO 32-Channel, 24 V, Sourcing Digital Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9426 has DI channels 0 to 3<br>1.     |
| DI7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |

| DI15:8  | Digital port consisting of channels 8 through 15.<br>Channel 15 is returned in the MSB, and channel<br>8 is returned in the LSB.     |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| DI23:16 | Digital port consisting of channels 16 through 23<br>. Channel 23 is returned in the MSB, and channe<br>l 16 is returned in the LSB. |
| DI31:24 | Digital port consisting of channels 24 through 31<br>. Channel 31 is returned in the MSB, and channe<br>l 24 is returned in the LSB. |
| DI31:0  | Digital port consisting of channels 0 through 31.<br>Channel 31 is returned in the MSB, and channel<br>0 is returned in the LSB.     |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# Methods

This device does not support any methods.

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9426 (Scan Interface)

CompactRIO 32-Channel, 24 V, Sourcing Digital Input Module

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return data as Boolean values.

### **Module Channels**

The NI 9426 has the following channels.

| Channel | Description                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. For the NI 9426, <b>x</b> is 0 to 31. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9426. Right-click the NI 9426 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

NI 9435

CompactRIO 4-Channel, AC/DC Universal Digital Input Module

Software Reference (?)

这 FPGA Interface 🛛 📀 Scan Interface

#### NI 9435 Pinout



# NI 9435 (FPGA Interface)

CompactRIO 4-Channel, AC/DC Universal Digital Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                                 |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9435 has DI channels 0 to 3                                        |
| DI3:0    | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in bit 3, and channel 0 is r<br>eturned in bit 0. Bits 4 through 7 return a zero. |

### Arbitration

This device supports only the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                                        |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un til the digital signal is low. The <b>Timeout</b> input s                                                                                                                                                                                                                                                                                                                                                                                          |

|                     | pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                                                                                                                                      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready.

While the module is performing digital input within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital input and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on. C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

#### NI 9435 (Scan Interface)

CompactRIO 4-Channel, AC/DC Universal Digital Input Module

🔊 Open example

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return data as Boolean values.

### **Module Channels**

The NI 9435 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o f the channel. For the NI 9435, <b>x</b> is 0 to 3. |

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9435. Right-click the NI 9435 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input or <u>quadrature</u> input.

NI 9436

CompactRIO 8 DI, ±100 VDC to ±250 VDC/100 VAC to 250 VAC, Sinking/Sourcing, 10 ms Input Module

Software Reference (?)

这 <u>FPGA Interface</u>

#### NI 9436 Pinout



# NI 9436 (FPGA Interface)

CompactRIO 8 DI,  $\pm 100$  VDC to  $\pm 250$  VDC/100 VAC to 250 VAC, Sinking/Sourcing, 10 ms Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

### Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9436 has DI channels 0 to 7           |
| DI7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |

### Arbitration

This device supports only the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                                        |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un til the digital signal is low. The <b>Timeout</b> input s                                                                                                                                                                                                                                                                                                                                                                                          |

|                     | pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                                                                                                                                      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready.

While the module is performing digital input within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital input and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on. C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

### NI 9436 (Scan Interface)

CompactRIO 8 DI, ±100 VDC to ±250 VDC/100 VAC to 250 VAC, Sinking/Sourcing, 10 ms Input Module

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

# **Module Channels**

The NI 9436 has the following channels.

| Channel | Description                                                                                                          |
|---------|----------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9436 has DI channels 0 to 7 |

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9436. Right-click the NI 9436 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input or <u>quadrature</u> input.

#### NI 9437

CompactRIO 8-Channel, 250 V, Sinking Digital Input Module

#### Software Reference (?)

FPGA Interface

### NI 9437 Pinout



# NI 9437 (FPGA Interface)

CompactRIO 8-Channel, 250 V, Sinking Digital Input Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9437 has DI channels 0 to 7           |
| DI7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |
## Arbitration

This device supports only the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                                        |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un til the digital signal is low. The <b>Timeout</b> input s                                                                                                                                                                                                                                                                                                                                                                                          |

|                     | pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                                                                                                                                      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

#### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital input before a loop containing digital input starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready.

While the module is performing digital input within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital input and the **Ready** output of the Check Status method to return FALSE.

## **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on. C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9437 (Scan Interface)

CompactRIO 8-Channel, 250 V, Sinking Digital Input Module

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels return calibrated floating-point data in volts.

## **Module Channels**

The NI 9437 has the following channels.

| Channel | Description                                                                                                          |
|---------|----------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9437 has DI channels 0 to 7 |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9437. Right-click the NI 9437 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### Digital Output Modules

\*

Use this book as a reference for the following information:

- FPGA I/O functions, I/O resources, arbitration options, methods, and properties each C Series digital output module supports in FPGA Interface mode
- I/O variables and properties each C Series digital output module supports in Scan Interface mode
- Instructions for using LabVIEW with CompactRIO digital output devices

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

### Advanced Configuration Dialog Box (FPGA Interface)

Click the **Advanced** button on the <u>C Series Module Properties</u> dialog box for the <u>NI</u> <u>9401</u>, <u>NI 9472</u>, <u>NI 9474</u>, <u>NI 9475</u>, <u>NI 9481</u>, or <u>NI 9485</u> to display this dialog box.

Use this dialog box to configure the number of output synchronizing registers for each DO channel in a single-cycle Timed Loop.

This dialog box includes the following components:

• **Channels**—Select the channel for which you want to configure the number of output synchronizing registers.

• Channel Configuration—Specifies the number of synchronizing <u>registers</u> between the DO channel executing on the FPGA target and the FPGA target hardware interface. The FPGA target hardware interface might be a physical I/O connector on the device or a connection to a section of the FPGA that contains circuitry designed by NI. Each synchronizing register executes in one clock cycle.

> **Caution** Select **0** only if you also use the <u>IP</u> <u>Integration Node</u> and the code contains its own synchronization registers.

• **O**—Specifies that the FPGA VI uses no synchronizing registers. Do not select this option for most FPGA Module applications.

**Note** If you select **0** for digital output resources in a single-cycle <u>Timed Loop</u>, you create a combinatorial circuit between the two resources. The combinatorial circuit might cause glitches on the output signal.

• **1**—Specifies that the FPGA VI uses one synchronizing register between the DO channel and the FPGA target hardware interface.

NI 9344

CompactRIO 4-Channel Switch Input and 4-Channel LED Output Module

Software Reference (?)

FPGA Interface

#### NI 9344 Front Panel



# **Related Topics**

FPGA Interface

## NI 9344 (FPGA Interface)

CompactRIO 4-Channel Switch Input and 4-Channel LED Output Module

Find examples

#### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device. When you write to an NI 9344 channel, the FPGA I/O Node does not automatically enable the channel for output.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description

| User LED <b>x</b> | LED output channel <b>x</b> , where <b>x</b> is the number of the channel. The NI 9344 has LED channels 0 to 3.                         |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| User Switch x     | Switch input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9344 has Switch channels<br>0 to 3.             |
| User LED 3:0      | Digital output port consisting of channels 0 thro<br>ugh 3. Channel 3 is returned in the MSB, and cha<br>nnel 0 is returned in the LSB. |
| User Switch 3:0   | Digital input port consisting of channels 0 throu<br>gh 3. Channel 3 is returned in the MSB, and chan<br>nel 0 is returned in the LSB.  |

## Arbitration

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>. Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho                                                                                                                                                                                                                                                                                                                                   |

|                     | w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                                                                                                                                                                 |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on High Level  | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                   |
| Wait on Low Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                       |
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

#### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

Method

Description



#### I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the module ID, 0x77C5.                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O</u> <u>Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the module is performing digital I/O within a single-cycle Timed Loop, do not perform property reads, use the Set Line Direction method, or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

### **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9344 (FPGA Interface)

Right-click an <u>NI 9344</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9375

CompactRIO 16-Channel Digital Input and 16-Channel Digital Output

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

## NI 9375 Pinout

# **Related Topics**

FPGA Interface <u>Avoiding Timing Uncertainty with the NI 9375</u>

## NI 9375 (FPGA Interface)

CompactRIO 16-Channel Digital Input and 16-Channel Digital Output

Find NI 9375 examples

### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> or <u>writing</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------------|
| DIx      | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. The NI 9375 has DI channels 0 to 1<br>5. |

| DI7:0       | Digital port consisting of DI channels 0 through<br>7. Channel 7 is returned in the MSB, and channe<br>l 0 is returned in the LSB.                                                                                                                                   |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DI15:8      | Digital port consisting of DI channels 8 through<br>15. Channel 15 is returned in the MSB, and chan<br>nel 8 is returned in the LSB.                                                                                                                                 |
| DI15:0      | Digital port consisting of DI channels 0 through 15. Channel 15 is returned in the MSB, and chan nel 0 is returned in the LSB.                                                                                                                                       |
| DOx         | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9375 has DO channels 0 t<br>o 15.                                                                                                                                           |
| DO7:0       | Digital port consisting of DO channels 0 through<br>7. Channel 7 is returned in the MSB, and channe<br>l 0 is returned in the LSB.                                                                                                                                   |
| DO15:8      | Digital port consisting of DO channels 8 through 15. Channel 15 is returned in the MSB, and chan nel 8 is returned in the LSB.                                                                                                                                       |
| DO15:0      | Digital port consisting of DO channels 0 through 15. Channel 15 is returned in the MSB, and chan nel 0 is returned in the LSB.                                                                                                                                       |
| $\triangle$ | <b>Caution</b> DI and DO operations that are run<br>concurrently may exhibit jitter. Access both<br>subsystems using a single I/O Node to avoid<br>jitter in your application. Refer to the <u>Avoiding</u><br><u>Timing Uncertainty</u> topic for more information. |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

## **Module Methods**

This device does not support any module methods.

## I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

Avoiding Timing Uncertainty with the NI 9375 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into DI and DO Node calls.

- Use a single I/O Node to access DI and DO operations to ensure proper sequencing.
- Do not perform the following operations concurrently:

– DI Node call

– DO Node call

Refer to the NI 9375 Digital Port Input Output VI in the labview\examples\Com pactRIO\Module Specific\NI 9375\NI 9375 Digital Port Input Output\NI 9375 Digital Port Input Output.lvproj for an example of the recommended way to use the DIO subsystems. C Series Module Properties Dialog Box for the NI 9375/9411/9421/9422/9423/9425/9426/9435/9436/9437/950x (FPGA Interface)

Right-click an <u>NI 9375</u>, <u>NI 9411</u>, <u>NI 9421</u>, <u>NI 9422</u>, <u>NI 9423</u>, <u>NI 9425</u>, <u>NI 9426</u>, <u>NI 9435</u>, <u>NI 9436</u>, <u>NI 9437</u>, <u>NI 9501</u>, or <u>NI 9505</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9375 (Scan Interface)

CompactRIO 16-Channel Digital Input and 16-Channel Digital Output

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

### **Module Channels**

The NI 9375 has the following channels.

| Channel | Description                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------|
| DIx     | Digital input channel <b>x</b> , where <b>x</b> is the number o<br>f the channel. For the NI 9375, <b>x</b> is 0 to 15. |
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9375, <b>x</b> is 0 to 15.    |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9375. Right-click the NI 9375 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9381

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

#### Software Reference (?)

😰 FPGA Interface 🛛 🕝 Scan Interface

#### NI 9381 Pinout



# Running AI and AO Operations Concurrently on the NI 9381

AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information.

# **Related Topics**

FPGA Interface Converting and Calibrating CompactRIO Analog Input Values Detecting Out-of-Range Channels Avoiding Timing Uncertainty with the NI 9381 Converting Voltage Values to Binary Values for the NI 9381

## NI 9381 (FPGA Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

Find NI 9381 examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

| Terminal | Description                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AI channels 0 to<br>7.            |
| AOx      | Analog output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9381 has AO channels 0 t<br>o 3.          |
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9381 has DIO chan<br>nels 0 to 3. |
| DIO3:0   | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

 $\triangle$ 

**Caution** AI and AO operations that are run concurrently may exhibit jitter. Access both subsystems using a single I/O Node to avoid jitter in your application. Refer to the <u>Avoiding</u> <u>Timing Uncertainty</u> topic for more information.

## Arbitration

Analog input and analog output channels of this device support only the <u>Arbitrate if</u> <u>Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for analog input and analog output channels of this device.

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

## I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for the DIO channels of this device.

| Method            | Description                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                         |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Me</u><br><u>le</u> ) topic for a descriptio                                                                                                                                                                                                        | ethod Node (FPGA Modu<br>n of this method.                                                                                                                                                                                                                              |
|                   | This method is available<br>DIO line direction to out<br>line direction in the <u>C Se</u><br>dialog box.                                                                                                                                                                    | e only when you set the<br>put. You can set the DIO<br>eries Module Properties                                                                                                                                                                                          |
| Set Output Enable | Sets the line direction of<br>he DIO3:0 digital port. R<br>hod Node (FPGA Module<br>tion on this method. Thi<br>jitter in an analog input<br>This method is available<br>programmable DIO line<br>You can enable program<br>on the module in the <u>C S</u><br>dialog box.   | f the digital channel or t<br>efer to the <u>FPGA I/O Met</u><br><u>e)</u> topic for more informa<br>is method can introduce<br>or analog output loop.<br>e only when you enable<br>changes on the module.<br>mable DIO line changes<br><u>Series Module Properties</u> |
| Wait on Any Edge  | Pauses the execution of<br>til the next falling or risin<br>nal. The <b>Timeout</b> input<br>ticks how long the Wait<br>its for the next falling or<br>causes the method to the<br>egative value causes the<br>tely, and a positive value<br>wait for that number of<br>out. | the I/O Method Node un<br>ng edge of the digital sig<br>t specifies in FPGA clock<br>on Any Edge method wa<br>rising edge. A value of 0<br>me out immediately, a n<br>e method to wait indefini<br>e causes the method to<br>clock ticks before timing                  |
|                   | <b>B</b>                                                                                                                                                                                                                                                                     | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                                                    |
|                   |                                                                                                                                                                                                                                                                              | For the first two secon<br>ds after resetting the F                                                                                                                                                                                                                     |

|                      | PGA VI, the time out w<br>l not start counting ur<br>il the module is identi<br>ed.                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Falling Edge | Pauses the execution of the I/O Method Node util the next falling edge of the digital signal. The <b>Timeout</b> input specifies in FPGA clock ticks here we long the Wait on Falling Edge method waits for the next falling edge. A value of 0 causes the method to time out immediately, a negative value causes the method to wait indefinitely, and a particle value causes the method to wait for that umber of clock ticks before timing out. |
|                      | Notes This method is<br>not available on the D<br>O3:0 port.                                                                                                                                                                                                                                                                                                                                                                                        |
|                      | For the first two secor<br>ds after resetting the I<br>PGA VI, the time out w<br>l not start counting ur<br>il the module is identi<br>ed.                                                                                                                                                                                                                                                                                                          |
| Wait on High Level   | Pauses the execution of the I/O Method Node u<br>til the digital signal is high. The <b>Timeout</b> inpu<br>specifies in FPGA clock ticks how long the Wait<br>n High Level method waits for the next high lev<br>l. A value of 0 causes the method to time out in<br>mediately, a negative value causes the method<br>o wait indefinitely, and a positive value causes<br>he method to wait for that number of clock tic<br>before timing out.     |
|                      | Notes This method is<br>not available on the D<br>O3:0 port.                                                                                                                                                                                                                                                                                                                                                                                        |
|                      | For the first two secor<br>ds after resetting the I<br>PGA VI, the time out w                                                                                                                                                                                                                                                                                                                                                                       |

|                     |                                                                                                                                                                                                                                                               | l not start counting unt<br>il the module is identifi<br>ed.                                                                                                                                                                                     |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Low Level   | Pauses the execution of<br>til the digital signal is lo<br>pecifies in FPGA clock ti<br>n Low Level method wa<br>A value of 0 causes the r<br>ediately, a negative valu<br>wait indefinitely, and a<br>method to wait for that<br>fore timing out.            | the I/O Method Node un<br>w. The <b>Timeout</b> input s<br>cks how long the Wait o<br>its for the next low level.<br>nethod to time out imm<br>te causes the method to<br>positive value causes the<br>number of clock ticks be                  |
|                     | E.                                                                                                                                                                                                                                                            | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                             |
|                     |                                                                                                                                                                                                                                                               | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt<br>il the module is identifi<br>ed.                                                                                                  |
| Wait on Rising Edge | Pauses the execution of<br>til the next rising edge of<br><b>Timeout</b> input specifie<br>w long the Wait on Risin<br>the next rising edge. A v<br>hod to time out immedi<br>auses the method to wa<br>itive value causes the m<br>mber of clock ticks befor | the I/O Method Node un<br>f the digital signal. The<br>s in FPGA clock ticks ho<br>g Edge method waits for<br>alue of 0 causes the met<br>ately, a negative value c<br>it indefinitely, and a pos<br>ethod to wait for that nu<br>re timing out. |
|                     | <b>e</b>                                                                                                                                                                                                                                                      | <b>Notes</b> This method is<br>not available on the DI<br>O3:0 port.                                                                                                                                                                             |
|                     |                                                                                                                                                                                                                                                               | For the first two secon<br>ds after resetting the F<br>PGA VI, the time out wil<br>l not start counting unt                                                                                                                                      |

il the module is identifi ed.

### Module Method

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. |

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for AI and AO channels of this device.

| Property   | Description                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight | Returns the LSB weight in nV/LSB for the channe<br>I. Use this value to <u>convert and calibrate</u> NI 9381<br>data if you set the <b>Calibration Mode</b> to <b>Raw</b> i<br>n the <u>C Series Module Properties</u> dialog box.          |
| Offset     | Returns the calibration offset in nV for the chan<br>nel. Use this value to convert and calibrate NI 93<br>81 data if you set the <b>Calibration Mode</b> to <b>Ra</b><br><b>w</b> in the <b>C Series Module Properties</b> dialog b<br>ox. |

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

This device supports the Number of Synchronizing Registers for Output Data synchronizing register option when used in SCTL output. This option supports the same functionality as the **Number of Synchronizing Registers for Output Data** option described in the <u>Advanced Code Generation FPGA I/O Properties Page</u> (FPGA Module) topic, with the exception that you can use this option only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the device is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the digital is performing digital I/O within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

Avoiding Timing Uncertainty with the NI 9381 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into AI node, AO Node, DO Node, and Set Output Data method calls. Additionally, failing to follow

these guidelines may result in lost data points for DO Node calls or Set Output Data method calls when either of them are made from inside a single-cycle Timed Loop.

- Use a single I/O Node to access AI and AO operations to ensure proper sequencing.
- Do not run the Set Output Enable method when an AI, AO, or DO subsystems is active.
- Do not perform the following operations concurrently:
  - AI Node call
  - AO Node call
  - Set Output Enable method call

Automatic line direction change when a DO call is made under the following conditions:

• The call is made from outside of a single-cycle Timed Loop.

Allow programmatic DIO line The direction

checkbox is checked in the <u>C Series</u> <u>Module Properties</u> dialog box.

• The DIO channel is configured as an input at the time when the DO node is called.

Refer to the NI 9381 Advanced IO VI in the labview\examples\CompactRIO\ Module Specific\NI 9381\NI 9381 Advanced IO\NI 9381 Advanc ed IO.lvproj for an example of the recommended way to use the AI, AO, and DIO subsystems.

C Series Module Properties Dialog Box for the NI 9381 (FPGA Interface)

Right-click an <u>NI 9381</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

Calibration Mode—Sets the calibration mode for the C Series module.
Select Calibrated if you want the FPGA I/O Node to return calibrated, fixed-point data from the module in units of volts. The fixed-point data is unsigned, with a word length of 18 bits and an integer word length of 3 bits for the analog input channels and a word length of 16 bits and an integer word length of 3 bits for the analog output channels. Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data from the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is Calibrated.

• **Channels**—Specifies the channel(s) for which you want to select the direction.

• Selected Channel(s) Settings—Specifies the direction for each channel.

• Hot Swap Behavior (Analog Output)—Specifies the state of the analog output channels when the C Series module is removed and reinserted with the FPGA VI loaded and running. The power-on output state is the state that a C Series output module is in when power is applied to the module. The default is Last output value.

• Allow Programmatic DIO Line Direction Change—Place a checkmark in this checkbox if you want to enable programmable DIO line changes on the module.

 $\triangle$ 

**Caution** Performing a DIO line direction change will affect the timing of any concurrent AI, AO, and DO operations. Refer to the <u>Avoiding Timing Uncertainty</u> topic for more information. Converting Voltage Values to Binary Values for the NI 9381 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the <u>C Series Module Properties</u> dialog box for the <u>NI 9381</u> if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in units of volts when writing to the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node accepts only binary values when writing to the module. You must convert output voltage values to binary values before you write them to the module. You must convert these values in the host VI.

#### Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

#### Binary Value = (Voltage Value - Offset) ÷ LSB Weight

where

**Binary Value** is the value you write to the FPGA I/O Node

**Current Value** is the voltage in V that you want the channel to output

**Offset** is the value returned by the Offset property

**LSB Weight** is the value returned by the LSB Weight property

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following values for **Offset** and **LSB Weight**:

**Offset** = -5249

LSB Weight =  $5.105 \text{ V} \div 2^{\text{DAC Resolution}}$ 

where

**DAC Resolution** is the DAC resolution value in the **NI 9381 Operating Instructions and Specifications**.

## NI 9381 (Scan Interface)

CompactRIO 0 V to 5 V, 12-bit, Multifunction Input/Output Module

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the AI channels return floating-point data in volts. The I/O variables for the AO channels write floating-point data in volts. The I/O variables for the DIO channels read and write boolean values.

#### **Module Channels**

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| Alx     | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.            |
| AOx     | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9381, <b>x</b> is 0 to 7.           |
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9381, <b>x</b> is 0 to 3 |

The NI 9381 has the following channels.

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9381. Right-click the NI 9381 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

• **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Direction**—Specifies the initial line direction of the selected channel(s) as input or output.

**Note** If you are using <u>direct access</u> to read from or write to AI or AO channels of the NI 9381, the conversion time is somewhat longer than 50  $\mu$ s.

NI 9401

E

CompactRIO 8-Channel, TTL Digital Input/Output Module

#### Software Reference (?)

FPGA Interface | 3 Scan Interface

## NI 9401 Pinout



## **Related Topics**

FPGA Interface Configuring the Initial Line Direction for the NI 9401

### NI 9401 (FPGA Interface)

CompactRIO 8-Channel, TTL Digital Input/Output Module

Find examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device. When you write to an NI 9401 channel, the FPGA I/O Node does not automatically enable the channel for output.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9401 has DIO chan<br>nels 0 to 7. |
| DIO3:0   | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |
| DIO7:4   | Digital port consisting of channels 4 through 7.<br>Channel 7 is returned in the MSB, and channel 4<br>is returned in the LSB.    |
| DIO7:0   | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

## Arbitration

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>. Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

## I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                                        |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.                                                                                                                                                                                                                                                                               |

|                     | A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                                                                                                                                                                                                                                              |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

#### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method             | Description                                                                                                                                                             |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status       | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|                    | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |
| Set Line Direction | <u>Sets the direction</u> of one port to input or output.                                                                                                               |

# I/O Properties

This device does not support any I/O properties.

## **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

## Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O</u> <u>Node Properties</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the module is performing digital I/O within a single-cycle Timed Loop, do not perform property reads, use the Set Line Direction method, or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on. C Series Module Properties Dialog Box for the NI 9401 (FPGA Interface)

Right-click an <u>NI 9401</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Initial Line Direction—Sets the <u>initial line direction</u> for each digital port to digital input or digital output. The default is digital input.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

Configuring the Initial Line Direction for the NI 9401 (FPGA Interface)

Each digital port on the <u>NI 9401</u> is initially configured as a digital input. You can configure the initial line direction for each port on the NI 9401 at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the line direction for each port at run time using the <u>FPGA I/O Method Node</u>. The execution of an I/O Method Node that is configured with a Set Line Direction method overwrites the value you configured in the **C Series Module Properties** dialog box.

Configuring Line Direction Using the C Series Module Properties Dialog Box

Complete the following steps to configure the line direction of each digital port using the **C Series Module Properties** dialog box.

1. <u>Configure</u> the CompactRIO system, and add an NI 9401.

- 2. Right-click the NI 9401 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the direction for each port from the **Initial Line Direction** pull-down menus.
- 4. Click the **OK** button.
- 5. Select File»Save All in the Project Explorer window.

Configuring Line Direction Using the FPGA I/O Method Node

Complete the following steps to configure the line direction of each digital port using the FPGA I/O Method Node.

- 1. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for the NI 9401.
- 2. Click the **Method** section and select the **Set Line Direction** method from the shortcut menu.
- 3. Right-click each digital port input and select **Create**»**Control** from the shortcut menu.
- 4. On the front panel of the VI, select the direction for each port from the digital port pull-down menus.

# NI 9401 (Scan Interface)

CompactRIO 8-Channel, TTL Digital Input/Output Module

🔊 Open digital input example 🛛 🛛 🐼 Open digital output example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

## Module Channels

The NI 9401 has the following channels.

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9401, <b>x</b> is 0 to 7 |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9401. Right-click the NI 9401 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- Initial Line Direction—Specifies the initial line direction of each fourchannel port as input or output.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input, <u>counter-driven output</u>, <u>pulse-width modulation</u> output, or <u>quadrature</u> input.

NI 9402

CompactRIO 4-Channel, LVTTL Digital Input/Output Module

Software Reference (?)

FPGA Interface | Scan Interface

### NI 9402 Pinout



# **Related Topics**

FPGA Interface Configuring the Line Direction for the NI 9402

# NI 9402 (FPGA Interface)

CompactRIO 4-Channel, LVTTL Digital Input/Output Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

# Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

Terminal

Description
| DIOx   | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9402 has DIO chan<br>nels 0 to 3. |
|--------|-----------------------------------------------------------------------------------------------------------------------------------|
| DIO3:0 | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in the MSB, and channel 0<br>is returned in the LSB.    |

### Arbitration

You can configure the arbitration settings for digital output channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>. Digital input channels of this device support only the **Never Arbitrate** option for arbitration. You cannot configure arbitration settings for the digital input channels of this device.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data      | Refer to the <u>FPGA I/O Method Node (FPGA Modu</u><br><u>le)</u> topic for a description of this method.                                                                                                                                                                                                                                                                                                                                                                                         |
| Set Output Enable    | <u>Sets the line direction</u> of the digital channel or t<br>he DIO3:0 digital port. Refer to the <u>FPGA I/O Met</u><br><u>hod Node (FPGA Module)</u> topic for more informa<br>tion on this method.                                                                                                                                                                                                                                                                                            |
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un<br>til the next falling or rising edge of the digital sig<br>nal. The <b>Timeout</b> input specifies in FPGA clock<br>ticks how long the Wait on Any Edge method wa<br>its for the next falling or rising edge. A value of 0<br>causes the method to time out immediately, a n<br>egative value causes the method to wait indefini<br>tely, and a positive value causes the method to<br>wait for that number of clock ticks before timing<br>out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un<br>til the next falling edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho                                                                                                                                                                                                                                                                                                                                   |

|                     | w long the Wait on Falling Edge method waits fo<br>r the next falling edge. A value of 0 causes the m<br>ethod to time out immediately, a negative value<br>causes the method to wait indefinitely, and a po<br>sitive value causes the method to wait for that n<br>umber of clock ticks before timing out.                                                                                                                                                                 |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on High Level  | Pauses the execution of the I/O Method Node un<br>til the digital signal is high. The <b>Timeout</b> input<br>specifies in FPGA clock ticks how long the Wait o<br>n High Level method waits for the next high leve<br>l. A value of 0 causes the method to time out im<br>mediately, a negative value causes the method t<br>o wait indefinitely, and a positive value causes t<br>he method to wait for that number of clock ticks<br>before timing out.                   |
| Wait on Low Level   | Pauses the execution of the I/O Method Node un<br>til the digital signal is low. The <b>Timeout</b> input s<br>pecifies in FPGA clock ticks how long the Wait o<br>n Low Level method waits for the next low level.<br>A value of 0 causes the method to time out imm<br>ediately, a negative value causes the method to<br>wait indefinitely, and a positive value causes the<br>method to wait for that number of clock ticks be<br>fore timing out.                       |
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un<br>til the next rising edge of the digital signal. The<br><b>Timeout</b> input specifies in FPGA clock ticks ho<br>w long the Wait on Rising Edge method waits for<br>the next rising edge. A value of 0 causes the met<br>hod to time out immediately, a negative value c<br>auses the method to wait indefinitely, and a pos<br>itive value causes the method to wait for that nu<br>mber of clock ticks before timing out. |

### Module Method

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

Method

Description



#### I/O Properties

This device does not support any I/O properties.

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

The NI 9402 supports the following output synchronizing register options:

Number of Synchronizing Registers for Output Data when used in SCTL

# Number of Synchronizing Registers for Output Enable when used in SCTL

These two options support the same functionality as the **Number of Synchronizing Registers for Output Data** and **Number of Synchronizing Registers for Output Enable** options described in the <u>Advanced Code Generation</u> <u>FPGA I/O Properties Page (FPGA Module)</u> topic, with the exception that you can use these options only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

While the module is performing digital I/O within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing any of these actions causes the module to be unable to perform digital I/O and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9402 (FPGA Interface)

Right-click an <u>NI 9402</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to select the line direction.

• Selected Channel(s) Settings—Specifies the line direction for each channel.

• **Direction**—<u>Sets the line direction</u> for the selected channel(s) to digital input or digital output. The default is digital input.

Configuring the Line Direction for the NI 9402 (FPGA Interface)

Each digital channel on the <u>NI 9402</u> is initially configured as a digital input. You can configure the initial line direction for each channel on the NI 9402 at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the line direction for each channel at run time using the <u>FPGA I/O Method Node</u>. The execution of an I/O Method Node that is configured with a Set Output Enable method overwrites the values you configured in the **C Series Module Properties** dialog box. In addition, the execution of an FPGA I/O Node configured for output automatically configures the line for output and overwrites the values you configured in the **C Series Module Set Output Enable** method.

Configuring Line Direction Using the C Series Module Properties Dialog Box

Complete the following steps to set the line direction of channels using the **C Series Module Properties** dialog box.

1. <u>Configure</u> the CompactRIO system, and add an NI 9402.

- 2. Right-click the NI 9402 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the line direction from the Channels table. You can select more than one channel by holding the <C trl> or <Shift> key when selecting channels.
- 4. Select the direction for the channel(s) from the **Direction** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring Line Direction of One Channel Using the FPGA I/O Method Node

Complete the following steps to set the line direction of a channel using the FPGA I/O Method Node.

- 1. <u>Create FPGA I/O items</u> for the channel of the NI 9402 for which you want to configure the line direction.
- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for this channel.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the **Enable** input and select **Create**»**Control** from the shortcut menu.
- 5. On the front panel of the VI, click the **Enable** Boolean control to set it to TRUE if you want to set the line direction of the channel to digital output.

Configuring Line Direction of Multiple Channels Using the FPGA I/O Method Node

Complete the following steps to set the line direction of multiple channels using the FPGA I/O Method Node.

1. <u>Create FPGA I/O items</u> for the DIO3:0 digital port of the NI 9402.

- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for the DIO3:0 digital port.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the **Enable** input and select **Create»Control** from the shortcut menu. The **Enable** control appears as an unsigned 8-bit integer. Each bit in the integer represents the line direction of one channel of the NI 9402.
- 5. On the front panel of the VI, use the **Enable** control to enter the line direction for each channel in the port. Change a bit to 1 to set the line direction of the corresponding channel to digital output. Leave a bit as 0 to set the line direction of the corresponding channel to digital input. Refer to the table below for examples of what to enter in the **Enable** control.

| Channel Line Direction<br>Configuration | Enable Control<br>(Floating Point) | Enable Control<br>(Binary) | Enable Control<br>(Hex) |
|-----------------------------------------|------------------------------------|----------------------------|-------------------------|
| Change all channels t<br>o input        | 0                                  | 0000                       | 0x00                    |
| Change all channels t<br>o output       | 15                                 | 1111                       | 0x0F                    |
| Change channel 0 to output              | 1                                  | 0001                       | 0x01                    |

# NI 9402 (Scan Interface)

CompactRIO 4-Channel, LVTTL Digital Input/Output Module

🔊 Open digital input example 🛛 🛛 🐼 Open digital output example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

# **Module Channels**

The NI 9402 has the following channels.

| Channel | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9402, <b>x</b> is 0 to 3 |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9402. Right-click the NI 9402 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to configure settings.

• **Direction**—Specifies the initial line direction of the selected channel(s) as input or output.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter</u> input, <u>counter-driven output</u>, <u>pulse-width modulation</u> output, or <u>quadrature</u> input.

#### NI 9403

CompactRIO 32-Channel, TTL Digital Input/Output Module

#### Software Reference (?)

FPGA Interface 6 Scan Interface

#### NI 9403 Pinout



# **Related Topics**

FPGA Interface Configuring the Line Direction for the NI 9403

# NI 9403 (FPGA Interface)

CompactRIO 32-Channel, TTL Digital Input/Output Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u> and <u>writing</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                          |
|----------|--------------------------------------------------------------------------------------------------------------------------------------|
| DIOx     | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. The NI 9403 has DIO chan<br>nels 0 to 31.   |
| DIO7:0   | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB.       |
| DIO15:8  | Digital port consisting of channels 8 through 15.<br>Channel 15 is returned in the MSB, and channel<br>8 is returned in the LSB.     |
| DIO23:16 | Digital port consisting of channels 16 through 23<br>. Channel 23 is returned in the MSB, and channe<br>l 16 is returned in the LSB. |
| DIO31:24 | Digital port consisting of channels 24 through 31<br>. Channel 31 is returned in the MSB, and channe<br>l 24 is returned in the LSB. |
| DIO31:0  | Digital port consisting of channels 0 through 31.<br>Channel 31 is returned in the MSB, and channel<br>0 is returned in the LSB.     |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> and <u>Never</u> <u>Arbitrate</u> options for arbitration. The default arbitration setting is **Arbitrate if Multiple Requestors Only**.

If you are sure that the design of the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels, you can place a checkmark in the **Disable Arbitration** checkbox on the <u>C Series Module Properties</u> dialog box to disable arbitration and reduce the amount of FPGA logic used by VIs. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

Method

Description

| Read and Set Output Data | First returns the data read from the digital line o<br>r port, then writes data to the line or port witho<br>ut enabling it. You can use the Read and Set Out<br>put Data method to optimize performance whe<br>n performing successive reads and writes on a D<br>IO resource. For the NI 9403, this method is faste<br>r than using a read FPGA I/O Node and a Set Out<br>put Data method. The data type of the output a<br>nd input depends on the I/O item. If the I/O item<br>is a digital line, <b>Data to Set</b> requires a Boolean<br>data type. If the I/O item is a digital port, <b>Data t</b><br><b>o Set</b> requires a numeric data type. |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data          | Refer to the <u>FPGA I/O Method Node (FPGA Modu</u><br><u>le)</u> topic for a description of this method.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Set Output Enable        | Sets the line direction of the digital channel or p<br>ort. Refer to the FPGA I/O Method Node (FPGA M<br>odule) topic for more information on this metho<br>d.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### **Module Methods**

This device does not support any module methods.

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

#### Hardware Documentation

Refer to the NI 9403 hardware documentation on ni.com/manuals for information about module specifications and how to use the module. Refer to the <u>CompactRIO</u> <u>Related Documentation</u> topic for additional CompactRIO documentation resources.

C Series Module Properties Dialog Box for the NI 9403 (FPGA Interface)

Right-click an <u>NI 9403</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to select the line direction.
- Selected Channel(s) Settings—Specifies the line direction for each channel.
  - **Direction**—<u>Sets the line direction</u> for the selected channel(s) to digital input or digital output. The default is digital input.
- **Disable Arbitration**—Place a checkmark in this checkbox if you want to change the arbitration setting to <u>Never Arbitrate</u> and reduce the amount of FPGA logic used by VIs. Check this box only if you are sure that the design of

the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked to keep the default <u>Arbitrate if Multiple Requestors Only</u> arbitration setting.

#### Configuring the Line Direction for the NI 9403 (FPGA Interface)

Each digital channel on the <u>NI 9403</u> is initially configured as a digital input. You can configure the initial line direction for each channel on the NI 9403 at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change the line direction for each channel at run time using the <u>FPGA I/O Method Node</u>. The execution of an I/O Method Node that is configured with a Set Output Enable method overwrites the values you configured in the **C Series Module Properties** dialog box. In addition, the execution of an FPGA I/O Node configured for output automatically configures the line for output and overwrites the values you configured in the **C Series Module Properties** dialog box or using the **Set Output Enable** method.

#### Configuring Line Direction Using the C Series Module Properties Dialog Box

Complete the following steps to set the line direction of channels using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an NI 9403.
- 2. Right-click the NI 9403 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the line direction from the Channels table. You can select more than one channel by holding the <C trl> or <Shift> key when selecting channels.
- 4. Select the direction for the channel(s) from the **Direction** pull-down menu.
- 5. Click the **OK** button.
- 6. Select File»Save All in the Project Explorer window.

Configuring Line Direction of One Channel Using the FPGA I/O Method Node

Complete the following steps to set the line direction of a channel using the FPGA I/O Method Node.

- 1. <u>Create FPGA I/O items</u> for the channel of the NI 9403 for which you want to configure the line direction.
- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for this channel.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the **Enable** input and select **Create**»**Control** from the shortcut menu.
- 5. On the front panel of the VI, click the **Enable** Boolean control to set it to TRUE if you want to set the line direction of the channel to digital output.

Configuring Line Direction of Multiple Channels Using the FPGA I/O Method Node

Complete the following steps to set the line direction of multiple channels using the FPGA I/O Method Node.

- 1. <u>Create FPGA I/O items</u> for the digital port of the NI 9403 that contains the channels you want to configure.
- 2. Place an FPGA I/O Method Node on the block diagram and <u>configure</u> it for this digital port.
- 3. Click the **Method** section and select the **Set Output Enable** method from the shortcut menu.
- 4. Right-click the Enable input and select Create»Control from the shortcut menu. If you configured the FPGA I/O Method Node for the DIO7:0, DIO15:8, DIO23:16, or DIO31:24 digital port, the Enable control appears as an unsigned 8-bit integer. If you configured the FPGA I/O Method Node for the DIO31:0 digital port, the Enable control appears as an unsigned 32-bit integer. Each bit in the integer represents the line direction of one channel of the NI 9403.

5. On the front panel of the VI, use the **Enable** control to enter the line direction for each channel in the port. Change a bit to 1 to set the line direction of the corresponding channel to digital output. Leave a bit as 0 to set the line direction of the corresponding channel to digital input. Refer to the table below for examples of what to enter in the **Enable** control if you configured the FPGA I/O Method Node for the DIO7:0 digital port.

| Channel Line Direction<br>Configuration | Enable Control (Hex) | Enable Control (Binary) |
|-----------------------------------------|----------------------|-------------------------|
| Change all channels to input            | 0x00                 | 0b0000000               |
| Change all channels to outpu<br>t       | 0xFF                 | 0b1111111               |
| Change channel 0 to output              | 0x01                 | 0b0000001               |
| Change channels 0 through 5 to output   | 0x3F                 | 0b00111111              |
| Change channels 3 and 7 to o utput      | 0x88                 | 0b10001000              |

Refer to the table below for examples of what to enter in the **Enable** control if you configured the FPGA I/O Method Node for the DIO31:0 digital port.

| Channel Line Direction<br>Configuration | Enable Control (Hex) | Enable Control (Binary)                |
|-----------------------------------------|----------------------|----------------------------------------|
| Change all channels to input            | 0x0000000            | 0b000000000000000000000000000000000000 |
| Change all channels to outpu<br>t       | 0xFFFFFFFF           | 0b111111111111111111111111111111111111 |
| Change channel 0 to output              | 0x0000001            | 0b000000000000000000000000000000000000 |
| Change channels 0 through 5 to output   | 0x000003F            | 0b000000000000000000000000000000000000 |
| Change channels 3 and 7 to o<br>utput   | 0x0000088            | 0b000000000000000000000000000000000000 |

## NI 9403 (Scan Interface)

CompactRIO 32-Channel, TTL Digital Input/Output Module

🔊 Open digital input example 🛛 🔊 Open digital output example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables for the channels read and write Boolean values.

### **Module Channels**

The NI 9403 has the following channels.

| Channel | Description                                                                                                                        |
|---------|------------------------------------------------------------------------------------------------------------------------------------|
| DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the n<br>umber of the channel. For the NI 9403, <b>x</b> is 0 to 3<br>1. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9403. Right-click the NI 9403 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to configure settings.

• Initial Line Direction—Specifies the initial line direction of the selected channel(s) as input or output.

NI 9470

CompactRIO 8-Channel Digital Output Module with Current Readback

Software Reference (?)

FPGA Interface

#### NI 9470 Pinout



# NI 9470 (FPGA Interface)

CompactRIO 8-Channel Digital Output Module with Current Readback

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

# Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| СН <b>х</b>    | Output setpoint for channel <b>x</b> , where <b>x</b> is the nu<br>mber of the channel. The NI 9470 has channels<br>0 to 7. The output setpoint depends on the Outp<br>ut Mode setting for the channel. Open Loop Mod<br>e supports output setpoints from 0% to 100%. C<br>losed Loop Mode support output setpoints from<br>0 A to 3.999 A.                                                                                                                                                                                                                                         |  |
| Start          | Channel that controls when the NI 9470 starts o<br>utputting PWM and acquiring readback data. If<br>TRUE is written to the <b>Start</b> channel, the NI 947<br>0 starts outputting PWM and acquiring readback<br>data. The DO <b>x</b> that have been enabled will be re<br>set to 0 V every time this I/O node is executed. W<br>hen the NI 9470 is outputting PWM and acquirin<br>g readback data, you must write TRUE to the <b>St</b><br><b>Op</b> channel before you can access properties. If<br>FALSE is written to the <b>Start</b> channel, no operat<br>ion is performed. |  |
| Stop           | Channel that controls when the NI 9470 stops o<br>utputting PWM and acquiring readback data. If<br>TRUE is written to the <b>Stop</b> channel, the NI 947<br>0 stops outputting PWM and acquiring readback<br>data. When the NI 9470 is outputting PWM and a<br>cquiring readback data, you must write TRUE to<br>the <b>Stop</b> channel before you can access propert<br>ies. If FALSE is written to the <b>Stop</b> channel, no o<br>peration is performed.                                                                                                                      |  |
| AverageCurrent | Average current readback. Readback is function<br>al after issuing a <b>Start</b> and depends on channel<br>enable. If channel is not enabled, the current re<br>ading will be 0. Represented as -4 A to 3.999 A.                                                                                                                                                                                                                                                                                                                                                                   |  |
| DutyCycle      | Duty cycle readback. Readback is functional aft<br>er issuing a <b>Start</b> and is independent of channe<br>l enable. Represented as 0% to 100%.                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |

| Voltage | Channel voltage readback. Readback is function           |
|---------|----------------------------------------------------------|
|         | al after issuing a <b>Start</b> and is independent of th |
|         | e channel enable. Voltage is represented as 0 V t        |
|         | o 40 V. Voltage readback nodes run at a constant         |
|         | data rate independent of the channel PWM freq            |
|         | uencies and should not be placed in the same lo          |
|         | op as the other NI 9470 I/O nodes.                       |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Channel Enable | <ul> <li>Enables or disables each channel. All channels a re disabled and DOx outputs are tristate when t he module powers on. You can execute the Set Channel Enable method before or after Start. To turn on the channels before acquisition, exec ute the method before Start. If the method is ex ecuted before Start, the channel will be enable d or disabled immediately, and the DOx output will output 0 V. If the method is executed after S tart, the channel will be enabled on the next write sequence.</li> <li>To Enable a channel, wire a Boolean co nstant set to TRUE.</li> <li>To Disable a channel, wire a Boolean c onstant set to FALSE.</li> </ul> |

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Output Status | Returns Booleans for each channel that indicate<br>s whether the module reported an over tempera<br>ture fault or any channel reported a power supp<br>ly fault or overcurrent fault during the last time t<br>he FPGA I/O Node communicated with the mod<br>ule. When the FPGA I/O Node communicates wit<br>h the module, the FPGA VI samples the states of<br>the module and channels and overwrites the pr<br>evious output status with the latest state of the<br>module and channels.                                                                                                                                                                                                                                                                                                                                                                              |
|                     | <ul> <li>Module Over Temperature—Returns<br/>a Boolean value. A value of TRUE indicate<br/>s that the module exceeded its temperatu<br/>re rating. When a Module Over Temperatu<br/>re occurs, all enabled channels will be dis<br/>abled, and their respective DOx outputs w<br/>ill drive to 0 V. Use the Set Channel Ena<br/>ble I/O Method after the over temperatur<br/>e fault condition is removed to re-enable t<br/>he channel without stopping the task, and<br/>the latched status will clear.</li> </ul>                                                                                                                                                                                                                                                                                                                                                    |
|                     | <ul> <li>Power Supply Fault—Returns an arra<br/>y of Boolean values. A value of TRUE in an<br/>y index indicates that a power fault has be<br/>en detected after the last status read on th<br/>e channel with the same number as the in<br/>dex. A value of FALSE indicates that no po<br/>wer fault was detected on that channel aft<br/>er the last status read. When a Power Sup<br/>ply Fault occurs, the channel with the sam<br/>e number as the index will be disabled, an<br/>d DOx will drive to 0 V. Use the Set Chan<br/>nel Enable I/O Method after the Power S<br/>upply Fault condition is removed to re-en<br/>able the channel without stopping the tas<br/>k, and the latched status will clear.</li> <li>Channel Overcurrent—Returns an ar<br/>ray of Boolean values. A value of TRUE in a<br/>ny index indicates that the channel with t</li> </ul> |

|                         | he same number as the index exceeded th<br>e current limit after the last status read. A<br>value of FALSE indicates that the channel<br>did not exceed the current limit after the l<br>ast status read. When a Channel Overcurr<br>ent fault occurs, the channel with the sam<br>e number as the index will be disabled, an<br>d DOx will drive to 0 V. Use the <b>Set Chan</b><br><b>nel Enable</b> I/O Method after the Channel<br>Overcurrent fault condition is removed to<br>re-enable the channel without stopping t<br>he task, and the latched status will clear. |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read Module Temperature | Reads the average measured temperature on th e module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                         | <ul> <li>Module Temperature—Returns the<br/>module temperature. Temperature readb<br/>ack is functional after issuing Start. Repre<br/>sented as -40 °C to 125 °C</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                |

# I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device. You must configure all channel properties before starting acquisition. Changing the properties during acquisition will not work.

| Property    | Description                                                                                                                     |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|
| Output Mode | Sets the channel to operate in either open loop<br>mode (duty cycle setpoint) or closed loop mod<br>(average current setpoint). |  |
| PWM Divisor | Configures the channel PWM frequency as a c<br>sor of the module's overall data rate. Divisor<br>ues range from 1 to 511.       |  |
|             | Note A divisor value o<br>f 1 is only supported w<br>hen the data rate is set<br>to 2,000 S/s or 2,048 S/<br>s.                 |  |

| Proportional Gain | Configures the proportional gain ( <b>duty cycle %</b> ,<br>Amps) coefficient of the closed loop PID control                                                                                                                                                                                                     |                                                                                                                               |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
|                   | E.                                                                                                                                                                                                                                                                                                               | <b>Note</b> This property on<br>ly applies to channels c<br>onfigured to Closed Lo<br>op Mode (Average Curr<br>ent Setpoint). |
| Integral Gain     | Configures the integral gain ( <b>duty cycle %</b> /Amp<br>s) coefficient of the closed loop PID control.                                                                                                                                                                                                        |                                                                                                                               |
|                   | E.                                                                                                                                                                                                                                                                                                               | <b>Note</b> This property on<br>ly applies to channels c<br>onfigured to Closed Lo<br>op Mode (Average Curr<br>ent Setpoint). |
| Derivative gain   | Configures the derivative gain ( <b>duty cycle %</b> /A mps) coefficient of the closed loop PID control.                                                                                                                                                                                                         |                                                                                                                               |
|                   | E.                                                                                                                                                                                                                                                                                                               | <b>Note</b> This property on<br>ly applies to channels c<br>onfigured to Closed Lo<br>op Mode (Average Curr<br>ent Setpoint). |
| Dither Amplitude  | Configures the channel dither amplitude. The<br>alue depends on the output mode to which the<br>channel is set. In open loop mode, the peak ar<br>plitude is duty cycle (percentage) with a range<br>f 0% to 100%. In closed loop mode, the peak a<br>plitude (amps) is current with a range of 0 A to<br>999 A. |                                                                                                                               |
|                   | <b>B</b>                                                                                                                                                                                                                                                                                                         | <b>Note</b> In closed loop m<br>ode, dither performanc<br>e depends on the PID r<br>esponse.                                  |
| Dither Divisor    | Configures the channel<br>visor of the channel's P\<br>lues range from 4 to 4,09                                                                                                                                                                                                                                 | dither frequency as a di<br>NM frequency. Divisor va<br>95.                                                                   |



**Note** In closed loop m ode, dither performanc e depends on the PID r esponse.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                                                                                                                                                                                     |                  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| Data Rate     | Sets the overall data rate. All I/O will be synchro<br>nized to this rate. You must configure the data ra<br>te before starting acquisition. There are four dat<br>a rates based on the master timebase source: |                  |
|               | 12.8 MHz OCLK                                                                                                                                                                                                   | 13.1072 MHz OCLK |
|               | 3.200 kS/s                                                                                                                                                                                                      | 3.277 kS/s       |
|               | 3.125 kS/s                                                                                                                                                                                                      | 3.200 kS/s       |
|               | 2.560 kS/s                                                                                                                                                                                                      | 2.621 kS/s       |
|               | 2.000 kS/s                                                                                                                                                                                                      | 2.048 kS/s       |
| Module ID     | Returns the module ID, 0x7A59.                                                                                                                                                                                  |                  |
| Serial Number | Returns the unique serial number of the module .                                                                                                                                                                |                  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                                                                                                                                                                               |                  |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

# Example

Refer to LabVIEW\examples\CompactRIO\Module Specific\NI 9470\ NI 9470 Getting Started.lvproj for an example on getting started with this module. C Series Module Properties Dialog Box for the NI 9470 (FPGA Interface)

Right-click an <u>NI 9470</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Master Timebase Source—Specifies the <u>master timebase source</u> that the module uses.
- **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.
- **Data Rate**—Specifies the rate at which the module acquires data.
- **Channel Configuration**—Launches the channel configuration dialog box to configure the channel settings.

Configuring Channels on the NI 9470 (FPGA Interface)

Complete the following steps to configure the channels of the NI 9470.

- 1. Right-click an <u>NI 9470</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.
- 2. Click the **Channel Configuration** button to open the Channel Configuration dialog box.
- 3. Select a channel to configure.
- 4. Configure the following settings.

• Output Mode—Specifies the output mode for the selected channel.

• **Duty Cycle**—Sets the channel to open loop mode without any internal control mechanism. You will have to implement your own control loop in your application.

• Average Current—Sets the channel to closed loop mode using an internal PID control loop. This PID control executes based on the PID coefficients.

• **PWM Divisor**—Specifies the PWM divisor value for the selected channel. Each channel runs based on the PWM frequency, which is derived by the formula **Data Rate** ÷ **PWM Divisor**. Supported values range 2 to 511. You can only set the PWM Divisor to a value of 1 if the data rate is set to 2,000 S/s or 2,048 S/s.

PID Response—Specifies the PID response for the selected channel. This option is only available if the channel's Output Mode is set to Average Current.

- **Slow**—The proportional, integral, and derivative gain coefficients are pre-set to provide a slow PID response speed. The output current will arrive at the intended setpoint at a slower rate.
- **Medium**—The proportional, integral, and derivative gain coefficients are pre-set to provide a medium PID response speed. The output current will arrive at the intended setpoint at a moderate rate.
- **Fast**—The proportional, integral, and derivative gain coefficients are pre-set to provide a fast PID response speed. The output current will arrive at the intended setpoint at a faster rate.

Custom—Customize your own PID response by entering your own
 Proportional Gain, Integral Gain, and Derivative Gain.

- **Proportional Gain**—Specifies the proportional gain coefficient for the selected channel. Specified in units of **(duty cycle %)** ÷ Amps.
- Integral Gain—Specifies the integral gain coefficient for the selected channel. Specified in units of (duty cycle %) ÷ Amps.

• **Derivative Gain**—Specifies the derivative gain coefficient for the selected channel. Specified in units of (**duty cycle %**) ÷ Amps.

• **Dither Amplitude**—Specifies the dither amplitude for the selected channel. Represents the dither peak amplitude for the channel. You can disable dither by setting this parameter to 0. The range depends on which **Output Mode** the channel is set.

| Output Mode     | Range          |
|-----------------|----------------|
| Duty Cycle      | 0% to 100%     |
| Average Current | 0 A to 3.999 A |

• **Dither Divisor**—Specifies the Dither Divisor for the selected channel, which controls the dither frequency. Dither frequency is derived using the formula **PWM Frequency** ÷ **Dither Divisor**.

- 5. Click **OK** to close the Channel Configuration dialog box.
- 6. Click **OK** to close the Module Properties Dialog Box.

Synchronizing the NI 9470 with Other Modules (FPGA Interface)

You can synchronize the NI 9470 with other modules that are connected to the same FPGA device if your application meets the following requirements:

- The modules must use the same master timebase source
- The modules must start acquisition mode at the same time
- Each channel of the NI 9470 must be in its own <u>FPGA I/O Node</u> residing in its own loop.

You must <u>create FPGA I/O items</u> for the module before you can configure the items using the FPGA I/O Node. Develop the FPGA VI to meet the guidelines described in the following table.

For delta-sigma modules, you will need to synchronize multiple sample rates.

| Guideline                      | Details                                      |  |
|--------------------------------|----------------------------------------------|--|
| Share a master timebase source | Configure the modules to share master timeba |  |
|                                | <u>e source</u> .                            |  |

| Start the synchronized acquisition                                                       | <ul> <li>Configure an FPGA I/O Node with Start channels for the module you want to sync hronize.</li> <li>Wire a Boolean constant set to TRUE to each Start channel.</li> <li>Ensure that all Start channels are in th e same FPGA I/O Node. The data will not b e synchronized if they are not.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acquire data from synchronized modules                                                   | <ul> <li>Create separate loops for each channel of the NI 9470 that runs at a different data rate. Channels that are configured to run at the same data rate can either be in the same loop or be in a separate loop.</li> <li>For channels that are configure an FPGA I /O Node in each loop. For channels that ar e configured to run at different data rates, configure an FPGA I /O Node in each loop. For channels that ar e configured to run at the same data rate, you can either configure one FPGA I/O No de for the all the channels or configure an FPGA I/O No de for the all the channels or configure an FPGA I/O Node for each channel. If you pla ce channels that are configured for differe nt data rates in the same loop, LabVIEW re turns an overrun warning, error 65539, fro m the FPGA I/O Node for the AI channels a nd an underflow warning, error 65676, fro m the FPGA I/O Node for the FPGA I/O Nod e returns the first data point. The length o f the delay depends on the data rate and t he PWM Divisor for each NI 9470 channel.</li> <li>Refer to Synchronizing Multiple Module s (FPGA Interface) for how to synchronize other DSA modules that are synchronized with the NI 9470.</li> </ul> |
| <u>Understand the maximum sample rate when sy</u><br><u>nchronizing multiple modules</u> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### Equation for synchronizing multiple sample rates

| 12.8 MHz OCLK | 13.1072 MHz OCLK | Time to First Channel Sample(s)                                                       |
|---------------|------------------|---------------------------------------------------------------------------------------|
| 3.200 kS/s    | 3.277 kS/s       | (14,472,838 + 4,000 * n) * (Mast<br>er Timebase Period ± 1 Master<br>Timebase Period) |
| 3.125 kS/s    | 3.200 kS/s       | (14,472,838 + 4,096 * n) * (Mast<br>er Timebase Period ± 1 Master<br>Timebase Period) |
| 2.560 KS/s    | 2.621 KS/s       | (14,472,838 + 5,000 * n) * (Mast<br>er Timebase Period ± 1 Master<br>Timebase Period) |
| 2.000 KS/s    | 2.048 KS/s       | (14,473,006 + 6,400 * n) * (Mast<br>er Timebase Period ± 1 Master<br>Timebase Period) |

#### Notes:

**Master Timebase Period** = period of the internal or external clock that the module uses (1/12.8 M Hz or 1/13.072 MHz).

**n** = channel PWN divisor. Refer to the <u>PWM Divisor I/O Property</u> for valid values of **n** for each data r ate divisor option.

Only data rates of 3.125 kS/s or 2.000 kS/s with 12.8 MHz OCLK or 3.200 kS/s or 2.048 kS/s with 13. 1072 MHz OCLK are compatible with other DSA modules for <u>synchronizing multiple modules</u>. The formulas above apply to each individual channel of the NI 9470 based on each channel's PW M divisor.

#### **Related Topics**

Synchronizing Multiple Modules (FPGA Interface)

Configuring the Master Timebase Source for a Module

<u>Understanding the Maximum Sample Rate when Synchronizing Multiple Modules</u> (FPGA Interface)

NI 9472

CompactRIO 8-Channel, 24 V, Sourcing Digital Output Module

#### Software Reference (?)

FPGA Interface | Scan Interface

#### NI 9472 Pinout



# NI 9472 (FPGA Interface)

CompactRIO 8-Channel, 24 V, Sourcing Digital Output Module

# FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                               |
|----------|---------------------------------------------------------------------------------------------------------------------------|
| DOx      | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9472 has DO channels 0 t<br>o 7. |

| Channel 7 is returned i<br>is returned in the LSB. | in the MSB, and channel 0 |
|----------------------------------------------------|---------------------------|
|----------------------------------------------------|---------------------------|

### Arbitration

You can configure the arbitration settings for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

# I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                    |                                                                                                                                                                                |
|--------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boo<br>the module is | lean value that indicates whether<br>ready.                                                                                                                                    |
|              |                                | <b>Note</b> During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital output before a loop containing digital output starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. The module might ignore or delay digital output operations if it is not ready.

While the module is performing digital output within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital output and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9472/9474/9475/9481/9482/9485 (FPGA Interface)

Right-click an <u>NI 9472</u>, <u>NI 9474</u>, <u>NI 9475</u>, <u>NI 9481</u>, <u>NI 9482</u>, or <u>NI 9485</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

# NI 9472 (Scan Interface)

CompactRIO 8-Channel, 24 V, Sourcing Digital Output Module

应 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

# **Module Channels**

The NI 9472 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9472, <b>x</b> is 0 to 7. |

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9472. Right-click the NI 9472 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

# **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter-driven</u> output or <u>pulse-width modulation</u> output.

NI 9474

CompactRIO 8-Channel, 24 V, High-Speed, Sourcing Digital Output Module

#### Software Reference (?)

🔁 FPGA Interface | 🕝 Scan Interface

# NI 9474 Pinout





# NI 9474 (FPGA Interface)

CompactRIO 8-Channel, 24 V, High-Speed, Sourcing Digital Output Module

# FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| DOx      | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9474 has DO channels 0 t<br>o 7.      |
| DO7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |

#### Arbitration

You can configure the arbitration settings for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. |

E/

**Note** During the first 2 seconds after you reset the FPGA VI, the error t erminals on this metho d may not correctly rep ort certain types of err ors.

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital output before a loop containing digital output starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. The module might ignore or delay digital output operations if it is not ready.

While the module is performing digital output within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital output and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9472/9474/9475/9481/9482/9485 (FPGA Interface)

Right-click an <u>NI 9472</u>, <u>NI 9474</u>, <u>NI 9475</u>, <u>NI 9481</u>, <u>NI 9482</u>, or <u>NI 9485</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

### NI 9474 (Scan Interface)

CompactRIO 8-Channel, 24 V, High-Speed, Sourcing Digital Output Module

📄 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.
### **Module Channels**

The NI 9474 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9474, <b>x</b> is 0 to 7. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9474. Right-click the NI 9474 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

### **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter-driven</u> output or <u>pulse-width modulation</u> output.

### NI 9475

CompactRIO 8-Channel, 60 V, High-Speed, Sourcing Digital Output Module

#### Software Reference (?)

FPGA Interface | 3 Scan Interface

NI 9475

CompactRIO 8-Channel, 60 V, High-Speed, Sourcing Digital Output Module

## NI 9475 Pinout



# NI 9475 (FPGA Interface)

CompactRIO 8-Channel, 60 V, High-Speed, Sourcing Digital Output Module

# FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                               |
|----------|---------------------------------------------------------------------------------------------------------------------------|
| DOx      | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9475 has DO channels 0 t<br>o 7. |

| DO7:0 | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
|-------|--------------------------------------------------------------------------------------------------------------------------------|

### Arbitration

You can configure the arbitration settings for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

# I/O Methods

This device does not support any I/O methods.

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital output before a loop containing digital output starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. The module might ignore or delay digital output operations if it is not ready.

While the module is performing digital output within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital output and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9472/9474/9475/9481/9482/9485 (FPGA Interface)

Right-click an <u>NI 9472</u>, <u>NI 9474</u>, <u>NI 9475</u>, <u>NI 9481</u>, <u>NI 9482</u>, or <u>NI 9485</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

# NI 9475 (Scan Interface)

CompactRIO 8-Channel, 60 V, High-Speed, Sourcing Digital Output Module

👰 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

# **Module Channels**

The NI 9475 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9475, <b>x</b> is 0 to 7. |

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9475. Right-click the NI 9475 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

### **Specialty Digital Configuration**

You can use the <u>Specialty Digital Configuration</u> page of the **C Series Module Properties** dialog box to configure channels of this module for <u>counter-driven</u> output or <u>pulse-width modulation</u> output.

NI 9476

36 V, 32-Channel (Sourcing Output), 500 µs C Series Digital Module

#### Software Reference (?)

这 FPGA Interface 🛛 📀 Scan Interface

### NI 9476 Pinout

| - <b>POLIS</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DO16 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 102200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | DO17 |
| - <b>19</b> 32101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DO18 |
| 2022                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DO19 |
| - <b>19</b> 539-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DO20 |
| - <b>26</b> 2 <b>1</b> 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DO21 |
| 97250                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | DO22 |
| - 1982 - 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DO23 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DO24 |
| 1000 <b>8</b> 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DO25 |
| - <b>D</b> 2 <b>D</b> | DO26 |
| 012300                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | DO27 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DO28 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DO29 |
| - <b>1</b> 915330-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DO30 |
| -0163 <b>1</b> 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DO31 |
| <b></b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Vsup |
| 2013350                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Vsup |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |



# NI 9476 (FPGA Interface)

36 V, 32-Channel (Sourcing Output), 500  $\mu s$  C Series Digital Module

🔊 Open example

Find related examples

# FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                          |
|----------|--------------------------------------------------------------------------------------------------------------------------------------|
| DOx      | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9476 has DO channels 0 t<br>o 31.           |
| DO7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB.       |
| DO15:8   | Digital port consisting of channels 8 through 15.<br>Channel 15 is returned in the MSB, and channel<br>8 is returned in the LSB.     |
| DO23:16  | Digital port consisting of channels 16 through 23<br>. Channel 23 is returned in the MSB, and channe<br>l 16 is returned in the LSB. |
| DO31:24  | Digital port consisting of channels 24 through 31<br>. Channel 31 is returned in the MSB, and channe<br>l 24 is returned in the LSB. |
| DO31:0   | Digital port consisting of channels 0 through 31.<br>Channel 31 is returned in the MSB, and channel<br>0 is returned in the LSB.     |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> and <u>Never</u> <u>Arbitrate</u> options for arbitration. The default arbitration setting is **Arbitrate if Multiple Requestors Only**. If you are sure that the design of the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels, you can place a checkmark in the **Disable Arbitration** checkbox on the <u>C Series Module Properties</u> dialog box to disable arbitration and reduce the amount of FPGA logic used by VIs. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                                            |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Output Status | Returns Booleans that indicate whether any cha<br>nnel reported an overcurrent fault during the la<br>st time the FPGA I/O Node communicated with t<br>he module. When the FPGA I/O Node communic<br>ates with the module, the FPGA VI samples the s<br>tates of the channels and overwrites the previou<br>s output status with the latest state of the chann<br>els. |
|                     | • Force Status Read—When the value o<br>f this input is FALSE, the method returns t<br>he cached status information from the las<br>t status read. When the value is TRUE, the<br>method gets the current status informatio<br>n from the module. Forcing a status read c<br>an introduce jitter into a digital output loo<br>p.                                       |
|                     | <ul> <li>Any Overcurrent—Returns a Boolean<br/>value. A value of TRUE indicates an overcu<br/>rrent condition on at least one channel.</li> </ul>                                                                                                                                                                                                                      |
|                     | <ul> <li>Channel Overcurrent—Returns an ar<br/>ray of Boolean values. A value of TRUE in a<br/>ny index indicates that the channel sharin</li> </ul>                                                                                                                                                                                                                   |

g a number with that index is in an overcu rrent condition.

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9476/9477 (FPGA Interface)

Right-click an <u>NI 9476</u> or <u>NI 9477</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• **Disable Arbitration**—Place a checkmark in this checkbox if you want to change the arbitration setting to <u>Never Arbitrate</u> and reduce the amount of FPGA logic used by VIs. Check this box only if you are sure that the design of the FPGA VI will never allow more than one digital output function to execute at the same time, even on different channels. If more than one digital output function could execute simultaneously in the FPGA VI, leave the box unchecked to keep the default <u>Arbitrate if Multiple Requestors Only</u> arbitration setting.

### NI 9476 (Scan Interface)

36 V, 32-Channel (Sourcing Output), 500 μs C Series Digital Module

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

# **Module Channels**

The NI 9476 has the following channels.

| Channel | Description                                                                                                          |
|---------|----------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9476, <b>x</b> is 0 to 31. |

# **Module-Specific Errors**

The NI 9476 can return the following module-specific errors.

| Error Code | Description                                                                                                                                                                                               |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65548      | One or more channels are in overcurrent or over<br>voltage protection mode. Check the terminals fo<br>r any fault condition that could be causing an ou<br>t-of-range voltage or current on the channels. |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9476. Right-click the NI 9476 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### NI 9477

CompactRIO 32-Channel, 5–60 V, Sinking Digital Output Module

#### Software Reference (?)

📴 FPGA Interface | 😉 Scan Interface

### NI 9477 Pinout



# NI 9477 (FPGA Interface)

CompactRIO 32-Channel, 5–60 V, Sinking Digital Output Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>writing</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| DOx      | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9477 has DO channels 0 t<br>o 31.     |
| DO7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |

| DO15:8  | Digital port consisting of channels 8 through 15.<br>Channel 15 is returned in the MSB, and channel<br>8 is returned in the LSB.     |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| DO23:16 | Digital port consisting of channels 16 through 23<br>. Channel 23 is returned in the MSB, and channe<br>l 16 is returned in the LSB. |
| DO31:24 | Digital port consisting of channels 24 through 31<br>. Channel 31 is returned in the MSB, and channe<br>l 24 is returned in the LSB. |
| DO31:0  | Digital port consisting of channels 0 through 31.<br>Channel 31 is returned in the MSB, and channel<br>0 is returned in the LSB.     |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> and <u>Never</u> <u>Arbitrate</u> options for arbitration. The default arbitration setting is **Arbitrate if Multiple Requestors Only**.

If you are sure that the design of the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels, you can place a checkmark in the **Disable Arbitration** checkbox on the <u>C Series Module Properties</u> dialog box to disable arbitration and reduce the amount of FPGA logic used by VIs. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked.

# Methods

This device does not support any methods.

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |  |
|---------------|--------------------------------------------------|--|
| Module ID     | Returns the <u>module ID</u> .                   |  |
| Serial Number | Returns the unique serial number of the module . |  |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |  |

### Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9476/9477 (FPGA Interface)

Right-click an <u>NI 9476</u> or <u>NI 9477</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Module Type**—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.

• **Disable Arbitration**—Place a checkmark in this checkbox if you want to change the arbitration setting to <u>Never Arbitrate</u> and reduce the amount of FPGA logic used by VIs. Check this box only if you are sure that the design of the FPGA VI will never allow more than one digital output function to execute at the same time, even on different channels. If more than one digital output function could execute simultaneously in the FPGA VI, leave the box unchecked to keep the default <u>Arbitrate if Multiple Requestors Only</u> arbitration setting.

## NI 9477 (Scan Interface)

CompactRIO 32-Channel, 5–60 V, Sinking Digital Output Module

👰 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

### Module Channels

The NI 9477 has the following channels.

| Channel | Description                                                                                                          |
|---------|----------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9477, <b>x</b> is 0 to 31. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9477. Right-click the NI 9477 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

NI 9478

CompactRIO 16-Channel, 0–50 V Sinking Digital Output Module with Programmable Current Limits

### Software Reference (?)

FPGA Interface | Scan Interface

### NI 9478 Pinout



# **Related Topics**

FPGA Interface Configuring Current Limits for the NI 9478

# NI 9478 (FPGA Interface)

CompactRIO 16-Channel, 0–50 V Sinking Digital Output Module with Programmable Current Limits



Find related examples

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>writing</u>, with this device.

# Terminals in Software

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                      |  |
|----------|----------------------------------------------------------------------------------------------------------------------------------|--|
| DOx      | Digital output channel <b>x</b> , where <b>x</b> is the number<br>of the channel. The NI 9478 has DO channels 0 t<br>o 15.       |  |
| DO7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB.   |  |
| DO15:8   | Digital port consisting of channels 8 through 15.<br>Channel 15 is returned in the MSB, and channel<br>8 is returned in the LSB. |  |
| DO15:0   | Digital port consisting of channels 0 through 15.<br>Channel 15 is returned in the MSB, and channel<br>0 is returned in the LSB. |  |

### Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

# I/O Methods

This device does not support any I/O methods.

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method              | Description                                                                                                                                                                                                                                                                                                                                           |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Output Status | Returns Booleans that indicate whether the mo<br>dule reported an overtemp fault or any channel<br>reported an overcurrent fault during the last tim<br>e the FPGA I/O Node communicated with the m<br>odule. When the FPGA I/O Node communicates<br>with the module, the FPGA VI samples the states<br>of the module and channels and overwrites the |

previous output status with the latest state of th e module and channels.

 Limit Selection—Specifies which curr ent limit status information the module re ads. Select Active Limit if you want the C hannel Overcurrent output to return T RUE for any channels that exceed the curr ent limit threshold specified for the <u>active</u> <u>current limit</u> for that channel. Select Limi t A to return TRUE for any channels that e xceed the current limit threshold specifie d for Current Limit A. Select Limit B to ret urn TRUE for any channels that exceed th e current limit threshold specified for Curr ent Limit B.

• Module Overtemp—Returns a Boolea n value. A value of TRUE indicates that the module exceeded its temperature rating.

 Channel Overcurrent—Returns an ar ray of Boolean values. A value of TRUE in a ny index indicates that the channel sharin g a number with that index exceeded the current limit, as specified by the Limit Se lection input, after the last status read. A value of FALSE indicates that the channel did not exceed the current limit after the l ast status read.

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

Property

Description

| Active Current Limit       | Sets the active current limit for each channel. T<br>he value in an index of the input array controls t<br>he active current limit for the channel sharing a<br>number with that index. Select <b>No Change</b> if y<br>ou do not want to modify the active current limi<br>t for the channel at run time. Select <b>Limit A</b> if y<br>ou want to set the active current limit for the ch<br>annel to Current Limit A. Select <b>Limit B</b> if you w<br>ant to set the active current limit for the channe<br>I to Current Limit B. Select <b>No Limit</b> if you want<br>the channel to have no current limit. |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Current Limit A            | Sets the current limit threshold for Current Limi<br>t A in binary values. You can use the following e<br>quation to calculate the binary value from ampe<br>res:<br>Binary Value = (Current Value / 5.12 A) × 256<br>The range of valid current limit values is 0–5.1 A,<br>which corresponds to binary values 0–255.                                                                                                                                                                                                                                                                                             |
| Current Limit B            | Sets the current limit threshold for Current Limi<br>t B in binary values. You can use the following e<br>quation to calculate the binary value from ampe<br>res:<br><b>Binary Value</b> = ( <b>Current Value</b> / 5.12 A) × 256<br>The range of valid current limit values is 0–5.1 A,<br>which corresponds to binary values 0–255.                                                                                                                                                                                                                                                                              |
| Module ID                  | Returns the <u>module ID</u> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Overcurrent Refresh Period | Sets the time in µs it takes a channel to automat<br>ically recover if the channel exceeds its active cu<br>rrent limit threshold. Values 2–255 enable overc<br>urrent refresh and specify the time in tens of µs.<br>For example, a value of 3 sets an overcurrent ref<br>resh period of 30 µs. A value of 0 disables overcu<br>rrent refresh so the channel remains disabled af<br>ter exceeding its active current limit until you wr<br>ite to the channel using an FPGA I/O Node. A val<br>ue of 1 is not supported and sets an overcurrent<br>refresh period of 20 µs.                                       |
| Serial Number              | Returns the unique serial number of the module .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Vendor ID                  | Returns the NI vendor ID, 0x1093.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

# Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9478 (FPGA Interface)

Right-click an <u>NI 9478</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channel(s) for which you want to select the active current limit.
- Selected Channel(s) Settings—Specifies the active current limit for each channel.

• Active Limit—<u>Sets the active current limit</u> for the selected channel(s). Select Limit A if you want to set the active current limit for the channel(s) to Current Limit A. Select Limit B if you want to set the active current limit for the channel(s) to Current Limit B. Select **No Limit** if you want the channel(s) to have no current limit.

• **Module Settings**—Specifies the current limit threshold settings for the module.

• **Current Limit A**—Sets the current limit threshold for Current Limit A in amperes. Valid values are 0–5.1 A.

• **Current Limit B**—Sets the current limit threshold for Current Limit B in amperes. Valid values are 0–5.1 A.

• Enable Overcurrent Refresh—Place a checkmark in this checkbox if you want to enable a channel to automatically recover if the channel exceeds its active current limit threshold. If overcurrent refresh is disabled, the channel remains off after an overcurrent condition until you write to the channel using an FPGA I/O Node.

 Overcurrent Refresh Period—Sets the time in μs it takes a channel to automatically recover if the channel exceeds its active current limit threshold. Valid values are 20–2550 μs. This option is available only if you select Enable Overcurrent Refresh.

#### Configuring Current Limits for the NI 9478 (FPGA Interface)

You can configure the active current limit for each channel and the current limit thresholds at edit time using the <u>C Series Module Properties</u> dialog box. You can programmatically change these settings at run time using the <u>FPGA I/O Property</u> <u>Node</u>. The execution of an I/O Property Node that is configured with a **Current Limit** property overwrites the value you configured in the **C Series Module Properties** dialog box.

### Configuring Current Limits Using the C Series Module Properties Dialog Box

Complete the following steps to configure the active current limit for each channel and the current limit thresholds for the NI 9478 using the **C Series Module Properties** dialog box.

- 1. <u>Configure</u> the CompactRIO system, and add an NI 9478.
- 2. Right-click the NI 9478 in the **Project Explorer** window and select **Properties** from the shortcut menu to display the **C Series Module Properties** dialog box.
- 3. Select the channel(s) for which you want to configure the active current limit from the **Channels** table. You can select more than one channel by holding the <Ctrl> or <Shift> key when selecting channels.

- 4. Select the active current limit for the channel(s) from the **Active Limit** pulldown menu.
- 5. Enter a value between 0 and 5.1 in the **Current Limit** text box that corresponds to the active current limit for the selected channel(s).
- 6. Place a checkmark in the **Enable Overcurrent Refresh** checkbox and set the time in the **Overcurrent Refresh Period** text box if you want to enable a channel to automatically recover if the channel exceeds its active current limit threshold.
- 7. Click the **OK** button.
- 8. Select File»Save All in the Project Explorer window.

#### Configuring Current Limits Using the FPGA I/O Property Node

Complete the following steps to configure the active current limit for each channel and the current limit thresholds using the FPGA I/O Property Node.

- 1. Place three FPGA I/O Property Nodes on the block diagram and <u>configure</u> them for the NI 9478.
- 2. Click the **Property** section on the first Property Node and select the **Active Current Limit** property from the shortcut menu.
- 3. Right-click the **Active Current Limit** input and select **Create»Control** from the shortcut menu.
- 4. On the front panel of the VI, select the active current limit for each channel from the **Active Current Limit** array.
- 5. Click the **Property** section on the second Property Node and select the **Current Limit A** property from the shortcut menu.
- 6. Right-click the **Current Limit A** input and select **Create**»**Control** from the shortcut menu.
- 7. Click the **Property** section on the third Property Node and select the **Current Limit B** property from the shortcut menu.
- 8. Right-click the **Current Limit B** input and select **Create**»**Control** from the shortcut menu.

9. On the front panel of the VI, enter binary values in the Current Limit controls to set the current limit thresholds. You can use the following equation in the host VI to calculate the binary value from amperes:
Binary Value = (Current Value / 5.12 A) × 256

### NI 9478 (Scan Interface)

CompactRIO 16-Channel, 0–50 V Sinking Digital Output Module with Programmable Current Limits

🔊 Open example

### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

### **Module Channels**

The NI 9478 has the following channels.

| Channel | Description                                                                                                          |
|---------|----------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9478, <b>x</b> is 0 to 15. |

### Module-Specific Errors

The NI 9478 can return the following module-specific errors.

| Error Code | Description                                                                                                                                                                                               |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65548      | One or more channels are in overcurrent or over<br>voltage protection mode. Check the terminals fo<br>r any fault condition that could be causing an ou<br>t-of-range voltage or current on the channels. |
| 65571      | Serial module over-temperature error: An over-t<br>emperature error has occurred since the last tim<br>e the module was accessed. Check for fault con<br>ditions or extraneous voltages on the I/O port.  |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9478. Right-click the NI 9478 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Specifies the type of C Series module. You cannot change this value.

- Location—Specifies a slot in the chassis for the C Series module.
- **Channels**—Specifies the channels for which you want to configure an active current limit.
- Active Limit—Specifies the current limit for the selected channel(s). You can select Limit A, Limit B, or No Limit.
- **Current Limit A**—Specifies one of two current limit values in amps for channels on the module. You can enter a value from 0 to 5.1.
- **Current Limit B**—Specifies one of two current limit values in amps for channels on the module. You can enter a value from 0 to 5.1.
- Enable Overcurrent Refresh—If you check this box, a channel that exceeds the current limit automatically recovers after a specified amount of time, the overcurrent refresh period. If you leave this box unchecked, a channel that exceeds the current limit remains disabled until you write to it.
- **Overcurrent Refresh Period**—Specifies the time in µs it takes a channel to automatically recover after exceeding the current limit. You can enter a value from 20 to 2,550.

### NI 9481

CompactRIO 4-Channel, Form A Electromechanical Relay Module

#### Software Reference (?)

FPGA Interface | Scan Interface

### NI 9481 Pinout



# NI 9481 (FPGA Interface)

CompactRIO 4-Channel, Form A Electromechanical Relay Module

# FPGA I/O Node

You can use an FPGA I/O Node, configured for writing, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                          |  |
|----------|------------------------------------------------------------------------------------------------------|--|
| CHx      | channel <b>x</b> , where <b>x</b> is the number of the channel<br>. The NI 9481 has channels 0 to 3. |  |

| CH3:0 | Digital port consisting of channels 0 through 3.   |
|-------|----------------------------------------------------|
|       | Channel 3 is returned in bit 3, and channel 0 is r |
|       | eturned in bit 0.                                  |

### Arbitration

You can configure the arbitration settings for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                         |                                                                                                                                                                                |
|--------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready. |                                                                                                                                                                                |
|              |                                                                     | <b>Note</b> During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital output before a loop containing digital output starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. The module might ignore or delay digital output operations if it is not ready.

While the module is performing digital output within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital output and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9472/9474/9475/9481/9482/9485 (FPGA Interface)

Right-click an <u>NI 9472</u>, <u>NI 9474</u>, <u>NI 9475</u>, <u>NI 9481</u>, <u>NI 9482</u>, or <u>NI 9485</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

# NI 9481 (Scan Interface)

CompactRIO 4-Channel, Form A Electromechanical Relay Module

应 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

# **Module Channels**

The NI 9481 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9481, <b>x</b> is 0 to 3. |

# C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9481. Right-click the NI 9481 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module

based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

#### NI 9482

CompactRIO 4-Channel, Form A Electromechanical Relay Module

#### Software Reference (?)

😰 FPGA Interface | 😉 Scan Interface

### NI 9482 Pinout



# NI 9482 (FPGA Interface)

CompactRIO 4-Channel, Form A Electromechanical Relay Module

### FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>writing</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                 |
|----------|-----------------------------------------------------------------------------------------------------------------------------|
| CHx      | channel <b>x</b> , where <b>x</b> is the number of the channel<br>. The NI 9482 has channels 0 to 3.                        |
| CH3:0    | Digital port consisting of channels 0 through 3.<br>Channel 3 is returned in bit 3, and channel 0 is r<br>eturned in bit 0. |

### Arbitration

You can configure the arbitration settings for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

# I/O Methods

This device does not support any I/O methods.

### **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                                                                                         |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                 |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep |

ort certain types of err ors.

# I/O Properties

This device does not support any I/O properties.

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property      | Description                                      |
|---------------|--------------------------------------------------|
| Module ID     | Returns the <u>module ID</u> .                   |
| Serial Number | Returns the unique serial number of the module . |
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital output before a loop containing digital output starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. The module might ignore or delay digital output operations if it is not ready.

While the module is performing digital output within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital output and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9472/9474/9475/9481/9482/9485 (FPGA Interface)

Right-click an <u>NI 9472</u>, <u>NI 9474</u>, <u>NI 9475</u>, <u>NI 9481</u>, <u>NI 9482</u>, or <u>NI 9485</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

- Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.
- Module Type—Specifies the type of C Series module. You cannot change this option.
- Location—Specifies a slot in the chassis for the C Series module.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

### NI 9482 (Scan Interface)

CompactRIO 4-Channel, Form A Electromechanical Relay Module

📄 Open example

# Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

### **Module Channels**

The NI 9482 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9482, <b>x</b> is 0 to 3. |

### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9482. Right-click the NI 9482 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this value.

• Location—Specifies a slot in the chassis for the C Series module.

NI 9485

CompactRIO 8-Channel, Solid-State Relay (SSR) Module

#### Software Reference (?)

😰 FPGA Interface | 😉 Scan Interface

### NI 9485 Pinout



# NI 9485 (FPGA Interface)

CompactRIO 8-Channel, Solid-State Relay (SSR) Module

# FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>writing</u>, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------|
| CHx      | channel <b>x</b> , where <b>x</b> is the number of the channel<br>. The NI 9485 has channels 0 to 7.                           |
| CH7:0    | Digital port consisting of channels 0 through 7.<br>Channel 7 is returned in the MSB, and channel 0<br>is returned in the LSB. |

### Arbitration

You can configure the arbitration settings for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

# I/O Methods

This device does not support any I/O methods.

# **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module method for this device.

| Method       | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the module is ready.                                                                                                     |
|              | Note During the first 2<br>seconds after you reset<br>the FPGA VI, the error t<br>erminals on this metho<br>d may not correctly rep<br>ort certain types of err<br>ors. |

# I/O Properties

This device does not support any I/O properties.

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property  | Description                    |
|-----------|--------------------------------|
| Module ID | Returns the <u>module ID</u> . |

| Serial Number | Returns the unique serial number of the module . |
|---------------|--------------------------------------------------|
| Vendor ID     | Returns the NI vendor ID, 0x1093.                |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced</u> <u>Configuration</u> dialog box.

When the module is within a single-cycle Timed Loop, it must be ready to perform digital output before a loop containing digital output starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. The module might ignore or delay digital output operations if it is not ready.

While the module is performing digital output within a single-cycle Timed Loop, do not perform property reads or remove the module from the chassis. Doing either of these actions causes the module to be unable to perform digital output and the **Ready** output of the Check Status method to return FALSE.

# **FPGA Target Clock Support**

This device supports only <u>top-level FPGA target clock rates</u> and <u>single-cycle Timed</u> <u>Loop clock rates</u> that are multiples of 40 MHz, such as 40 MHz, 80 MHz, 120 MHz, and so on.

C Series Module Properties Dialog Box for the NI 9472/9474/9475/9481/9482/9485 (FPGA Interface)

Right-click an <u>NI 9472</u>, <u>NI 9474</u>, <u>NI 9475</u>, <u>NI 9481</u>, <u>NI 9482</u>, or <u>NI 9485</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module
based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Advanced—Launches the <u>Advanced Configuration</u> dialog box.

## NI 9485 (Scan Interface)

CompactRIO 8-Channel, Solid-State Relay (SSR) Module

📄 Open example

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI. The I/O variables write Boolean values to the channels.

## **Module Channels**

The NI 9485 has the following channels.

| Channel | Description                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------|
| DOx     | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9485, <b>x</b> is 0 to 7. |

#### C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9485. Right-click the NI 9485 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

- **Module Type**—Specifies the type of C Series module. You cannot change this value.
- Location—Specifies a slot in the chassis for the C Series module.

#### Functional Safety Modules

Use this book as a reference for the following information:

- I/O variables and properties each C Series functional safety module supports in Scan Interface mode.
- Instructions for using LabVIEW with CompactRIO functional safety devices

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

#### NI 9350

**.** 

8-Channel 24 V Sinking DI, 8-Channel 24 V Sourcing DO SIL 3 Capable C Series Functional Safety Module

#### Software Reference (?)

Scan Interface

#### C Series Functional Safety Manual (?)

C Series Functional Safety Manual

#### NI 9350 Pinout



## NI 9350 (Scan Interface)

8-Channel 24 V Sinking DI, 8-Channel 24 V Sourcing DO SIL 3 Capable C Series Functional Safety Module

## Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI.

- **Digital input**—reads the Boolean state of that channel.
- **Digital output**—reads the Boolean state of that channel. When the User Program sets the channel to passthrough, the User Program will use the value in the output scan buffer. When the channel is not set to passthroughin the User Program, the User Program ignores the value in the output scan buffer.
- State machine variable—reads the Boolean value of that variable in the User Program.
- User LED0—reads the Boolean value of the LED in the User Program.

## Module Channels

The NI 9350 has the following channels.

| Channel      | Description                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------|
| DIx          | Digital input channel <b>x</b> , where <b>x</b> is the number o f the channel. For the NI 9350, <b>x</b> is 0 to 7.   |
| DOx          | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9350, <b>x</b> is 0 to 7.   |
| Var <b>x</b> | State machine variable <b>x</b> , where <b>x</b> is the number of the variable. For the NI 9350, <b>x</b> is 0 to 23. |
| User LED0    | User-configurable LED                                                                                                 |

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9350. Right-click the NI 9350 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Indicates the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Indicates the type of C Series module. You cannot change this value.

- Location—Indicates a slot in the chassis for the C Series module.
- **Read Module Information**—Reads the Build Number and Program GUID of the current User Program installed on the C Series module.
- **Build Number**—Indicates the build number of the current User Program installed on the C Series module.
- **Program GUID**—Indicates the program GUID of the current User Program installed on the C Series module.
- Mode—Indicates the current operating mode of the C Series module.
  - Power Up—Indicates module is powering up.

• Unprogrammed—Indicates User Program is not written to the C Series module.

• User Program Download—Indicates the User Program is downloading to the C Series module.

 Module Firmware Download—Indicates firmware is downloading to the C Series module.

Verification—Indicates User Program has successfully downloaded.
 Requires user verification.

- Operational—Indicates C Series module is running the User Program.
- Reserved—Indicates C Series module is in Reserved mode.

• Fail-safe—Indicates User Program has detected a fault that triggered Failsafe mode. User must address fault and cycle power to return the C Series module to Operational mode.

• Change Mode to X—Updates C Series module from Verification mode to Operational mode or from Operational mode to Verification mode.

• Path to New User Program—Specifies the file path of the User Program selected for download.

• **Build Number**—Indicates the build number of the User Program selected for download.

• **Program GUID in New Program**—Indicates the program GUID of the User Program selected for download.

• **Download**—Downloads the selected User Program to the C Series module.

#### **Module Methods**

Use the Invoke Node to access the following module properties for this device.

| Method               | Description                                                                                                                                                                                                                                   |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Channel Status | Returns Boolean arrays that indicate the channe<br>l status, including various faults. The index num<br>ber in the array corresponds to the channel num<br>ber on the module, so that index 0 indicates the<br>channel status for DI0 or DO0. |

|                     | The following parameters are available:                                                                                  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------|
|                     | <ul> <li>DO Internal Readback—Indicates wheth<br/>er the DO signal is high or low.</li> </ul>                            |
|                     | <ul> <li>DO Channel Overcurrent Fault—Indicat<br/>es an overcurrent fault has been detected.</li> </ul>                  |
|                     | <ul> <li>DO Channel Open Circuit Fault—Indicat<br/>es an open circuit fault has been detected.</li> </ul>                |
|                     | <ul> <li>DI Channel Discrepancy Fault—Indicate<br/>s a discrepancy fault has been detected.</li> </ul>                   |
|                     | <ul> <li>Channel Test Pulse Fault—Indicates a t<br/>est pulse fault has been detected.</li> </ul>                        |
|                     | <ul> <li>Channel Readback Fault—Indicates a re<br/>adback fault has been detected.</li> </ul>                            |
| Check Module Status | Returns the module status, including digital out put values and various faults.                                          |
|                     | The following parameters are available:                                                                                  |
|                     | <ul> <li>Mode—Returns an enum value that rea<br/>ds the operating mode of the NI 9350.</li> </ul>                        |
|                     | <ul> <li>Power Up—Indicates module is powe<br/>ring up.</li> </ul>                                                       |
|                     | <ul> <li>Unprogrammed—Indicates User Prog<br/>ram is not written to the C Series modul<br/>e.</li> </ul>                 |
|                     | <ul> <li>User Program Download—Indicates t<br/>he User Program is downloading to the<br/>C Series module.</li> </ul>     |
|                     | <ul> <li>Module Firmware Download—Indicat<br/>es firmware is downloading to the C Ser<br/>ies module.</li> </ul>         |
|                     | <ul> <li>Verification—Indicates User Program<br/>has successfully downloaded. Requires<br/>user verification.</li> </ul> |
|                     | <ul> <li>Operational—Indicates C Series mod</li> </ul>                                                                   |

|                    | <ul> <li>Reserved—Indicates C Series module<br/>is in Reserved mode.</li> <li>Fail-safe—Indicates User Program ha<br/>s detected a fault that triggered Fail-saf<br/>e mode. User must address fault and cy<br/>cle power to return the C Series module<br/>to Operational mode.</li> </ul>                                             |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>User Program Running—Returns Boole<br/>an value to indicate the status of the User<br/>Program.</li> </ul>                                                                                                                                                                                                                     |
|                    | <ul> <li>Internal Fault—Returns Boolean value t<br/>o indicate whether an internal fault has be<br/>en detected.</li> </ul>                                                                                                                                                                                                             |
|                    | <ul> <li>Temperature Fault—Returns Boolean v<br/>alue to indicate whether a temperature fa<br/>ult has been detected.</li> </ul>                                                                                                                                                                                                        |
|                    | <ul> <li>Power Supply Fault—Returns Boolean<br/>value to indicate whether a power supply<br/>fault has been detected.</li> </ul>                                                                                                                                                                                                        |
| Start Program      | Starts the User Program.                                                                                                                                                                                                                                                                                                                |
| Set Mode           | Sets the operating mode for the NI 9350 as an e<br>num value. Valid values are Operational or Verifi<br>cation.                                                                                                                                                                                                                         |
| Read Current State | Returns an array of U8 values. The array index c<br>orresponds to the state machine number in the<br>User Program and the U8 value indicates the cur<br>rent state of that state machine. Refer to the rep<br>ort.log file generated by the Functional Safety E<br>ditor to index the state machines and identify th<br>e state number. |

## **Module Properties**

Use the **Property Node** to access the following module properties for this device.

| Property                | Description                                                       |
|-------------------------|-------------------------------------------------------------------|
| Firmware Version Number | Returns U32 value to indicate the version of the module firmware. |

| User Program GUID           | Returns a string to indicate the GUID assigned to the User Program. |
|-----------------------------|---------------------------------------------------------------------|
| User Program Version Number | Returns U32 value to indicate the build number of the User Program. |

#### NI 9351

4-Channel 0-20 mA 16-bit AI, 4-Channel 24 V Sinking DI, 4-Channel 24 V Sourcing DO SIL 3 Capable C Series Functional Safety Module

#### Software Reference (?)

#### Scan Interface

#### C Series Functional Safety Manual (?)

🗈 C Series Functional Safety Manual

#### 0000 DO0 DIO COM COM DO1 DI1 DO2 DI2 COM COM DO3 DI3 Vsup AIO COM COM Al1 Vsup ĸ Vsup Al2 COM COM Vsup AI3 Vsup COM

#### NI 9351 Pinout

## NI 9351 (Scan Interface)

4-Channel 0-20 mA 16-bit AI, 4-Channel 24 V Sinking DI, 4-Channel 24 V Sourcing DO SIL 3 Capable C Series Functional Safety Module

#### Module I/O Variables

To use I/O from this module in a VI, drag and drop <u>I/O variables</u> from the **Project Explorer** window to the block diagram of the VI.

- Analog input—reads the analog signal of that channel.
- **Digital input**—reads the Boolean state of that channel.

• **Digital output**—reads the Boolean state of that channel. Writes a Boolean value to the output scan buffer. When the channel is set to passthrough in the User Program, the User Program will use the value in the output scan buffer. When the channel is not set to passthrough in the User Program, the User Program ignores the value in the output scan buffer.

- State machine variable—reads the Boolean value of that variable in the User Program.
- User LED0—reads the Boolean value of the LED set by the User Program.

#### **Module Channels**

| Channel      | Description                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------|
| Alx          | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9351, <b>x</b> is 0 to 3.     |
| DIx          | Digital input channel <b>x</b> , where <b>x</b> is the number o f the channel. For the NI 9351, <b>x</b> is 0 to 3.   |
| DOx          | Digital output channel <b>x</b> , where <b>x</b> is the number of the channel. For the NI 9351, <b>x</b> is 0 to 3.   |
| Var <b>x</b> | State machine variable <b>x</b> , where <b>x</b> is the number of the variable. For the NI 9351, <b>x</b> is 0 to 23. |
| User LED0    | User-configurable LED                                                                                                 |

The NI 9351 has the following channels.

## C Series Module Properties Dialog Box

Use this dialog box to configure the NI 9351. Right-click the NI 9351 in the **Project Explorer** window and select **Properties** to display this dialog box. You can configure the following options.

• Name—Indicates the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• Module Type—Indicates the type of C Series module. You cannot change this value.

• Location—Indicates a slot in the chassis for the C Series module.

• **Read Module Information**—Reads the Build Number and Program GUID of the current User Program installed on the C Series module.

• **Build Number**—Indicates the build number of the current User Program installed on the C Series module.

• **Program GUID**—Indicates the program GUID of the current User Program installed on the C Series module.

- Mode—Indicates the current operating mode of the C Series module.
  - Power Up—Indicates module is powering up.
  - Unprogrammed—Indicates User Program is not written to the C Series module.

• User Program Download—Indicates the User Program is downloading to the C Series module.

 Module Firmware Download—Indicates firmware is downloading to the C Series module.

Verification—Indicates User Program has successfully downloaded.
 Requires user verification.

- Operational—Indicates C Series module is running the User Program.
- Reserved—Indicates C Series module is in Reserved mode.

• Fail-safe—Indicates User Program has detected a fault that triggered Failsafe mode. User must address fault and cycle power to return the C Series module to Operational mode.

• Change Mode to X—Updates C Series module from Verification mode to Operational mode or from Operational mode to Verification mode.

• Path to New User Program—Specifies the file path of the User Program selected for download.

• **Build Number**—Indicates the build number of the User Program selected for download.

• **Program GUID in New Program**—Indicates the program GUID of the User Program selected for download.

• **Download**—Downloads the selected User Program to the C Series module.

#### **Module Methods**

Use the <u>Invoke Node</u> to access the following module properties for this device.

| Method               | Description                                                                                                                                                                                                                                                                                    |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Channel Status | Returns Boolean arrays that indicate the channe<br>I status, including various faults. The index num<br>ber in the array corresponds to the channel num<br>ber on the module, so that index 0 indicates the<br>channel status for DI0, DO0, or AI0.<br>The following parameters are available: |
|                      | • DO Internal Readback—Indicates wheth<br>er the DO signal is high or low.                                                                                                                                                                                                                     |
|                      | <ul> <li>DO Channel Overcurrent Fault—Indicat<br/>es an overcurrent fault has been detected.</li> </ul>                                                                                                                                                                                        |
|                      | <ul> <li>DO Channel Open Circuit Fault—Indicat<br/>es an open circuit fault has been detected.</li> </ul>                                                                                                                                                                                      |
|                      | <ul> <li>DI Channel Discrepancy Fault—Indicate<br/>s a discrepancy fault has been detected.</li> </ul>                                                                                                                                                                                         |
|                      | <ul> <li>Channel Test Pulse Fault—Indicates a t<br/>est pulse fault has been detected.</li> </ul>                                                                                                                                                                                              |

|                     | <ul> <li>Channel Readback Fault—Indicates a re<br/>adback fault has been detected.</li> <li>AI Discrepancy Fault—Indicates a discre<br/>pancy fault has been detected.</li> <li>AI Overcurrent Fault—Indicates a overc<br/>urrent fault has been detected.</li> <li>AI Discrepancy Warning—Indicates whic<br/>h AI channel in a 2003 configuration is out<br/>of discrepancy range.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check Module Status | <ul> <li>Returns the module status, including digital out put values and various faults.</li> <li>The following parameters are available: <ul> <li>Mode—Returns an enum value that rea ds the operating mode of the NI 9351.</li> <li>Power Up—Indicates module is powe ring up.</li> <li>Unprogrammed—Indicates User Prog ram is not written to the C Series modul e.</li> <li>User Program Download—Indicates t he User Program is downloading to the C Series module.</li> <li>Module Firmware Download—Indicat es firmware is downloading to the C Series module.</li> <li>Verification—Indicates User Program has successfully downloaded. Requires user verification.</li> <li>Operational—Indicates C Series module is running the User Program.</li> <li>Reserved—Indicates C Series module is in Reserved mode.</li> <li>Fail-safe—Indicates User Program ha s detected a fault that triggered Fail-saf e mode. User must address fault and cv</li> </ul> </li> </ul> |

|                    | <ul> <li>cle power to return the C Series module<br/>to Operational mode.</li> <li>User Program Running—Returns Boole<br/>an value to indicate the status of the User<br/>Program.</li> <li>Internal Fault—Returns Boolean value t<br/>o indicate whether an internal fault has be<br/>en detected.</li> <li>Temperature Fault—Returns Boolean v<br/>alue to indicate whether a temperature fa<br/>ult has been detected.</li> <li>Power Supply Fault—Returns Boolean<br/>value to indicate whether a power supply<br/>fault has been detected.</li> </ul> |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start Program      | Starts the User Program.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Set Mode           | Sets the operating mode for the NI 9351 as an e<br>num value. Valid values are Operational or Verifi<br>cation.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Read Current State | Returns an array of U8 values. The array index c<br>orresponds to the state machine number in the<br>User Program and the U8 value indicates the cur<br>rent state of that state machine. Refer to the rep<br>ort.log file generated by the Functional Safety E<br>ditor to index the state machines and identify th<br>e state number.                                                                                                                                                                                                                    |

## **Module Properties**

Use the **Property Node** to access the following module properties for this device.

| Property                    | Description                                                         |
|-----------------------------|---------------------------------------------------------------------|
| Firmware Version Number     | Returns U32 value to indicate the version of the module firmware.   |
| User Program GUID           | Returns a string to indicate the GUID assigned to the User Program. |
| User Program Version Number | Returns U32 value to indicate the build number of the User Program. |

## Modular Instruments Modules

Use this book as a reference for information about which FPGA I/O functions, I/O resources, arbitration options, methods, and properties each C Series modular instruments module supports in FPGA Programming mode.

To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

NI 9770

\*

CompactRIO 30 kHz to 100 MHz, 50 Ω, AC Coupled RF Receiver Module

#### Software Reference (?)

FPGA Interface

#### NI 9770 Pinout



## **Related Topics**

FPGA Interface <u>Acquiring Data from a Module (FPGA Interface)</u> <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Configuring the Data Rate for a Module (FPGA Interface)</u> <u>Synchronizing Multiple NI 9770 Modules</u> <u>Understanding Loop Timing (FPGA Interface)</u>

## NI 9770 (FPGA Interface)

30 kHz to 100 MHz, 50 Ω, AC Coupled RF Receiver Module

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                                                                                                                                                                                         |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RF In/I  | Returns the I data that comes from the RF IN co<br>nnector.<br>The I and Q data from each module must be acc<br>essed from within the same FPGA I/O Node. Do<br>not access I and Q data on multiple modules in t<br>he same FPGA I/O Node if the modules are not s<br>ynchronized or do not use the same data rate. |
| RF In/Q  | Returns the Q data that comes from the RF IN co<br>nnector.<br>The I and Q data from each module must be acc<br>essed from within the same FPGA I/O Node. Do<br>not access I and Q data on multiple modules in t<br>he same FPGA I/O Node if the modules are not s<br>ynchronized or do not use the same data rate. |

| Onboard Clock | Provides access to the onboard clock in LabVIE<br>W. The onboard clock frequency is 12.288 MHz.<br>Use the FPGA I/O Node in a single-cycle Timed L<br>oop to access this channel. You must export the<br><b>Onboard Clock</b> of the module to access this c<br>hannel.                                                                           |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start         | Channel that controls when the module starts a cquiring IQ data.<br>If you write TRUE to the <b>Start</b> channel, the mod ule starts acquiring data. When the module is ac quiring data, you must write TRUE to the <b>Stop</b> c hannel before you can access properties for this module.                                                       |
|               | If you write FALSE to the <b>Start</b> channel, no oper<br>ation is performed.<br>Refer to the NI 9770 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9770\NI 9770 Getting<br>Started\NI 9770 Getting Started.<br>lvproj directory for an example of using the <b>S</b><br><b>tart</b> and <b>Stop</b> channels. |
| Stop          | Channel that controls when the module stops a cquiring data.<br>If you write TRUE to the <b>Stop</b> channel, the mod ule stops acquiring data. When the module is ac quiring data, you must write TRUE to the <b>Stop</b> c hannel before you can access properties for the module.                                                              |
|               | If you write FALSE to the <b>Stop</b> channel, no oper<br>ation is performed.<br>Refer to the NI 9770 Getting Started VI in the la<br>bview\examples\CompactRIO\Module<br>Specific\NI 9770\NI 9770 Getting<br>Started\NI 9770 Getting Started.<br>lvproj directory for an example of using the <b>S</b><br>tart and <b>Stop</b> channels.         |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method          | Description                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configure RF In | Configures the RF center frequency of the modu<br>le and input signal reference level.                                                                                                                                                                                                                                                                                      |
|                 | <ul> <li>Center Frequency—Specifies in Hz th<br/>e desired RF center frequency that the mo<br/>dule should tune to.</li> </ul>                                                                                                                                                                                                                                              |
|                 | <ul> <li>Reference Level—Specifies in dBm th<br/>e expected total power of the RF input sig<br/>nal.</li> </ul>                                                                                                                                                                                                                                                             |
|                 | <ul> <li>LO Source—Optional parameter that s pecifies the source of the LO signal that th e module uses for RF downconversion. Op tions are Internal or LO In. When Intern al, the module uses the internal LO signal that originates from within the module. W hen LO In, the module uses the signal that t is connected to the LO IN connector on t he module.</li> </ul> |
|                 | • LO In Frequency—Optional paramete<br>r that specifies the frequency in Hz of the<br>signal connected to the LO IN connector o<br>n the module. When you set the LO Sour<br>ce to LO In, you must connect a signal to<br>the LO IN connector on the module and us                                                                                                          |

e this parameter to specify the frequency of that signal.

• Downconverter Gain—Returns the n et signal gain in dB of the RF downconvert er. Use this parameter to scale the IQ data to the proper power level, as seen at the R F IN connector on the module.



Note Refer to the N 19770 Getting Starte d VI in labview\e xamples\Compa ctRIO\Module Specific\NI 97 70\NI 9770 Ge tting Started \NI 9770 Gett ing Started.l vproj for an exam ple of how to use Do wnconverter Gain t o scale the IQ data.

#### **Check Cached Status**

Returns the following status information that re ports whether various conditions occurred on th e module since the last execution of the **Check Cached Status** method:

• IQ Data Overflow—Returns a Boolean value. A value of TRUE indicates that the R F input subsystem tried to acquire a signal that is larger in amplitude than the ADC ca n accurately measure using the current ha rdware gain configuration. This problem may result from using a reference level th at is too low for the supplied input signal.

• LO PLL Unlocked—Returns a Boolean value. A value of TRUE indicates that the L O PLL is in an unlocked state. The LO PLL must be locked in order to ensure that cor rect data is acquired from the module.

• Sample Clock PLL Unlocked—Retur ns a Boolean value. A value of TRUE indica tes that the sample clock PLL is in an unlo cked state. When synchronizing multiple modules, the sample clock PLL must be lo cked in order to ensure that the modules are synchronized properly.

## I/O Properties

This device does not support any I/O properties.

#### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property         | Description                                                                                                                                                                                                                                                                                                         |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Rate        | Sets the rate at which the module acquires IQ d ata.                                                                                                                                                                                                                                                                |
| Peak RF In Power | Returns the peak signal power level in dBm that<br>was measured at the RF IN connector across the<br>full RF frequency range of the module. The peak<br>is cleared when this property is read.                                                                                                                      |
|                  | Note This value only u<br>pdates while the modu<br>le is acquiring IQ data.<br>When the acquisition s<br>tops, this property retu<br>rns the last measured<br>peak signal power leve<br>l.                                                                                                                          |
| LO Out Enabled   | When set to TRUE, the module drives the LO sig<br>nal to the LO OUT connector on the module. Thi<br>s property is used to <u>share the LO signal</u> across<br>multiple NI 9770 modules.<br>This property cannot be set to FALSE when the <b>L</b><br><b>O Source</b> is set to <b>LO In</b> . The module always dr |

|                    | ives LO OUT when using an external LO signal o<br>n the LO IN connector on the module.                                                                                                                                                                                         |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Downconverter Gain | Returns the net signal gain in dB of the RF down<br>converter. Use this parameter to scale the IQ dat<br>a to the proper power level, as seen at the RF IN<br>connector on the module.                                                                                         |
|                    | Note Refer to the NI 9<br>770 Getting Started VI i<br>n labview\exampl<br>es\CompactRIO\M<br>odule Specific\N<br>I 9770\NI 9770<br>Getting Started<br>\NI 9770 Gettin<br>g Started.lvpro<br>j for an example of ho<br>w to use Downconvert<br>er Gain to scale the IQ<br>data. |
| RF Attenuation     | Configures the amount of RF attenuation in dB t<br>hat is applied to the input signal. The valid para<br>meter range is 0 dB to 30 dB. You can read or wri<br>te to this property. If you write to this property,<br>you must read Downconverter Gain again.                   |
| IF Attenuation     | Configures the amount of IF attenuation in dB t<br>hat is applied to the input signal. The valid para<br>meter range is 0 dB to 30 dB. You can read or wri<br>te to this property. If you write to this property,<br>you must read Downconverter Gain again.                   |
| Module ID          | Returns the Module ID, 0x7827.                                                                                                                                                                                                                                                 |
| Serial Number      | Returns the unique serial number of the module .                                                                                                                                                                                                                               |
| Vendor ID          | Returns the NI vendor ID, 0x1093.                                                                                                                                                                                                                                              |
|                    |                                                                                                                                                                                                                                                                                |

# Single-Cycle Timed Loop

You can use the **Onboard Clock** channel in the single-cycle Timed Loop. You cannot use the other channels on the NI 9770 with the single-cycle Timed Loop.

Refer to the <u>Understanding Loop Timing (FPGA Interface)</u> topic for information about loop timing for this module.

C Series Module Properties Dialog Box for the NI 9770 (FPGA Interface)

Right-click an <u>NI 9770</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

• Location—Specifies a slot in the chassis for the C Series module.

• Master Timebase Source—Specifies the master timebase source used by the module.

- **Export Onboard Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.
- **Data Rate**—Specifies the rate at which the module acquires data.
- Center Frequency (Hz)—Specifies the RF center frequency at which the module acquires data.
- **Reference Level (dBm)**—Specifies the expected total power in dBm of the RF input signal.

#### Synchronizing Multiple NI 9770 Modules (FPGA Interface)

You can synchronize multiple NI 9770 modules that are connected to the same FPGA device if your application meets the following requirements:

• The modules must use the same master timebase source

- The modules must start acquisition mode at the same time
- A single <u>FPGA I/O Node</u> function must read the synchronous data

You must <u>create FPGA I/O items</u> for the NI 9770 before you can configure the items using the FPGA I/O Node. Develop the FPGA VI to meet the guidelines described in this topic.



**Note** The NI 9770 does not support synchronization with other non-NI 9770 modules.

Sharing a Master Timebase Source

Configure the modules to share the same master timebase source.

#### Sharing the LO Signal

You can share a local oscillator (LO) signal between a master module and one or more slave modules to enable a repeatable phase relationship between the master module and the slave modules.

Complete the following steps to configure the modules to share the same LO signal.

- 1. Designate one module as the master module, which will drive its LO signal to a slave module.
- 2. Connect the LO OUT terminal on the master module to the LO IN terminal on the slave module.



#### Notes

• You can add multiple slave modules in a daisy-chain configuration by connecting the LO OUT terminal of one slave module to the LO IN terminal of the next slave module.

• Add 50 Ω termination to the LO OUT terminal of the last slave module in the chain.

- 3. Configure the master module to export its LO signal on the LO OUT terminal by setting the LO Out Enabled property of the master module to TRUE.
- 4. Read the **LO Frequency** property of the master module. This value is used to configure the frequency of the LO IN signal on the slave module.
- Configure the slave module to import its LO signal from the LO IN connector. Use the Configure RF In method of the slave module to set the following values:

| Parameter       | Value                                                                        |
|-----------------|------------------------------------------------------------------------------|
| LO Source       | LO In                                                                        |
| LO In Frequency | The value returned by the <b>LO Frequency</b> pr operty of the master module |

#### Starting the Synchronized Acquisition

Configure an FPGA I/O Node with **Start** channels for the NI 9770 modules you want to synchronize and wire a Boolean constant set to TRUE to each **Start** channel.



Acquiring Data from Synchronized NI 9770 Modules with the Same Data Rate

Configure an FPGA I/O Node with all of the channels from which you want to synchronously sample.



3

**Note** Ensure that all I/O channels are in the same FPGA I/O Node. Otherwise, the FPGA I/O Node will not return synchronized data.

Refer to the Synchronizing NI 9770 Modules (FPGA) VI in the labview\examples \CompactRIO\Module Specific\NI 9770\NI 9770 Multi-Module S ynchronization\NI 9770 Multi-Module Synchronization.lvpro j for an example of synchronizing multiple modules with the same data rate. Acquiring Data from Synchronized NI 9770 Modules with Different Data Rates

If you synchronize NI 9770 modules that are configured for different data rates, create a <u>separate loop</u> for each data rate in the FPGA VI. In each loop, configure an FPGA I/O Node with all of the channels that are configured for the data rate of that loop. If you place NI 9770 channels that are configured for different data rates in the same loop, LabVIEW returns an overrun warning from the FPGA I/O Node (<u>error 65539</u>) when you run the VI. There is a delay before the FPGA I/O Node returns the first data point. The length of the delay depends on the data rate of the NI 9770.

NI 9775

CompactRIO 4-Ch, ±10 V, 20 MS/s, 14-Bit Digitizer

Software Reference (?)

FPGA Interface

#### NI 9775 Pinout



## **Related Topics**

FPGA Interface <u>NI 9775 Acquisition Modes</u> <u>Acquiring Data from a Module (FPGA Interface)</u> <u>Configuring the Master Timebase Source for a Module (FPGA Interface)</u> <u>Configuring the Data Rate for a Module (FPGA Interface)</u> <u>Synchronizing Multiple Modules</u> <u>Understanding Loop Timing (FPGA Interface)</u>

## NI 9775 (FPGA Interface)

CompactRIO 4-Ch, ±10 V, 20 MS/s, 14-Bit Digitizer

🔊 Open example

Find related examples

## FPGA I/O Node

You can use an <u>FPGA I/O Node</u>, configured for <u>reading</u>, with this device.

| EK.      | <b>Note</b> You can <u>synchronize</u> an NI 9775 module<br>with other modules that have a <u>selectable</u><br><u>timebase source</u> .                              |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| E.       | <b>Note</b> You can only use the 12.8 MHz exported clock of the NI 9469 as the reference clock of the NI 9775. You cannot use the 13.1072 MHz clock with the NI 9775. |
| <b>B</b> | <b>Note</b> You can only use another NI 9775 or the NI 9469 configured to export its clock as the reference clock for the NI 9775.                                    |

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                          |
|----------|------------------------------------------------------------------------------------------------------|
| Alx      | Analog input channel x, where x is the number o<br>f the channel. The NI 9775 has AI channels 0 to 3 |
|          | •                                                                                                    |

|                 | Caution Do not acces<br>s AI channels on multip<br>le modules from the sa<br>me FPGA I/O Node if th<br>e modules are not sync<br>hronized or do not use<br>the same data rate.                       |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Clock | Gives access to the reference clock in the LabVIE<br>W block diagram. Export the onboard clock of th<br>e NI 9775 and use the FPGA I/O Node in a single-<br>cycle timed loop to access this channel. |
| Start           | Controls when the NI 9775 starts acquiring data.                                                                                                                                                     |
| Stop            | Controls when the NI 9775 stops acquiring data.<br>When the 9775 is acquiring data, you must write<br>TRUE to this channel before you can access pro<br>perties of the module.                       |

## Arbitration

This device supports only the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration. You cannot configure arbitration settings for this device.

## I/O Methods

This device does not support any I/O methods.

## **Module Methods**

Use the <u>FPGA I/O Method Node</u> to access the following module methods for this device.

| Method            | Description                                                                                                                                                                                                                                                                                                                       |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fetch Record Data | Fetches the next available sample from each ch<br>annel in the Triggered Records. Updates the nu<br>mber of remaining elements of the current recor<br>d, and the number of remaining records. This m<br>ethod cannot be executed at the same time as t<br>he Al <b>x</b> I/O node or any of the Trigger Record Met<br>hod Nodes. |

|                            | <ul> <li>Records Remaining—Indicates the n umber of records available to be fetched f rom the module.</li> <li>Elements Remaining—Indicates the number of samples available to be fetche d from the current record.</li> <li>Timeout—Specifies the minimum num ber of ticks the Method Node waits before timing out. The Method Node times out if the data is not yet available to access. Set this parameter to -1 if you want the Method Node to wait indefinitely.</li> </ul> |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Trigger Record on HW Event | Triggers a record event whenever a hardware ev<br>ent occurs on a single channel. Any hardware ev<br>ent that occurs outside of this execution will be l<br>ost. Once there are no more records available to<br>trigger, you cannot send any more triggers.                                                                                                                                                                                                                      |
|                            | <ul> <li>AI Channel—Specifies which input cha<br/>nnel the hardware event will come from.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                             |
|                            | <ul> <li>Trigger Slope—Specifies the slope dir<br/>ection of the hardware event. Can be eith<br/>er "Positive" or "Negative".</li> </ul>                                                                                                                                                                                                                                                                                                                                         |
|                            | <ul> <li>Trigger Level—Specifies the voltage le vel used to trigger a record.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                         |
|                            | • Hysteresis Value—Specifies the hyste<br>resis value for the trigger. If the Trigger Slo<br>pe is positive, the Hysteresis Value will be<br>below the Trigger Level. If the Trigger Slop<br>e is negative, the Hysteresis Value will be a<br>bove the Trigger Level.                                                                                                                                                                                                            |
|                            | • <b>Timeout</b> —Specifies the minimum num<br>ber of ticks the Method Node waits before<br>timing out. The Method Node times out if<br>the module cannot be triggered or if the h<br>ardware event condition has not been me<br>t. Set this parameter to -1 if you want the<br>Method Node to wait indefinitely. The har                                                                                                                                                        |

|                                               | dware event may be missed if timeout is s et to a small number of ticks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Trigger Record On HW Event (Multiple Sources) | Triggers a record event whenever a hardware ev<br>ent occurs on any channel. Any hardware event<br>that occurs outside of this execution will be lost.<br>Once there are no more records available to trig<br>ger, you cannot send any more triggers.                                                                                                                                                                                                                                                                                                    |
|                                               | • <b>Trigger Configuration</b> —Specifies the trigger configurations for each channel. E ach of these contains the following chann els: Enable, Trigger Slope, Trigger Level, a nd Hysteresis Value.                                                                                                                                                                                                                                                                                                                                                     |
|                                               | • Timeout—Specifies the minimum num<br>ber of ticks the Method Node waits before<br>timing out. The Method Node times out if<br>the module cannot be triggered or if the h<br>ardware event condition has not been me<br>t. Set this parameter to -1 if you want the<br>Method Node to wait indefinitely. The har<br>dware event may be missed if timeout is s<br>et to a small number of ticks.                                                                                                                                                         |
| Trigger Record                                | <ul> <li>Signals the module to trigger a record. Once the re are no more records available to trigger, you c an not send any more triggers.</li> <li>Timeout—Specifies the minimum num ber of ticks the Method Node waits before timing out. The Method Node times out if the module cannot be triggered. Set this p arameter to -1 if you want the Method No de to wait until the module can trigger. Se t this parameter to 0 if you want the Meth od Node to trigger immediately if there is not already already a record being acquire d.</li> </ul> |

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following I/O properties for this device.

| Property                                        | Description                                    |
|-------------------------------------------------|------------------------------------------------|
| Enable Analog Filter                            | Changes the configuration of the analog filter |
| LSB Weight (High-Resolution)                    | Returns the LSB weight in nV/LSB.              |
| LSB Weight (High-Speed, Analog Filter Disabled) | Returns the LSB weight in nV/LSB.              |
| LSB Weight (High-Speed, Analog Filter Enabled)  | Returns the LSB weight in nV/LSB.              |
| Offset (High-Resolution)                        | Returns the calibration offset in μV.          |
| Offset (High-Speed, Analog Filter Disabled)     | Returns the calibration offset in μV.          |
| Offset (High-Speed, Analog Filter Enabled)      | Returns the calibration offset in μV.          |

### **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following module properties for this device.

| Property                     | Description                                                                      |
|------------------------------|----------------------------------------------------------------------------------|
| Module ID                    | Returns the Module ID, 0x7889.                                                   |
| Serial Number                | Returns the unique serial number of the module .                                 |
| Vendor ID                    | Returns the NI vendor ID, 0x1093.                                                |
| Record Data Rate             | Specifies the rate at which the module acquires data for the Record Acquisition. |
| Record Pre-Trigger Samples   | Specifies the number of acquired samples prior to the trigger of a record.       |
| Continuous Data Rate         | Specifies the rate at which the module acquires data in continuous mode.         |
| Records Available to Fetch   | Returns the number of records available to fetch in the module.                  |
| Records Available to Trigger | Returns the number of records available to trigg er in memory.                   |
| Total Record Samples         | Specifies the number of samples per record.                                      |

Timing Mode

Changes the module configuration between Hig h-Speed and High-Resolution

## Single-Cycle Timed Loop

This device does not support the single-cycle Timed Loop.

C Series Module Properties Dialog Box for the NI 9775 (FPGA Interface)

Right-click an <u>NI 9775</u> C Series module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure a C Series module.

This dialog box includes the following components:

• Name—Specifies the name of the C Series module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the slot number. You can use this field to give the module a descriptive name.

• **Module Type**—Specifies the type of C Series module. You cannot change this option.

- Location—Specifies a slot in the chassis for the C Series module.
- Calibration Mode—Sets the calibration mode for the C Series module. Can be either "Calibrated" or "Raw."

• **Reference Clock Source**—Specifies the master timebase source used by the module.

• **Export Reference Clock**—Place a checkmark in this checkbox if you want to make this module accessible as a master timebase source to other modules.

• **Record Data Rate**—Specifies the rate at which the module acquires data for the Record Acquisition.

• **Record Pre-Trigger Samples**—Sets the number of acquired samples prior to the trigger of a record.

• **Record Samples**—Specifies the number of samples per record. The maximum number of record samples depend on the number of channels enabled.

• **Continuous Data Rate**—Specifies the rate at which the module acquires data in continuous mode. The maximum data rate depends on the number of channels enabled.

• **Channel Configuration**— Enables or disables each channel. Also sets the analog filter configuration for each channel.

• **Timing Mode**—Changes the module configuration between high-speed and high-resolution.

• Maximum Number of Records—Indicates the maximum number of records that can be potentially triggered based on the number of channels enabled and the record samples.

• **Reference Trigger Source**—Specifies the master trigger source used by this module. The default value is "Same as Ref Clock," which will set the trigger source for this module to the same as the reference clock source. You can configure a different reference trigger source as the reference clock source.

• **Export Reference Trigger**—Allows you to select this module as a reference trigger source for other modules. This checkbox will not appear if the reference trigger source is set to "Same as Ref Clock."

NI 9775 Acquisition Modes (FPGA Interface)

The <u>NI 9775</u> has three different acquisition modes: continuous mode, record mode, and advanced mode.

#### Continuous Mode

In continuous mode, the NI 9775 transfers real-time data to the chassis at an aggregate rate of 4MS/s across all channels. The NI 9775 will default to continuous mode after executing the Start I/O Node. You can configure the data rate through the Module Property **Continuous Data Rate**. The maximum value of the data rate varies based on the configuration, and can be found in the device datasheet at ni.com/manuals.

#### Implementing Continuous Mode

- 1. Configure the Timing Mode, Continuous Data Rate and Analog Filter Configuration.
- 2. Run the **Start** I/O Node.
- 3. Run the **Alx** I/O Node as many times as needed.
- 4. Run the **Stop** I/O Node.

Dpen example (continuous mode)

#### Record Mode

In record mode, the NI 9775 stores samples into onboard memory at up to 20 MS/s then transfers the data to the chassis at a slower rate. The start of the data collection is based on a trigger signal sent to the device. This signal can be digital or analog. The collected data is stored in the buffer until the entire acquisition is restarted.

#### **Implementing Record Mode**

- 1. Configure the Timing Mode, Record Data Rate, Record Samples, Record Pre-Trigger Samples, and Analog Configuration.
- 2. Run the **Start** I/O Node.
- 3. Trigger a record using any of the following nodes: **Trigger Record**, **Trigger Record**, **Trigger Record on HW Event**, or **Trigger Record on HW Event** (Multiple Sources).
- 4. Run the **Fetch Record Data** Method Node until there are no more samples available to fetch.
- 5. Run the **Stop** I/O Node.

🛃 Open example (record mode)

#### Advanced Mode

In advanced mode, the NI 9775 combines the functionality of continuous mode and record mode to enable more complex triggering. Advanced mode can use live data

from continuous mode to trigger a faster collection rate using record mode. This can be used for applications such as pattern detection or frequency triggering, and gives you more advanced triggering options.

#### **Implementing Advanced Mode**

- 1. Configure Timing Mode, Record Data Rate, Record Samples, Record Pre-Trigger Samples, Analog Filter Configuration, and Continuous Data Rate.
- 2. Run the **Start** I/O Node.
- 3. Use the **Alx** I/O Node to build a custom trigger condition.
- 4. Trigger on the custom trigger condition using any Trigger Record Method Node for as many times as needed, up to the number of available records.
- 5. Run the **Fetch Record Data** Method Node until there are no more samples available to fetch.
- 6. Run the **Stop** I/O Node.

Open example (advanced mode)