In this lab, we implement a CR–RC² shaping amplifier in Sci‐Compiler. The CR (high‐pass) stage and RC² (two consecutive low‐pass filters) stage together create a classic pulse‐shaping network frequently used in nuclear pulse spectroscopy and other signal processing applications where pulses must be transformed into a well‐defined shape.

CR-RC2 Shaper Ciruit
CR-RC2 Shaper Ciruit


1. Introduction to CR–RC² Shaping

Why Use a Shaping Amplifier?

In many detector readout systems (e.g., radiation detectors, photodiodes, or scintillation counters), the raw signals are often short pulses on top of a baseline. These signals can have:

  • Noise in both low‐frequency (baseline drift) and high‐frequency (electronic noise) regimes.
  • Varying pulse lengths that can complicate measurement of pulse amplitude or area.

A CR–RC² network shapes each pulse to:

  1. Reduce Low‐Frequency Noise by filtering out slow variations in the baseline (the CR differentiator acts as a high‐pass filter).
  2. Limit High‐Frequency Noise by smoothing the signal with the RC² low‐pass sections (two integrator stages).
  3. Produce a More Uniform Pulse Shape that is easier to measure for amplitude (peak detection) or to integrate for charge measurement.

Theoretical Overview

  1. CR (High‐Pass) Stage

    • Conceptually differentiates the input signal.
    • Removes slow drifts and offsets in the baseline (frequencies near DC).
    • The output appears as a short “spike” in response to a step or rapidly changing signal.
  2. RC² (Double Low‐Pass) Stage

    • Two cascaded RC filters.
    • Each RC filter has a time constant \(\tau = RC\).
    • In the time domain, these integrators shape the short spikes from the CR stage into semi‐Gaussian or “rounded” pulses with controlled rise and fall times.

The result is a semi‐Gaussian‐like output that peaks at a well‐defined time after each pulse arrives. This shape helps reduce noise contributions and provides consistent pulse height measurement.

Mathematical Explanation (Exponential Input with \(\tau_d \gg \tau_\text{sh}\))

To better understand how a CR–RC² shaper works from a mathematical standpoint, let us consider an exponential input of amplitude \(A\) and decay constant \(\tau_d\), under the condition \(\tau_d \gg \tau_\text{sh}\). Here, \(\tau_\text{sh} = RC\) is the shaping time of the circuit. If \(\tau_d\) is much larger than \(\tau_\text{sh}\), the input signal decays so slowly that, over the time window where the CR–RC² acts, the signal can be approximated by a step of amplitude \(A\).


1. Overall Transfer Function in the Laplace Domain

A CR–RC² circuit can be viewed as the cascade of:

  1. A CR (high‐pass) filter, with transfer function: \[ H_{CR}(s) = \frac{sRC}{1 + sRC}, \]
  2. An RC² filter formed by two consecutive low‐pass stages: \[ H_{RC^2}(s) = \frac{1}{(1 + sRC)^2}. \]

Combining these, the total transfer function is: \[ H_{\text{tot}}(s) = H_{CR}(s) ,\cdot, H_{RC^2}(s) = \frac{sRC}{1 + sRC},\cdot,\frac{1}{(1 + sRC)^2} = \frac{sRC}{(1 + sRC)^3}. \] Setting \(\tau = RC\), we get: \[ H_{\text{tot}}(s) = \frac{s,\tau}{(1 + s,\tau)^3}. \]


2. Impulse Response of the CR–RC²

To understand the output waveform, we look at the inverse Laplace transform of \(H_{\text{tot}}(s)\), i.e., the impulse response \(h_{\text{tot}}(t)\). Through partial fraction decomposition, we can write:

\[ \frac{s,\tau}{(1 + s\tau)^3}=\frac{1}{(1 + s\tau)^2} - \frac{1}{(1 + s\tau)^3}. \]

The inverse Laplace transforms of each term yield: \[ \mathcal{L}^{-1}{\frac{1}{(1+s\tau)^2}} = \frac{t}{\tau} e^{-t/\tau}. \] \[ \mathcal{L}^{-1}{\frac{1}{(1+s\tau)^3}} = \frac{t^2}{2\tau^2} e^{-t/\tau}. \]

CR-RC2 pulse response
CR-RC2 pulse response

Hence,

\[ h_{\text{tot}}(t) = \left[\frac{t}{\tau} - \frac{t^2}{2,\tau^2}\right] e^{-t/\tau}, \quad t \ge 0. \]


3. Convolution with a Slowly Decaying Input (Exponential with \(\tau_d \gg \tau\))

If the input is \(v_{\text{in}}(t) = A,e^{-t/\tau_d}\), but \(\tau_d \gg \tau\), then over the time window in which the shaper reaches its peak (on the order of a few \(\tau\)), \(v_{\text{in}}(t)\) remains almost constant at \(A\). This effectively corresponds to a step input of amplitude \(A\) at \(t=0\).

The output is given by the convolution: \[ y(t) = v_{\text{in}}(t) * h_{\text{tot}}(t). \] Under the step approximation (amplitude \(A\)), the convolution becomes: \[ y(t) \approx A \int_{0}^{t} h_{\text{tot}}(\tau),\mathrm{d}\tau. \]

Taking the derivative of \(y(t)\) with respect to \(t\) yields \(y’(t) = Ah_{\text{tot}}(t)\). This derivative goes to zero where \(h_{\text{tot}}(t)\) vanishes (apart from \(t=0\)), indicating the peak occurs at \(t = 2\tau\). The peak value follows from:

\[ y_{\max} = y(2\tau) = A \int_{0}^{2\tau} h_{\text{tot}}(u),\mathrm{d}u=A\bigl(2\tau e^{-2}\bigr). \]

Numerically, \[ y_{\max} ;\approx; A \times 0.2707\tau, \] where \(\tau = RC\). Thus, for a slowly decaying input signal (decay time much longer than \(\tau\)), the CR–RC² shaper transforms it into a semi‐Gaussian‐like pulse with a well‐defined peak time (\(t=2\tau\)) and amplitude (\(\sim 0.27 A\tau\)). This behavior explains how the CR–RC² stage “differentiates” the input (removing slow components) and then “smooths” it with two low‐pass sections, producing an output pulse that is ideal for amplitude or energy measurements in many data‐acquisition systems.

Noise Analysis as a Function of Shaping Time

In addition to shaping the input pulse, the CR–RC² network also filters noise. Different types of electronic noise (e.g., series noise from the front‐end amplifier, parallel or “1/f” noise from detector leakage current, etc.) have frequency‐dependent characteristics. The shaping time \(\tau\) (i.e., the \(\tau = RC\) time constant of the shaper) determines the bandwidth over which noise is integrated.

  1. Short Shaping Time (\(\tau\) small)

    • Higher‐frequency components are passed more readily, reducing low‐frequency noise contributions.
    • However, series noise (often having substantial high‐frequency components) may increase.
    • Pulse amplitude measurements can be more sensitive to high‐frequency “white” noise if \(\tau\) is too short.
  2. Long Shaping Time (\(\tau\) large)

    • The bandwidth is reduced, cutting off high‐frequency components more strongly.
    • Series noise is attenuated but parallel noise (e.g., leakage current) increases if the shaping time is too long.
    • Long shaping can also cause overlap of pulses at high count rates.

A classic way to quantify noise is through the Equivalent Noise Charge (ENC), which often depends on shaping time as

\[ \text{ENC}^2(\tau) \approx A_s,\frac{1}{\tau} + A_p,\tau + A_f, \]

where:

  • \(A_s\) is a constant related to the series noise (higher with shorter shaping times).
  • \(A_p\) is related to parallel (low‐frequency) noise (higher with longer shaping times).
  • \(A_f\) accounts for flicker (1/f) noise or other slowly varying noise sources.

Minimizing \(\text{ENC}^2(\tau)\) with respect to \(\tau\) yields an optimal shaping time \(\tau_\text{opt}\) that balances both the parallel and series noise contributions. Practically, one chooses \(\tau\) so that:

  1. The pulse shape is suitable for measurement (adequate amplitude and well‐defined peak).
  2. The total noise is minimized (improving signal‐to‐noise ratio).
  3. The pulse width is short enough to handle expected pulse rates without excessive pile‐up (overlap).

Overall, the CR–RC² shaper can be tuned (by choosing \(\tau = RC\)) to reach a trade‐off between noise performance, signal fidelity, and rate‐handling capability.


2. Hardware/FPGA Implementation in Sci‐Compiler

Below is the simplified block diagram in Sci‐Compiler:

Sci-Compiler Block Diagram
Sci-Compiler Block Diagram

  1. Analog In Pin – The raw 16‐bit ADC input.
  2. Unsigned <-> Signed Converters – Convert the 16‐bit unsigned ADC to a signed format for filtering.
  3. Butterworth (IIR‐I) Filter – Configured as a High Pass (CR) filter.
  4. FX GAIN – A digital gain stage.
  5. Butterworth (IIR‐II) Filter – Configured as a Low Pass (the RC² portion), repeated if needed.
  6. Oscilloscope – Displays both the input and shaped outputs.

Note: In traditional analog electronics, you would have a resistor‐capacitor network for CR, followed by two RC integrators. In Sci‐Compiler, we approximate these with digital IIR filters: one high‐pass and two low‐pass sections.


3. CR–RC² Filter Configuration

3.1 CR (High Pass)

  • Cutoff Frequency: Set in the filter’s properties (e.g., 1 MHz or 50 kHz, etc.).
  • This stage attenuates DC and low‐frequency components.
  • In classical analog design, the time constant (\tau_d = R \times C) determines how quickly the output returns to zero after a pulse.

Configurazione CR (High Pass)
Configurazione CR (High Pass)

3.2 RC² (Low Pass)

  • Two cascaded low‐pass filters, each with its own cutoff frequency (e.g., 100 kHz).
  • Each integrator extends the pulse shape in time, limiting fast fluctuations (noise).
  • The overall time constant (\tau_i) can be chosen to set how wide you want the shaped pulse to be.

configurazione RC² (Low Pass)
configurazione RC² (Low Pass)

3.3 Gain Stage

  • An FX GAIN block applies a digital multiplication after the CR filter to scale the signal.
  • Internally, OUT = (Gain × IN) / 256, allowing fine adjustments without saturating the FPGA’s internal signal width.

Configurazione Gain IP
Configurazione Gain IP


4. Example Oscilloscope Traces

Input vs. Shaped Outputs

  1. Channel 1 (Blue) – The raw ADC input, showing a series of exponential pulses with a 50 µs decay time.
  2. Channel 2 (Green) – The CR (high‐pass) output, looks like a quick positive spike, returning to baseline.
  3. Channel 3 (Cyan) – The final RC² output, a smoother pulse with a distinct peak and decay.

Input vs Output signals
Input vs Output signals

Zoomed‐In View

CR output signal (Green) RC2 output signal (Cyan)
CR output signal (Green) RC2 output signal (Cyan)

Here you see:

  • Green spike from the CR differentiator.
  • Cyan shape from the double RC² integration, providing a gently rising and falling pulse.

DT4810 Input signal, 50us decay time
DT4810 Input signal, 50us decay time

5. Why CR–RC² is Widely Used

  • Noise Reduction: By eliminating low‐frequency drift and high‐frequency noise, the SNR (Signal‐to‐Noise Ratio) for each pulse is improved.
  • Time Constant Selection: You can choose (\tau_d) (CR) and (\tau_i) (RC) to optimize for different detectors and pulse widths.
  • Pulse Pile‐Up Management: A shaped pulse that returns to baseline faster can help mitigate overlapping events.
  • Ease of Peak Detection: The shaped waveform has a well‐defined peak for amplitude measurement.

In radiation detection and nuclear spectroscopy, CR–RC² shaping is a classic approach to achieve near‐Gaussian pulses, giving excellent energy resolution with minimal ballistic deficit.


6. Practical Tips

  • Set the High‐Pass Cutoff below your pulse’s main frequency content but high enough to remove baseline drift.
  • Set the Low‐Pass (RC²) Cutoff to shape the pulses for the desired rise and fall times. If too slow, pulses overlap more easily; if too fast, noise can dominate.
  • Use an Appropriate Digital Gain to ensure that the shaped amplitude fits within the FPGA’s numeric range.
  • Observe the Oscilloscope to verify that pulses have minimal overshoot and settle back to baseline before the next pulse arrives.

7. Conclusion

A CR–RC² shaping amplifier combines a high‐pass differentiator (CR) with double low‐pass integrators (RC²). This classic design:

  1. Removes baseline drift.
  2. Attenuates high‐frequency noise.
  3. Shapes pulses into a more uniform, easily measured form.

In Sci‐Compiler, these filters are realized via Butterworth IIR blocks (configured as high‐pass or low‐pass) plus an optional Gain stage. By choosing appropriate cutoff frequencies, you can replicate standard analog shaping times in a fully digital pipeline—a powerful technique for modern data acquisition systems in nuclear, medical, and industrial measurements.