



# QICK AMO Extension Updates

Leandro Stefanazzi  
September 27, 2023

# Architecture of Generator

- Fifth order polynomial function for frequency modulation:

$$f[t] = c_0 + c_1t + c_2t^2 + c_3t^3 + c_4t^4 + c_5t^5$$

- Third order polynomial function for amplitude modulation:

$$a[t] = a_0 + a_1t + a_2t^2 + a_3t^3$$

- Gain for modulation scaling.
- tProc control for sweep start and control.
- Independent parameter memory per DDS instance.
- 32 independent DDS instances.
- Last DDS AM output routed to DAC.

# AMO Generator V4 Block Diagram

- 32 independent DDSs: FM, AM and Memory.
- Parameter memory: configurable size (256 actual).
- tProc control: address, wait, quantization and ctrl.
- ctrl field: phase reset, saturation logic, DDS 31 disable.



# Generator Control

- Parameter memory holds sweep coefficients.
- Each memory location stores a set.
- The total number of sets can be controlled by Firmware.

|   | 8    | 18   | 16   | 16    | 16    | 16    | 18    | 18   | 18    | 18    | 18    | 18    | 18    | 18    |
|---|------|------|------|-------|-------|-------|-------|------|-------|-------|-------|-------|-------|-------|
| 0 | CTRL | POFF | AM_G | AM_C3 | AM_C2 | AM_C1 | AM_CO | FM_G | FM_C5 | FM_C4 | FM_C3 | FM_C2 | FM_C1 | FM_CO |
| 1 | CTRL | POFF | AM_G | AM_C3 | AM_C2 | AM_C1 | AM_CO | FM_G | FM_C5 | FM_C4 | FM_C3 | FM_C2 | FM_C1 | FM_CO |
| 2 | CTRL | POFF | AM_G | AM_C3 | AM_C2 | AM_C1 | AM_CO | FM_G | FM_C5 | FM_C4 | FM_C3 | FM_C2 | FM_C1 | FM_CO |
| : | :    | :    | :    | :     | :     | :     | :     | :    | :     | :     | :     | :     | :     | :     |

- The tProc pushed waveforms in real time.
- Parameters: set number, duration and quantization.

| 8    | 8    | 32   | 32   | ctrl[0]:phase reset, ctrl[1]:saturation, ctrl[2]:dds 31 enable |
|------|------|------|------|----------------------------------------------------------------|
| qsel | ctrl | wait | addr |                                                                |

# Test Firmware



# FPGA Resource Usage



- > axis\_clock\_converter\_2 (d\_1\_axis\_clock\_converter\_2\_0)
- > axis\_clock\_converter\_3 (d\_1\_axis\_clock\_converter\_3\_0)
- > axis\_set\_reg\_0 (d\_1\_axis\_set\_reg\_0\_0)
- > axis\_sg\_int4\_v1\_0 (d\_1\_axis\_sg\_int4\_v1\_0\_0)
- > axis\_sg\_int4\_v1\_1 (d\_1\_axis\_sg\_int4\_v1\_1\_0)
- > axis\_signal\_gen\_amo\_0 (d\_1\_axis\_signal\_gen\_amo\_0\_0)
- > axis\_signal\_gen\_amo\_1 (d\_1\_axis\_signal\_gen\_amo\_1\_0)
- > axis\_signal\_gen\_amo\_2 (d\_1\_axis\_signal\_gen\_amo\_2\_0)
- > axis\_signal\_gen\_amo\_3 (d\_1\_axis\_signal\_gen\_amo\_3\_0)
- > axis\_switch\_gen (d\_1\_axis\_switch\_gen\_0)
- > axis\_switch\_gen\_amo (d\_1\_axis\_switch\_gen\_amo\_0)
- > axis\_tproc64x32\_x8\_0 (d\_1\_axis\_tproc64x32\_x8\_0\_0)
- > clk\_tproc (d\_1\_clk\_tproc\_0)
- < rot\_100 (d\_1\_rot\_100\_0)

# Scope Capture: modulation



# Scope Capture: modulation



# Scope Capture: auxiliary output



# Scope Capture: saturation logic

