# Hall-A Tritium Analysis Meeting

# JLab 250 MHz Flash ADC Modules

Eric Pooser Jefferson Lab

07/18/2018

On Behalf of the Hall-C DAQ Working Group









Science

# FADC250: Technical Details

- Jefferson Lab's fast electronics group developed and maintains high speed and high density 250 MHz pipelined flash ADC modules
- Conditions, samples, digitizes, and processes fast negative-going analog signals at 250 MHz
- Data are stored in circular buffers every 4 ns
- Conforms to VME64x switched serial (VXS) standard
- Serial data is routed via the back plane to a switch slot at a rate of 6 Gb/s
- Provides information for energy deposition, timing, hits, and trigger information
- Currently utilized for production running in Hall's B, C, and D
- 72 channel FADC125's utilized for drift chamber readout in Hall-D







07/18/2018

#### **FADC250: Architecture**

- 16 channel 50  $\Omega$ , coax, LEMO inputs
- There are 3 configurable ranges available *via*. jumpers: 0.5, 1.0, 2.0 V
- Differential signal conditioning scales the input signals to within the 12-bit dynamic range of the ADC's
- Individual channel offsets are effected by means of DACs under VME control
- Digitized data and clock signals are fed to a pair of FPGA's for data processing and temporary storage
- Third FPGA combines data from data processing FPGAs
- ADC data is stored in RAM for event building and is readout via VME
- Fourth FPGA handles the control, trigger, and interface functions



#### F.J. Barbosa, et al., GlueX Doc 1022

Hall-A Tritium Analysis Meeting





Eric Pooser

07/18/2018

3

#### **FADC250: Performance Specifications**



- 8 µs pipeline with user programmable trigger latency and readout window widths
- Sparsification, charge, pedestal, timing, and peak values are obtainable
- Hit information with user defined thresholds and trigger processing also available
- Internal clock domains governed by differential PECL clock with < 2 ps jitter</li>



Eric Pooser

|                                                                | fADC-250 Specifications<br>VME64x with VXS, Pipelined 250 MSPS Flash ADC Module |                                                                                                                                                               |                                                                                                                                                                                                                                                                                  |  |
|----------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DC TR ST<br>CK<br>STRC<br>TRC<br>STATUS1<br>G Q<br>Q<br>Q<br>Q | Signal Inputs                                                                   | Number<br>Range<br>Offset                                                                                                                                     | 16 S Version (50 Ohm, LEMO)*<br>-0.5V, -1V & -2V. User Selectable<br>±10% FS per channel via DACs                                                                                                                                                                                |  |
|                                                                | Clock                                                                           | Sampling<br>Jitter<br>Source                                                                                                                                  | 250 MSPS, Differential<br>1 pS (10-bit ADC), 350 fS (12-bit ADC)<br>Internal and External                                                                                                                                                                                        |  |
|                                                                | Control<br>Inputs/Outputs                                                       | Clock<br>Trigger<br>Status 1<br>Status 2<br>Sync<br>Trigger                                                                                                   | N – Diff., LVPECL (Front Panel & Backplane)<br>IN, OUT - Differential (Front Panel & Backplane)<br>OUT – Differential (Front Panel & Backplane)<br>OUT – Differential (Front Panel & Backplane)<br>OUT – Differential (Front Panel & Backplane)<br>SW Software Strobe (Internal) |  |
|                                                                | Conversion<br>Characteristics                                                   | Resolution<br>INL<br>DNL<br>SNR<br>Data Latency                                                                                                               | 10-bit (8 and 12-bit by chip replacement)<br>± 0.8 LSB<br>± 0.5 LSB<br>56.8 dB @ 100 MHz Input<br>32 nS                                                                                                                                                                          |  |
| $\sim$                                                         | Trigger Latency                                                                 | 8 µS                                                                                                                                                          |                                                                                                                                                                                                                                                                                  |  |
| $\sim$                                                         | Data Memory                                                                     | 8 µS                                                                                                                                                          |                                                                                                                                                                                                                                                                                  |  |
|                                                                | Data Processing                                                                 | Sparcification<br>Windowing<br>Charge, Pedestal, Peak, Energy Sum on VXS for Trigger<br>Time (Over Threshold, Relative to trigger)<br>Output (Backplane, VXS) |                                                                                                                                                                                                                                                                                  |  |
| DC-250                                                         | Interface                                                                       | VME64x – 2eVME Data Transfer Cycles (40, 80, 160 & 320 MB/sec) with VXS-P0                                                                                    |                                                                                                                                                                                                                                                                                  |  |
| <u> </u>                                                       | Packaging 6U VME64x                                                             |                                                                                                                                                               |                                                                                                                                                                                                                                                                                  |  |
|                                                                | Power                                                                           | +3.3V, +5V, +12V, -12V                                                                                                                                        |                                                                                                                                                                                                                                                                                  |  |
|                                                                |                                                                                 |                                                                                                                                                               |                                                                                                                                                                                                                                                                                  |  |

#### F.J. Barbosa, et al., GlueX Doc 1022

Hall-A Tritium Analysis Meeting



07/18/2018

4

#### **FADC250: Bench Performance**

- FADC250's provide excellent resolution and pedestal differences of <10%</li>
  - Pedestal variation is a measure of the intrinsic rms resolution
  - $\sigma$  = 1.5 LSB for single channel
  - $\sigma = 1.43 \pm 0.06$  LSB for 8 channels
- No cross talk present even under saturating conditions, effects are within noise margins







# FADC250: FPGA Pulse Processing

- ADC samples are stored in 2048 sample circular raw buffers
- When a trigger is received, the 12-bit trigger number counter is incremented and a PTW number of ADC samples are stored in the unprocessed buffer
- PTW is user programmable from 5 to 511 (9-bits, ≈ 2 µs)
- PL is user programmable from 0 to 2047 (11-bits, ≈ 8 µs)
- Sample processing is comprised of two modes (> 0x0C00)
  - 9 → Production Mode
  - 10 → Debug Mode





# FADC250: Production Mode (9)

- Pulse identification is initiated if number of consecutive pulses samples (NSAT) are above the programmable threshold (TET)
- The pulse duration includes the ADC number of samples before (NSB) and after (NSA) the first sample crossed the threshold (TC)
- NSA ∈ [2, 511] (9 bits), NSB ∈ [-8, 8] (4 bits) : + indicates number of samples before TC,
   indicates number of samples after TC to be excluded from the pulse duration
- The pulse data only includes samples within PTW even if NSB and/or NSA extend beyond PTW
- Up to four pulse are detectable within PTW
- Pulse must have at least one sample < TET before pulse is identified
- If NSB > 0, TC must be within last NSAT + 1 samples of the window
- If NSB < 0, TC must be within last NSAT + NSB + 2 samples of the window





# FADC250: Production Mode (9)

- Pulse integral is the sum of samples of the defined pulse duration (18 bit word)
  - Integral quality bits (3 bits) identify instances of under & over flow, exceeding PTW
- Pulse pedestal is the sum of NPED samples after the beginning of PTW
  - NPED  $\in$  [4, 15], if pedestal is above MaxPed, or identified as under or over flow, quality bit is set
- Pulse amplitude (12 bit word) identifies maximum value of identified pulse
  - Found when the current sample is less than the one that preceded it
- Pulse time is the time in which the leading edge of the identified pulse reaches half of its maximum sampled amplitude





07/18/2018 Hall-A Tritium Analysis Meeting 8



# FADC250: Production Mode (9)

- With V<sub>ped</sub> & V<sub>peak</sub> known, the half amplitude V<sub>mid</sub> is computed: V<sub>mid</sub> = (V<sub>peak</sub> - V<sub>ped</sub>) / 2
- Samples before and after V<sub>mid</sub> are determined: SN-1 & SN+1
- The 4 ns time between V(SN-1) & V(SN+1) is divided into 64 sub-samples (62.5 ps)
- The high resolution time (t<sub>mid</sub>) corresponding to Vmid is determined via. linear interpolation
- $t_{mid} = 64^*(V_{mid} V(SN-1)) / (V(SN+1) V(SN-1))$
- The fine time is time-walk independent (CFD)
- Coarse time is reported as the time in which V(SN-1) occurred (4 ns jitter)
- If the high resolution pulse time algorithm fails, the time reported is the TC time (coarse) and time quality bits are set







07/18/2018 9



#### FADC250: Debug Mode (10)

- In addition to calculating the pedestal, amplitude, integral, and high resolution pulse time, all the samples in PTW are recorded if there is at least one pulse identified
- All data written out includes both a trigger number, and trigger time



25 Raw Events of FADC Mode 10 Sample Data Slot 3 Channel 15

#### Hall A/C FADC250 Decoder

- Fadc250Module class is maintained in podd, resides in hana\_decode directory
- Backwards compatible with pre 0x0C00 firmware versions
- Standalone utility tstfadc\_main.C included in podd/hana\_decode
- Scans crate for F250 modules, histograms all possible data in crate/slot identified as a F250



#### Hall A/C FADC250 Threshold Script

- calc\_thresh.cxx in podd/hana\_decode utilizes the output of tstfadc\_main.cxx to produce a CRL readable file containing the individual thresholds for each FADC channel in a readout crate
- Currently, the script only applies a single global threshold for all channels in a single crate



12



07/18/2018 Hall-A Tritium Analysis Meeting



- "Good" ADC variables are calculated in the detector class CoarseProcess method
- FADC error flag cut
  - Removes events in which the FADC250 FPGA fails
  - adcErrorFlag is recorded for each detector for each event and is stored in the ROOT tree
- Pulse time cut -
  - Removes events which are not within the defined "prompt-peak" time window





07/18/2018 Hall-A Tritium Analysis Meeting

13



14

- Implementation of "Good" ADC & TDC Variables
  - vector <Double t>
- Low-level fiducial event selection methods implemented to select best hits in each detector channel
- Currently present in all detector classes aside from the drift chambers
- Hodoscopes are only nontracking detectors with TDC's





07/18/2018 Hall-A Tritium Analysis Meeting



- "Raw" and "pedestal subtracted" ADC data are still constructed as TClonesArray objects
  - Sparsified scalar data objects
  - Only written to the ROOT tree if the "fDebugAdc" has been set to "true (1)"
- "Good" ADC & TDC data are constructed as unsparsified vector objects



SHMS Heavy Gas Cherenkov Good Pulse Amplitude





07/18/2018 Hall-A Tritium Analysis Meeting

15



- Vector data objects can be histogrammed via. the "eye" variable in DEF-files
- The "eye" variable can have its index increased by an arbitrary integer amount
- 2D histogram of scalars produces single scalar – histogram
- 2D histogram of vectors produces vector of histograms
- Adding prefix "s" to 2D histogram of vectors produces single scalar histogram

| TH1F | h1 | P.hgcer.goodAdcPulseAmp[0]            |
|------|----|---------------------------------------|
| TH1F | h2 | P.hgcer.goodAdcPulseAmp[1]            |
| TH1F | h3 | P.hgcer.goodAdcPulseAmp[2]            |
| TH1F | h4 | <pre>P.hgcer.goodAdcPulseAmp[3]</pre> |

| TH2F | h1 | [I+1] | P.hgcer.npe             |
|------|----|-------|-------------------------|
| TH2F | h2 | [I+1] | P.hgcer.goodAdcPed      |
| TH2F | h3 | [I+1] | P.hgcer.goodAdcPulseInt |

| TH2F | h1 | P.hgcer.adcX | P.hgcer.adcY |
|------|----|--------------|--------------|
| TH2F | h2 | P.hgcer.adcX | P.hgcer.adcZ |
| TH2F | h3 | P.hgcer.adcY | P.hgcer.adcZ |

| TH2F | h1 | P.hgcer.goodAdcX | P.hgcer.goodAdcY |
|------|----|------------------|------------------|
| TH2F | h2 | P.hgcer.goodAdcX | P.hgcer.goodAdcZ |
| TH2F | h3 | P.hgcer.goodAdcY | P.hgcer.goodAdcZ |





07/18/2018 16

Hall-A Tritium Analysis Meeting





- FADC reference time present in all relevant ROC's
  A copy of the TDC reference time is fed into an DC sirewit in
  - time is fed into an RC circuit in order to smear out the NIM logic signal
- AdcPulseTimeRaw objects contain the raw FADC times
- AdcPulseTime objects are reference time subtracted via THcRawAdcHit class
- AdcTdcDiffTime objects are reference time subtracted FADC times minus the hodoscope start time

Eric Pooser





#### **FADC250: Time-walk Calibrations**

- For individual PMT's with both FADC and TDC readouts, time-walk corrections can be made on an individual basis
- High resolution, time-walk independent FADC time serves as self reference to time-walk dependent TDC time

Timewalk Effect Volts Baseline Threshold Analog Signal A Analog Signal B Analog Signal C Discriminator Output A Discriminator Output B Discriminator Output C - "Timewalk" t<sub>A</sub>t<sub>B</sub>t<sub>C</sub>  $Time \longrightarrow$ 07/18/2018 Eric Pooser 19



TDC-ADC Time vs. Pulse Amp Plane 1x Side pos Paddle 7

# FADC250: Clock Slippage

- FADC's modules with firmware version 0xC0D found to have their trigger times (internal 250 MHz clock) slip randomly by 4 ns with firmware present during fall 2017 and spring 2018 run
- Correction applied in THcHitList::DecodeToHitList() via of comparing trigger time provided by the TI module to the trigger time in each FADC module
- Addressed with firmware version 0xC0F





TDC-ADC Time Plane 1x Side pos



#### **FADC250 Threshold Scans**





Eric Pooser

07/18/2018 21 Hall-A Tritium Analysis Meeting



# FADC250 Threshold Scans

22

- All trigger PID components reside in scalers, TDC's, and FADC's (where appropriate)
- One can study off-line the effects of imposing hardware discriminator threshold cuts via software cuts
- Consider an example for HMS:
  - E/P in calorimeter
  - Select pions via Cherenkov
  - Cut on PRHI TDC channel
  - Calculate ratio to determine appropriate threshold for pion suppression





07/18/2018 Hall-A Tritium Analysis Meeting



#### **FADC250 Threshold Scans**

Perform hardware threshold scan of PRHI leg

Eric Pooser

HMS PRHI PID (NPE SUM = 0.0)







#### **Slide Title**

Perform software threshold scan of PRHI leg

HMS PRHI PID (NPE SUM = 0.0)



# Hall-A Tritium Analysis Meeting











# Backup Slides



Eric Pooser

07/18/2018 26 Hall-A Tritium Analysis Meeting



#### **Slide Title**



Eric Pooser

07/18/2018 27 Hall-A Tritiu

Hall-A Tritium Analysis Meeting

