

## **PulseBlasterDDS**<sup>™</sup>

## Model DDS-I-300

(USB Board Version SP7)

## **Owner's Manual**

SpinCore Technologies, Inc. https://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.

© 2007 - 2025 SpinCore Technologies, Inc. All rights reserved.

SpinCore Technologies, Inc. reserves the right to make changes to the product(s) or information herein without notice.

PulseBlasterDDS<sup>™</sup>, PulseBlaster<sup>™</sup>, 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. Introduction                                                                                                                                                                                                                                                                                                                                                                         | <u>3</u>                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                         | 4                                                  |
| Product Overview                                                                                                                                                                                                                                                                                                                                                                        |                                                    |
| Board Architecture                                                                                                                                                                                                                                                                                                                                                                      |                                                    |
| Block Diagram                                                                                                                                                                                                                                                                                                                                                                           |                                                    |
| Product Specifications                                                                                                                                                                                                                                                                                                                                                                  |                                                    |
| RF Output Level                                                                                                                                                                                                                                                                                                                                                                         |                                                    |
| II. Installation                                                                                                                                                                                                                                                                                                                                                                        | <u>8</u>                                           |
| Installing the PulseBlasterDDS-I-300                                                                                                                                                                                                                                                                                                                                                    |                                                    |
| Testing the PulseBlasterDDS-I-300                                                                                                                                                                                                                                                                                                                                                       |                                                    |
| III. Using the PulseBlasterDDS-I-300                                                                                                                                                                                                                                                                                                                                                    | 11                                                 |
| Controlling the PulseBlasterDDS-I-300 with SpinAPI                                                                                                                                                                                                                                                                                                                                      |                                                    |
| Frequency and Phase Registers                                                                                                                                                                                                                                                                                                                                                           |                                                    |
| Sample Output                                                                                                                                                                                                                                                                                                                                                                           | 12                                                 |
| Shape and Amplitude Registers (AWG)                                                                                                                                                                                                                                                                                                                                                     |                                                    |
| Sample Output                                                                                                                                                                                                                                                                                                                                                                           | 14                                                 |
| Pulse Programs                                                                                                                                                                                                                                                                                                                                                                          | <u>16</u>                                          |
| Control lines                                                                                                                                                                                                                                                                                                                                                                           |                                                    |
| Triggering                                                                                                                                                                                                                                                                                                                                                                              |                                                    |
| Clock output on BNC0                                                                                                                                                                                                                                                                                                                                                                    | <u>18</u>                                          |
| Clock Input Signal Standard                                                                                                                                                                                                                                                                                                                                                             | <u>19</u>                                          |
| IV. PCI Connection - Connecting to the PulseBlasterDDS-I-300-PCI boards                                                                                                                                                                                                                                                                                                                 | <u>20</u>                                          |
| Connector Information                                                                                                                                                                                                                                                                                                                                                                   | <u>20</u>                                          |
| BNC Connectors                                                                                                                                                                                                                                                                                                                                                                          | 20                                                 |
| Long IDC Headers                                                                                                                                                                                                                                                                                                                                                                        | <u>20</u>                                          |
| HWTrig/Reset Header                                                                                                                                                                                                                                                                                                                                                                     | 21                                                 |
| V. USB Connection - Connecting to the PulseBlasterDDS-I-300-USB boards                                                                                                                                                                                                                                                                                                                  | 22                                                 |
| Power Requirements                                                                                                                                                                                                                                                                                                                                                                      | 22                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                         |                                                    |
| Power Connectors                                                                                                                                                                                                                                                                                                                                                                        |                                                    |
| Power Connectors<br>Digital Output Connectors                                                                                                                                                                                                                                                                                                                                           | 23                                                 |
| Power Connectors<br>Digital Output Connectors<br>Header JP302                                                                                                                                                                                                                                                                                                                           | 23<br>25                                           |
| Power Connectors<br>Digital Output Connectors                                                                                                                                                                                                                                                                                                                                           | 23<br>25                                           |
| Power Connectors<br>Digital Output Connectors<br>Header JP302<br>Connector Locations<br>VI. External Frequency Modulation                                                                                                                                                                                                                                                               | 23<br>25<br>26<br>26                               |
| Power Connectors<br>Digital Output Connectors<br>Header JP302<br>Connector Locations                                                                                                                                                                                                                                                                                                    | 23<br>25<br>26<br>26                               |
| Power Connectors<br>Digital Output Connectors<br>Header JP302<br>Connector Locations<br>VI. External Frequency Modulation                                                                                                                                                                                                                                                               | 23<br>25<br>26<br>26                               |
| Power Connectors         Digital Output Connectors         Header JP302         Connector Locations         VI. External Frequency Modulation         Header JP302 (Frequency Select and HW Trigger/Reset)                                                                                                                                                                              | 23<br>25<br>26<br>26<br>26<br>28                   |
| Power Connectors<br>Digital Output Connectors<br>Header JP302<br>Connector Locations<br><u>VI. External Frequency Modulation</u><br>Header JP302 (Frequency Select and HW Trigger/Reset)<br>VII. PulseBlasterDDS-I-300 Interface for LabVIEW.                                                                                                                                           | 23<br>25<br>26<br>26<br>26<br>28<br>28             |
| Power Connectors.         Digital Output Connectors.         Header JP302.         Connector Locations.         VI. External Frequency Modulation.         Header JP302 (Frequency Select and HW Trigger/Reset).         VII. PulseBlasterDDS-I-300 Interface for LabVIEW.         Overview of SpinCore LabVIEW GUI Interface.         Appendix I: Generating RF Outputs Above 100 MHz. | 23<br>25<br>26<br>26<br>26<br>28<br>28<br>29       |
| Power Connectors                                                                                                                                                                                                                                                                                                                                                                        | 23<br>25<br>26<br>26<br>26<br>28<br>28<br>29<br>31 |

## I. Introduction

### **Product Overview**

PulseBlasterDDS is a high-performance signal generator that combines two units – the digital waveform synthesis unit (DDS, Direct Digital Synthesis), and the PulseBlaster Timing Processor.

The PulseBlaster Timing Processor provides all the necessary timing control signals required for overall system control and pulse synchronization. This part of the PulseBlasterDDS design also generates the programmable-length digital (TTL logic) pulses. By adding DDS features, PulseBlasterDDS can now provide not only programmable TTL pulses but also RF (Radio Frequency) output signals. By utilizing the PulseBlaster Timing Processor core, the combined system can generate sophisticated pulse sequences with single-clock accuracy, meeting high-performance demands of advanced users.

The PulseBlasterDDS-I-300 is equipped with one 300 MHz DAC (Digital-to-Analog Converter), and it can produce useful output signal frequencies from DC (Direct Current) (0 Hz) to 100 MHz. Arbitrary Waveform Generation (AWG), output gating and attenuation, and user-programmable amplitude, frequency, and phase modulation are standard. In addition to the ability to modulate the envelope of the generated signal, the shape of the carrier signal can be custom-defined as well, giving the user the opportunity to explore novel excitation modes. Select designs allow for external frequency modulation using dedicated hardware input lines.

Packaged in a small USB form factor, the PulseBlasterDDS-I-300 series of boards provide users the ability to control their systems through the generation of fully synchronized digital and analog excitation pulses, ranging from simple RF and TTL pulses to sophisticated excitation schemes with nested loops, subroutines, etc., providing users with a compelling price/performance proposition unmatched by any other device on the market today.

Please note that currently, the PCI board version SP6 is only available for special orders.

#### **Board Architecture**

#### **Block Diagram**

Figure 1, on the next page, presents the general architecture of the PulseBlasterDDS-I-300 board. The two major building blocks are the DDS Core (top level blocks in Figure 1), and the PulseBlaster Timing Core (PB Core, bottom level of blocks in Figure 1).

The DDS Core contains a Numerically Controlled Oscillator (NCO) that is equipped with programmable frequency and phase registers that are under the pulse program control through the PulseBlaster Timing Core. Following the NCO, the Arbitrary Waveform Generator (AWG) unit can modulate the signal envelope to a user programmable shape, e.g., a sinc shape. Scaling, or attenuation of the signal amplitude, is also under program control, as well as the additional gating (blanking) in the digital domain.

The PB Core controls the timing of the gating pulses and provides the necessary control signals for frequency, phase, shape and amplitude registers. The PB Core also outputs TTL signals to the outside world, as programmed by the user. The PB processor core executes instructions as written by the user and stored in the on-chip SRAM module, and, once programmed, the processor operates autonomously.



Figure 1: PulseBlasterDDS-I-300 Board Architecture.

The DDS and PB cores are driven from a common clock source (the 50 MHz<sup>1</sup> Reference Clock in Figure 1). The onboard clock source is removable and, in lieu of the on-board clock, any 3.3 V TTL compatible clock source of arbitrary stability can be used.

The DDS and PB cores have been integrated onto a single silicon chip. High performance DAC chip and high-current output amplifier complement the design. User control of the system is provided through the host-programming interface over the PCI bus or USB controller.

<sup>&</sup>lt;sup>1</sup>A 75 MHz clock may be used with the PulseBlasterDDS-I-300.

### **Product Specifications**

|                    | Parameter                        | Min       | Тур                         | Max      | Units |
|--------------------|----------------------------------|-----------|-----------------------------|----------|-------|
| Analog Output      | D/A sampling rate                |           |                             | 300      | MHz   |
|                    | D/A sampling precision           |           |                             | 14       | bits  |
|                    | Output voltage range (peak-peak) |           | 1 - 4 <sup>(1)</sup>        | -        | V     |
|                    | Phase resolution                 |           | 0.09 <sup>(2)</sup>         | -        | deg.  |
|                    | Frequency resolution             |           | 1.11 <sup>(3)</sup>         | -        | Hz    |
|                    | RF Output <sup>(8)</sup>         | DC (0 Hz) |                             | 0        | MHz   |
| Digital Output     | Number of digital outputs        |           | 4 <sup>(4)</sup>            | 9        |       |
|                    | Logical 1 output voltage         |           | 3.3 <sup>(5)</sup>          | -        | V     |
|                    | Logical 0 output voltage         |           | 0                           | -        | V     |
|                    | Output drive current             |           |                             | 25       | mA    |
|                    | Rise/Fall time                   |           | 1                           | -        | ns    |
| Digital Input      | Logical 1 input voltage          | 1.7       |                             | 3.3      | V     |
| (HW_Trig,HW_Reset) | Logical 0 input voltage          | 0         |                             | 0        | V     |
| Pulse Program      | # of instruction words           |           | 1024 to 4096 <sup>(6)</sup> | -        | words |
|                    | Pulse resolution                 |           | 13.3(7)                     | -        | ns    |
|                    | Instruction length               | 66.6 ns   |                             | 693 days |       |

 Table 1: PulseBlasterDDS-I-300 Product Specifications.

#### Notes

- Analog output voltage is factory adjustable up to 4 V<sub>pp</sub> at 10 MHz. See RF Output Level section on the next page for more information.
- 2) Phase-offset control word is 12-bit wide.
- 3) Assuming a 50 MHz reference clock and a 300 MHz NCO frequency. Frequency control word is 28-bit wide.
- 4) On PCI boards, all 24 control bits are routed to on-board IDC header, and signals that are not used internally can be utilized to control outside devices. Please contact SpinCore if you require more digital outputs; custom designs with more output bits may be available.
- 5) This is the value seen without using termination. When the line is terminated with 50  $\Omega$ , the output voltage will be lower.
- 6) This number can be larger on USB boards. Please contact SpinCore for custom design featuring a larger number of instruction words.
- 7) Assuming a 50 MHz reference clock and a 75 MHz PulseBlaster timing core frequency.
- 8) The RF output can operate from direct current DC (0 Hz) to 100 MHz. The analog output is DC coupled.

### **RF Output Level**

There are currently two different options for PulseBlasterDDS-I-300 RF analog output amplifier – the standard gain and the high gain. Figure 2, below shows the typical frequency characteristics of the analog output signals for the two output options. The standard-gain PulseBlasterDDS-I-300 for a 50  $\Omega$  load has an output voltage of 1 Volt peak-to-peak at 10 MHz, with a 3 dB bandwidth of about 85 MHz. The high-gain amplifier with a 50  $\Omega$  load has a maximum output voltage of about 3.75 Volts peak-to-peak, with a 3 dB bandwidth of about 21 MHz, while covering the same frequency range as the standard-gain board.



**Figure 2:** PulseBlasterDDS-I-300 analog output voltage vs. output frequency. The dotted line represents the standard-gain output amplifier, and the solid line represents the high-gain output amplifier. The voltage values are for a 50 Ohm load impedance. The zero dBm output value for both amplifiers occurs at approximately 90 MHz.

Please note, the sustained analog output voltage feature is only available on PCI boards. To obtain a sustained analog output voltage, set the frequency register to 0.0 Hz, and use the content of the phase registers to control the actual output voltage level.

## **II. Installation**

#### Installing the PulseBlasterDDS-I-300

To install the board you must complete the following three steps:

- 1. Download and install the latest SpinAPI software package and example programs on your computer. These are available at: <a href="https://www.spincore.com/support/spinapi/">https://www.spincore.com/support/spinapi/</a>
  - SpinAPI is a custom Application Programming Interface (API) package developed by SpinCore Technologies, Inc. SpinAPI is designed to be used only with SpinCore Technologies, Inc. products. SpinAPI can be utilized using C/C++, or LabVIEW (described in Section VII). The API will also install the necessary drivers.
- 2. Shut down the computer
  - For the PCI board: Insert the PulseBlasterDDS-I-300 card into an available PCI slot and fasten the PC bracket securely with a screw.
  - For the USB board: Plug one end of the USB cable into the PulseBlasterDDS-I-300 board and the other end into the host computer. Next, power the board through the 5-pin DIN-type connector or 6-position Molex-style connector. We recommend purchasing the <u>RadioProcessorUSB Power Supply</u>, which has the 6-pin output connector and is pin-compatible with the power connector of the PBDDS-I-300-USB board. For more information on powering the PulseBlasterDDS-I-300 USB board please read Power Connectors in Section V. USB Connection - Connecting to the PulseBlasterDDS-I-300-USB boards.
  - **Warning:** Do not connect PEG (PCI Express Graphics) power connectors available in some computers directly to the 6-position Molex-style power connector. Doing so will cause irreparable damage to the board. SpinCore Technologies is not liable for any damage caused by this.
- Turn on the computer and follow the installation prompts. Windows may recognize your board as a RadioProcessor board but the board will still function as it should, as the functionality of the PBDDS-I-300 is a sub-set of the functionality of the RadioProcessor.
- 4. The simplest way to test whether the device has been installed properly and can be controlled as intended is to run a simple test program. These example files can be found in the SpinAPI package.

### **Testing the PulseBlasterDDS-I-300**

Once your board is installed properly, the functionality of the device can be tested using example programs available from the installed SpinAPI. All output sequences generated by test programs can be verified using an oscilloscope.

If you are using a high input impedance oscilloscope to monitor the PulseBlasterDDS-I-300's output, place a resistor that matches the characteristic impedance of the transmission line in parallel with the coaxial transmission line at the oscilloscope input by attaching it to the line through a T-Adapter(e.g., a 50  $\Omega$  resistor with a 50  $\Omega$  transmission line, see Figures 3 and 4 below). For ease of observing the pulsed RF signals, the oscilloscope should be triggered by any of the TTL outputs. When using an oscilloscope with an adjustable bandwidth, set the bandwidth to as large as possible. Failure to do so may yield inaccurate readouts on the oscilloscope.



Figure 3: Left: BNC T-Adapter and Right: BNC 50 Ohm resistor.



**Figure 4:** BNC T-Adapter on oscilloscope with coaxial transmission line connected on the left and BNC 50 Ohm resistor connected on the right, to terminate the line.

The first program is pbdds\_i\_300\_excite\_test. This will produce a 1.0 MHz sine wave on the Analog Out connection and a logical high signal on the Digital Out connection - these signals will turn on for 10 µs and off for 1 ms and will be repeated indefinitely. The Digital Out on the oscilloscope can be used to trigger the capture of the analog signal.

The signal output can be stopped by using the pb\_stop.exe program. The corresponding pb\_start.exe will restart the PBDDS board. Reloading the board with a new program will also stop the execution of any running program.

Next, pbdds\_i\_300\_phase\_test will produce a 1.0 MHz output on the Analog Out connection which will turn on for 8 µs and off for 1 ms. The sin wave will cycle through 4 phase offset registers(one every 2 µs, 90 degrees apart) and will repeat indefinitely.

To test the AWG feature of the board, use pbdds\_i\_300\_awg. This program will ask for two amplitude values and one frequency value, and then it will load the board to output two sinc-shaped pulses, one with each amplitude value. This will repeat every 1 ms.

Along with the executable programs, the folder also contains the C source code of all test programs. Any source code can be modified, thus allowing the user to start making customized programs as necessary. More information on compiling on Windows can be found at: <u>https://www.spincore.com/support/spinapi/Windows\_Help.shtml</u>.

## **III. Using the PulseBlasterDDS-I-300**

### Controlling the PulseBlasterDDS-I-300 with SpinAPI

This section describes the function and use of each feature of the PulseBlasterDDS-I-300.

The PulseBlasterDDS-I-300 is a highly versatile excitation board, and as a result there are many possible approaches to program the board. However, most applications can be programmed following these basic steps:

- 1. Load frequency and phase registers with desired values.
- 2. Load shape and DDS data and amplitude registers (if applicable).
- 3. Specify a pulse program which will control the timing of the experiment.
- 4. Trigger the pulse program. The experiment will then proceed autonomously.

These steps are described below. For each of the steps, the relevant SpinAPI functions are listed which control the actions needed to perform that particular step.

SpinAPI is a control library which allows programs to be written to communicate with your SpinCore board. The most straightforward way to interface with this library is with a C/C++ program, and the API definitions are described in this context. However, virtually all programming languages and software environments (including software such as LabVIEW and MATLAB) provide mechanisms for accessing the functionality of standard libraries such as SpinAPI.

Please see the example programs described in the preceding section, "Testing the PulseBlasterDDS-I-300," for an an explanation of how to use SpinAPI. A reference document for the API is available online at: <a href="https://spincore.com/support/spinapi/">https://spincore.com/support/spinapi/</a>. Under the "Download" bullet there is a link called "SpinAPI References".

#### **Frequency and Phase Registers**

The PulseBlasterDDS-I-300 contains one Numerically Controlled Oscillator and associated digital circuitry that drives the on-board digital-to-analog (DAC) converter, thus forming the Analog Output channel. The frequency and phase of the output signal are controlled by selecting values from a bank of on-board registers. These registers should be programmed with appropriate values after board initialization, but before triggering the board. Each pulse instruction selects which register is used at any given time during an experiment. The number of available registers for each channel is given in the table below. Certain designs allow the user to select frequency registers using dedicated hardware control lines. See section VI. External Frequency Modulation for more information.

| Register Bank | Number of registers |
|---------------|---------------------|
| Frequency     | 16                  |
| Phase         | 16 <sup>2</sup>     |

#### Table 2: Frequency Register information.

#### Relevant SpinAPI functions:

pb\_start\_programming()
pb\_set\_phase()
pb\_set\_freq()
pb\_stop\_programming()

#### Sample Output

Figure 5, below, shows an example RF 70 MHz output pulse that was generated by the board. The data was captured using a Tektronix TDS224 oscilloscope. Notice the time base of 25 ns/division.



<sup>&</sup>lt;sup>2</sup>Firmware design 10-16 has been modified to have 4 available TX phase registers.

Figure 6, below, demonstrates the zero-latency phase-switching agility. In this figure, two short back-to-back pulses were recorded with a 180-degree phase offset and a 70 MHz carrier frequency (expanded view).



**Figure 6:** Two RF output pulses, back to back, with a 180 degree phase switch and 70 MHz RF frequency.

Figure 7, below, demonstrates the frequency-shift agility. In this figure, the frequency jumps from 20 MHz to 10 MHz with no latency.



Figure 7: Frequency shift from 20 MHz to 10 MHz.

### Shape and Amplitude Registers (AWG)

The AWG (Arbitrary Waveform Generator) system can be programmed with a wide variety of parameters. The main features of this system are:

- RF outputs can be shaped by an arbitrary waveform (for example, a sinc waveform).
- RF outputs can be scaled by a constant value.
- The RF carrier signal itself can be set to waveforms other than a sinewave (e.g., triangle wave, square wave, etc.).
- The shortest possible pulse is 66.6 ns, the longest is 693 days.

To make use of the AWG feature, use the pb\_inst\_dds\_shape() function to generate the instructions of your pulse program. This function has two additional parameters over the standard pb\_inst\_dds() function. They are:

use\_shape: if this is 0, no shape will be applied to the pulse. If it is nonzero, whatever waveform is loaded as the shape will be used to shape the RF pulse. The shape waveform can be loaded by the user with the pb\_dds\_load() function

amp: This selects which amplitude register to use. The values stored in the amplitude register can be set with the pb\_set\_amp() function.

#### Relevant SpinAPI functions:

```
pb_start_programming()
pb_inst_dds()
pb_inst_dds_shape()
pb_stop_programming()
pb_set_amp()
pb_dds_load()
```

Example program that are included with SpinAPI in the PBDDS-I-300 directory demonstrate how the AWG capabilities are used. The source code for those programs is well documented, aiding in gaining a better understanding on how the AWG features of the board are controlled.

#### Sample Output

Figures 8-10 illustrate sample capabilities of the AWG features of the PBDDS-I-300 board. Figure 8 demonstrates a simple sinc-shaped soft pulse of 0.5 ms in duration. The shape of the pulse is not limited to a sinc-shape - it is user-loadable with any arbitrary waveform. Figure 9 illustrates that multiple soft pulses can be generated in a pulse sequence,

and multiple amplitudes can be assigned to individual pulses. Figure 10 shows that it is also possible to combine soft and hard RF pulses in a sequence.



Figure 8: Sinc-shaped soft pulse. Pulse duration of 0.5 ms.



Figure 9: Combination of soft RF pulses with variable amplitudes.



Figure 10: Combination of soft and hard RF pulses in sequence.

#### **Pulse Programs**

The PulseBlasterDDS-I-300 contains an integrated PulseBlaster pulse generation timing core. This timing core controls all aspects of the systems functionality by setting internal control lines at user specified times. Nine user programmable digital outputs are also available for control of external hardware. The internal control lines and user programmable outputs are collectively referred to as flags. The pulse program modifies these flags in a user-defined way to control all aspects of an experiment.

The PulseBlaster uses a robust instruction set to enable the creation of complex pulse programs with ease. Each instruction is defined by an Operational Code (OpCode) which specifies the action of that instruction and an optional Instruction data (inst\_data) field which elaborates on that action. In addition, each instruction specifies the desired value for the flags, as well as the execution time of the given instruction, i.e., the delay until the next instruction starts executing. The "next" instruction is not necessarily the next sequential instruction, as the instruction set contains branching and looping instructions which can cause the program to be executed out of sequential order. A list of the available instructions is given in the following table (Table 3).

| OpCode # | Instruction | Inst_data field                                                         | Function                                                                                                                                                                                                                                                           |
|----------|-------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | CONTINUE    | Unused                                                                  | Program execution continues to next instruction.                                                                                                                                                                                                                   |
| 1        | STOP        | Unused                                                                  | Stop execution of program. Analog<br>outputs turn off. Digital outputs may be<br>turned off or remain from their previous<br>state depending on the firmware.                                                                                                      |
| 2        | LOOP        | Number of desired loops. This value must be greater than or equal to 1. | Specify beginning of a loop.<br>Execution continues to next instruction.<br>Data used to specify number of loops                                                                                                                                                   |
| 3        | END_LOOP    | Address of beginning of loop                                            | Specify end of a loop. Execution returns to beginning of loop and decrements loop counter.                                                                                                                                                                         |
| 4        | JSR         | Address of first subroutine<br>instruction                              | Program execution jumps to beginning of a subroutine                                                                                                                                                                                                               |
| 5        | RTS         | Unused                                                                  | Program execution returns to<br>instruction after JSR was called                                                                                                                                                                                                   |
| 6        | BRANCH      | Address of instruction to skip to                                       | Program execution continues at<br>specified instruction. This behaves like<br>the goto statement found in many<br>programming languages                                                                                                                            |
| 7        | LONG_DELAY  | Number of desired loops. This value must be greater than or equal to 2. | For long interval instructions.<br>Executes length of pulse given in the<br>time field multiplied by the value in the<br>data field.                                                                                                                               |
| 8        | WAIT        | Unused                                                                  | Program execution pauses and waits<br>for a software or hardware trigger to<br>resume it. The latency between a trigger<br>occurring and the program resuming is<br>the time used as the delay for the wait<br>instruction plus a fixed time of 6 clock<br>cycles. |

Table 3: PulseBlaster Instructions.

#### **Control lines**

To control the operation of the PulseBlasterDDS-I-300, each instruction in the pulse program specifies a flag word which sets both the internal control lines and user programmable digital outputs. The control lines stay in the given state for the duration of the instruction. The internal control lines are described below in Table 4.

| Control Line                         | Function                                                                                |
|--------------------------------------|-----------------------------------------------------------------------------------------|
| frequency select                     | Selects between the 16 available frequency registers <sup>3</sup>                       |
| TX <sup>4</sup> channel phase select | Selects between the 16 available phase registers⁵                                       |
| tx_enable                            | Enables TX output on the Analog Out connector. If this control line is disabled,        |
|                                      | the Analog Out channel is turned off (zero output voltage).                             |
| phase_reset                          | When this control line is enabled, all DDS channels will be reset to their time=0       |
|                                      | phase. For example, if a channel is set to use a phase register with 90deg, it will be  |
|                                      | reset to the midpoint output level and stay that way until the phase reset control line |
|                                      | is disabled. This allows the phase of pulses to be synchronized between scans.          |

Table 4: Internal control lines.

### Triggering

The PulseBlasterDDS-I-300 can be triggered in two ways, either by software trigger or hardware trigger. The software trigger is initiated by sending a command from the host PC. Because these boards are typically used with non real-time operating systems, the exact time between issuing a software trigger and the board acting on that trigger cannot be precisely specified. For precision control, the pulse program can also be triggered by setting the HW\_Trigger pin to a logical 0. This will cause the pulse program to be triggered within two clock cycles (starting a program), or a minimum of 8 clock cycles (resuming from WAIT instruction).

Triggering the pulse program has one of the following three effects:

- 1. Begin execution of a pulse program.
- 2. Restart execution of a pulse program after the board has been reset.
- 3. Resume execution of a pulse program which is currently paused by a WAIT instruction.

Relevant SpinAPI functions:

pb\_start()

<sup>&</sup>lt;sup>3</sup>Firmware design 10-16 has been modified to have 1024 available frequency registers.

<sup>&</sup>lt;sup>4</sup>TX refers to RF output.

<sup>&</sup>lt;sup>5</sup>Firmware design 10-16 has been modified to have 4 available phase registers.

### **Clock output on BNC0**

PulseBlasterDDS-I-300 boards have the capability of outputting a 10 MHz<sup>6</sup> signal on the BNC0 connector (PCI boards), or on one of the on-board IDC headers (USB boards). This signal is a 50% duty cycle square wave derived directly from the on-board 50 MHz clock oscillator, and is intended for synchronization purposes.

To enable this output, call the following SpinAPI function:

pb\_set\_radio\_control(BNC0\_CLK);

To have BNC0 return to normal pulse program behavior, call:

```
pb_unset_radio_control(BNC0_CLK);
```

If this clock output is enabled, loading the board with another pulse program will not affect the output clock signal. The 10 MHz signal will continue to be present on the output connector until one of the following events occurs: (1) the computer is turned off, (2)  $pb\_unset\_radio\_control(BNC0\_CLK)$  is called, or (3)  $pb\_set\_defaults()$  is called. Condition 3 may occur if you are using multiple programs to control your PulseBlasterDDS-I-300, and can be avoided by making sure that only one of the programs calls  $pb\_set\_defaults()$  and that this program is not run after the one that calls  $pb\_set\_radio\_control(BNC0\_CLK)$ .

NOTE: When enabled, this option does not affect the functionality of the Digital Output 0 pin on the IDC connector. This pin will still serve as a digital output under control of the pulse program.

### **Clock Input Signal Standard**

The PulseBlasterDDS-I-300 is a digital system built in CMOS technology and powered off a 3.3 V DC source. It will accept external clock signals that conform to the low-voltage 3.3 V TTL standard only. Negative voltage will damage the processor chip, and thus any external sinusoidal signal would need to be converted to the positive-only TTL signal prior to using with the PulseBlasterDDS-I-300. Do not attempt to drive a PulseBlasterDDS-I-300 board with an external clock while an oscillator module is also connected.



*Figure 11:* Both the bare header socket and the installed clock module are shown above. Please note the proper orientation of the 50 MHz clock.

<sup>&</sup>lt;sup>6</sup>Assuming a 50 MHz clock. A 75 MHz clock would give a 15 MHz reference signal.

## IV. PCI Connection - Connecting to the PulseBlasterDDS-I-300-PCI boards Connector Information

There are two main connector types on the PulseBlasterDDS-I-300 PCI board: the BNC connectors and the IDC headers – see Figure 12 below. BNC connectors are mounted on the PCI bracket and are available outside of the computer. The IDC connectors are mounted on-board and are available inside the computer only. There are two long IDC headers and one short IDC header.



Figure 12: PCI Board Connector Locations.

#### **BNC Connectors**

The four BNC connectors provide the primary output interface of the PulseBlasterDDS-I-300 PCI board. All connectors are impedance matched to 50  $\Omega$ . BNC2 is the Analog Output port. BNC1 and BNC0 are both general purpose digital outputs which can be controlled through the pulse program. BNC3 is not used for the PulseBlasterDDS-I-300.

The analog output connector (BNC2), is not equipped with an interpolating filter. This allows for maximum flexibility in output frequency, but it means that the output may appear quantized if no filter is used on the output. To eliminate this behavior and obtain a smooth RF pulse, the user may filter the output with a bandpass or lowpass filter which will cut off the undesired frequency components above the intended RF signal.

#### Long IDC Headers

| 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 |

#### Figure 13: IDC header pinout.

There are two long (2x13 pins) IDC headers on the PulseBlasterDDS-I-300 PCI board. The headers provide access to all 24 bits of the flag word, nine of which are available to the user as general purpose digital outputs. These are labeled Flag0..11\_Out and Flag12..23\_Out. On each IDC header the top row of pins (14-26) are grounds, and the signals are carried on pins 1-13.

Each pin on an IDC header corresponds to a bit in the flag field of an instruction. The association between bits and pins is shown in the table below (Table 5, next page). In the PBDDS-I-300 design, the flag bits that are used to select frequency and phase registers are also routed to the IDC connectors so external hardware can be used to determine the state of the program.

| Bit in<br>flag word | Function                  | Pin on<br>Flag1223 |
|---------------------|---------------------------|--------------------|
| N/A                 | Ground                    | 14-26              |
| N/A                 | Unused                    | 13                 |
| 23                  | Digital output 8          | 12                 |
| 22                  | Digital output 7          | 11                 |
| 21                  | Digital output 6          | 10                 |
| 20                  | Digital output 5          | 9                  |
| 19                  |                           | 8                  |
| 18                  |                           | 7                  |
| 17                  | TX phase register select  | 6                  |
| 16                  |                           | 5                  |
| 15                  | tx_enable                 | 4                  |
| 14                  |                           | 3                  |
| 13                  | Frequency register select | 2                  |
| 12                  |                           | 1                  |

| Bit in flag<br>word | Function                  | Pin on<br>Flag011 |
|---------------------|---------------------------|-------------------|
| N/A                 | Ground                    | 14-26             |
| N/A                 | Unused                    | 13                |
| 11                  | Frequency register select | 12                |
| 10                  | Digital output 4          | 11                |
| 9                   | phase_reset               | 10                |
| 8                   |                           | 9                 |
| 7                   | Shape period select       | 8                 |
| 6                   |                           | 7                 |
| 5                   | Amplitude coloct          | 6                 |
| 4                   | Amplitude select          | 5                 |
| 3                   | Digital output 3          | 4                 |
| 2                   | Digital output 2          | 3                 |
| 1                   | Digital output 1 (BNC1)   | 2                 |
| 0                   | Digital output 0 (BNC0)   | 1                 |

Table 5: IDC connector pin out.

#### HWTrig/Reset Header

| 4 | 3 |
|---|---|
| 2 | 1 |

**Figure 14:** HWTrig/Reset Header pinout.

Figure 14 presents the layout of the short 2x2 IDC header that is the Hardware Trigger/Reset connector. This is an input connector, for hardware triggering (HW\_Trigger) and resetting (HW\_Reset). Pins 3 and 4 are grounds, and pins 1 and 2 are the reset and trigger inputs, respectively. Both inputs are pulled high by an on board  $10k\Omega$  pull up resistor.

**HW\_Trigger** (pin 2) When this input detects a falling edge (for example by shorting it with pin 4), a hardware trigger is produced. This has the same effects as issuing a trigger through software, although the hardware trigger is more precise, since there are no software latencies involved.

**HW\_Reset** (pin 1) When this input detects a falling edge (for example by shorting it with pin 3), the pulse program is reset.

## V. USB Connection - Connecting to the PulseBlasterDDS-I-300-USB boards

#### **Power Requirements**

- 1. Recommended values and maximum currents:
  - +5V, 2.0 A (Digital Section)
  - +6 V, 1.0 A (Analog Section, Positive Voltage)
  - -6 V, 0.2 A (Analog Section, Negative Voltage)

All three voltages need to be applied simultaneously or damage to the board will result.

- 2. Two independent grounds exist: Digital Ground and Analog Ground. Power sources should be connected as follows:
  - Digital Ground should be connected to the ground point of +5 V supply.
  - Analog Ground should be connected to the center point (Ground Point) of the +6V and -6V supplies.
- 3. The PulseBlasterDDS-I-300-USB requires USB 2.0 to operate.

#### **Power Connectors**

The PBDDS-USB has two power connectors wired in parallel: A 5-pin DIN-type connector and a 6-pin Molex-style connector. The pin and signal arrangements for these two connection points are shown below in Figures 15 and 16, respectively.







Figure 16: Molex-style Power Connector (Power 1).

If you will be making your own power supply to connect to the Molex-style power connector, you will need the following parts or their equivalents: One 6-pin female Mini-Fit Jr.™ connector (DigiKey part No. WM23702-ND) and six Mini-Fit Jr.™ crimp receptacles (DigiKey part No. WM2501-ND).

**Warning:** Do not connect PEG (PCI Express Graphics) power connectors available in some computers directly to the 6-position Molex-style power connector. Doing so will cause irreparable damage to the board. SpinCore Technologies is not liable for any damage caused by this.

A dedicated DC/DC power supply is optionally available from SpinCore Technologies, Inc. For more information, please see: <u>https://spincore.com/products/SP11/RadioProcessor-USB-Power-Supply.shtml</u> or the Related Products and Accessories section below.

#### **Digital Output Connectors**

The digital outputs of the PBDDS-USB are present on both the J300 and J301 connectors. J300 is a standard DB-9 connector and J301 is a 5x2 shrouded IDC header. The pinouts of these connectors and the corresponding signal names are shown on the next page in Figures 17 and 18 and Table 6 and Table 7 respectively.



Figure 17: DB-9 Output Connector J300. Left: DB-9 Male. Right: DB-9 Female.

| Pin number | Function   | Pin number | Function   |
|------------|------------|------------|------------|
| 1          | Reserved   | 1          | Flag bit 0 |
| 2          | Flag bit 2 | 2          | Flag bit 1 |
| 3          | Flag bit 3 | 3          | Flag bit 3 |
| 4          | Flag bit 1 | 4          | Flag bit 2 |
| 5          | Flag bit 0 | 5          | Reserved   |
| 6          | Ground     | 6          | Ground     |
| 7          | Ground     | 7          | Ground     |
| 8          | Ground     | 8          | Ground     |
| 9          | Ground     | 9          | Ground     |

Table 6: DB-9 Output Connector J300 signal list, Male (left) and Female (right).



| Pin number | Function   |
|------------|------------|
| 1          | Ground     |
| 2          | Flag bit 0 |
| 3          | Ground     |
| 4          | Flag bit 1 |
| 5          | Ground     |
| 6          | Flag bit 3 |
| 7          | Ground     |
| 8          | Flag bit 2 |
| 9          | Ground     |
| 10         | Reserved   |

 Table 7: Shrouded IDC Output Header J301 signal list.

### Header JP302

The unshrouded male header labeled JP302 contains the *Hardware Trigger* and *Hardware Reset* lines. This header, see Figure 19 and Table 8, on the next page, for the layout and pin assignments, also offers a 10 MHz output that is derived from the master clock oscillator. This signal is ideal for synchronization purposes and is present on pin 2 of the header.

|       |             |             |             |             |             | 1      |
|-------|-------------|-------------|-------------|-------------|-------------|--------|
| Pin 2 | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | Pin 10 |
| Pin 1 | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | Pin 9  |
|       |             |             |             |             |             |        |

| Figure 19: Output Header JP302 | Figure | 9: Outpu | ut Header | JP302. |
|--------------------------------|--------|----------|-----------|--------|
|--------------------------------|--------|----------|-----------|--------|

| Pin number | Function          |
|------------|-------------------|
| 1          | Ground            |
| 2          | 10 MHz out or N/C |
| 3          | Ground            |
| 4          | N/C               |
| 5          | Ground            |
| 6          | N/C               |
| 7          | Ground            |
| 8          | Hardware Trigger  |
| 9          | Ground            |
| 10         | Hardware Reset    |

Table 8: Output Header JP302 signal list.

**HW\_Trigger** (pin 8) When this input detects a falling edge (for example by shorting it with pin 4), a hardware trigger is produced. This has the same effects as issuing a trigger through software, although the hardware trigger is more precise, since there are no software latencies involved.

**HW\_Reset** (pin 10) When this input detects a falling edge (for example by shorting it with pin 3), the pulse program is reset.

### **Connector Locations**



Figure 20: USB Board Connector Locations.

## **VI. External Frequency Modulation**

There exists a custom firmware design (EEPROM Code 12-17) which allows the user to select between frequency registers using dedicated hardware control lines to perform FSK modulation. The use of these frequency control lines to select between frequency registers is described below.

#### Header JP302 (Frequency Select and HW Trigger/Reset)

The unshrouded male header labeled JP302 contains the three hardware Frequency Select pins in addition to the *Hardware Trigger* and *Hardware Reset* pins.

|       |             |             |             |             |             | _      |
|-------|-------------|-------------|-------------|-------------|-------------|--------|
| Pin 2 | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | Pin 10 |
| Pin 1 | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | Pin 9  |
|       |             |             |             |             |             | -      |

Figure 21: Output Header JP302.

| Pin number | Function           |
|------------|--------------------|
| 1          | Ground             |
| 2          | Frequency Select 0 |
| 3          | Ground             |
| 4          | Frequency Select 1 |
| 5          | Ground             |
| 6          | Frequency Select 2 |
| 7          | Ground             |
| 8          | Hardware Trigger   |
| 9          | Ground             |
| 10         | Hardware Reset     |

Table 9: Output Header JP302 signal list.

Designs with external frequency modulation control have three hardware frequency select input pins located as shown in Table 9 above. These three pins can be used to select between eight different frequency registers. To use the hardware frequency select lines set the software frequency register parameter to zero and drive the hardware frequency select lines as necessary. Table 10, below, shows appropriate values to select between the frequency registers where a '1' refers to a 3.3 V TTL high state and '0' refers to a TTL low state (ground).

| HW Frequency Select<br>2 | HW Frequency Select<br>1 | HW Frequency Select<br>0 | Frequency Register |
|--------------------------|--------------------------|--------------------------|--------------------|
| 0                        | 0                        | 0                        | 0                  |
| 0                        | 0                        | 1                        | 1                  |
| 0                        | 1                        | 0                        | 2                  |
| 0                        | 1                        | 1                        | 3                  |
| 1                        | 0                        | 0                        | 4                  |
| 1                        | 0                        | 1                        | 5                  |
| 1                        | 1                        | 0                        | 6                  |
| 1                        | 1                        | 1                        | 7                  |

**Table 10:** Frequency Register Selection list. In order to use the hardware frequency select lines

 be sure to set the software frequency register select value to 0.

#### Important Notes:

• To select between frequency registers via software, all hardware frequency select lines must first be set to logical 0. Software frequency selection is performed by setting the frequency register select parameter (the first argument of the pb inst radio(...) or pb inst radio shape(...) functions) to the desired value.

• To select between frequency registers via hardware, the software frequency register select parameter must first be set to 0.

• The hardware frequency select input lines are pulled low by on board five  $11\Omega$  pull-down resistors. Therefore, the default state when nothing is connected is logical 0.

## VII. PulseBlasterDDS-I-300 Interface for LabVIEW

### **Overview of SpinCore LabVIEW GUI Interface**

SpinCore has developed an easy-to-use LabVIEW Graphical User Interface (GUI) that allows the user to program and control PulseBlasterDDS-I-300 boards. Simply set the parameters as described in this manual and run the program to control the digital pulse and RF generation of the board. A sample screenshot is shown on the next page.

For more information see the LabVIEW manual at: <u>https://www.spincore.com/support/PBLV/PBLV\_DDS\_Manual.pdf</u>

The LabVIEW interface can be downloaded at: https://www.spincore.com/support/PBLV/DDS.shtml



Figure 22: Example of PulseBlasterDDS-I-300 LabVIEW Extensions User Interface.

## Appendix I: Generating RF Outputs Above 100 MHz

In order to generate RF outputs above 100 MHz, a phase-coherent up-conversion is required. The diagram in Figure A1.1, below, presents a simplified system that can output above 100 MHz. The PulseBlasterDDS-I-300 utilizes a 50 MHz on board clock to derive the 300 MHz clock for the D/A converter and the 10 MHz clock output. In the proposed system, the 10 MHz clock output of the PulseBlasterDDS-I-300 board would then drive the high-frequency synthesizer (e.g., the PTS brand) directly.



**Figure A1.1:** Simplified block diagram of a complete, phase-coherent high-field system with the use of PulseBlasterDDS-I-300. Mini-Circuits mixer (ZAD-1-1+) can be used for high-field operation up to 500 MHz. Filtering is essential for quality results.

Using the setup above with a Mini-Circuits high pass filter (BHP-300+), the RF out of the PulseBlasterDDS-I-300 was up-converted to 300 MHz. In the following example, the frequency of the RF Out PulseBlasterDDS-I-300 was set to 70 MHz. Figure A1.2 is an image of the 70 MHz RF out signal from the PulseBlasterDDS-I-300.



**Figure A1.2:** Zoomed in image of the 70 MHz, 5 us pulse from the RF out of the PulseBlasterDDS-I-300 that is terminated with a 50 ohm resistor.

Below is the output of the PTS250 synthesizer outputting at 230 MHz.



**Figure A1.3:** Zoomed in image of the 230 MHz pulse from the PTS250 synthesizer that is terminated with a 50 ohm resistor.

Figure A1.4 is an image of the up-converted and filtered 300 MHz output.



**Figure A1.4:** Zoomed in image of the 300 MHz up-converted and filtered pulse terminated with a 50 ohm resistor.

## **Related Products and Accessories**

- 1. RadioProcessor Complete single-card solution for RF pulse generation and acquisition. For more information, please visit <a href="https://www.spincore.com/products/RadioProcessor/">https://www.spincore.com/products/RadioProcessor/</a>
- 2. If you require a specific number of amplitude registers, memory words, alternative clock frequencies, or an Oven Controlled Crystal Oscillator (OCXO), please inquire with SpinCore Technologies through our contact form, which is available at <a href="https://www.spincore.com/contact.shtml">https://www.spincore.com/contact.shtml</a>
- 3. Power Supply for PulseBlasterDDS-I-300-USB boards. For more information, please visit: https://www.spincore.com/products/SP11/RadioProcessor-USB-Power-Supply.shtml

## **Contact Information**

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

Telephone (USA):352-271-7383Website:https://www.spincore.comWeb Contact Form:https://spincore.com/contact.shtml

## **Document Information**

For revision history, please contact SpinCore.