# JLab Hall B 6 GeV DVCS Trigger Design

Benjamin Raydo, braydo@jlab.org, Nov. 18th, 2007

# **Trigger Design Description**

The DVCS triggering logic uses a simple algorithm to detect clusters from the 424 channel calorimeter detector. Custom FPGA software was written for CAEN V1495 logic units. A diagram of the system is shown in Figure 1 showing the various boards, cables, and ports used for the trigger. The 424 channel calorimeter is split into 4 identical pieces (referred to by quadrants 1, 2, 3, and 4 as shown in Figure 1) where each piece is rotated 90° from the adjacent pieces. Each quadrant contains 106 channels which are discriminated and finally fed into CAEN V1495 logic units which are called QTrigger boards because each QTrigger board processes information for its corresponding quadrant of the detector. The 4 QTrigger boards send detected clusters to a central board called the MTrigger board. The MTrigger processes the detected clusters from each quadrant and detects any clusters that may be formed along the edges of adjacent quadrants. Finally, the MTrigger will generate a trigger when the current number of detected clusters exceeds a programmable value. A hodoscope is shown with corresponding hardware that will later be used for more efficient triggering. The hodoscope part of the trigger will be described when information is available on the detector (currently the rest of the DVCS trigger ignores all inputs from the hodoscope detector inputs).



## Figure 1: DVCS Trigger System Setup

# **Summary of Specifications**

Trigger output delay: 55-70ns Minimum trigger output width: 15ns Tower discriminator minimum output width: 32ns Programmable trigger on 1-31 detected clusters Programmable cluster definition (in a 3x3 window): 1-9 tower hits Maskable tower inputs: force 1, force 0, normal input Cluster peak detection

# **Cluster Detection Algorithm**

A cluster is defined as any point on the calorimeter that has more than **A\_THRESHOLD** (a programmable value) number of towers hit on a 3x3 window formed by all adjacent towers (up, down, left, right, and diagonals). The trigger system computes the sum of hit towers inside each 3x3 window of the 424 points in the detector. This summing translates a map of 424 hit towers to a map of 424 window sums. The A\_THRESHOLD is then applied to all 424 sums to detect the clusters.

A peak detector is applied to the resulting 424 window sums to filter out adjacent reported clusters that were formed from the same hit towers. This is important when the trigger is requiring 2 or more cluster hits, because there typically exist more than 1 identified cluster for the same hit towers because you can move the 3x3 window over by 1 and still be above the threshold. The peak detector will allow a cluster to be reported if the cluster has more towers in its 3x3 window than any of its neighbors. A bias is put in place to deal with adjacent clusters having an equal number of towers in their 3x3 windows. The following figure illustrates how the peak detection and bias is implemented:

|                                                     | Quadrant 1 Peak           | N   | ≥  | ٧  | ≥  | ≥  | ٧  | N  | ≥  | >  |
|-----------------------------------------------------|---------------------------|-----|----|----|----|----|----|----|----|----|
|                                                     | Bias Logic                | ≥   |    | ٨  | ≥  |    | ٨  | N  |    | ٨  |
|                                                     |                           | Σ   | >  | >  | λ١ | >  | >  | Λ١ | >  | >  |
|                                                     |                           | N   | IV | ٧  | ١V | ١V | ٧  | ١V | ١V | ٧  |
|                                                     |                           | ≥   |    | ٨  | ≥  |    | ٨  | V  |    | >  |
| Q4 peak bias logic is th<br>Q1 logic rotated 90 deg | ie<br>ree                 | ≥   | >  | ٨  | ≥  | >  | ٨  | ٨  | >  | ٨  |
|                                                     |                           | Ν   | Σ  | ٧  | Σ  | Σ  | ٧  | ١V | ≥  | ٧  |
|                                                     |                           | ≥   |    | ٨  | ≥  |    | ٨  | Σ  |    | >  |
|                                                     |                           | ≥   | >  | >  | ≥  | >  | ٨  | Σ  | >  | >  |
|                                                     | Quadrant 4 Peak           | I۷  | IV | ٧٢ | I۷ | IY | ۶V | I۷ | JV | ۶V |
|                                                     | Blas Logic                | V V |    | IV | Y  | _  | 17 | ٧  |    | IV |
|                                                     |                           | É#  | V  | V  | V  | V  | V  | ۷  | V  | V  |
| Modified bias logic on<br>for each quadrant to a    | left perimeter            | I۷  | ١V | IV | I۷ | IV | IV | I۷ | IV | ١V |
| rotated bias logic bloc                             | rotated bias logic blocks |     |    |    |    |    | IV | ۷  |    | IV |
|                                                     |                           | V   | V  | ۷  | ۷  | V  | ۷  | ۷  | V  | V  |
|                                                     |                           | I۷  | ١V | IV | I۷ | ١V | IV | I۷ | IV | ١V |
|                                                     |                           | ۷   |    | IV | V  |    | IV | ۷  |    | ١V |
|                                                     |                           | V   | v  | V  | v  | V  | V  | V  | V  | V  |

## Figure 2: Cluster Peak Detection and Bias Logic

The above figure shows that at each cluster hit, it must be greater than its neighbor, or it must be greater-than-or-equal its neighbor. The ">" and ">=" were placed and chosen to ensure no loss of detection of clusters and no duplicate reporting of clusters.

A modification of the bias shown in the above figure is done because the basic bias logic is not compatible with adjacent version of itself with a 90° rotation. This modification makes the bias logic compatible at the intersections of adjacent quadrant (without this, clusters could be counted twice at these locations).

# QTrigger Design

Four QTrigger boards (V1495 Logic Units) perform cluster detection on each quadrant of the detector. The symmetry of the system allows each QTrigger board to run with identical code and register settings. The QTrigger boards runs synchronously at 200MHz, which is derived from a 100MHz reference oscillator distributed by the MTrigger board. The MTrigger also distributes a SYNC signal that synchronizes the state machines and sampling times of each QTrigger. At 200MHz, the QTrigger synchronously samples the 424 discriminators every 3 clock cycles (every 15ns) to determine the current hit towers. Next, the QTrigger board looks at the 3x3 windows in its quadrant and computes a map for the quadrant containing the window sums. The window sums are then checked for valid clusters and go through the peak detection logic. Finally the found clusters are counted. During these processing stages, messages about the hit bits at the perimeter of the quadrant are sent to the MTrigger for cluster finding processing on 3x3 windows that overlap two adjacent quadrants. A 32bit parallel bus transmits information from the QTrigger to the MTrigger boards at the synchronous lock rate of 200MHz. Figure 3 shows the message format and contents sent from the QTrigger to the MTrigger.

## Figure 3: QTrigger->MTrigger Message Format

# Parallel Bus Messages

| 0  | 1  | 2  | 3  | 4  |     |     |     |     |     |     |
|----|----|----|----|----|-----|-----|-----|-----|-----|-----|
| 5  | 6  | 7  | 8  | 9  | 10  |     |     |     |     |     |
| 11 | 12 | 13 | 14 | 15 | 16  | 17  |     |     |     |     |
| 18 | 19 | 20 | 21 | 22 | 23  | 24  | 25  |     |     |     |
| 26 | 27 | 28 | 29 | 30 | 31  | 32  | 33  | 34  |     |     |
| 35 | 36 | 37 | 38 | 39 | 40  | 41  | 42  | 43  | 44  |     |
| 45 | 46 | 47 | 48 | 49 | 50  | 51  | 52  | 53  | 54  | 55  |
| 56 | 57 | 58 | 59 | 60 | 61  | 62  | 63  | 64  | 65  | 66  |
| 67 | 68 | 69 | 70 | 71 | 72  | 73  | 74  | 75  | 76  | 77  |
|    | 78 | 79 | 80 | 81 | 82  | 83  | 84  | 85  | 86  | 87  |
|    |    | 88 | 89 | 90 | 91  | 92  | 93  | 94  | 95  | 96  |
|    |    | 97 | 98 | 99 | 100 | 101 | 102 | 103 | 104 | 105 |
|    |    |    |    |    |     |     |     |     |     |     |

MSG0 = 11110b, TOWERS(69-67,58-56,47-45,37-35,28-26,20-18,13-11,7-5,2-0) MSG1 = 1110b, TOWERS(105-78) MSG2 = 10101b, CLUSTERCOUNT, CLUSTERS(1,6,12,19,27,36,46,57,68,88-96)

The first and second message sends the MTrigger the information needed to detect clusters across quadrant as well as perform the peak finding logic. The third message sends the count of clusters found in its quadrant and the cluster bits for the bits in the quadrant that can be suppressed in the MTrigger (the QTrigger doesn't know if these cluster need to be suppressed because it does not know about hit bits on the adjacent

quadrant that could suppress this clusters). Extra bits in each message above are fixed at a value that is currently used as keys for simple error detection.

Note: The QTrigger require that the following registers are written to:

| Register    | Description        |  |  |  |  |
|-------------|--------------------|--|--|--|--|
| A_THRESHOLD | Threshold Register |  |  |  |  |

See the VME Register description for further details on registers.

# **MTrigger Design**

The MTrigger board (V1495 Logic Unit) distributes the synchronous clock and SYNC to each of the QTrigger boards and processes the output from each QTrigger board. The MTrigger board receives messages (see figure 3) from each QTrigger board over four 32bit busses running at 200MHz. The messages contain enough information for the MTrigger to detect clusters at the intersections of all QTrigger quadrants and complete the cluster peak detection processing. Any cluster found along the intersections are added to the cluster counts from each QTrigger board and compared against the programmable cluster count threshold (see below) to determine if there is a trigger. The MTrigger makes a trigger decision every 15ns (at the same rate as the QTrigger tower samples). The propagation delay for the trigger (from sampling the discriminator outputs to asserting the trigger) is ~55ns (see Figure 4), but has a jitter of 15ns with respect to the actual event (defined at the outputs of the tower discriminators) so the trigger. These delays are subject to change (by +/-10ns) until the timing has been finalized (to be completed shortly).



## Figure 4: Trigger Assertion Delay

RegisterDescriptionA\_THRESHOLDThreshold RegisterA\_CLUSTCNTCluster Count Register

See the VME Register description for further details on registers.

# System Hardware Setup/Wiring

| Figure 5: | VME Module/Crate Lavout |
|-----------|-------------------------|
|-----------|-------------------------|

|        |        | 0<br>Frank        |                   | 0                 | 0                 | 0                 | 0                 |                   | 0                 | 0              | 0<br>E A E N     | 0<br>HARS         | 0<br>HARS         | 0                                      | 0<br>HARS                              |                                        |                                 | 0<br>FAES                       | 0                                      |                                 | Top Crate                                                                                                                                                               |
|--------|--------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|----------------|------------------|-------------------|-------------------|----------------------------------------|----------------------------------------|----------------------------------------|---------------------------------|---------------------------------|----------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |        |                   | .00               |                   |                   |                   |                   |                   | .00,0             | .00,           |                  | .00,0             |                   | .00,0                                  | .00.                                   |                                        |                                 |                                 |                                        |                                 | Slot 1: CPU<br>Slot 2: Unused<br>Slot 3: Hodoscope Ch64-79<br>Slot 4: Hodoscope Ch48-63<br>Slot 5: Hodoscope Ch32-47                                                    |
|        |        | 0'0<br>00         | 00                | 0 0<br>0 0        | 0 0<br>0 0        | 0°0<br>00         | 0°0<br>00         | 0°0<br>00         | 0°0<br>00         | 0°0<br>00      | 0°0<br>00        | 0°0<br>00         | 0°0<br>00         | 0°0<br>00                              | 0°0<br>00                              | 0°0<br>00                              | 0°0<br>00                       | 0°0<br>00                       | 0°0<br>00                              | 0°0<br>00                       | Slot 6: Hodoscope Ch16-31<br>Slot 7: Hodoscope Ch0-15<br>Slot 8: Q3 Ch96-105<br>Slot 9: Q3 Ch96-95<br>Slot 10: Q3 Ch64-79<br>Slot 10: Q3 Ch64-79<br>Slot 10: Q3 Ch64-79 |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        |                                        |                                 |                                 |                                        |                                 | Slot 12: Q3 Ch3247<br>Slot 12: Q3 Ch3247<br>Slot 13: Q3 Ch16-31<br>Slot 14: Q3 Ch0-15<br>Slot 15: Q4 Ch96-105<br>Slot 15: Q4 Ch96-105<br>Slot 17: Q4 Ch64-70            |
|        |        |                   | 00                |                   |                   |                   |                   |                   |                   |                |                  |                   | 00                |                                        |                                        |                                        |                                 |                                 |                                        |                                 | Slot 17: Q4 Ch48-63<br>Slot 19: Q4 Ch48-63<br>Slot 19: Q4 Ch32-47<br>Slot 20: Q4 Ch16-31<br>Slot 21: Q4 Ch0-15                                                          |
|        |        | ****              | • • •             | • • •             | • • •             |                   | :09<br>           | :0°               | • • • •           |                | :0°              | • • • •           | ••••              | • • • •                                | • • • •                                | :0°                                    | :0°                             | * <b>0 ?</b>                    |                                        |                                 |                                                                                                                                                                         |
|        |        |                   |                   |                   |                   |                   |                   | , <b>, , , ,</b>  |                   |                |                  |                   |                   |                                        |                                        |                                        |                                 |                                 | . <b>.</b>                             |                                 |                                                                                                                                                                         |
|        |        | 0 0<br>0 0<br>0 0 | 0 0<br>0 0     | 0<br>0<br>0<br>0 | 0 0<br>0 0<br>0 0 | 0 0<br>0 0<br>0 0 | 0 0<br>0 0<br>0 0                      | 0 0<br>0 0<br>0 0                      | 0 0<br>0 0<br>0 0                      | 0 0<br>0 0<br>0 0               | 0 0<br>0 0<br>0 0               | 0 0<br>0 0<br>0 0                      | 00                              |                                                                                                                                                                         |
|        |        | 16 CH<br>LED      | NE CH<br>LED      | 14 CH<br>LED      | 14 CH<br>LED      | 16 CH<br>LED      |                   |                   |                   | 18 CH<br>LED   |                  |                   | NE CH<br>LED      |                                        |                                        |                                        |                                 |                                 |                                        |                                 | Middle Crote                                                                                                                                                            |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        |                                        | Mod. V1495                      | Mod. V1495                      |                                        | Mod. V1495                      | Slot 1: CPU<br>Slot 2: Unused<br>Slot 3: Unused                                                                                                                         |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   | structure<br>N<br>L<br>V<br>D<br>S     | structure<br>N<br>L<br>V<br>D<br>S     | articitation<br>N<br>L<br>V<br>D<br>S  | I<br>N<br>U<br>D<br>S           | I<br>N<br>L<br>V<br>S           | articitation<br>N<br>L<br>V<br>D<br>S  | I<br>N<br>U<br>V<br>S           | Slot 5: Unused<br>Slot 5: Unused<br>Slot 6: Unused<br>Slot 7: Unused<br>Slot 8: Unused<br>Slot 9: Unused                                                                |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        |                                        | É<br>C<br>L<br>A D              |                                 |                                        |                                 | Slot 11: Unused<br>Slot 12: Unused<br>Slot 13: Unused<br>Slot 14: Unused<br>Slot 15: Hodoscope LU Q14<br>Slot 15: Hodoscope LU Q14                                      |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        | I N<br>L<br>V<br>D<br>S                |                                 | I N L V D S                     |                                        |                                 | Slot 17: QTrigger LU Q3<br>Slot 18: QTrigger LU Q2<br>Slot 19: MTrigger LU<br>Slot 20: QTrigger LU Q1<br>Slot 21: QTrigger LU Q4                                        |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        |                                        | L B                             |                                 |                                        |                                 |                                                                                                                                                                         |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        |                                        |                                 |                                 |                                        |                                 |                                                                                                                                                                         |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   | L<br>V<br>D<br>S                       | L<br>V<br>D<br>S                       | L<br>V<br>D<br>S                       | U<br>V<br>S                     | L V D S                         | V<br>D<br>S                            | L<br>V<br>D<br>S                |                                                                                                                                                                         |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   | C F<br>GENERAL<br>PURPOSE<br>VME BOARD | C F<br>GENERAL<br>PURPOSE<br>VME BOARD | C F<br>GENERAL<br>PURPOSE<br>VME BOARD | GENERAL<br>PURPOSE<br>VME BOARD | GENERAL<br>PURPOSE<br>VME BOARD | C F<br>GENERAL<br>PURPOSE<br>VME BOARD | GENERAL<br>PURPOSE<br>VME BOARD |                                                                                                                                                                         |
|        |        |                   |                   |                   |                   |                   | Nod. V895         | O<br>Mod. V895    | Mod. V895         | O<br>Mod. V£95 | O<br>Mod. V895   | Mod. V895         | O<br>Mod. V895    | Mod. V895                              | Mod. V895                              | Mod. V895                              | Mod. V895                       | Mod. V895                       | O<br>Mod. V895                         | O<br>Mod. V895                  | Bottom Crate<br>Slot 1: CPU<br>Slot 2: Unused                                                                                                                           |
|        |        |                   |                   |                   |                   |                   | 00<br>00<br>00    | 00<br>00<br>00    | 00<br>00<br>00    | 00<br>00<br>00 | 00<br>00<br>00   | 00<br>00<br>00    | 00<br>00<br>00    | 00<br>00<br>00                         | 00<br>00<br>00                         | 00<br>00<br>00                         | 00<br>00<br>00                  | 00<br>00<br>00                  | 00<br>00<br>00<br>00                   | 00<br>00<br>00<br>00            | Slot 3: Unused<br>Slot 4: Unused<br>Slot 5: Unused<br>Slot 6: Unused<br>Slot 7: Unused<br>Slot 8: 02 Ch96-105                                                           |
|        |        |                   |                   |                   |                   |                   | Ĩ                 |                   | Ĩ                 | Ï              |                  | Ĩ                 | Ï                 | Ĩ                                      | Ĩ                                      | Ĩ                                      | Ĩ                               |                                 | Î                                      | Î                               | Slot 9: Q2 Ch80-95<br>Slot 10: Q2 Ch64-79<br>Slot 11: Q2 Ch48-63<br>Slot 12: Q2 Ch32-47<br>Slot 13: Q2 Ch16-31<br>Slot 14: Q2 Ch0-Ch15                                  |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        |                                        |                                 |                                 |                                        |                                 | Slot 15: Q1 Ch96-105<br>Slot 16: Q1 Ch80-95<br>Slot 17: Q1 Ch64-79<br>Slot 18: Q1 Ch48-63<br>Slot 19: Q1 Ch32-47<br>Slot 20: Q1 Ch16-31                                 |
|        |        |                   |                   |                   |                   |                   |                   | 00                | 00                |                | 00               | 00                | 00                | 00                                     | 00                                     | 00                                     | 00                              |                                 | 10 9<br>10 9                           |                                 | Slot 21: Q1 Ch0-15                                                                                                                                                      |
|        |        |                   |                   |                   |                   |                   |                   |                   |                   |                |                  |                   |                   |                                        |                                        |                                        |                                 |                                 |                                        |                                 |                                                                                                                                                                         |
|        |        |                   |                   |                   |                   |                   | 00<br>00<br>00    | 00<br>00<br>00    | 00<br>00<br>00    | 00             | 00<br>00<br>00   | 00<br>00<br>00    | 00<br>00<br>00    | 00<br>00<br>00                         | 00<br>00<br>00                         | 00<br>00<br>00                         | 00<br>00<br>00                  | 00<br>00<br>00                  | 00<br>00                               | 0000                            |                                                                                                                                                                         |
|        |        |                   |                   |                   |                   |                   | 00°               | <b>00</b>         | 100°              | 10 0<br>14CH   | 00°              | 100°              | 00°               | 10 0<br>10 0                           | 100°                                   | 100<br>KCH                             | 100<br>KCH                      | 00°                             | 00°                                    | 10 0<br>10 0                    |                                                                                                                                                                         |
| slot 1 | slot 2 | Slot 3            | Slot 4            | slot 5            | slot 6            | slot 7            | Slot 8            | slot 9 Ø          | slot 10 Ø         | slot 11 Ø      | slot 12 Ø        | slot 13 Ø         | slot 14 Ø         | slot 15 Ø                              | slot 16 Ø                              | slot 17 Ø                              | slot 18 Ø                       | slot 19 Ø                       | slot 20 Ø                              | slot 21 Ø                       |                                                                                                                                                                         |

# Table 1: Wiring Map

| Frame Crate/Slot/Port    | To Crate/Slot/Port | Cable          | Description            |
|--------------------------|--------------------|----------------|------------------------|
| M/19/E                   | M/20/C             | DVCS_BUSCOM-20 | Q1 Trig COM            |
| M/19/B                   | M/18/C             | DVCS_BUSCOM-20 | Q2 Trig COM            |
| M/19/A                   | M/17/C             | DVCS_BUSCOM-20 | Q3 Trig COM            |
| M/19/D                   | M/21/C             | DVCS_BUSCOM-20 | Q4 Trig COM            |
| M/19/F2,3                | M/20/G0,1          | DVCS_LEMO-TBD  | Q1 CLK,SYNC            |
| M/19/F4,5                | M/18/G0,1          | DVCS_LEMO-TBD  | Q2 CLK,SYNC            |
| M/19/F6,7                | M/17/G0,1          | DVCS LEMO-TBD  | O3 CLK,SYNC            |
| M/19/F0,1                | M/21/G0,1          | DVCS LEMO-TBD  | 04 CLK,SYNC            |
| M/15/F                   | M/20/F             | DVCS BUSCOM-20 | Q1 Hodoscope Hits      |
| M/16/C                   | M/18/F             | DVCS BUSCOM-20 | Q2 Hodoscope Hits      |
| M/16/F                   | M/17/F             | DVCS BUSCOM-20 | Q3 Hodoscope Hits      |
| M/15/C                   | M/21/F             | DVCS BUSCOM-20 | Q4 Hodoscope Hits      |
| M/15/D ch0-15            | Т/7/А              | DVCS DISC-TBD  | Hodoscope Hits 0-15    |
| M/15/D ch16-31           | T/6/A              | (shared)       | Hodoscope Hits 16-31   |
| M/15/B ch0-15            | T/5/A              | DVCS DISC-TBD  | Hodoscope Hits 32-47   |
| M/15/B ch16-31           | T/4/A              | (shared)       | Hodoscope Hits 48-63   |
| M/15/A ch0-15            | Т/3/А              | DVCS DISC-TBD  | Hodoscope Hits 64-79   |
| M/16/D ch0-15            | Т/7/В              | DVCS DISC-TBD  | Hodoscope Hits 0-15    |
| M/16/D ch16-31           | T/6/B              | (shared)       | Hodoscope Hits 16-31   |
| M/16/B ch0-15            | T/5/B              | DVCS DISC-TBD  | Hodoscope Hits 32-47   |
| M/16/B ch16-31           | T/4/B              | (shared)       | Hodoscope Hits 48-63   |
| M/16/A ch0-15            | T/3/B              | DVCS DISC-TBD  | Hodoscope Hits 64-79   |
| M/20/E ch0-15            | B/21/A             | DVCS DISC-TBD  | O1 Tower Hits 0-15     |
| M/20/E ch16-31           | B/20/A             | (shared)       | O1 Tower Hits 16-31    |
| M/20/B ch0-15            | B/19/A             | DVCS DISC-TBD  | O1 Tower Hits 32-47    |
| M/20/B ch16-31           | B/18/A             | (shared)       | O1 Tower Hits 48-63    |
| M/20/D ch0-15            | B/17/A             | DVCS DISC-TBD  | O1 Tower Hits 64-79    |
| M/20/D ch16-31           | B/16/A             | (shared)       | O1 Tower Hits 80-95    |
| M/20/A_ch0-15            | B/15/A             | DVCS DISC-TBD  | O1 Tower Hits 96-105   |
| M/18/E_ch0-15            | B/14/A             | DVCS DISC-TBD  | O2 Tower Hits 0-15     |
| M/18/E_ch16-31           | B/13/A             | (shared)       | O2 Tower Hits 16-31    |
| M/18/B_ch0-15            | B/12/A             | DVCS DISC-TBD  | $O_2$ Tower Hits 32-47 |
| M/18/B_ch16-31           | B/11/A             | (shared)       | 02 Tower Hits 48-63    |
| M/18/D_ch0-15            | B/10/A             | DVCS DISC-TBD  | $O_2$ Tower Hits 64-79 |
| M/18/D ch16-31           | B/9/A              | (shared)       | O2 Tower Hits 80-95    |
| M/18/A_ch0-15            | B/8/A              | DVCS DISC-TBD  | 02 Tower Hits 96-105   |
| M/17/E_ch0-15            | T/14/A             | DVCS DISC-TBD  | O3 Tower Hits 0-15     |
| M/17/E_ch16-31           | T/13/A             | (shared)       | O3 Tower Hits 16-31    |
| M/17/B_ch0-15            | T/12/A             | DVCS DISC-TBD  | O3 Tower Hits 32-47    |
| M/17/B_ch16-31           | T/11/A             | (shared)       | O3 Tower Hits 48-63    |
| M/17/D_ch0-15            | T/10/A             | DVCS DISC-TBD  | O3 Tower Hits 64-79    |
| M/17/D ch16-31           | T/9/A              | (shared)       | O3 Tower Hits 80-95    |
| M/17/A_ch0-15            | T/8/A              | DVCS DISC-TBD  | O3 Tower Hits 96-105   |
| M/21/F_ch0-15            | T/21/A             | DVCS DISC-TBD  | O4 Tower Hits 0-15     |
| M/21/E_ch16-31           | T/20/A             | (shared)       | O4 Tower Hits 16-31    |
| M/21/B_ch0-15            | Τ19/Δ              | DVCS DISC-TRD  | O4 Tower Hits 32-47    |
| M/21/B_ch16-31           | Τ/18/Δ             | (shared)       | O4 Tower Hits 48-63    |
| M/21/D_ch0-15            | Τ/17/Δ             | DVCS DISC-TRD  | O4 Tower Hits 64-79    |
| $M/21/D_{ch16-31}$       | Τ/16/Δ             | (shared)       | O4 Tower Hits 80-95    |
| M/21/A_ch0-15            | T/15/A             | DVCS DISC-TBD  | O4 Tower Hits 96-105   |
| M/19/C                   | -                  |                | Not Connected          |
| M/15/F                   | -                  |                | Not Connected          |
| M/15/E<br>M/16/E         |                    |                | Not Connected          |
| $M/15/\Delta ch16_{-31}$ | -                  | -              | Not Connected          |
| M/16/Δ ch16-31           | -                  | -              | Not Connected          |
| $M/20/\Delta$ ch16-31    | -                  | -              | Not Connected          |
| M/18/Δ ch16_31           |                    | -              | Not Connected          |
| M/17/A_ch16.21           | -                  | -              | Not Connected          |
| M/21/A_ch16_21           | -                  | -              | Not Connected          |
| M/18/G1                  | -                  | -              | Not Connected          |
| 10/01                    | -                  | -              |                        |

# Cable 1: DVCS\_LEMO-XX



# Cable 2: DVCS\_BUSCOM-XX



# Cable 3: DVCS\_DISC-XX



## Figure 6: Detector Tower Map



Note: This image is a view of the towers looking in the same direction as the beam flow.

Follow the Table 1 for wiring the tower outputs into the discriminators. Quadrant channels should be placed into the discriminators in ascending order (i.e. Quadrant Channel 0 to Bottom Crate, Slot 21, Input 0, Channel 1 to Input 1, ... Channel 16 to Bottom Crate Slot 20, Input 0, etc...).

# **QTrigger/MTrigger VME Register Map**

#### **Board ID Register – A\_BOARDIDS (offset = 0x0000)**

16bit Read-Only. Supported on QTrigger, MTrigger

| Bits(15:9)    | Board Type ID |                   |
|---------------|---------------|-------------------|
|               | 1001101b      | MTrigger Board ID |
|               | 1010001b      | QTrigger Board ID |
| Bits(8:6)Opti | on Board D ID |                   |
| Bits(5:3)Opti | on Board E ID |                   |
| Bits(2:0)Opti | on Board F ID |                   |
|               | 000b          | CAEN A395A Board  |
|               | 001b          | CAEN A395B Board  |
|               | 010b          | CAEN A395C Board  |
|               | 011b          | CAEN A395D Board  |
|               |               |                   |

#### Board Revision Register - A\_REVISION (offset = 0x0002)

16bit Read-Only. Supported on QTrigger, MTrigger

Bits(15:0) Board Software Revision

Ex: 0x0100 should be read as "V1.0"

#### Error Register – A\_ERRORS (offset = 0x0004)

16bit Read-Only. Supported on QTrigger, MTrigger. This register is automatically cleared each time it is read.

| Bit(0) | PLL Lock Indicator               |                                                                                             |
|--------|----------------------------------|---------------------------------------------------------------------------------------------|
|        | 0b                               | PLL has not lost lock since last read                                                       |
|        | 1b                               | PLL lost lock since last register read                                                      |
|        | Note: MTrigger use<br>100MHz CLI | es onboard 40MHz CLK for PLL reference oscillator. QTrigger uses K on G0 for PLL reference. |
| Bit(1) | <b>Option Board F Error</b>      |                                                                                             |
|        | 0b                               | Correct Option F Board Installed                                                            |
|        | 1b                               | Incorrect Option F Board Installed                                                          |
| Bit(2) | Option Board E Error             |                                                                                             |
|        | 0b                               | Correct Option E Board Installed                                                            |
|        | 1b                               | Incorrect Option E Board Installed                                                          |
| Bit(3) | Option Board D Error             |                                                                                             |
|        | 0b                               | Correct Option D Board Installed                                                            |
|        | 1b                               | Incorrect Option D Board Installed                                                          |
| Bit(4) | Q1 Com Status (MTri              | gger board only, read as 0 on QTrigger)                                                     |
| Bit(5) | Q2 Com Status (MTri              | gger board only, read as 0 on QTrigger)                                                     |
| Bit(6) | Q3 Com Status (MTri              | gger board only, read as 0 on QTrigger)                                                     |
| Bit(7) | Q4 Com Status (MTri              | gger board only, read as 0 on QTrigger)                                                     |
|        | 0b                               | No comm error found with QTrigger comm                                                      |
|        | 1b                               | Error occurred on QTrigger comm                                                             |
|        |                                  |                                                                                             |

#### Config0 Register $- A_CONFIG0$ (offset = 0x0010 - 0x001C) Config1 Register $- A_CONFIG1$ (offset = 0x0020 - 0x002C)

16bit Write-Only. Supported on QTrigger.

Bit(x) Quadrant Tower Bit(x) configuration Config(1:0)

| 00b | Tower Input uneffected          |
|-----|---------------------------------|
| 01b | RFU (to be used with Hodoscope) |
| 10b | Force Tower Input to 0          |
| 11b | Force Tower Input to 1          |

Ex: Writing to the Quadrant 2 QTrigger board Write 0x0004 @ QTrigger2\_Base + 0x0010 Write 0x8004 @ QTrigger2\_Base + 0x0020

This forces tower 2 input of quadrant 2 to be read as 1b regardless of actual pin value. This forces tower 15 input of quadrant 2 to be read as 0b regardless of actual pin value. Tower 0, 3-14 inputs of quadrant 2 are read as the real input value.

These registers represent the 106 tower inputs of the quadrant the QTrigger board represents. Refer to the Detector Tower Map. Quadrant Tower 0 begins with bit 0 at offset 0x0010 and 0x0020, and ends with Quadrant Tower 105 at bit 9 at offset 0x001C and 0x002C.

After reset, each tower input is configured are CONFIG0 = 0b, CONFIG1 = 0b

#### Threshold Register – A\_THRESHOLD (offset = 0x0030)

16bit Write-Only. Supported on QTrigger, MTrigger.

| Bit(3:0)  | Defines the cluster for 3x3 windows. The number of towers hit in any 3x3 window must be greater |
|-----------|-------------------------------------------------------------------------------------------------|
|           | than this value to be considered a cluster.                                                     |
| Bit(15:4) | RFU (Write values are ignored)                                                                  |

#### Cluster Count Register – A\_CLUSTCNT (offset = 0x0032)

16bit Write-Only. Supported on MTrigger.

| Bit(6:0)  | When the number of clusters found are greater than or equal to this value a trigger is generated. |
|-----------|---------------------------------------------------------------------------------------------------|
| Bit(15:7) | RFU (Write values are ignored.                                                                    |

#### Hit Tower Register – A\_TOWERS (offset = 0x0040 – 0x004C)

16bit Read-Only. Supported on QTrigger. This register is automatically cleared each time it is read.

| D'.  | < >    |
|------|--------|
| D 1t | 1 37 1 |
| DII  | I X I  |
| 210  | (1)    |
|      |        |

| Tower Hit Indicator |                                                 |
|---------------------|-------------------------------------------------|
| 0b                  | Tower x was not hit since last read of register |
| 1b                  | Tower x was hit since last read of register     |

These registers represent the 106 tower inputs of the quadrant the QTrigger board represents. Refer to the Detector Tower Map. Quadrant Tower 0 begins with bit 0 at offset 0x0040, and ends with Quadrant Tower 105 at bit 9 at offset 0x004C.

## **HDL Source Code**

## **MTrigger & QTrigger Files**

## File

V1495usr/spare\_if\_rtl.vhd V1495usr/tristate\_if\_rtl.vhd V1495hal/v1495usr\_hal.vqm V1495usr/v1495usr\_pkg.vhd

## **QTrigger Files**

## File

V1495hal/v1495usr\_q.vhd QTrigger/QPLLBlock.vhd QTrigger/ParallelCom.vhd QTrigger/QTrigger.vhd QTrigger/QTrigger\_pkg.vhd QTrigger/QInputMask.vhd QTrigger/FF.vhd

## **MTrigger Files**

## File

V1495hal/v1495usr\_m.vhd MTrigger/MPLLBlock.vhd MTrigger/ParallelComRx.vhd MTrigger/MTrigger.vhd MTrigger/QISectClusters.vhd MTrigger/QISectSum.vhd MTrigger/TriggerDetect.vhd

## Description

CAEN V1495 Supplied Source Code CAEN V1495 Supplied Source Code CAEN V1495 Supplied Source Code Register Address Names

## Description

CAEN V1495 Supplied Source Code Altera Quartus Megablock PLL Generator Parallel Bus Transmitter Main QTrigger Body Cluster Functions Tower Input Masking Altera Quartus Megablock DFF Generator

## Description

CAEN V1495 Supplied Source Code Altera Quartus Megablock PLL Generator Parallel Bus Receiver Main MTrigger Body Intersecting Quadrant Cluster Detection Intersecting Quadrant Window Summing Cluster Counting, Trigger Generation