The ATLAS Level-1 Central Trigger Processor Core Module (CTP\_CORE)

- Introduction
- Central Trigger Processor (CTP)
- Core Module (CTP\_CORE)
- Testbeam Results

On behalf of P. Borrego Amaral<sup>1</sup>, N. Ellis<sup>1</sup>, P. Farthouat<sup>1</sup>, P. Gallno<sup>1</sup>, J. Haller<sup>1</sup> H. Pessoa Lima Jr.<sup>2</sup>, T. Maeno<sup>1</sup>, T. Pauly<sup>1</sup>, I. Resurreccion Arcas<sup>1</sup>, J. M. de Seixas<sup>2</sup>, G. Schuler<sup>1</sup>, R. Spiwoks<sup>1</sup>, R. Torga Teixeira<sup>1</sup>, T. Wengler<sup>1</sup> <sup>1</sup>CERN, <sup>2</sup>Universidade Federal de Rio de Janeiro

# The ATLAS Experiment



General-purpose Experiment at CERN's Large Hadron Collider (LHC): Proton-Proton collisions at 14 TeV centre-of-mass energy. About 25 collisions per bunch crossing (BC) every 25 ns (40 MHz) ⇒ Interaction rate of 1 GHz.

IEEE NSS2004, Rome, 19/10/2004

## The Trigger/DAQ System



Level-1 Trigger: Electronics + Firmware

Level-2 Trigger + Event Filter: Computers + Networks + Software

The Level-1 Trigger System



See Poster N33-103 on the ATLAS Level-1 Central Trigger System. See Poster N33-104 on the ATLAS Local Trigger Processor.

IEEE NSS2004, Rome, 19/10/2004

# The Central Trigger Processor (1)

• Trigger Input:

- **Multiplicities** from Calorimeter and Muon Triggers: electrons/photons, taus/hadrons, jets, and muons;
- **Energy flags** from Calorimeter Trigger:  $\Sigma E_T$ ,  $E_T^{miss}$ ,  $\Sigma E_T^{jet}$
- Calibration requests from sub-detectors.
- Other specialized triggers: scintillators, beam pick-ups, etc.
- $\Rightarrow$  Up to a total number of **160 trigger inputs** at any one time.

Plus **internal triggers** from CTP core module: random triggers, prescaled clock, bunch crossing groups.

# The Central Trigger Processor (2)

• Level-1 Accept (L1A)

- Derived from trigger inputs according to trigger menu:

- Up to **256 trigger items** are made from combinations of conditions on the trigger inputs, e.g.

 $1EM10 \equiv at \ least \ one \ electron/photon \ with \ E_T \geq 10 \ GeV$ 

**1MU6** = at least one muon with  $p_T \ge 10$  GeV/c

**XE20**  $\equiv$  missing energy of at least 20 GeV

- Each trigger item has a mask, a priority<sup>1</sup> and a prescaling factor. <sup>1</sup> for dead-time (see later, CTP Core Module)

- L1A is the OR of all trigger items.

- An example of a trigger menu might contain

| 1MU6           | mask = ON, priority = LOW, prescaling = 1000 |
|----------------|----------------------------------------------|
| 2MU6           | mask = ON, priority = HIGH, prescaling = 1   |
| 1EM20 AND XE20 | mask = ON, priority = LOW, prescaling = 1    |

•••

# The Central Trigger Processor (3)

• Additional Functionality:

- Trigger type word (8 bits) accompanying every L1A.
- **Dead-time** in order to prevent front-end buffers becoming full (see later, CTP Core Module).
- Region-of-Interest (RoI) for the Level-2 Trigger and event data for the Read-out System (ROS) and for monitoring.
- Timing signals, e.g Event Counter Reset (ECR), ...
- Constraints:
  - Trigger latency target, i.e. from trigger input to L1A:  $100 \text{ ns} \equiv 4 \text{ BC}.$
  - Trigger menu changes with physics/beam/detector conditions.

### **CTP** - The Design



**9U VME64x** + custom backplanes

> CTP\_MI (Machine Interface) Timing (Input Module) CTP\_IN **Trigger input** CTP\_MON (Monitoring Module) **Bunch-to-bunch monitoring CTP\_CORE** (Core Module) **Trigger menu + Readout** (Output Module) **Trigger fan-out** CTP\_OUT (Calibration Module) **CTP CAL Sub-detector calibration requests**

R.Spiwoks

IEEE NSS2004, Rome, 19/10/2004

### **CTP** - The Trigger Path



CTP\_IN modules receive, synchronize and align the trigger inputs, and route them to the PIT bus (Pattern-in-time).

CTP\_CORE module receives and synchronizes the PITs, compares with trigger menu and generates Level-1 Accept (L1A), sends L1A to the COM bus.

CTP\_OUT receives L1A from the COM bus and fans it out to sub-detector LTPs.

### **CTP** - The Timing Path



CTP\_MI module receives timing signals from LHC, generates additional timing signals and sends all to the COM bus.

CTP\_OUT modules receive busy signals from sub-detector LTPs and send them to the COM bus.

All CTP modules receive timing signals from the COM bus.

### **CTP - The Readout & Monitoring**



CTP\_CORE module sends Region-of-Interest (RoI) information to the Level-2 Trigger and event data to the Readout System.CTP\_MON produces a bunch-by-bunch histogram of signals from the PIT bus.All CTP modules provide monitoring data to the VMEbus.

### **CTP** - The Calibration Requests



CTP\_OUT modules receive calibration requests from sub-detector LTPs and send them to the CAL bus.

CTP\_CAL time-multiplexes calibration requests, receives additional trigger inputs and sends all to a CTP\_IN module.

### The CTP Core Module (1)

• Trigger Combinations:

**Combinations of signals from the PIT bus + internal to CTP\_CORE using** 

Look-up Tables (LUT) for trigger conditions, and

Content-addressable Memories (CAM) for combinations of trigger conditions.

Each CAM contains a 256-bit word and is ternary,

i.e. allows bitwise matching of "0", "1" or "don't care".



Implemented using Xilinx Virtex II Pro (XC2VP50).

# The CTP Core Module (2)

- Prescaling and Masking:
  - Prescale: programmable 24-bit down-counter  $\Rightarrow$  256 TAP (Trigger items after Prescaling).
  - Mask: programmable mask + dead-time + busy  $\Rightarrow$  256 TAV (Trigger items after Veto).
  - OR: over all 256 TAVs
    - $\Rightarrow$  1 L1A (Level-1 Accept).
  - Generate 8-bit trigger type using eight 256-bit masks.



#### Implemented using Altera Stratix (EP1S60).

IEEE NSS2004, Rome, 19/10/2004

### The CTP Core Module (3)

• Dead-time:

Simple deadtime:

- Constant time after each L1A:

*No L1As for n BCs after each L1A.* **Current baseline (programmable): n = 4.** 

**Complex deadtime:** 

 Leaky-bucket algorithm: *Not more than n L1As in m BCs.* Current baseline (programmable): 8 L1As in 80 μs.

⇒ Two leaky-bucket algorithms are used, associated to the priority of each trigger item (high/low).

Implemented using same FPGA as for Prescaling and Masking.

# The CTP Core Module (4)

- Readout & Monitoring:
  - **Copied into FIFOs at every L1A:** 
    - 160 Signals from the **PIT** bus + 12 internal triggers;
    - 256 Trigger items before prescaling (TBP);
    - 256 Trigger items after prescaling (TAP);
    - 256 Trigger items after veto (TAV);
    - 64-bit UTC time-stamp (linked to GPS) with 5-ns jitter.
    - Implemented in two Altera Stratix (EP1S60) with 128 signals for data exchange between them (firmware to be written):



### **The ATLAS Combined Testbeam**



#### **Test beam programme during 2004**

for prototypes and final modules of all ATLAS sub-detectors and trigger and data acquisition.

### The Level-1 Trigger at the Combined Testbeam



#### **Trigger Input:**

Calorimeter Trigger: Muon Trigger: Scintillators:

 $4\times3$  bit e/ $\gamma$  +  $4\times3$  bit jet multiplicities +1 bit total E<sub>T</sub>,  $6\times3$  bit muon multiplicities,  $3\times1$  bit scintillators.

#### **CTP:**

```
    CTP_MI,
    CTP_IN (out of up to 3),
    CTP_CORE,
    CTP_OUT (out of up to 4),
    CTP_MON.
```

### The CTP at the Combined Testbeam



### **CTP - Some Results**

• Trigger Generation:

51 signals from PIT bus used to form 18 trigger items.Prescaling and masking tested to work correctly.L1A used as trigger for readout of the combined sub-detectors.

• Latency Measurement (preliminary!):



 $\begin{array}{l} Scintillator \ Trigger \rightarrow L1A \ at \ CTP\_CORE \approx \ 130 \ ns. \\ But \ some \ cable \ delays \ not \ taken \ into \ account \ and \\ \ CTP \ timing \ not \ yet \ optimised. \end{array}$ 

### **Conclusion**

CTP\_CORE has been used during testbeam to generate trigger using 51 trigger inputs and 18 trigger items.

CTP latency is already close to the target of 100 ns.

Work on the CTP will continue in laboratory, e.g. CTP\_CORE readout and corrections to firmware which were identified during the testbeam.

**CTP** will be available for ATLAS commissioning next year.