II. LAB. * Open the LabVIEW program (Start > All Programs > National Instruments > LabVIEW 2012 > LabVIEW 2012).

Similar documents
ECE 463 Lab 1: Introduction to LabVIEW

Basic Data Acquisition with LabVIEW

Shift Register: Exercise # 1: Shift Register Example VI. 1. Build the following front panel. Figure (8.1): Shift register exercise front panel

Small rectangles (and sometimes squares like this

LabVIEW Basics. Based on LabVIEW 2011 Student Edition

INTRODUCTION TO LABVIEW

Linear Control Systems LABORATORY

B. Including the Event Structure within a loop. C. Configuring a Timeout case within the Event Structure

Remote C API User Manual

IEEE Testing Signal Compliance of ZigBee Standard

Arrays are lists of elements of the same data type. They are analogous to arrays in traditional languages.

Introduction to LabVIEW

Aliki User Manual. Fons Adriaensen

Lesson 4 Implementing a VI

Certified LabVIEW Associate Developer Exam. Test Booklet

Dept. of Electrical, Computer and Biomedical Engineering. Data Acquisition Systems and the NI LabVIEW environment

LabVIEW Express VI Development Toolkit User Guide

LabVIEW Statechart Module Tutorial

Table 1. Inputs and Outputs

Certified LabVIEW Associate Developer Examination

ME 365 EXPERIMENT 3 INTRODUCTION TO LABVIEW

Certified LabVIEW Associate Developer Examination

DSP First Lab 02: Introduction to Complex Exponentials

CLAD Sample Exam 06. B. Panel Resize. C. Panel Close? D. Value Change

PHYC 500: Introduction to LabView. Exercise 8 (v 1.3) M.P. Hasselbeck, University of New Mexico. Arrays, XY Graphs, Disk I/O

Part 1. Creating an Array of Controls or Indicators

Cal-Bay Systems XY Plotter, Time-Base Recorder, Automated Tester. Users Guide. Rev 3.1

Homework Assignment 9 LabVIEW tutorial

Introduction to LabVIEW

Certified LabVIEW Associate Developer Exam. Test Booklet

Lab 2: Introduction to LabVIEW 8.5

Lab 1: Getting familiar with LabVIEW: Part I

PHY 351/651 LABORATORY 1 Introduction to LabVIEW

Section 1 Establishing an Instrument Connection

Step-by-Step Data Acquisition Part II Exercise 2: Generating an Analog Output Waveform

2 Lab 2: LabVIEW and Control System Building Blocks

A. Front Panel Design Lesson 4 Implementing a VI

Introduction to LabVIEW Exercise-1

ECE 202 LAB 1 INTRODUCTION TO LABVIEW

Hands-On Introduction to. LabVIEW. for Scientists and Engineers. Second Edition. John Essick. Reed College OXFORD UNIVERSITY PRESS

University of Illinois Department of Electrical and Computer Engineering ECE 451 Automated Microwave Measurements Laboratory

Lecture 3 (week Feb 8-12) Expanding the Features of a VI. Select the Loop Condition. A. Structures--While Loop. A. Structures--For Loop

How do you roll? Fig. 1 - Capstone screen showing graph areas and menus

ni.com Preparing for the CLAD Exam

Labview. Masood Ejaz

Capstone Appendix. A guide to your lab computer software

LabVIEW TM Real-Time 2: Architecting Embedded Systems Exercises

Learn the three palettes. Learn how data is passed in LabVIEW. Create a subvi using two different methods.

Flexible GFDM PHY Tutorial

Advanced Programming Features

WELCOME TO LabVIEW 1

Learn LabVIEW 2010 / 2011 Fast

NMS Spectrum Analyzer Application

SCHEMATIC DESIGN IN QUARTUS

CLAD Sample Exam 03. C. A control that output a cluster of the controls / indicators on the tabs.

The LabVIEW Programming Environment and Basic Operations

ENGR 1000, Introduction to Engineering Design

ECE 451 Automated Microwave Measurements Laboratory. Experiment No. 2. Automated RF Power Detection Using LabVIEW

PHYC 500: Introduction to LabView. Exercise 15 (v 1.2) Producer Consumer Event Structure. M.P. Hasselbeck, University of New Mexico

Z-Wave (ITU-T G.9959) Measurement Suite. Data Sheet

Using the ThinkRF R5500 Real- Time Spectrum Analyzer with LabVIEW

VME Data Acquisition System, ADC Read

Arrays. Collection of data elements that are of same type

CLAD Sample Exam 04. B. When you create an Array constant on the Block Diagram, it is not visible on the Front Panel.

ET4254 Communications and Networking 1

PCI Express 1.0a and 1.1 Add-In Card Transmitter Testing

Introduction to Electronics Workbench

Interpreting Data in IX1D v 3 A Tutorial

LabVIEW Case and Loop Structures ABE 4423/6423 Dr. Filip To Ag and Bio Engineering, Mississippi State University

GETTING STARTED GUIDE

Reference. Menu Overview. Functions Common to Generator (TX) and Analyzer (RX) AC Power. Selecting 115 VAC or 230 VAC Operation

PHYC 500: Introduction to LabView. Exercise 16 (v 1.2) Controlling hardware with DAQ device. M.P. Hasselbeck, University of New Mexico

LABVIEW LAB SKILLS ACTIVITY 1 PROGRAMING ENVIRONMENT

1. Overview of LabVIEW VI

LABVIEW HANDOUT 3 CHAPTER 3: THE MATHSCRIPT NODE AND XY GRAPH

Outline. Lecture 16: Wireless Networking. Physical Layer (Layer 1) Ethernet: Wireless is Different. Attenuation Over Space

D1.5a Create Access Master Files

FRC LabVIEW Sub vi Example

Using LabVIEW. with. BiPOM Boards. Quick Start Guide. Document Revision: Date: 18 September, 2009

Virtual Instrumentation With LabVIEW

Exercise 0 - Open and Run a Virtual Instrument (Slide 12)

Part 1. Summary of For Loops and While Loops

Hands-on Lab 1: LabVIEW NI-DAQ Basics 1

ENGR 1000, Introduction to Engineering Design

LabVIEW programming I

Analog Input Sample Rate

Virtual Instrumentation With LabVIEW

NI LabView READ THIS DOCUMENT CAREFULLY AND FOLLOW THE INSTRIUCTIONS IN THE EXERCISES

ME 224: EXPERIMENTAL ENGINEERING. Lecture 2

NI-IMAQdx VI Reference Help

Lab 4: Digital Electronics BMEn 2151 Introductory Medical Device Prototyping Prof. Steven S. Saliterman

Certified LabVIEW Associate Developer Sample Exam 1. Test Booklet

LabVIEW Communications Application Framework 2.1

Awesome PowerPoint Tricks for Effective Presentations

LabVIEW Academy. 12. óra event, property node

Originally released in 1986, LabVIEW (short for Laboratory Virtual Instrumentation

The Mathcad Workspace 7

Engineering Innovation Center LabVIEW Basics

Bergmans Mechatronics LLC. User Guide. LabSocket-E v1.0. Jan Copyright 2017 Bergmans Mechatronics LLC. Alliance Partner

Analyzing Digital Jitter and its Components

Transcription:

II. LAB Software Required: NI LabVIEW 2012, NI LabVIEW 4.3 Modulation Toolkit. Functions and VI (Virtual Instrument) from the LabVIEW software to be used in this lab: For Loop (Function), Unbundle By Name (Function), Bundle By Name (Function), Array Subset (Function), Decimate (single shot) (VI), Complex to Polar (Function), Square (Function), Add Array Elements (Function), Greater? (Function), Select (Function), Numeric Constant, DBL Numeric Constant, and Shift Register. PART-1: MAXIMUM ENERGY ALIGNMENT INPUTS: Input complex waveform (cluster of 3 elements: t0 (double [64-bit real (~ 15 digits precision)]), dt (double [64-bit real (~ 15 digits precision)]), and Y (1-D array of double complex [~15 digit precision])). OUTPUTS: Aligned complex waveform (cluster of 3 elements: t0 (double [64-bit real (~ 15 digits precision)]), dt (double [64-bit real (~ 15 digits precision)]), and Y (1-D array of double complex [~15 digit precision])), alignment offset (samples) (long [32-bit integer (-2147483648 to - 2147483647)]). A virtual instrument template ( student_align_maxenergy.vit ) is provided to you with these inputs and outputs. The template should be populated according to instructions. Then, newly created VIs are plugged in the receiver USRP control file. PROCEDURE In this part, we develop a LabVIEW virtual instrument as a timing synchronization unit which uses maximum energy alignment algorithm for symbol timing recovery operation that can use the received complex waveforms through the USRP N210 receiving hardware as input and applies time synchronization algorithm on them. We now detail the construction of the VI at hand in Lab View: a) Setup * Open the LabVIEW program (Start > All Programs > National Instruments > LabVIEW 2012 > LabVIEW 2012). * Open student_align_maxenergy.vit file (Open Existing (OR Ctrl+O) > Select student_align_maxenergy.vit > OK). A basic graphic user interface (GUI) opens. (NOTE: If a warning window pops up, click on Ignore option). * Open Block Diagram (Window > Show Block Diagram (OR Ctrl+E)).

* Delete error in (no error) and error out clusters. * Enable Functions Palette (View > Functions Palette or right click on anywhere of the block diagram window). * Place a For Loop (Functions Palette > Programming > Structures > select and drag For Loop). b) Define number of iterations * Connect RX oversample factor to the count (N) terminal of the For Loop. * Connect this count (N) terminal of the For Loop to decimating factor input of Decimate (single shot).vi function. c) Decimation (filtering) * Place an Array Subset inside the For Loop (Functions Palette > Programming > Array > Array Subset). This function returns a portion of the input array starting at <index> and containing <length> elements. * Place an Unbundle By Name outside the For Loop (Functions Palette > Programming > Cluster, Class, & Variant > Unbundle By Name). This function returns the elements of the input cluster whose names we specify. * Connect the input complex waveform to input cluster port of one of the Unbundle By Name functions. This input specifies the continuous-time samples of the modulated complex baseband waveform data. * The box reads t0. Change it to Y (Right click menu > Select Item > Y). Y will give us the array of complex samples. * Connect element output of this Unbundle By Name to Array input of the Array Subset function. * There will be an error mark on this new wire. In order to remove this error, right click on the loop tunnel (connection box on the border of the For Loop) and select Disable Indexing option. * Place a Decimate (single shot).vi inside the For Loop (Functions Palette > Signal Processing > Signal Operation > Decimate (single shot).vi). This function decimates (reduces the sampling rate of ) the input sequence <X> by the <decimating factor> and the <averaging> Boolean control. Since we do not use the averaging feature of this function, it will give an output

sequence yi = xi* mwhere i=0,1,2,,(size-1) and and m is the <decimating factor>. n size= m, n is the number of elements in <X> * Connect Subarray output of Array Subset function to X input of Decimate (single shot).vi function. d) Energy calculation * Place a Complex To Polar inside the For Loop (Functions Palette > Mathematics > Numeric > Complex > Complex To Polar). This function breaks a complex input into its polar components (i.e., magnitude and phase). * Connect Decimated Array output of Decimate (single shot).vi function to Z input of Complex To Polar function. * Place a Square inside the For Loop (Functions Palette > Mathematics > Numeric > Square). This function computes the square of the input value. * Connect r (magnitude) output of Complex To Polar function to the input of Square function. * Place an Add Array Elements inside the For Loop (Functions Palette > Mathematics > Numeric > Add Array Elements). This function returns the sum of all elements in the numeric input array. * Connect output of Square function to the input of Add Array Elements function. e) Maximum energy detection * Place a Select function inside the For Loop (Functions Palette > Programming > Comparison > Select). * Add a shift register to the For Loop (Right click on the border of the For Loop > Right click menu > Add Shift Register). This function passes values from previous iterations through a loop to the next iteration. * Place a DBL Numeric Constant outside the For Loop (Functions Palette > Mathematics > Numeric > DBL Numeric Constant). Leave its value as 0. * Place a Greater? function inside the For Loop (Functions Palette > Programming > Comparison > Greater?). This function compares two inputs and gives a Boolean response at its output. * Connect output of Add Array Elements function to x input of the Greater? function. * Connect the DBL Numeric Constant to shift register s downward arrow.

* Connect this shift register arrow to y input of the Greater? function. * Connect the wire between DBL Numeric Constant shift register arrow and the Greater? function to f input of Select function. * Connect x > y? output of the Greater? function to s input of this Select function. * Connect the output of this Select function to the upward arrow of its own shift register. f) End of iteration? * Place a Numeric Constant outside the For Loop (Functions Palette > Mathematics > Numeric > Numeric Constant). Leave its value as 0. * Place another Select function inside the For Loop (Functions Palette > Programming > Comparison > Select). * Add another shift register to the For Loop (follow the same steps as above). * Connect the Numeric Constant to this shift register s downward arrow. * Connect this shift register arrow to f input of this new Select function. * Connect s inputs of both Select functions to each other. * Connect the iteration terminal (i) of the For Loop to index input of the Array Subset function. * Connect t input of the second Select function (connected to the Numerical Constant) to this wire (between i and index input). * Connect the output of this second Select function to the upward arrow of its own shift register. * Connect this second shift register upward arrow to alignment offset (samples). g) Form aligned complex waveform * Place an Array Subset outside the For Loop (Functions Palette > Programming > Array > Array Subset). * Connect index input of the outside Array Subset function to the wire between second shift register upward arrow and alignment offset (samples).

* Place another Unbundle By Name outside the For Loop (Functions Palette > Programming > Cluster, Class, & Variant > Unbundle By Name). * Connect the wire between input complex waveform and the first Unbundle By Name to the input of this second Unbundle By Name function. * The box reads t0. Change it to Y (Right click menu > Select Item > Y). * Connect element output of this Unbundle By Name to Array input of the outside Array Subset function. * Place a Bundle By Name outside the For Loop (Functions Palette > Programming > Cluster, Class, & Variant > Bundle By Name). * Connect Subarray output of this Array Subset function to element input of Bundle By Name function. * Connect the wire between input complex waveform and Unbundle By Name functions to input cluster input of Bundle By Name function. * The box reads t0. Change it to Y (Right click menu > Select Item > Y). * Connect output cluster output of Bundle By Name function to the aligned complex waveform element. At the end, your block diagram should look like the one below in Fig 1 and your front panel should look like the one in Fig 2: Fig 1 Complete block diagram

Fig 2 Complete front panel For visual reference, check this video out (note to Gil: please add your video here): See the video: How to build Lab5_align_MaxEnergy_student.vi * In order to check if your file has errors click on Operate > Run (OR Ctrl+R). If no error window is generated, then your file is good. * SAVE it AS a new file by adding your name at the end (example: if your name is John, then the new file name is student_align_maxenergy_john.vi ). PART-2: SIMULATION In this part we use the provided transmitter and receiver templates to plug in our VI files and test their operation before using them with the USRP boards. In order to simulate your maximum energy and early late gate timing synchronization designs, please follow these steps: * Open the LabVIEW program (Start > All Programs > National Instruments > LabVIEW 2012 > LabVIEW 2012) a) Receiver setup * Open receiver.vi file (Open Existing (OR Ctrl+O) > Select receiver.vi > OK). A basic graphic user interface (GUI) opens. (NOTE: If a warning window pops up, click on Ignore option.) * Open Block Diagram (Window > Show Block Diagram (OR Ctrl+E)).

* Locate the synchronize.vi (synch) in the block diagram and double click on it to open its front panel and block diagram. * On synchronize.vi block diagram, go to case selector and select the timing estimation case. * Locate the symbol_timing.vi (symbol timing) in the block diagram and double click on it to open its front panel and block diagram. * On symbol_timing.vi block diagram, go to case selector and select the Max Energy case. * Locate the align_maxenergy.vi (max energy align) in the block diagram and replace it with your newly created student_align_maxenergy_<name>.vi file (Right click on the max energy align box > Replace > All Palettes > Select a VI >insert your student_align_maxenergy_<name>.vi file). b) Simulator setup * Open simulator.vi file (Open Existing (OR Ctrl+O) > Select simulator.vi > OK). A basic graphic user interface (GUI) opens. (NOTE: If a warning window pops up, click on Ignore option.) * Click on Run Continuously button (two looping arrows). c) Data collection Bring up the simulator front panel and perform the following measurements shown on Fig 5, 6, and 7. Detailed information on front panel objects can be found in Appendix-A of this document.

Fig 5 Simulator front panel received constellation view Fig 6 Simulator front panel eye diagram view with ideal noise power setting (-infinity)

Fig 7 Simulator front panel eye diagram view with more realistic noise power setting (- 15 db) Repeat the simulation using following TX oversample factor and RX oversample factor settings: from 4 to 20 by steps of 4 for both BPSK and QPSK and collect screenshots of both constellation and eye diagram views. Also, change the delay (sec) value to 8.2E-10 for both BPSK and QPSK and collect screenshots of both constellation and eye diagram views. All collected screenshots should be used for report preparation. PART-3: USRP OPERATION In this part we use the provided top_tx and top_rx templates to plug in our VI files and use them with the USRP boards. In order to operate using USRPs, please follow these steps: * Open the LabVIEW program (Start > All Programs > National Instruments > LabVIEW 2012 > LabVIEW 2012). a) Transmitter setup * Open top_tx.vi file (Open Existing (OR Ctrl+O) > Select top_tx.vi > OK). A basic graphic user interface (GUI) opens. (NOTE: If a warning window pops up, click on Ignore option.) * Open Block Diagram (Window > Show Block Diagram (OR Ctrl+E)).

* Set the following values in Table 1 on top_tx front panel, HW parameters tab: Table 1 Top_tx HW parameters settings * Set the following values in Table 2 on top_tx front panel, modulation parameters tab: Table 2 Top_tx modulation parameters settings * Click on Run Continuously button (two looping arrows). b) Receiver setup LABEL VALUE USRP IP Address <IP> from NI-USRP configuration utility Active antenna J1 Carrier frequency (in HZ) 2.47G Gain (in db) 10 Generation Mode Continuous LABEL VALUE TX oversample factor 20 TX Sample Rate 20M Packet length (bits) 500 Pulse shaping filter Root Raised Cos Training Sequence Type Length 16 Frank Sequence On another computer with a connected USRP: * Open receiver.vi file (Open Existing (OR Ctrl+O) > Select receiver.vi > OK). A basic graphic user interface (GUI) opens. (NOTE: If a warning window pops up, click on Ignore option.) * Open Block Diagram (Window > Show Block Diagram (OR Ctrl+E)). * Locate the synchronize.vi (synch) in the block diagram and double click on it to open its front panel and block diagram. * On synchronize.vi block diagram, go to case selector and select the timing estimation case. * Locate the symbol_timing.vi (symbol timing) in the block diagram and double click on it to open its front panel and block diagram. * On symbol_timing.vi block diagram, go to case selector and select the Max Energy case.

* Locate the align_maxenergy.vi (max energy align) in the block diagram and replace it with your newly created student_align_maxenergy_<name>.vi file (Right click on the max energy align box > Replace > All Palettes > Select a VI >insert your student_align_maxenergy_<name>.vi file). * Open top_rx.vi file (Open Existing (OR Ctrl+O) > Select top_rx.vi > OK). A basic graphic user interface (GUI) opens. (NOTE: If a warning window pops up, click on Ignore option.) * Set the following values in Table 3 on top_rx front panel, HW parameters tab: Table 3 Top_rx HW parameters settings * Set the following values in Table 4 on top_rx front panel, modulation parameters tab: * Click on Correct Frequency Offset button. Table 4 Top_rx modulation parameters settings * Click on Run Continuously button (two looping arrows). For visual reference, check this video out: See the video: How to build USRP operation c) Data Collection LABEL VALUE USRP IP Address <IP> from NI-USRP configuration utility Active antenna J1 Carrier frequency (in HZ) 2.47G Gain (in db) 10 Capture Time (s) 400u LABEL VALUE RX oversample factor 2 RX Sample Rate 2M Pulse shaping filter Root Raised Cos Training sequence Frank Frame Detection Method Self Reference w/ Power Normalization Your top_tx (which we use to control the transmitting USRP) window should look like the ones in Fig 8 and Fig 9 below:

Fig 8 Top_tx front panel when BPSK is selected as modulation type Fig 9 Top_tx front panel when QPSK is selected as modulation type Your top_rx (which we use to control the receiving USRP) window should look like the ones in Fig 10 and Fig 11 below:

Fig 10 Top_rx front panel when BPSK is selected as modulation type

Fig 11 Top_rx front panel when QPSK is selected as modulation type Detailed information on front panel objects can be found in Appendix-A of this document. Bring up the top_tx and top_rx front panels and perform the measurements shown on Fig 8, 9, 10, 11 above. Repeat the USRP operation using following TX oversample factor and RX oversample factor settings: from 4 to 20 by steps of 4 for both BPSK and QPSK and collect screenshots of both constellation and eye diagram views of both top_tx and top_rx front panels. They should be used for report preparation. NOTE: Do not forget to keep the symbol rate constant by fixing the rate between oversample factors and sample rates. For example, if you increase oversample factor from 2 to 4, increase sample rate from 2M to 4M as well. PART-4: HOMEWORK QUESTIONS #1: Write a lab report describing the experiments and results you observed. Include in the report the images you collected in Part-3 and Part-4.

#2: Answer the following questions: What is the effect of TX and RX oversample factor and added delay in simulation on both constellation and eye diagram? What is the difference between simulation and USRP operation? PART-1: SIMULATION APPENDIX A On simulator.vi front panel you can manipulate the following values: TRANSMITTER SECTION a) TX oversample factor: Data type is long [32-bit integer (-2147483648 to 2147483647)]. This specifies the number of desired samples per symbol for the pulse shaping filter. It must be an even number larger than 2. b) TX sample rate: Data type is double [64-bit real (~15 digit precision)]. This specifies the transmitter sampling rate in Hertz (or samples per second). It must be specified between 195.312k and 100M. c) Noise power: Data type is double [64-bit real (~15 digit precision)]. This specifies the level of noise power in db. It can be any value between Infinity (Inf) and +Inf. RECEIVER SECTION d) RX oversample factor: Data type is long [32-bit integer (-2147483648 to 2147483647)]. This specifies the number of desired samples per symbol for the pulse shaping filter. It must be an even number larger than 2. It should be same as TX oversample factor. e) RX sample rate: Data type is double [64-bit real (~15 digit precision)]. This specifies the transmitter sampling rate in Hertz (or samples per second). It must be specified between 195.312k and 100M. f) Correct frequency offset: Data type is Boolean [TRUE or FALSE]. This compensates the effect of the frequency offset between transmitted and received signals. It can be set as on or off. g) Symbol timing recovery method: Data type is string. This chooses the method to be used for symbol timing recovery. It can be any one of the following five options: MT Align to Ideal Symbols, Max Energy, Early-Late Gate, Gardner, or Fixed Offset. SHARED SECTION

h) Modulation type: Data type is string. This chooses the modulation scheme to be used in both transmitter and receiver. It can be either BPSK or QPSK. i) Packet length: Data type is long [32-bit integer (-2147483648 to 2147483647)]. This specifies the packet length to be transmitted and received in bits. j) Iterations: Data type is long [32-bit integer (-2147483648 to 2147483647)]. This changes how many times the simulation is performed. Higher number of iterations increases the accuracy, but decreases the processing speed. k) Training sequence type: Data type is string. This chooses the training sequence to be used in both transmitter and receiver. It can be Length 11 Barker Sequence, Length 16 Frank Sequence, or Neumann Hoffman Binary Code. l) Pulse shaping filter: Data type is unsigned word [16-bit integer (0 to 65535)]. This selects the pulse shaping and matched filtering pulses to be used in both transmitter and receiver. It can be Raised Cosine, Root Raised Cosine, or Gaussian. m) Filter parameter: Data type is double [64-bit real (~15 digit precision)]. It sets the roll-off (or excess bandwidth) factor for Raised Cosine and Root Raised Cosine filters. It can be any real number between 0 and 1. In the graph field you see four different tabs: 1) Received constellation: This graph shows continuously changing I (in-phase or real) and Q (quadrature or imaginary) values of the constellation points as symbols received. These constellation points are the ones detected by the ML detector we constructed in Part-2. 2) Received eye diagram: An eye diagram is an oscilloscope display in which a digital data signal from a receiver is repetitively sampled and applied to the vertical input, while the data rate is used to trigger the horizontal sweep. It is called so because its shape resembles an eye. An open eye pattern corresponds to minimal signal distortion (due to intersymbol interference and noise). 3) Received signal: These two graphs show the Amplitude (in Volts) change of the received signal I and Q components in time domain. 4) Power delay profile: This graph gives the amplitude of the signal received through a multipath channel as a function of time delay (sec). The time delay is the difference in travel time between multipath arrivals. PART-2: USRP OPERATION On Top_tx.vi and Top_rx.vi front panels you can manipulate the following common values: HW PARAMETERS TAB

a) Device name: Data type is IVI session of class niusrp. This area is to enter the IP address of the connected USRP. b) Active antenna: Data type is string. This area is to enter the antenna name to be used. c) Carrier frequency: Data type is double [64-bit real (~15 digit precision)]. This area is to enter the frequency of RF signal in Hertz (Hz). d) Gain: Data type is double [64-bit real (~15 digit precision)]. This area is to enter the aggregate gain applied to the RF signal in decibel (db). MODULATION PARAMETERS TAB e) Modulation type: Data type is string. This chooses the modulation scheme to be used in both transmitter and receiver. It can be either BPSK or QPSK. f) TX (or RX) oversample factor: Data type is long [32-bit integer (-2147483648 to 2147483647)]. This specifies the number of desired samples per symbol for the pulse shaping filter. It must be an even number larger than 2. g) TX (or RX) sample rate: Data type is double [64-bit real (~15 digit precision)]. This specifies the transmitter sampling rate in Hertz (or samples per second). It must be specified between 195.312k and 100M. h) Pulse shaping filter: Data type is unsigned word [16-bit integer (0 to 65535)]. This selects the pulse shaping and matched filtering pulses to be used in both transmitter and receiver. It can be Raised Cosine, Root Raised Cosine, or Gaussian. i) Filter parameter: Data type is double [64-bit real (~15 digit precision)]. It sets the roll-off (or excess bandwidth) factor for Raised Cosine and Root Raised Cosine filters. It can be any real number between 0 and 1. j) Training sequence type: Data type is string. This chooses the training sequence to be used in both transmitter and receiver. It can be Length 11 Barker Sequence, Length 16 Frank Sequence, or Neumann Hoffman Binary Code. The following items are only on top_rx.vi: k) Correct frequency offset: Data type is Boolean [TRUE or FALSE]. This compensates the effect of the frequency offset between transmitted and received signals. It can be set as on or off. l) Symbol timing recovery method: Data type is string. This chooses the method to be used for symbol timing recovery. It can be any one of the following five options: MT Align to Ideal Symbols, Max Energy, Early-Late Gate, Gardner, or Fixed Offset. m) Training sequence: Data type is unsigned word [16-bit integer (0 to 65535)]. This chooses the training sequence to be used in the receiver. It can be Barker, Frank, or Neumann H. In the graph fields of top_tx.vi and top_rx.vi you see the following graphs:

1) (top_tx) Transmitted constellation: This graph shows the theoretical/ideal constellation points for the selected modulation scheme (two constellation points one at (I,Q)=(+1,0) and the other one at (-1,0) for BPSK; four constellation points one at (I,Q)=(+0.707,+0.707), second at (+0.707,-0.707), third at (-0.707,+0.707), and fourth at (-0.707,-0.707) for QPSK). 2) (top_rx) Signal constellation: This graph shows continuously changing I (in-phase or real) and Q (quadrature or imaginary) values of the constellation points as symbols received. 3) (top_tx and top_rx) Eye diagram: It is shown on both transmitting and receiving window. The transmitting window diagram is static, while receiving window diagram is dynamic. 4) Received signal: These two graphs show the Amplitude (in Volts) change of the received signal I and Q components in time domain. In order to export the values of a graph or array on the simulation window, follow this path and pick the output format you need: Right click on the graph/array > Export > Export (clipboard/excel/simplified image). In order to copy the current value of an indicator, right click on the indicator while simulation is running and select Copy Data. This copies the current value as an image. Also, if you need to run the simulator only for one loop, you can click on the single arrow ( Run ).