# Wideband Full-Stokes parameterized spectrometer for Xilinx RFSoC Platform

PROJECT PLAN

Team 41 Professor Phillip Jones Advisers Team Members/Roles **Brian Bradford** Vishal Joel Jared Danner Louis Hamilton Nick Knuth Team Email sdmay19-41@iastate.edu Team Website sdmay19-41.sd.ece.iastate.edu

Revised: 9/28/2018/#1.0

# **Table of Contents**

| 1 l                                       | 1 Introductory Material 7                                |    |  |
|-------------------------------------------|----------------------------------------------------------|----|--|
|                                           | 1.1 Acknowledgement                                      | 7  |  |
|                                           | 1.2 Problem Statement (2 paragraphs)                     | 7  |  |
|                                           | 1.3 Operating Environment (one paragraph +)              | 7  |  |
|                                           | 1.4 Intended Users and Intended Uses (two paragraph +)   | 8  |  |
|                                           | 1.5 Assumptions and Limitations                          | 8  |  |
|                                           | 1.6 Expected End Product and Other Deliverables          | 8  |  |
| 2 Proposed Approach and Statement of Work |                                                          |    |  |
|                                           | 2.1 Objective of the Task                                | 9  |  |
|                                           | 2.2 Functional Requirements                              | 9  |  |
|                                           | 2.3 Constraints Considerations                           | 10 |  |
|                                           | 2.4 Previous Work And Literature                         | 10 |  |
|                                           | 2.5 Proposed Design                                      | 10 |  |
|                                           | 2.6 Technology Considerations                            | 10 |  |
|                                           | 2.7 Safety Considerations                                | 11 |  |
|                                           | 2.8 Task Approach                                        | 11 |  |
|                                           | 2.9 Possible Risks And Risk Management                   | 11 |  |
|                                           | 2.10 Project Proposed Milestones and Evaluation Criteria | 12 |  |
|                                           | 2.11 Project Tracking Procedures                         | 12 |  |
|                                           | 2.12 Expected Results and Validation                     | 12 |  |
|                                           | 2.13 Test Plan                                           | 12 |  |
| 3                                         | Project Timeline, Estimated Resources, and Challenges    | 13 |  |
|                                           | 3.1 Project Timeline                                     | 13 |  |
|                                           | 3.2 Feasibility Assessment                               | 13 |  |
|                                           | 3.3 Personnel Effort Requirements                        | 14 |  |
|                                           | 3.4 Other Resource Requirements                          | 14 |  |

| 3.5 Financial Requirements | 14 |
|----------------------------|----|
| 4 Closure Materials        |    |
| 4.1 Conclusion             | 14 |
| 4.2 References             | 19 |
| 4.3 Appendices             | 15 |

# List of Figures

Figure 1: Proposed Design Diagram



Figure 2: Functional Block Diagram



Figure 3: Basic Project Implementation



Figure 4: Ethernet Block Diagram [7]



Figure 5: Xilinx RFSoC ADC Diagram [8]



### List of Tables

# List of Symbols

# List of Definitions

CASPER - Collaboration for Astronomy Signal Processing and Electronics Research

*MiGen* - Fragmented Hardware Description Language based in python to automate the VLSI design process.

*Xilinx* - FPGA manufacturer. \*The FPGA used in this project is a Xilinx product.

DSP - Digital Signal Processing

FPGA - Field Programmable Gate Array

SoC - System on a Chip

*PYNQ* - Python productivity for Zynq platforms

### *IP core* - Intellectual Property core

casperfpga - a python library used to interact and interface with CASPER Hardware. Functionality includes being able to reconfigure firmware, as well as read and write registers across the various communication interfaces.

# 1 Introductory Material

#### 1.1 ACKNOWLEDGEMENT

CASPER [1], the "Collaboration for Astronomy Signal Processing and Electronic Research" have addressed this problem by developing platform independent hardware and open source software to take advantage of developments in Field Programmable Gate Array (FPGA) and Analog to Digital Converter (ADC) technology and "quickly" target new platforms such as the Xilinx RFSoC evaluation board (ZCU111).

Xilinx University Program - Donation of the Xilinx RFSoC Eval Board.

Alan Langman (Engineer @ Vermeer Corporation) - Technical guidance for Migen, CASPER, and spectrometer related material.

Dan Werthimer (Chief Scientist: SETI@Home) - Project idea, CASPER, and digital signal processing support.

#### 1.2 PROBLEM STATEMENT (2 PARAGRAPHS)

The problem our team will be challenged with is overhauling the CASPER Toolflow in order to allow for developers to easily become proficient in using and expanding on the existing tool set. The current toolflow prohibits new developers from making quick progress due to lack of documentation, the need for prior knowledge on MATLAB / Simulink, and an absence of support for other FPGA platforms beyond Xilinx, such as Altera or Lattice. In doing so, our team will also develop the board support package for the Xilinx RFSoC Eval Board.

This project will work toward porting of the CASPER spectrometer instrument and its dependent libraries to the Xilinx RFSoC evaluation platform. Using the RFSoC allows for the ADC, DAC, processor, and networking to all be on a single board rather than needing separate components and interfaces for each. The team will also look at improving the board support package by migrating the current tools to use Migen, an open source python library for generating and building gateware projects [4]. The ultimate goal of the new toolflow, which incorporates support for Migen and PYNQ, is to make FPGA programming easier so that researchers/developers can quickly develop instrumentation to meet their scientific requirements. The team will also work on extending the toolchain to support the Xilinx PYNQ infrastructure [5], which will be interfaced to the existing CASPER Python libraries.

#### 1.3 OPERATING ENVIRONMENT (ONE PARAGRAPH +)

The end product will be operating within already operational server racks that are climate regulated to match manufacturer specification of optimal operating conditions including:

temperature, humidity, and dust ingression. Therefore, the end product does not need to be built to work in non-common conditions due to its surrounding climate being externally controlled.

#### 1.4 Intended Users and Intended Uses (two paragraph +)

CASPER [1] is a community of hundreds of scientists and engineers around the world, who collaborate on the development of radio astronomy instrumentation. The CASPER community has reached out to developers to integrate Xilinx's new RFSoC platform into their current tools. Once supported, anyone making use of the open-source tools will be able to quickly develop digital instrumentation for their specific applications.

Should time allow, we will begin the next iteration of the UC Berkeley SETI Research Center's Search for Extraterrestrial Radio Emissions from Nearby Developed Intelligent Populations (SERENDIP) program [3]. This installment would be the next generation instrument system for the Search for Extraterrestrial Intelligence (SETI) coined SERENDIP VII. The system will be an open-source, ultra-high resolution, wide-bandwidth dual-pol spectrometer to be used on the world's largest radio telescopes.

#### 1.5 Assumptions and Limitations

At this point in time, our team is assuming that basic device drivers have been developed and tested. That the CASPER spectrometer instrument will be nearly 100% compatible and operational on the Xilinx RFSoC Platform.

#### 1.6 EXPECTED END PRODUCT AND OTHER DELIVERABLES

Our expected deliverable is a Board Support Package for a Xilinx Zyng Ultrascale+ RFSoC evaluation board. The board support package includes porting for the CASPER spectrometer and its dependent libraries for the Xilinx board. The CASPER tool flow is to be migrated to support Migen, an open source python library for generating and building gateware projects. It should support Xilinx Python drivers to interface with existing CASPER libraries. We must include full documentation of the implementation of the board support package. This end product is to be delivered by the end of Senior Design in May 2019.

# 2 Proposed Approach and Statement of Work

#### 2.1 OBJECTIVE OF THE TASK

#### Expected tasks:

- 1. Porting of the CASPER spectrometer instrument and dependent libraries to the Xilinx ZCU111 evaluation platform.
  - a. General board support
  - b. Ethernet interface
  - c. ADC interface
- 2. Migrating the current CASPER Toolflow to use Migen, an open source python library for generating and building gateware projects.
- 3. Support for Xilinx PYNQ infrastructure, which will interface to existing CASPER Python libraries.
- 4. Documentation of project for future users: source code, gateware, and firmware descriptions.

#### Additional task:

1. Wideband full stokes parameterised spectrometer (polarimeter) for radio astronomy applications, targeting the Xilinx Zyng RFSoC platform.

#### 2.2 FUNCTIONAL REQUIREMENTS

Successful creation of a Board Support Package file. This includes proper integration of the existing toolflow and any new tools to create a working Board Support Package for the Xilinx Zynq RFSoC platform. Migen will be used as the generation tool for our project which will include ensuring that it is both integrated in the current tool flow and a new tool flow of our own design.

Proper documentation of process. We will need to document our process so that the open source project work can be continued by others. We also need to document our process to allow for review by the CASPER project and to give a tutorial of how our updated tool flow works.

Proper documentation of tools used. Proper documentation of our work and use of Migen is important for expanding Migen itself. We also need to document how the existing toolflow and its tools integrate with Migen.

#### 2.3 Constraints Considerations

- Functional
  - CASPER spectrometer support
    - The Xilinx board must be made to support the CASPER Spectrometer and the libraries it is dependent on.
  - Migen
    - Migen must be able to send script to CASPER's Vivado to produce projects that the FPGA can use.
  - Spectrometer
    - Parameterized inputs for user to quickly build
- Non-Functional
  - Backwards compatibility
    - The ability to STILL use MATLAB/Simulink and existing CASPER tool flow, instead of Migen to program the board.
  - Open source
    - Anyone can use our code in their application.

CASPER operates entirely under the GNU General Public License V2.0. This grants the use of the source code to anyone for commercial or private use. This also means anyone has the right to modify and/or distribute the code, however CASPER accepts no liabilities or warranties on said source code.

CASPER has a stated code of conduct, as part of working with CASPER we must adhere to the policies outlined in this document [9]. Otherwise, we'll adhere Iowa State ECE's lab safety procedures outlined by ECpE Lab Safety Procedures [10]. This mostly ensures no unintentional damage is done to lab equipment and individuals present in the lab. The boards that we are working with are costly and proper lab procedures will ensure there are minimal chances for damaging the boards.

### 2.4 Previous Work And Literature

Two previous CASPER Toolflow board support projects were completed in past two years by the South African Radio Astronomy Observatory's (SARAO) support for the SKARAB board [11], and the Institute of Automation, Chinese Academy of Sciences support for the SNAP2 board [12]. In both cases a Microblaze softcore processor was used as a system controller. This softcore processor is currently implemented in the FPGA fabric/programmable logic. We can now take advantage of the hardcore ARM processor on board as the system controller with the Zyng architecture and port the existing Microblaze code to run on ARM. In both cases a python library called *casperfpqa* is used to interface with the board, which requires a steep learning curve for new developers. Instead, we will leverage PYNQ support of the Zynq architecture to achieve the same functionality requiring less development time.

Should we complete the Board Support Package before the end of Senior Design, we will attempt to implement the next generation SETI spectrometer: SERENDIP VII. This would be the next iteration of this application, the prior was SERENDIP VI [6]. It would be an improvement by both bandwidth and spectral resolution.

#### 2.5 Proposed Design

The proposed design to address our problem (as seen in Figure 1 in the Figure section) is to manipulate the current CASPER toolflow and use Migen to add the ability to target various FPGA platforms as well as to ease the development of Board Support Packages. Migen can also be used as an alternative front-end to MATLAB/Simulink, removing the current toolflow's dependency on this closed-source software.

Figure 2 shows a high level functional design we are aiming to achieve for the SETI spectrometer. The four sections we can break Figure 2 into are: ADC interface, DSP logic, networking, and PYNQ software control. The DSP logic will be implemented in the CASPER toolflow's Simulink frontend following the inner block labeled 'DSP' in Figure 2. Figure 4 shows specifically how the ethernet and networking will be implemented on board. Figure 5 depicts a block diagram of the RFSoC onboard ADCs and how they differ from the previous generation of ADCs.

Strengths of our proposed solution are portability, accessibility, and scalability. Using Migen as our frontend development allows for accessibility and scalability for developers because it is an open-source python library rather than a MATLAB implementation with a Python interface. Successful implementation of the toolflow using the RFSoC board will allow for greater portability because the entire system will be on a single board rather than needing separate components and interfaces. A weakness of our proposed design is the application using the board is constrained to the ADC on the board and the processing constraints of the on board processor. A trade-off of our proposed design is the use of Xilinx IP cores to implement particular functionality. This sacrifices specific functionalities of our application to be restricted to only Xilinx hardware, but increases the development time. We could alternatively have spent time implementing open-source IP cores that would have been platform agnostic, but would've taken more time to implement.

#### 2.6 Technology Considerations

If successful in implementation, this would be the first Zynq SoC board to be integrated in the tool flow allowing for the board to run everything rather than needing auxiliary components. Using Migen should allow the toolflow to be ported completely to python removing the need for MATLAB and the current clunky python implementation while maintaining backwards compatibility with the MATLAB tools. A weakness of the technology being used is the heavy reliance on Migen and the potential for it not to work. A trade off of having a SoC is that we are constrained to the components on board such as the ADC and processor.

#### 2.7 SAFETY CONSIDERATIONS

We must obey all posted signs and warnings as well as instructions issued by the lab instructor in the laboratory. We must know the location of the fire extinguishers, First Aid

kits and their proper use. The improper or unsafe use of laboratory equipment is potentially dangerous. Therefore, we must not use lab equipment for purposes other than this class' work. We must understand the emergency shutdown procedures (when necessary) for any lab equipment that we are using. We must understand and comply with electrical safety procedures.

#### 2.8 TASK APPROACH



This diagram displays a basic approach towards our proposed project timeline. Initially, we begin with the board support package and once we have that covered we can begin our simple spectrometer implementation. Our final product would be the parameterised spectrometer (polarimeter) for radio astronomy applications. This diagram demonstrates a very basic approach towards our project's implementation.

#### 2.9 Possible Risks And Risk Management

- Completely new concept There isn't any other Zynq Soc-type platform that supported within the CASPER's community. So overall, the whole project implementation is fairly new.
- Lack of documentation on Migen Migen's documentation is quite lacking. Their
  documentation offers the bare minimum assistance required to set up the tool, but
  when it comes to our project implementation a lot of research will need to be done
  to get it up and working.
- New to the project members Most of the team members are fairly new to working with FPGA boards, at least at this level. Therefore there is a big learning curve that needs to be addressed.

#### 2.10 Project Proposed Milestones and Evaluation Criteria

#### **Milestones:**

- Getting around the dependency on MATLAB/Simulink while not completely eliminating the backward compatibility with these tools.
- Reliable documentation and open source tools, gateware, firmware descriptions that may gain attention from other developers.
- Open source tools that may help with support for other FPGA platforms.

#### 2.11 PROJECT TRACKING PROCEDURES

Our group will make use of the Issue Board included with our Iowa State GitLab repository. This is a project management tool that can be used to plan, organize, and visualize our workflow towards tasks involved with our project. We will also keep an eye on the activity metrics that are tracked by GitLab. The Wiki Board will be used to document things as we progress through our project.

#### 2.12 EXPECTED RESULTS AND VALIDATION

Our desired outcome would be the Xilinx RFSoC board fully supported within the current CASPER Toolflow as well as Migen. We will validate the functionality of the ethernet interface by both echoing UDP packets through the interface and ensuring the board will DHCP correctly to obtain an IP address. We will validate the functionality of ADC interface by generating a signal in the lab and ensuring that the ADC digitizes the signal correctly. We will validate the general board support within the CASPER Toolflow and Migen by compiling the CASPER Wideband Spectrometer tutorial for our board. This tutorial design also incorporates both the Ethernet and ADC interfaces as well as DSP logic which will demonstrate programmable logic and processing system board support.

#### 2.13 TEST PLAN

(We are not far enough along to be able to give a solid test plan yet.)

# 3 Project Timeline, Estimated Resources, and Challenges

#### 3.1 PROJECT TIMELINE



This gantt chart is based off of the tasks listed in section 2.1. The gap in the middle is the break between semesters. The first main section is doing an initial port of the current toolflow to the new board we will be using. This is so that we can integrate the new architecture of a SoC into the existing toolflow and find any issues with the new architecture quickly. The substeps within this section are researching the CASPER project and its current toolflow. The next section is developing a basic board support package for the new board to learn its architecture. The next step will be including networking support through the use of the on board ethernet port. The final step in this section will be adding the ADC interface and the DSP logic. This section should result in a successful port of the current toolflow to the new board. The next section will be writing Migen libraries to support the new board's architecture and the current toolflow's front end system. The final section will be developing a support package for the PYNQ libraries available for the board and use them along with Migen as a new interface in the toolflow. The first substep in this section will be looking at PYNQ's capabilities and configuring it for the CASPER toolflow. The next step will be testing this implementation and the overall

implementation of the project as a whole. Throughout the semester there will be documentation work as shown by the final section.

#### 3.2 FEASIBILITY ASSESSMENT

Our project group, client, and advisor have assessed the required tasks needed complete the overall goal and we have concluded that it will be difficult, but doable if given the proper amount of time and effort.

Some foreseen challenges that our group has accounted for are: the variable scope of the supported libraries already created for our desired Xilinx platform (board support package), getting the required hardware to achieve meaningful testing, and our assumption that Migen will work as specified and not cause any unforeseen problems.

#### 3.3 Personnel Effort Requirements

(Our tasks are not concrete enough to create a table at this detail yet.)

#### 3.4 OTHER RESOURCE REQUIREMENTS

- Xilinx Zynq Ultrascale+ RFSoC evaluation board.
- Xilinx platform cable.
- Access to the ISU ECPE linux servers and their tools.

#### 3.5 FINANCIAL REQUIREMENTS

There is no current foreseen financial resources required for this project given that the Xilinx University Program donates the Xilinx Zynq RFSoC board for our project.

## **4 Closure Materials**

#### 4.1 CONCLUSION

The problem our team will be challenged with is overhauling the CASPER Toolflow in order to allow for developers to easily become proficient in using and expanding on the existing tool set. In doing so, our team will also continue development of the board support package for the Xilinx RFSoC Eval Board.

The stated problem is a necessary task that, when completed, will ensure that the CASPER organization is well equipped and able to continue its development into the future on a solid foundation.

#### 4.2 REFERENCES

1. Casper-dsp.org. (2018). The Collaboration for Astronomy Signal Processing and Electronics Research. [online] Available at: http://casper-dsp.org/ [Accessed 23] Oct. 2018].

- 2. Price, D. (2018). *Spectrometers and Polyphase Filterbanks in Radio Astronomy*. [online] Arxiv.org. Available at: https://arxiv.org/abs/1607.03579 [Accessed 23 Oct. 2018].
- 3. Ieeexplore.ieee.org. (2018). Commissioning and testing of SERENDIP VI instrumentation USNC-URSI national radio science meeting IEEE Conference Publication. [online] Available at: https://ieeexplore.ieee.org/document/7436240/ [Accessed 23 Oct. 2018].
- 4. M-labs.hk. (2018). *Migen* | *M-Labs*. [online] Available at: https://m-labs.hk/migen/index.html [Accessed 23 Oct. 2018].
- 5. Readthedocs.org. (2018). *PYNQ* | *Read the Docs*. [online] Available at: https://readthedocs.org/projects/pynq/ [Accessed 23 Oct. 2018].
- 6. Ieeexplore.ieee.org. (2018). Commissioning and testing of SERENDIP VI instrumentation USNC-URSI national radio science meeting IEEE Conference Publication. [online] Available at: https://ieeexplore.ieee.org/document/7436240/ [Accessed 23 Oct. 2018].
- 7. Xilinx.com. (2018). [online] Available at: https://www.xilinx.com/support/documentation/application\_notes/xapp1305-ps-p l-based-ethernet-solution.pdf [Accessed 23 Oct. 2018].
- 8. Xilinx.com. (2018). *Programmable RFSoC*. [online] Available at: https://www.xilinx.com/products/technology/rfsampling.html [Accessed 23 Oct. 2018].
- 9. GitHub. (2018). casper-astro/mlib\_devel. [online] Available at: https://github.com/casper-astro/mlib\_devel/blob/6904b15a79ecfcoo656d77bd3d36 b47958e452fb/CODE\_OF\_CONDUCT.md [Accessed 25 Oct. 2018].
- 10. "Safety Electrical and Computer Engineering Iowa State University", *Ece.iastate.edu*, 2018. [Online]. Available: https://www.ece.iastate.edu/the-department/safety/. [Accessed: 25- Oct- 2018]
- 11. W. New, "JASPER and the SKARAB", 2017 CASPER Workshop, California Institute of Technology, 2017.
- 12. L. Shu, "SNAP2's development toolflow and applications", 2018 CASPER Workshop, Guizhou Province, China, 2018.

### 4.3 APPENDICES

(We have no appendices to include at this time.)