About Perry
I’m a Junior at the Milwaukee School of Engineering pursuing a bachelor’s in computer engineering. With over 10 years of hobbyist experience with RTL and hardware development - my passion for computers and hardware started early at just 10 years old. I’ve developed custom software/hardware solutions that have been deployed across the country through previous internship experience and I’m eager to continue applying my passion, skill, knowledge and love for the field of computer engineering to create more innovative and elegant solutions.
Skills
- Python (Tkinter, PyQt, matplotlib, tensorflow, pytorch, transformers, pandas, pyserial, Qiskit, Flask)
- VHDL
- Verilog/SystemVerilog
- C
- C++
- Java
- Kotlin
- JavaScript
- HTML/CSS
- Bash
- TCL (Tcl/Tk)
- Perl
- Git
- Jenkins
- AXI4, AXI4-Lite
- Quartus, Modelsim, Vivado, Vitis HLS
- RISC-V, ARM, Microblaze
- UVM, CocoTB, PyUVM
- MATLAB, Simulink, Speedgoat HIL
- I2C, SPI, Serial, MII
- Logic Analyzers, JTAG, PLL, DLL
- NI Multisim
- Digital Signal Processing
- Superscalar and Parallel Architectures
- PCB Design (EasyEDA, JLCPCB)
- Jupyter Notebook
- MS Office, Excel
Websites
- easytrig.com Free and Easy Engineering Calculators.
- wrelks.com Blog website, resource collection for Qiskit/QuantumComputing, Quantum circuit sim w/ math
- relks.org Artificial Intelligence that survives in space.
- perrynewlin.com (Here!) minimalist portfolio website.
- theoneduck.com Software solutions for the everyday user, no subscriptions just elegant working stuff.
Certifications
- Quantum Algorithms for Cybersecurity, Chemistry, and Optimization
Institution:
Massachusetts Institute of TechnologyLink to Certification.
- Introduction to Quantum Computing
Institution:
Massachusetts Institute of TechnologyLink to Certification.
- Certificate of Quantum Excellence
Institution:
IBM QuantumLink to Certification.
- Introduction to Quantum Computing Course
Institution:
IBM QuantumLink to Certification.
- Arduino Fundamentals | Electronics and Physical Computing
Institution:
ArduinoLink to Certification.
Projects
- CSMA/CD Networking Protocol Implemented and Pipelined on Artix 7 FPGA | 2025
Technologies Used: VHDL, QuestaSim, TCL, Vivado, Manchester Encoding, EasyEDA, JLCPCB
- Project Objective: Implement MSOE networking protocol in pure hardware - Deep pipelines.
- Implementation tested up to 2mbps with >98% accuracy.
- Implementation recognizes collisions mid transmission and knows to retransmit packets to directed device when network returns idle, successfully interacting over RJ45 switch.
- Features: CRC8, packet construction around message, 255 unique addresses, broadcasting address, and two UART communication ports for sending and reading network messages.
- The two UART boards that talk to the FPGA feature a CP2102 and use a USB type C connector; these were developed in EasyEDA and printed through JLCPCB.
- Developed TCL/Tk scripts for building project and running testbenches on new git clone.
- Eight-stage calibration pipeline on the Manchester decoder to handle 25% tolerance.
- Result: Successfully achieved interoperability with another implementation through switch.
- Broadcast UDP Packets with Artix 7 FPGA through Homelab Network Switch | 2025
Technologies Used: VHDL, Vivado, MII, UDP
- Project Objective: Broadcast hardcoded UDP packets to contain message payloads.
- Designed and implemented a pure hardware solution for the Artix 7 FPGA that can transmit UDP packets over ethernet through the PHY via MII interface connected to the PL.
- UDP packets contain custom payloads any device in my home lab network can receive.
- Result: Completed – College Junior Year, plans to expand functionality further.
- Inference of Quantized Neural Networks with Ultrascale+ FPGAs | 2024–2025
Technologies Used: Python, Vivado, Vitis (HLS), GitLab, Pytorch, Tensorflow
- Project Objective: Run quantized neural networks in parallel >150MHz on Ultrascale+.
- Designed and developed Pytorch & Tensorflow python programs to train sequential neural networks with ReLU activation to predict patterns for people with diabetes, sensor failure, and nonlinear abnormal trigonometry functions.
- Developed python scripts to extract weights and biases from trained networks.
- Developed python scripts to quantize exported weights and biases in 16/8/4bit, and ternary.
- Developed python scripts to write and save new VHDL hardware entities and packages for synthesizing hardware capable of inference – deep pipelining was utilized for timing.
- Result: <1Watt for inference of 1000neurons – Expanding functionality.
- Create my own Chatbot Server Stack | 2024–2025
Technologies Used: Wireguard, Python (llama_cpp, HTTPServer, Flask), HTML, CSS, JS
- Project Objective: Local hosted LLM accessible through webserver on VPN subnet.
- Local inference of a quantized 8billion parameter LLM using llama_cpp.
- I developed and deployed a frontend webpage hosted on my desktop that would send and receive responses generated by the LLM to the site.
- HTTP server on 10.0.0.2:5000 listens for incoming payload, processes JSON payload, responds with JSON message.
- Custom commands on frontend user input for clearing screen and providing help messages.
- Enter questions are sent to the Flask server on 10.0.0.2:5001, this is forwarded to the LLM.
- Result: From anywhere in the world, I can access my VPN server which gives me access to my locally hosted alliterated LLM.
- FPGA Based Arbitrary Waveform Generator with Custom PCBs | 2023–2024
Technologies Used: VHDL, Vivado, C, CubeIDE, SPI
- Project Objective: FPGA – Parallel DAC Waveform generator.
- Designed and printed PCBs each with one parallel DAC and ADC with two SMA connectors.
- Parallel DACs connected to an Artix 7 FPGA development board, user toggles switches on the FPGA board to change the frequency of the output wave and the type.
- Waves implemented (square, sine, triangle, and sawtooth).
- Waveform fed into onboard ADC of an STM32F411 microcontroller, driven by interrupts.
- STM32 drives a LED dot matrix display to showcase the varying voltage levels of waveform.
- Result: Generated various waveforms through my custom PCBs, demo on perrynewlin.com.
- Develop Website for Phasor Calculation & Testbenches Generation | 2023–2025
Technologies Used: HTML, CSS, JS (chart.js, three.js)
- Project Objective: Create a website for calculating phasors.
- Designed and created easytrig.com – a website that makes math operations pertaining to circuit analysis far easier to perform on mobile devices.
- Render outputs from OpenAI’s ChatGPT in markdown and convert to PDF.
- Add, subtract, multiply, and divide phasors with steps rendered in real-time.
- Render phasors as sinusoids with zooming and autozoom features.
- Plot imaginary numbers as vectors and have length calculated in real-time.
- Added tool to generate VHDL testbench boilerplate code based on entity ports.
- Result: Easytrig gets 1000+ monthly visits, bringing free and powerful tools to the masses.
- Develop, Synthesize, and Implement soft ARMv4 Processor in VHDL | 2022
Technologies Used: VHDL, Quartus, ModelSim
- Project Objective: ARM processor on Intel DE10 FPGA development board.
- In Digital Logic II I implemented the ARMv4 ISA as a soft processor in VHDL on the DE10.
- Implemented w/ VHDL: instruction fetch, decode, execute, memory, and register writeback.
- Verified program execution, and writeback functionality with comprehensive testbenches.
- IROM compatible with the following assembly: MOV, LDR, STR, ADD, SUB, CMP, BEQ.
- Result: Executed a program to light up LEDs that utilized branches, arithmetic, and load/store.
- Custom Handheld Microcontroller Game Console | 2020–2021
Technologies Used: C, Arduino, I2C, UI design, FRAM, JTAG (AVR Programmer), PCB Design
- Project Objective: Portable handheld game console using custom PCBs.
- Designed custom board using 32u4 microcontroller.
- Designed and programmed custom games rendered on a 128x32 I2C screen.
- Games which include object avoidance with built in difficulty increase as score increments.
- Designed custom FRAM logic to store user scores after console shutdown.
- Result: Could play custom made two-color games in a case < 1” wide at more than 40 frames.
- Accessibility OLED Watch to Display my Class Schedule | 2018
Technologies Used: C, Arduino, I2C, UI design
- Project Objective: Create a watch using a low powered MCU that displays my class schedule.
- Designed wristwatch with 16u4 development board, LiPo battery, & I2C OLED display.
- Designed U.I to display class schedule for which day of week it was.
- Displayed schedule could be cycled using a single push button input, debounced.
- Result: No longer had to remember a long schedule, just look at my custom watch!
- Simple as Possible 1 Single Cycle Computer | 2015–2016
Technologies Used: 74LS series ICs, EEPROMs, Oscilloscope, Function Generator
- Project Objective: Build 8-bit SAP-1 Computer From Scratch.
- Used 74LS series logic chips and other DIP based chips to build an 8bit computer entirely on breadboards.
- After 7 months it was completed and was able to run the JMP command.
- After 8 months it could play the Fibonacci sequence all on its own.
- Features: 8-Bit instruction register, 4-bit program counter, 8-Bit accumulator and B-register.
- Inspired by Ben Eater.
- Result: Can perform a jump instruction and run a loaded program in the EEPROM.
Relevant Coursework
- Superscalar, Multicore, and Multiprocessor Architecture
Course Code: CPE 4510 — Milwaukee School of Engineering - Advanced Embedded Systems
Course Code: CPE 3600 — Milwaukee School of Engineering - Computer Architecture
Course Code: CE 1921 — Milwaukee School of Engineering - Differential Equations
Course Code: MTH 2130 — Milwaukee School of Engineering - Digital Logic I
Course Code: CE 1901 — Milwaukee School of Engineering - Digital Logic II
Course Code: CE 1911 — Milwaukee School of Engineering - Discrete Mathematics
Course Code: MTH 2310 — Milwaukee School of Engineering - Embedded Systems
Course Code: CPE 2610 — Milwaukee School of Engineering - Ethics for Managers & Engineers
Course Code: PHL 3101 — Milwaukee School of Engineering - Physics II — Electromagnetism
Course Code: PH 2021 — Milwaukee School of Engineering - Probability and Statistics
Course Code: MTH 2480 — Milwaukee School of Engineering - Systems Programming
Course Code: CPE 2600 — Milwaukee School of Engineering - Waves, Relativity, Thermodynamics
Course Code: PH 1980T — Milwaukee School of Engineering
Gallery
Interesting pictures I take during the creative process.
To prevent un-authorized use, a vast majority of the gallery is hidden (>500Pictures/Videos). Thank you for understanding.