Data acquisition electronics and reconstruction software for real time
  3D track reconstruction within the MIMAC project by Bourrion, O. et al.
Preprint typeset in JINST style - HYPER VERSION
Data acquisition electronics and reconstruction
software for real time 3D track reconstruction within
the MIMAC project
O. Bourriona∗, G. Bossona, C. Grignona, J.L. Boulya, J.P. Richera, O. Guillaudina,
F. Mayeta, J. Billarda and D. Santosa.
aLaboratoire de Physique Subatomique et de Cosmologie,
Université Joseph Fourier Grenoble 1,
CNRS/IN2P3, Institut Polytechnique de Grenoble,
53, rue des Martyrs, Grenoble, France
E-mail: olivier.bourrion@lpsc.in2p3.fr
ABSTRACT: Directional detection of non-baryonic Dark Matter requires 3D reconstruction of low
energy nuclear recoils tracks. A gaseous micro-TPC matrix, filled with either 3He, CF4 or C4H10
has been developed within the MIMAC project. A dedicated acquisition electronics and a real time
track reconstruction software have been developed to monitor a 512 channel prototype. This auto-
triggered electronic uses embedded processing to reduce the data transfer to its useful part only,
i.e. decoded coordinates of hit tracks and corresponding energy measurements. An acquisition
software with on-line monitoring and 3D track reconstruction is also presented.
KEYWORDS: Electronic detector readout concepts (gas, liquid); Particle tracking detectors
(Gaseous detectors).
∗Corresponding author.
ar
X
iv
:1
11
0.
43
48
v3
  [
as
tro
-p
h.I
M
]  
2 N
ov
 20
11
Contents
1. Introduction 1
2. MIMAC detector readout principle 1
3. Front end ASIC 3
3.1 Requirements 3
3.2 Design overview 3
4. Readout electronics 4
4.1 Electronic board overview 4
4.2 FPGA firmware 4
5. Acquisition software 7
6. Summary 7
1. Introduction
Directional detection of dark matter is known to be a promising search strategy of galactic Dark
Matter [1, 2]). Recent studies have shown that, within the framework of dedicated statistical data
analysis, a low exposure directional detector could lead either to a high significance discovery of
galactic Dark Matter [3, 4] or to a conclusive exclusion [5].
A gaseous micro-TPC matrix, filled with either 3He, CF4 or C4H10 has been developed within
the MIcro TPC MAtrix of Chambers (MIMAC) project [6]. To demonstrate the relevance of the
concept, specific front-end ASIC and a dedicated acquisition electronic were developed in order
to equip a prototype detector featuring an anode of 10.85× 10.85 cm2 where 2× 256 strips are
monitored. This auto-triggered acquisition electronic uses embedded processing to reduce data
transfer to its useful part only, i.e. decoded coordinates of hit tracks and corresponding energy
measurements. To be fully exploited, an acquisition software with on-line monitoring and track
reconstruction has been written.
2. MIMAC detector readout principle
As shown in figure 1, the MIMAC prototype µTPC is composed of a pixelized anode featuring 2
orthogonal series of 256 strips of pixels (X and Y) [7] and a micromesh grid defining the delimita-
tion between the amplification (grid to anode) and the drift space (cathode to grid). Each strip of
pixels is monitored by a current preamplifier and the fired pixel coordinate is obtained by using the
coincidence between the X and Y strips (the pixel pitch is 424 µm). A coincidence is defined as
– 1 –
particle
particle
Recoil ionization
track
e-
cathode
micromesh grid
anode
E
 
 1
 k
V
/c
m

E ~ 80 kV/cmamplification gap
424 µm
strip of pixel readout
Current
preamplifier
drift space
2
0
 c
m
Figure 1. Schematic of the MIMAC micro-TPC using a micromegas composed of a pixelized anode featur-
ing 2 orthogonal series of 256 strips of pixels and a micromesh grid defining the delimitation between the
amplification (grid to anode) and the drift space (cathode to grid).
having at least one strip of pixels fired in each direction (X, Y) at the same sampling time. The ion-
ization energy of the recoil energy is obtained by instrumenting the micromesh grid with a Charge
Sensitive Preamplifier (CSP).
As illustrated in figure 2, the coordinates in the anode plane (X, Y) are reconstructed by col-
lecting primary electrons produced in the drift region. Knowing the electron drift velocity, the
third dimension (Z) is obtained by sampling the anode signal every 20 ns. Note, that due to the
multiplexed readout of the anode, each time slice picture is rectangular.
t=0 ns
t=20 ns
t=40 ns
t=60 ns
Figure 2. The coordinates in the anode plane (X, Y) are reconstructed by collecting primary electrons
produced in the drift region. Knowing the electron drift velocity, the third dimension (Z) is obtained by
sampling the anode signal every 20 ns. Due to the multiplexed readout of the anode, each time slice picture
is rectangular.
– 2 –
3. Front end ASIC
3.1 Requirements
In the early stage of the project it was decided to design an ASIC in order to be able to fulfill the
final objective, which is to equip about 2500 chambers of 1024 strips of pixels (512+512). This
minimizes space requirement and power demand while allowing cost reduction on a large scale.
After going through a first prototype phase, 16 channels ASICs equipping a 2×96 strips of pixels
chamber [8], a 64 channel version was designed [9]. This was determined to be a good balance
between integration scale on one side and complexity, fabrication yield and available packages on
the other side.
To be able to recover the third coordinate (Z) of the track, a fast switching current comparator
having a threshold as low as 200 nA must be designed in order to have a precise time over threshold
measurement of each current preamplifier output. This requirement is driven by the worst case
where the recoil energy is as low as 500 eV in a chamber having its gain limited to 3000 and
where the diffusion is maximized (i.e interaction farthest from the anode) and the recoil track
is parallel to the anode (the charge deposit is distributed along different strips). Another strong
system requirement is to minimize the board level interconnection to allow an easy integration
with a readout system.
3.2 Design overview
The front end ASIC, whose block diagram is shown in figure 3, is composed of 4 groups of 16
channels. Each channel is composed of a current preamplifier having a gain of 15, a fast compara-
tor (modified CMOS inverter kept in linear region) and a 5 bit DAC for setting the threshold. A
1
6
 c
h
a
n
n
e
ls
1
6
 b
it
PLL
50MHz
reference
Clock 400 MHz
Serial interface
5 bit
To FPGA or microcontroller
8
 b
it
 s
e
ri
a
liz
e
r
8
 b
it
 s
e
ri
a
liz
e
r
L
V
D
S
 o
u
tp
u
ts
current 
preamp
Strip
of pixels comp
DAC
Auto zero
amplifier LSB 
200 nA
current 
preamp
Strip
of pixels comp
DAC
Auto zero
amplifier LSB 
200 nA
X15
X15
Figure 3. Front end ASIC block diagram. The 64 channels are decomposed in 4 groups of 16 channels.
Each channel is composed of a current preamplifier having a gain of 15, a fast comparator (modified CMOS
inverter kept in linear region) and a 5 bit DAC for setting the threshold. A serial link is used to configure the
DAC. The comparator outputs are transferred serially.
trade-off was made between the DAC resolution and the achievable preamplifier offset. The DAC
– 3 –
dynamic range, and thus its design complexity can be greatly reduced by using an autozero pream-
plifier. This kind of amplifier measures periodically (every second) its offset during a few dozen µs
and determines the compensation to apply to reduce the residual output offset. The 5 bit DAC is
designed with a 200 nA LSB (input equivalent: 13.3 nA).
The comparator outputs are sampled at a 50 MHz rate and serialized at 400 MHz, thereby
reducing the interconnection by a factor of 8 and as a side benefit also diminishing the power
consumption. The serial outputs rely on the Low Voltage Differential Signaling (LVDS) standard
to lower the electronic noise. It should be noted that using the same reference clock allows syn-
chronous sampling between ASICs. Finally, a slow serial link is used to configure the 64 DACs
and to individually enable/disable each channel (kill possible dead channels, ...) and to provide the
synchronization pattern to be used. The ASIC was fabricated in austriamicrosystems BiCMOS-
SiGe 350 nm process. It uses an effective area of 3.9 mm×5.8 mm= 22 mm2 and requires a total
power of 445 mW.
4. Readout electronics
4.1 Electronic board overview
The readout electronic, which is an upgrade of a previous work [10], comprises 8 dedicated ASICs,
a FPGA (Field Programmable Gate Array), a flash ADC (Analog to Digital Converter) and an USB
interface for Data Acquisition (DAQ) and slow control (see figure 4). The connection between the
anode located inside the chamber and the electronics at ambient pressure is done via an airtight
interface [7]. Each strip input is equipped with a discharge protection. The hit strip information,
that is sampled at a rate of 50 MHz, is transferred by 8 LVDS serial links at 400 MHz to a unique
processing FPGA. This FPGA allows the auto-triggering and does the first level event building.
In parallel to the anode signal processing, the grid signal is fed to flash ADC and sampled at
50 MHz. While keeping a very good energy resolution, an estimation of the charge deposit through
time can be obtained off-line by deriving the digitized CSP signal.
The board has a dimension of 25 cm×25 cm and uses 9.4 W in operation.
4.2 FPGA firmware
As shown in figure 5, the FPGA deserializes the data received from the ASIC and for each group
of 16 channels a local trigger is built (OR). The first level processing starts at this stage, i.e. when
a coincidence exists between X and Y strips, a local recording takes place (start date + positions).
In theory, a single event would be defined as continuously firing strips. Unfortunately, the primary
electron distribution can be noncontinuous, therefore untriggered strips can split the track (clusters).
To cope with this, the recording is actually stopped when there are no more fired strips for a preset
number of clock cycles.
Most of the time a few strips only are fired, hence by using an adequate data encoding (shown
in table 1), the data payload per event can be reduced. For instance, when 2 strips in X and 2 strips
in Y are fired in the same time slice, taking advantage of the encoding, only 64 bit are transfered
instead of 512. This first encoding and processing stage is done in parallel for the X and Y side. At
the following stage, dedicated state machines search and aggregate data from the same time slice in
– 4 –
ASIC
LVDS
data link
ASIC
LVDS
data link
64
64
In
te
rf
a
c
e
 c
o
n
n
e
c
to
r
ASIC
LVDS
data link
ASIC
LVDS
data link
64
64
In
te
rf
a
c
e
 c
o
n
n
e
c
to
r
X
 s
id
e
Y
 s
id
eFPGA
XILINX
VIRTEX5
Flash ADC
10 bit
USB
µC
ASIC
LVDS
data link
ASIC
LVDS
data link
64
In
te
rf
a
c
e
 c
o
n
n
e
c
to
r
64
ASIC
LVDS
data link
ASIC
LVDS
data link
64
In
te
rf
a
c
e
 c
o
n
n
e
c
to
r
64
Grid CSP
input
USB con-
nector
Figure 4. Block diagram of the acquisition board. It comprises 8 dedicated ASICs, a FPGA, a flash ADC
and an USB interface for DAQ and slow control interface.
16
trig
da
ta
 in
sel
13 bit
time counter
delay
run
1024 x 18
memory
da
ta
 o
ut
FSM
acknowledge
time tag
data available
management
position
FSM write add
decoding
and
readout
data
raw
position
LSB serial
MSB serial
13
read add
deserializer
13
position 16
Figure 5. Block diagram of the ASIC interface. It comprises the data deserializer, the local trigger building,
intermediate buffering and the first level processing.
Bit # [15..13] 12 [11..10] [9..8] [7..4] [3..0]
Content 0 X or Y ASIC# Group# 0 ch#
Table 1. Position data encoding.
order to perform the first level event building. This association is done in several stages, in order to
concentrate more and more the data, and to present a single buffer to the USB interface. The right
side of figure 6 offer a graphical representation of the FSM. Starting from the IDLE state, the FSM
waits for the first ASIC (or group) to present data. When it is the case, the current date is saved and
the position decoding is performed. Then the FSM looks if an other group presents position data
marked with the same date, if yes the data are decoded and appended to the output buffer in the
– 5 –
same time slot, if not the time slot is closed and the search for a new time slot continues. At this
stage, two possibilities remain: either no more data are available and the FSM returns to the IDLE
state or data are still available and the earliest data has to be found. For that, a scan of the dates is
made (seek_next_group) in order to find the first ASIC in time. This scanning is complexified by
the fact that the time counter has a short span (13 bit which corresponds to ∼1.31 ms), therefore it
is performed in two stages. First the search is performed from the current date up to the maximum
counter value, and if not successful, the current date is set to zero and the searching is performed
again until the group is found (check roll over state).


	










	






	










	





	





IDLE
save current date
find first group
scan word
seek next group
same time
all bit scanned
data available
write end of TAG
all bit scanned
no more data
new group found
no group found
no more data
available
seek_next_group
data still available
check roll over
clear counter
no group found
in current span
data group found
no data available
time reset
Figure 6. Left figure shows the block diagram of the parallel and cascaded processing. Right figure shows
the state machine in charge of decoding the strip coordinates and the strategy used to do the first level of
same time slice hit coordinate data aggregation.
The energy measurement is done in parallel to the position processing. The CSP signal record-
ing is armed by the position triggering, but given the fact that the signal path delay is different for
the anode and the grid signal, the actual recording is performed when the grid integrated signal is
digitized. As a consequence of the low level signal compared to the noise level, a slope condition,
which is more robust and noise immune than using a simple level threshold, is used. Taking ad-
vantage of the FPGA, dedicated filtering techniques were implemented to remove low frequency
noise (below 20 kHz) and thus to further enhance the signal to noise ratio without degrading the
event signal shape. For that, a delayed version of the ADC signal is continuously subtracted with
the output of a Cascaded Integrator-Comb (CIC) filter which is used to isolate the low frequency
– 6 –
noise part of the signal. The resulting signal is then fed into a low pass Finite Impulse Response
(FIR) filter in order to provide additional data smoothing.
Consequently to the parallel processing, the position and energy data are recorded in separate
FIFOs for USB readout.
5. Acquisition software
The first task of the acquisition software is to re-associate the position and the energy data. As
shown in figure 7, it uses the position information which is provided in a list of X/Y coordinates
fired per time slice. Knowing that an event is defined as continuously triggering strips, the al-
gorithm basically searches continuous triggering position (in time) and searches a discontinuity
(time tag jumps by more than the preset value) to close the event. Once the event is defined, the
energy information with a corresponding time tag is associated. The event building is then fin-
ished and contains directly the coordinates of the fired strips coordinate for each time slice and the
corresponding digitized grid signal.
The second task of the acquisition software is to provide a real time display (see figure 8).
The Graphical User Interface (GUI) provides 3 projections of the track (XY-XZ-YZ), the number
of fired strips per time slice, the Track CSP digitized signal and its derivative. It also offers the
possibility to search (energy, duration, ...) and display a specific recoil track. An energy histogram
of the run is also built on line and displayed on an other tab (not shown in figure 8).
6. Summary
A complete dedicated solution from front-end to back-end was developed to instrument a MIMAC
prototype (256×256). Several MIMAC electronics can be connected per computer and the event
building developed can be performed in several stages provided a common time tagging electronic
board is designed and a synchronization upgrade is implemented.
References
[1] D.N. Spergel, Phys. Rev. D37 (1988) 1353
[2] S. Ahlen et al., Int. J. Mod. Phys. A25 (2010) 1
[3] J. Billard et al., Phys. Lett. B691 (2010) 156-162
[4] J. Billard, F. Mayet and D. Santos, Phys. Rev. D83 (2011) 075002
[5] J. Billard, F. Mayet and D. Santos, Phys. Rev. D82 (2010) 055011
[6] D. Santos et al., J. Phys. Conf. Ser. 65 (2007) 012012
[7] F. J. Iguaz et al., 2011 JINST 6 P07002 (2011)
[8] J.P. Richer et al., Nucl. Instr. Meth. A620 (2010) 470-476
[9] J.P. Richer et al., these proceedings, arXiv:1110.4579
[10] O. Bourrion et al., Nucl. Instr. Meth. A662 (2010) 207
– 7 –
data readout
both queues
empty?
yes
Event in
construction?
no
start construction
save current date
no
all positions
retrieved?
yes
Energy track
retrieved?
yes
get position
no
close event construction
yes
get energy samples
no
Figure 7. Graphical representation of the event building algorithm. It uses the position information which is
provided in a list of X/Y coordinates fired per time slice. Knowing that an event is defined as continuously
triggering strips, the algorithm basically searches continuous triggering position (in time) and searches a
discontinuity (time tag jumps by more than the preset value) to close the event. Once the event is defined,
the energy information with a corresponding time tag is associated.
– 8 –
Figure 8. Screenshot of the real time display. The 3 projections of the track (XY-XZ-ZY), the number of
fired strips per time slice, the grid digitized signal and its derivative can be seen.
– 9 –
