

# SpinCore PulseBlasterDDS

# LabVIEW Extensions

# **User's Manual**

| Instructions  | Frequencies (MHz)                      | Phases (Deg) |  |  |  |
|---------------|----------------------------------------|--------------|--|--|--|
| Comments      |                                        | ÷ o          |  |  |  |
|               |                                        | A D          |  |  |  |
|               | (v) 10                                 | A) 0         |  |  |  |
| Length        |                                        | ÷0           |  |  |  |
| TTL Output    |                                        | 40           |  |  |  |
|               | ······································ | 40           |  |  |  |
| $\frac{1}{2}$ |                                        | 4 D          |  |  |  |
|               |                                        | ÷ 0          |  |  |  |
|               | ······································ | AT D         |  |  |  |
| 6             |                                        | A) 0         |  |  |  |
|               |                                        | 40           |  |  |  |

SpinCore Technologies, Inc. http://www.spincore.com

# Congratulations and *thank you* for choosing a design from SpinCore Technologies, Inc.

We appreciate your business!

At SpinCore we try to fully support the needs of our customers. If you are in need of assistance, please contact us and we will strive to provide the necessary support.

© 2008 SpinCore Technologies, Inc. All rights reserved.

SpinCore Technologies, Inc. reserves the right to make changes to the product(s) or information herein without notice. RadioProcessor™, PulseBlaster™, SpinCore, and the SpinCore Technologies, Inc. logos are trademarks of SpinCore Technologies, Inc. All other trademarks are the property of their respective owners.

SpinCore Technologies, Inc. makes every effort to verify the correct operation of the equipment. This equipment version is not intended for use in a system in which the failure of a SpinCore device will threaten the safety of equipment or person(s).

# **Table of Contents**

| I. Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 5                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| II. Installation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 8                                                                            |
| Method 1: Stand-Alone Executables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 8                                                                            |
| Method 2: Customizable VIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 8                                                                            |
| III. General Information                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9                                                                            |
| Instruction Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 9                                                                            |
| Register Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 10                                                                           |
| Path Terminals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 12                                                                           |
| Error Terminals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 13                                                                           |
| LabVIEW Program Flow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 13                                                                           |
| IV. VI descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 14                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                              |
| Main VI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 14                                                                           |
| Main VI<br>PBLV_DDS_Interface.vi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>14</b><br>14                                                              |
| Main VI<br><u>PBLV_DDS_Interface.vi</u><br>Example VIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 14<br>14<br>15                                                               |
| Main VI         PBLV_DDS_Interface.vi.         PBLV_DDS_freq_test.vi.         PBLV_DDS_freq_test.vi.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>14</b><br>                                                                |
| Main VI         PBLV_DDS_Interface.vi         Example VIs         PBLV_DDS_freq_test.vi         PBLV_DDS_freq_test.vi         PBLV_DDS_phase_test.vi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                              |
| Main VI         PBLV_DDS_Interface.vi         PBLV_DDS_freq_test.vi         PBLV_DDS_freq_test.vi         PBLV_DDS_phase_test.vi         PBLV_DDS_amp_test.vi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                              |
| Main VI         PBLV_DDS_Interface.vi         Example VIs         PBLV_DDS_freq_test.vi         PBLV_DDS_phase_test.vi         PBLV_DDS_amp_test.vi         Basic SubVIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                              |
| Main VI       PBLV_DDS_Interface.vi         PBLV_DDS_Interface.vi       Example VIs         PBLV_DDS_freq_test.vi       PBLV_DDS_phase_test.vi         PBLV_DDS_amp_test.vi       PBLV_DDS_amp_test.vi         Basic SubVIs       pb_error_handler.vi                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                              |
| Main VI       PBLV_DDS_Interface.vi         PBLV_DDS_Interface.vi       Example VIs         PBLV_DDS_freq_test.vi       PBLV_DDS_phase_test.vi         PBLV_DDS_amp_test.vi       PBLV_DDS_amp_test.vi         Basic SubVIs       pb_error_handler.vi         pb_init.vi.       PBLV_I                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                              |
| Main VI       PBLV_DDS_Interface.vi.         PBLV_DDS_Interface.vi.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                              |
| Main VI       PBLV_DDS_Interface.vi.         PBLV_DDS_Interface.vi.       Example VIs.         PBLV_DDS_freq_test.vi.       PBLV_DDS_phase_test.vi.         PBLV_DDS_amp_test.vi.       PBLV_DDS_amp_test.vi.         Basic SubVIs.       pb_error_handler.vi.         pb_init.vi.       pb_set_default.vi.         pb_core_clock.vi.       PBLV_init.vi.                                                                                                                                                                                                                                                                                                                                                                |                                                                              |
| Main VI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                              |
| Main VI       PBLV_DDS_Interface.vi.         PBLV_DDS_Interface.vi.       PBLV_DDS_freq_test.vi.         PBLV_DDS_phase_test.vi.       PBLV_DDS_amp_test.vi.         PBLV_DDS_amp_test.vi.       PBLV_DDS_amp_test.vi.         Basic SubVIs.       pb_error_handler.vi.         pb_init.vi.       pb_set_default.vi.         pb_start_programming.vi.       pb_start_programming.vi.                                                                                                                                                                                                                                                                                                                                     | <b>14</b> 14 14 15 15 15 17 17 19 <b>21</b> 21 21 21 21 21 21 21 21 21 21 22 |
| Main VI         PBLV_DDS_Interface.vi.           PBLV_DDS_freq_test.vi.         PBLV_DDS_freq_test.vi.           PBLV_DDS_phase_test.vi.         PBLV_DDS_amp_test.vi.           PBLV_DDS_amp_test.vi.         PBLV_DDS_amp_test.vi.           Basic SubVIs.         pb_error_handler.vi.           pb_init.vi.         pb_set_default.vi.           pb_set_default.vi.         pb_start_programming.vi.           pb_set_freq.vi.         pb_set_phase.vi.                                                                                                                                                                                                                                                              |                                                                              |
| Main VI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                              |
| Main VI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                              |
| Main VI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                              |
| Main VI         PBLV_DDS_Interface.vi.         PBLV_DDS_freq_test.vi.         PBLV_DDS_phase_test.vi.         PBLV_DDS_amp_test.vi.         PBLV_DDS_amp_test.vi.         Basic SubVIs.         pb_error_handler.vi.         pb_set_default.vi.         pb_set_default.vi.         pb_set_freq.vi.         pb_set_freq.vi.         pb_set_freq.vi.         pb_set_amp.vi.         pb_set_amp.vi.         pb_inst_dds.vi.         pb_stop_programming.vi.         pb_stop_programming.vi.         pb_stop_programming.vi.         pb_stop_programming.vi.         pb_stop_programming.vi.         pb_stop_programming.vi.         pb_stop_programming.vi.         pb_stop_programming.vi.         pb_stop_programming.vi. |                                                                              |

| V. Contact Information24 |
|--------------------------|
|--------------------------|

### I. Overview

The SpinCore PulseBlasterDDS LabVIEW Extensions (PBLV-DDS) provide the functionality of programming and controlling digital pulse and RF generation in PulseBlasterDDS and RadioProcessor boards using the simple NI LabVIEW graphical programming interface. The package contains basic subVIs that can be used to include PulseBlasterDDS interaction from your own LabVIEW programs, as well as some complete example VIs. Additionally, all of the examples are available as stand-alone applications to control.

The PBLV-DDS is an intuitive graphical equivalent of the SpinAPI C functions. The GUI (known as the front panel) has all the inputs needed to access the PulseBlaster including instruction registers, clock frequency, and buttons for loading, starting, and stopping the board. The input is then used in the back-end code (known as the block diagram) to access the C functions that control and program the PulseBlasterDDS. The LabVIEW block diagram is a one-to-one equivalent of the corresponding C code, without having to write code. An example of the front panel and block diagram are shown in Figure 1 and Figure 2.

Note: For information on using the the Digital Pulse Generation functionality of the board in LabVIEW, please see the PulseBlaster LabVIEW Extensions <u>documentation</u>. (<u>http://www.spincore.com/CD/PBLV/PBLV\_Manual.pdf</u>)</u>

All example VIs and subVIs are described in detail below.



Figure 1: Example of PulseBlasterDDS LabVIEW Extensions User Interface



Figure 2: Example of PulseBlaster-DDS LabVIEW Extensions Block Diagram

## **II. Installation**

There are two methods of using the PulseBlasterDDS LabVIEW Extensions. The first method is a set of stand-alone executables which will control the PulseBlasterDDS boards with a simple, intuitive interface with no other necessary knowledge of LabVIEW programming. The second method is a set of LabVIEW VIs which can be used with the LabVIEW Development platform to create custom programs using the PBLV interface.

### Method 1: Stand-Alone Executables

In order for PBLV-DDS-II stand-alone executables to work, the following must be installed:

- SpinCore Driver Suite Please see the <u>SpinCore Driver Suite Installation Guide</u> (<u>http://www.spincore.com/support/spinapi/instructions/</u>) for more information.
- National Instruments <u>LabVIEW Run-Time Engine 2010</u> (<u>http://www.spincore.com/support/PBLV/LVRTE2010std.exe</u>) - Note if you have LabVIEW 2010 or later installed, this is not needed.
- LabVIEW PulseBlaster Extensions Stand-Alone executables located here.

### Method 2: Customizable VIs

In order for PBLV-DDS-II customizable VIs to work, the following must be installed:

- SpinCore Driver Suite Please see the <u>SpinCore Driver Suite Installation Guide</u> (<u>http://www.spincore.com/support/spinapi/instructions/</u>) for more information.
- National Instruments LabVIEW 8.6 or later If you do not have LabVIEW 8.6 or later installed, you may download a <u>30-day evaluation</u>. (<u>https://lumen.ni.com/nicif/us/lveval/content.xhtml</u>) of the latest LabVIEW development software.
   (NOTE: Customizable VIs for versions of LabVIEW as old as LabVIEW 8.0 are available. For customizable VIs older than LabVIEW 8.6 please contact SpinCore Technologies via the <u>web forum</u>.)
- LabVIEW PulseBlaster Extensions located <u>here</u>. (NOTE: Customizable VIs use the C-calling convention. For customizable VIs that use the WINAPI calling convention please contact SpinCore Technologies via the <u>web forum</u>.)

# **III. General Information**

### Instruction Description



Throughout the PulseBlasterDDS LabVIEW Extension, the instruction word, corresponding to a given interval in the pulse sequence, is given as shown to the left. The instruction on the front panel (Figure 3) is broken up into 10 fields displayed from top to bottom:

- <u>Comment space</u> is an empty text box. This area is used to annotate your instruction and is not programmed onto the PulseBlasterDDS board.
- <u>Time</u> is the duration that the current instruction is to be held in microseconds. Range and resolution varies depending on what board is being used. This corresponds to "length" in SpinAPI.
- <u>Output Pattern</u> determines the state of each TTL output bit. If an LED is on then it's corresponding output bit is high, and if the LED is off then it's corresponding output bit is low. This corresponds to "flags" in SpinAPI.
- <u>RF Output Enable</u> tells the DDS board whether the RF output should be enabled during this instruction. This corresponds to "tx\_enable" in SpinAPI.
- <u>Phase Reset</u> tells the DDS board to reset the phase of all DDS channels to their time=0 phase. They will stay in this state until the value of this bit returns to 0. This corresponds to "phase\_reset" in SpinAPI.
- <u>Frequency Register Select</u> determines which frequency register will be used for the RF output during this instruction. Refer to your board manual for the number of frequency registers available. This

Figure 3: PulseBlaster Instruction

corresponds to "freq" in SpinAPI.

- <u>Phase Register Select</u> determines which phase register will be used for the RF output during this instruction. Refer to your board manual for the number of phase registers available. This corresponds to "tx\_phase" in SpinAPI.
- <u>Amplitude Register Selects</u> determines which amplitude register will be used for the RF output during this instruction. Refer to your board manual for the number of amplitude registers available. This corresponds to "amp" in SpinAPI.
- <u>Program Flow</u> determines the flow of program instructions *after* the bit pattern is displayed. This corresponds to "inst" in SpinAPI. Available instructions are:

- CONTINUE Program execution continues to next instruction.
- STOP Stop execution of program.
- LOOP Specify beginning of a loop. Execution continues to next instruction. Instruction data used to specify number of loops.
- END\_LOOP Execution returns to beginning of loop and decrements loop counter. Instruction data used to specify beginning of loop.
- JSR Program execution jumps to beginning of a subroutine. Instruction data used to specify address of first subroutine instruction.
- RTS Program execution returns to instruction after JSR was called.
- BRANCH Program execution continues at specified instruction. Instruction data specifies address of next instruction.
- LONG\_DELAY For long interval instructions. Data field specifies a multiplier of the length field. Execution continues to next instruction.
- WAIT Program execution stops and waits for software or hardware trigger.
   Execution continues to next instruction after receipt of trigger. (Please see SpinAPI documentation for more information on limits of certain Op Codes)
- Instruction Data is the data to be used for certain instructions determined by the Op Code. This corresponds to "inst\_data" in SpinAPI. Note for certain instructions this field is not used.

Figure 4 Below shows detail of the corresponding instruction word as depicted in LabVIEW's block diagram.



Figure 4: Example of how the instruction is created and sent to the board in the PBLV-DDS Block Diagram

### **Register Descriptions**

In each PBLV-DDS program, there are 3 banks of registers which must be set before programming the board. These are the frequency registers, phase registers and amplitude registers as shown in Figure 5.

Frequencies are specified in MHz and can be programmed in the range specified in your board manual. The registers shown on the front panel range from 0 at the top down to 15 at the bottom, but the number of frequency registers available vary depending on the board. See your board manual for the number of output frequency registers available. The specific frequency registers must be set in the register bank in order to be used in an instruction as described above. If the register box is white, then it will be programmed to the board and can be used. If it is grayed out, it will not be programmed and therefore cannot be used in an instruction. To make a grayed out register box white, simply click inside the box and type the value you want. To gray out a white register box, right-click on the box, select "Data Operations", and then select "Delete Element."

Phases are specified in degrees and can be set from 0.0 to 365.0 degrees. The registers shown on the front panel range from 0 at the top down to 15 at the bottom, but the number of phase registers available vary depending on the board. See your board manual for the number of output phase registers available. The specific phase registers must be set in the register bank in order to be used in an instruction as described above. If the register box is white, then it will be programmed to the board and can be used. If it is grayed out, it will not be programmed and therefore cannot be used in an instruction. To make a grayed out register box white, simply click inside the box and type the value you want. To gray out a white register box, right-click on the box, select "Data Operations", and then select "Delete Element."

Amplitudes are specified as a percentage of full power and ranges from 0.0 to 1.0. The registers shown on the front panel range from 0 at the top down to 3 at the bottom. There are only 4 amplitude registers available. The specific frequency registers must be set in the register bank in order to be used in an instruction as described above. If the register box is white, then it will be programmed to the board and can be used. If it is grayed out, it will not be programmed and therefore cannot be used in an instruction. To make a grayed out register box white, simply click inside the box and type the value you want. To gray out a white register box, right-click on the box, select "Data Operations", and then select "Delete Element."

| Frequencies (MHz)          | Phases (Deg) | Amplitudes (0-1) |
|----------------------------|--------------|------------------|
|                            | ÷) o         |                  |
|                            | 90           | € 0.5            |
| ÷ 5                        | ÷) 180       |                  |
| ÷ 10                       | A) D         |                  |
| 15                         |              |                  |
| $\frac{\lambda}{\nabla}$ 1 | ÷) O         |                  |
| $\frac{x}{\tau}$ 1         | A D          |                  |
|                            | A) D         |                  |
|                            | é) o         |                  |
|                            | ÷) o         |                  |
|                            | ζ) O         |                  |
| × 1                        | ÷) o         |                  |
|                            | ÷) o         |                  |
|                            | ÷) o         |                  |
|                            | ÷ O          |                  |
|                            | A) 0         |                  |

Figure 5: Frequency, Phase and Amplitude Registers

### Path Terminals

All of the SubVIs have path input and output terminals. This is a reference to the path where spinapi.dll is installed on the PC. The default is C:\SpinCore\SpinAPI\dll\spinapi.dll however this may be changed depending on the

installation. All subVIs should have the "path in" input connected. For ease of programming, the path terminals can be daisy chained since all subVIs point to the same dll. See Figure 6 and Figure 7 for an example of chaining these terminals.





Figure 7: Example of chaining path and error terminals

### **Error Terminals**

All of the SubVIs have error input and output terminals. When a VI is built, the "error out" terminal of a subVI should be connected to the "error in" terminal of the following subVI. These terminals are used to help facilitate sequential execution of the functions, as well as provide debugging information to the user if an error occurs in the VI. See Figure 6 and Figure 7 for an example of these terminals. When chaining, the order of the subVIs corresponds to the order in which the functions will be called.

### LabVIEW Program Flow

The LabVIEW Block diagram is set up to independently control the four major functions (start/restart, stop/reset, load, change) using four while loops running in parallel. Within each loop is another loop that continuously waits for the specified button to be pressed. Once the button is pressed, the inner loop will exit and program flow will be passed to the chain of subVIs. After the chain of functions complete, program flow will return to the inner loop to wait for the button again. An example of this is shown in Figure 8.



Figure 8: LabVIEW Program Flow Example

# **IV. VI descriptions**

### Main VI

#### PBLV\_DDS\_Interface.vi

The PBLV-DDS Interface VI allows the user complete control of the PulseBlasterDDS board.

To start the VI press the Run button at the top of the LabVIEW window (for standalone programs, the program is run automatically when opened). First you must insert the clock frequency value of the board into the "clock\_freq (MHz)" field as well as the path to spinapi.dll as described above. Next, make any instruction set you want by editing the instruction fields. Use the "# of Instructions" field to increase or decrease the number of instructions you want to program. Once you have your instruction set, you can edit the frequency, phase, and amplitude registers to the values you want.

When the instructions and registers are set up correctly, you must first load the board by clicking the "LOAD BOARD" button and then wait until the button becomes inactive. To start the program click on the "START" button, and to stop the program click on the "STOP" button. If there are multiple boards connected to your computer, the "CHANGE BOARD" button will change the board that is being programmed to the one specified by the "board\_num" field. All four functions are independent and may be run at any time, however an instruction sequence must be loaded into the board before it can be started. **Caution**: After pressing STOP, all digital output bits may maintain their final state. The RF output will return to 0V when the stop button is pressed.

See Figure 1 for a screen shot of the PBLV-DDS Interface.

### **Example VIs**

#### PBLV\_DDS\_freq\_test.vi

The PBLV-DDS Frequency Test VI outputs a sine wave cycling through 4 different frequencies which are set in the frequency registers.

To start the VI press the Run button at the top of the LabVIEW window (for standalone programs, the program is run automatically when opened). First you must insert the clock frequency value of the board into the "clock\_freq (MHz)" field as well as the path to spinapi.dll as described above. Next, the appropriate frequency, phase, and amplitude registers must be set. Initially frequency registers 0,1,2, and 3 are set to 1,5,10 and 15 MHz respectively, phase register 0 is set to 0 degrees, and amplitude register 0 is set to 1. Then the instructions must be set up appropriately. This VI programs the PBDDS board with 6 instructions. The first instruction resets the phase and the RF output is disabled. The next four instructions use phase register 0 and amplitude register 0, 1, 2, and 3 respectively. All instructions use phase register 0 and amplitude register 0. The last instruction disables the output for 1 ms to allow for oscilloscope triggering. You may change these instructions, and registers as desired.

When the instructions and registers are set up correctly, you must first load the board by clicking the "LOAD BOARD" button and then wait until the button becomes inactive. To start the program click on the "START" button, and to stop the program click on the "STOP" button. If there are multiple boards connected to your computer, the "CHANGE BOARD" button will change the board that is being programmed to the one specified by the "board\_num" field. All four functions are independent and may be run at any time, however an instruction sequence must be loaded into the board before it can be started. **Caution**: After pressing STOP, all digital output bits may maintain their final state. The RF output will return to 0V when the stop button is pressed.

See Figure 9 for a screen shot of the PBLV-DDS Frequency Test.

| <b>SpinCore PulseBl</b> a<br>ile <u>E</u> dit <u>V</u> iew <u>P</u> roj | ect <u>O</u> perate | Extension - DI<br>Tools <u>W</u> indow | )S-I Frequency<br>Help            | / Test [PBLV_[            | )DS_I_freq_te                                        | est.vi] Front Panel                              | *                |                    |                      |           |
|-------------------------------------------------------------------------|---------------------|----------------------------------------|-----------------------------------|---------------------------|------------------------------------------------------|--------------------------------------------------|------------------|--------------------|----------------------|-----------|
| ₽ 0                                                                     | 13pt App            | ication Font                           |                                   | - 🖷 - 🏷 -                 | 1                                                    |                                                  |                  |                    | • Search             |           |
|                                                                         |                     |                                        | SpinCo                            | ore Pulse<br>DDS<br>SpinC | Blaster L<br>-I Freque<br>Core Techno<br>www.spincor | abVIEW Ext<br>ency Test<br>logies, Inc.<br>e.com | ensions          |                    |                      |           |
| Instructions                                                            |                     |                                        |                                   |                           |                                                      | Frequencies (MHz)                                | Phases (Deg      | ) Amplitudes (0-1) | $\frown$             |           |
| Comments                                                                | Comments            | Comments                               | Comments                          | Comments                  | Comments                                             | <u>/</u> <u>7</u> 1                              | ÷) o             |                    |                      | $\geq$    |
|                                                                         |                     |                                        |                                   |                           |                                                      | <u>/</u> 5                                       | 0                |                    |                      |           |
| Length                                                                  | Length              | Length                                 | Length                            | Length                    | Length                                               |                                                  |                  | <u>/</u> 1         |                      |           |
| 1.000                                                                   | 1.000               | 1.000                                  | 1.000                             | 1.000                     | 1000.000                                             | (T) 15                                           | 0                |                    |                      |           |
| TTL Output                                                              | TTL Output          | TTL Output                             | TTL Output                        | TTL Output                | TTL Output                                           | 1                                                |                  |                    | CHANGE BOAF          | 2D        |
|                                                                         |                     |                                        |                                   |                           |                                                      | 1                                                | 0                |                    |                      |           |
| 2                                                                       | 2                   | 2                                      |                                   | 2                         | 2                                                    |                                                  | 0                |                    |                      |           |
|                                                                         |                     |                                        |                                   |                           |                                                      |                                                  | 0                |                    | LOAD BOAR            | )         |
| 5                                                                       | 5                   | 5                                      | 5                                 | 5                         | 5                                                    |                                                  |                  |                    |                      |           |
| <u> </u>                                                                |                     |                                        |                                   | 57                        |                                                      |                                                  |                  |                    |                      |           |
|                                                                         | 8                   | 8                                      | 8                                 | 8                         | 8                                                    |                                                  |                  |                    | START/RESTA          | RT        |
| TX_enable                                                               | TX_enable           | TX_enable                              | TX_enable                         | TX_enable                 | TX_enable                                            |                                                  |                  |                    | -                    |           |
| Phase Reset                                                             | Phase Reset         | Phase Reset                            | Phase Reset                       | Phase Reset               | Phase Reset                                          |                                                  |                  |                    |                      |           |
| Freq Register                                                           | Freq Register       | Freq Register                          | Freq Register                     | Freq Register             | Freq Register                                        |                                                  |                  |                    | STOP                 |           |
|                                                                         | - O                 | $\frac{\lambda}{\tau}$ 1               | <u>/</u> 2                        | x 3                       | A) O                                                 |                                                  |                  |                    |                      |           |
| Phase Register                                                          | Phase Register      | Phase Register                         | Phase Register                    | Phase Register            | Phase Register                                       | Y                                                | 510              |                    | Caution:             |           |
| Amp Register                                                            | Amp Register        | Amp Register                           | Amp Register                      | Amp Register              | Amp Register                                         |                                                  |                  |                    | After pre            | ssing     |
| 0                                                                       | 0                   |                                        |                                   |                           | ÷) o                                                 | Clock Freq (Mt                                   | (7) board r      | N 192              | output bits may      |           |
| Op Code                                                                 | Op Code             | Op Code                                | Op Code                           | Op Code                   | Op Code<br>Branch                                    | / 75                                             | (+) 0            |                    | maintain their final |           |
| Instruct Data                                                           | Instruct Data       | Instruct Data                          | Instruct Data                     | Instruct Data             | Instruct Data                                        |                                                  |                  |                    | state.               |           |
| 0(;)                                                                    | t) O                | $0\left(\frac{\lambda}{2}\right)$      | $0\left(\frac{\lambda}{2}\right)$ | (Ý) O                     | 0                                                    | Location of spinar                               | pinAPI\dll\spina | api.dl             |                      | <b>b</b>  |
|                                                                         |                     |                                        |                                   |                           |                                                      |                                                  |                  | INDIRU             | INIEM IS             |           |
|                                                                         |                     |                                        |                                   |                           |                                                      |                                                  | La               | <b>DVIEW</b> E     | valuation Sof        | tware     |
| valuation 🔺                                                             |                     |                                        |                                   |                           |                                                      |                                                  |                  |                    |                      | <u>ار</u> |

Figure 9: LabVIEW PulseBlasterDDS Extension – Frequency Test

#### PBLV\_DDS\_phase\_test.vi

The PBLV-DDS Phase Test VI outputs a sine wave cycling through 4 different phases which are set in the phase registers.

To start the VI press the Run button at the top of the LabVIEW window (for standalone programs, the program is run automatically when opened). First you must insert the clock frequency value of the board into the "clock\_freq (MHz)" field as well as the path to spinapi.dll as described above. Next, the appropriate frequency, phase, and amplitude registers must be set. Initially phase registers 0, 1, 2, and 3 are set to 0°, 90°, 180°, and 270° respectively, frequency register 0 is set to 1 MHz, and amplitude register 0 is set to 1. Then the instructions must be set up appropriately. This VI programs the PBDDS board with 6 instructions. The first instruction resets the phase and the RF output is disabled. The next four instructions enable output for 1 us and use phase registers 0, 1, 2, and 3 respectively. All instructions use frequency register 0 and amplitude register 0. The last instruction disables the output for 1 ms to allow for oscilloscope triggering. You may change these instructions, and registers as desired.

When the instructions and registers are set up correctly, you must first load the board by clicking the "LOAD BOARD" button and then wait until the button becomes inactive. To start the program click on the "START" button, and to stop the program click on the "STOP" button. If there are multiple boards connected to your computer, the "CHANGE BOARD" button will change the board that is being programmed to the one specified by the "board\_num" field. All four functions are independent and may be run at any time, however an instruction sequence must be loaded into the board before it can be started. **Caution**: After pressing STOP, all digital output bits may maintain their final state. The RF output will return to 0V when the stop button is pressed.

See Figure 10 for a screen shot of the PBLV-DDS Phase Test.

| SpinCore Pulse<br>Edit <u>V</u> iew I | Blaster LabVI<br>Project Operat | EW Extension<br>e <u>T</u> ools <u>W</u> ind | - DDS-I Phase<br>ow <u>H</u> elp | Test [PBLV_D                      | DS_I_phase_t                                              | est.vi] Front Pa                            | nel                             |                        |                                       |
|---------------------------------------|---------------------------------|----------------------------------------------|----------------------------------|-----------------------------------|-----------------------------------------------------------|---------------------------------------------|---------------------------------|------------------------|---------------------------------------|
| ⇒                                     | 13pt                            | Application Font                             | ╶                                | ·⊡• ≝• (                          | \$ <b>5</b> -                                             |                                             |                                 |                        | Search 🔍 🤶 🎬                          |
|                                       |                                 |                                              | SpinCo                           | ore Pulsel<br>DE<br>SpinC         | Blaster La<br>DS-I Phase<br>fore Technolo<br>www.spincore | abVIEW Ex<br>e Test<br>ogies, Inc.<br>e.com | xtension                        | S                      |                                       |
| Instructions                          |                                 |                                              |                                  |                                   |                                                           | Frequencies (M                              | Hz) Phases (De                  | g) Amplitudes (        | (0-1)                                 |
| Comments                              | Comments                        | Comments                                     | Comments                         | Comments                          | Comments                                                  |                                             | - <del>(</del> ) 0              | $-\frac{\lambda}{v}$ 1 |                                       |
|                                       |                                 |                                              |                                  |                                   |                                                           | × 1                                         | 90                              |                        |                                       |
| Length                                | Length                          | Length                                       | Length                           | Length                            | Length                                                    |                                             | ()<br>180                       |                        | <u> </u>                              |
| 1.000                                 | 1.000                           | 1.000                                        | 1.000                            | 1.000                             | 1000.000                                                  |                                             | 270                             | 1                      |                                       |
| 0                                     | 0                               | 0                                            |                                  | 0                                 | 0                                                         |                                             |                                 | _                      | CHANGE BOARD                          |
|                                       |                                 |                                              |                                  |                                   |                                                           |                                             |                                 | -                      |                                       |
|                                       |                                 |                                              |                                  | $\mathbf{S} \frac{\mathbf{Z}}{3}$ |                                                           |                                             |                                 |                        |                                       |
|                                       |                                 |                                              |                                  |                                   |                                                           | $\frac{\lambda}{\tau}$ 1                    | $-\frac{1}{\tau}$ 0             |                        |                                       |
| 6                                     | 6                               | 6                                            | 6                                | 6                                 | 6                                                         | $\frac{\lambda}{\nabla}$ 1                  |                                 |                        |                                       |
| 8                                     | 8                               |                                              | 8                                |                                   | 8                                                         |                                             |                                 |                        | START/RESTART                         |
| TX_enable                             | TX_enable                       | TX_enable                                    | TX_enable                        | TX_enable                         | TX_enable                                                 | <u> </u>                                    |                                 |                        |                                       |
| Phase Reset                           | Phase Reset                     | Phase Reset                                  | Phase Reset                      | Phase Reset                       | Phase Reset                                               |                                             |                                 | _                      |                                       |
| Freq Register                         | Freq Register                   | Freq Register                                | Freq Register                    | Freq Register                     | Freq Register                                             |                                             |                                 |                        | STOP                                  |
| 0                                     | ÷0                              | ÷ o                                          | ÷ o                              | ÷ o                               | ÷ O                                                       |                                             |                                 | -                      |                                       |
| Phase Register                        | Phase Register                  | Phase Register                               | Phase Register                   | Phase Register                    | Phase Register                                            |                                             |                                 |                        | After pressing                        |
| Amp Register                          | Amp Register                    | Amp Register                                 | Amp Register                     | Amp Register                      | Amp Register                                              |                                             |                                 |                        | STOP, all                             |
| 0<br>Op Code                          | 0<br>Op Code                    | O<br>Op Code                                 | 0<br>Op Code                     | O Op Code                         | 0<br>Op Code                                              | Clock Freq (                                | MHz) board_                     | num                    | maintain their final                  |
| Continue                              | Continue<br>Testruct Data       | Continue                                     | Continue                         | Continue                          | Branch                                                    |                                             | 0                               |                        | state.                                |
|                                       |                                 |                                              |                                  |                                   |                                                           | Location of s                               | spinapi.dll<br>pre\SpinAPI\dll\ | spipapi. dll           |                                       |
|                                       |                                 |                                              |                                  |                                   |                                                           |                                             |                                 | NATIO                  | ONAL<br>UMENTS<br>Evoluction Software |
| aluation                              |                                 |                                              |                                  |                                   |                                                           |                                             | 1.3                             | inalean-               | Evaluation Soltware                   |

Figure 10: LabVIEW PulseBlasterDDS Extension – Phase Test

#### PBLV\_DDS\_amp\_test.vi

The PBLV-DDS Amplitude Test VI outputs a sine wave cycling through 4 different amplitudes which are set in the amplitude registers.

To start the VI press the Run button at the top of the LabVIEW window (for standalone programs, the program is run automatically when opened). First you must insert the clock frequency value of the board into the "clock\_freq (MHz)" field as well as the path to spinapi.dll as described above. Next, the appropriate frequency, phase, and amplitude registers must be set. Initially amplitude registers 0, 1, 2, and 3 are set to 0.25, 0.5, 0.75, and 0.99 respectively (this signifies 25%, 50%, 75% and 99% amplitude), frequency register 0 is set to 1 MHz, and amplitude register 0 is set to 1. \*Note that due to an unknown issue in some boards, if the amplitude is set to 1 (100%) the output waveform is inverted.\* Next the instructions must be set up appropriately. This VI programs the PBDDS board with 6 instructions. The first instruction resets the phase and the RF output is disabled. The next four instructions enable output for 1 us and use amplitude register 0, 1, 2, and 3 respectively. All instructions use frequency register 0 and phase register 0. The last instruction disables the output for 1 ms to allow for oscilloscope triggering. You may change these instructions and registers as desired.

When the instructions and registers are set up correctly, you must first load the board by clicking the "LOAD BOARD" button and then wait until the button becomes inactive. To start the program click on the "START" button, and to stop the program click on the "STOP" button. If there are multiple boards connected to your computer, the "CHANGE BOARD" button will change the board that is being programmed to the one specified by the "board\_num" field. All four functions are independent and may be run at any time, however an instruction sequence must be loaded into the board before it can be started. **Caution**: After pressing STOP, all digital output bits may maintain their final state. The RF output will return to 0V when the stop button is pressed.

See Figure 11 for a screen shot of the PBLV-DDS Phase Test.



Figure 11: LabVIEW PulseBlasterDDS Extension – Amplitude Test

### **Basic SubVIs**

These SubVIs use Call Library Function Nodes to access SpinAPI's C-functions. By default these nodes use the C-calling convention. For customizable VIs that use the WINAPI calling convention please contact SpinCore Technologies via the <u>web forum</u>.

#### pb\_error\_handler.vi

This VI will catch an error from SpinAPI and pass it into the LabVIEW code for debugging purposes. It takes the return code from any function call and determines if there is an error (return code is a negative number). If an error occurred, the VI calls pb\_get\_error from SpinAPI which returns the error text. This error text added to the LabVIEW error cluster and the error status bit is set true. All functionality will be bypassed if a previous error is passed into the VI.

#### pb\_init.vi

#### Corresponds to the SpinAPI function int pb\_init()

This VI initializes the SpinCore board. It calls the pb\_init function from SpinAPI using the Call Library Function Node. It then checks for an error using the pb\_error\_handler. If there was an error at this stage, the VI determines if the board was not previously closed, if so the VI clears the error, closes the board and retries pb\_init. All functionality will be bypassed if an error is passed into the VI.

#### pb\_set\_default.vi

#### Corresponds to the SpinAPI function int pb\_set\_default()

This VI sets the RadioProcessor/PBDDS to its default state. This function should generally be called after pb\_init() to make sure the RadioProcessor is in a usable state. It is REQUIRED that this be called at least once after the board is powered on. It calls the pb\_set\_defaults function from SpinAPI using the Call Library Function Node. It then checks for an error using the pb\_error\_handler. All functionality will be bypassed if an error is passed into the VI.

#### pb\_core\_clock.vi

#### Corresponds to the SpinAPI function void set\_clock(double clock\_freq)

This VI sets the clock frequency of the board in MHz. It calls the pb\_set\_clock function from SpinAPI using the Call Library Function Node. All functionality will be bypassed if an error is passed into the VI.

#### pb\_start\_programming.vi

Corresponds to the SpinAPI function int pb\_start\_programming(int device)

This VI initializes the system to receive programming information. It calls the pb\_start\_programming function from SpinAPI using the Call Library Function Node. The Device Enum Control sets the device input of the pb\_start\_programming function. It then checks for an error using the pb\_error\_handler. All functionality will be bypassed if an error is passed into the VI.

#### pb\_set\_freq.vi

#### Corresponds to the SpinAPI function int pb\_set\_freq(double freq)

This VI will write the given frequency, in MHz to a frequency register on a DDS enabled board. and then check for errors. To do this, first call pb\_start\_programming.vi, and pass it "Frequency Registers". The first call pb\_set\_freq.vi will then program frequency register 0, the second call will program frequency register 1, etc. When you have programmed all the registers you intend to, call pb\_stop\_programming.vi. All functionality will be bypassed if an error is passed into the VI.

#### pb\_set\_phase.vi

#### *Corresponds to the SpinAPI function int pb\_set\_phase(double phase)*

This VI will write the given phase to a phase register on DDS enabled boards and then check for errors. To do this, first call pb\_start\_programming.vi, and specify the appropriate bank of phase registers (TX Phase Registers or RX Phase Registers) as the argument. The first call pb\_set\_phase.vi will then program phase register 0, the second call will program phase register 1, etc. When you have programmed all the registers you intend to, call pb\_stop\_programming.vi. The given phase value may be rounded to fit the precision of the board. All functionality will be bypassed if an error is passed into the VI.

#### pb\_set\_amp.vi

#### Corresponds to the SpinAPI function int pb\_set\_amp(float amp, int addr)

This VI will write the given amplitude to the given amplitude register on DDS enabled boards and then check for errors. The VIs pb\_start\_programming.vi and pb\_stop\_programming.vi are not needed to set the amplitude. The given amplitude value may be rounded to fit the precision of the board. All functionality will be bypassed if an error is passed into the VI.

#### pb\_inst\_dds.vi

Corresponds to the SpinAPI function int pb\_inst\_radio\_shape (int freq, int cos\_phase, int sin\_phase, int tx\_phase, int tx\_enable, int phase\_reset, int trigger\_scan, int use\_shape, int amp, int flags, int inst, int inst\_data, double length) with shape functionality disabled.

This VI sends one instruction of the DDS pulse program to the board. It calls the pb\_inst\_radio\_shape function from SpinAPI using the Call Library Function Node. The instruction control is the 80-bit VLIW to be programmed to the board. It contains the 4 bit frequency register, 4 bit phase register, 1 bit tx\_enable, 1 bit phase reset, 9 bit digital output, Op Code (which instruction to be executed), instruction data and length that the instruction should be carried out It then checks for an error using the pb\_error\_handler. All functionality will be bypassed if an error is passed into the VI.

#### pb\_stop\_programming.vi

#### Corresponds to the SpinAPI function int pb\_stop\_programming()

This VI tells the board that programming the is complete. It calls the pb\_stop\_programming function from SpinAPI using the Call Library Function Node. It then checks for an error using the pb\_error\_handler. All functionality will be bypassed if an error is passed into the VI.

#### pb\_close.vi

#### Corresponds to the SpinAPI function int pb\_close()

This VI releases SpinCore board. It calls the pb\_close function from SpinAPI using the Call Library Function Node. It then checks for an error using the pb\_error\_handler. All functionality will be bypassed if a previous error is passed into the VI.

#### pb\_start.vi

#### Corresponds to the SpinAPI function int pb\_start()

Once board has been programmed, this instruction will start execution of pulse program. It calls the pb\_start function from SpinAPI using the Call Library Function Node. It then checks for an error using the pb\_error\_handler. All functionality will be bypassed if an error is passed into the VI.

#### pb\_stop.vi

#### Corresponds to the SpinAPI function int pb\_stop()

This VI stops output of the board. It calls the pb\_stop function from SpinAPI using the Call Library Function Node. It then checks for an error using the pb\_error\_handler. All functionality will be bypassed if an error is passed into the VI.

# **V. Contact Information**

SpinCore Technologies, Inc. 4631 NW 53rd Avenue, SUITE 103 Gainesville, FL 32653 USA

Telephone (USA): Fax (USA): Website: Web Form: 352-271-7383 352-371-8679 http://www.spincore.com http://www.spincore.com/contact.shtml