Project
Loading...
Searching...
No Matches
DigiParams.cxx
Go to the documentation of this file.
1// Copyright 2019-2020 CERN and copyright holders of ALICE O2.
2// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
3// All rights not expressly granted are reserved.
4//
5// This software is distributed under the terms of the GNU General Public
6// License v3 (GPL Version 3), copied verbatim in the file "COPYING".
7//
8// In applying this license CERN does not waive the privileges and immunities
9// granted to it by virtue of its status as an Intergovernmental Organization
10// or submit itself to any jurisdiction.
11
14
15#include <fairlogger/Logger.h> // for LOG
17#include <cassert>
18
20
21using namespace o2::itsmft;
22
24{
25 // make sure the defaults are consistent
26 setNSimSteps(mNSimSteps);
27}
28
30{
31 // set ROFrame length in nanosecongs
32 mROFrameLength = lNS;
33 assert(mROFrameLength > 1.);
34 mROFrameLengthInv = 1. / mROFrameLength;
35}
36
38{
39 // set number of sampling steps in silicon
40 mNSimSteps = v > 0 ? v : 1;
41 mNSimStepsInv = 1.f / mNSimSteps;
42}
43
44void DigiParams::setChargeThreshold(int v, float frac2Account)
45{
46 // set charge threshold for digits creation and its fraction to account
47 // contribution from single hit
48 mChargeThreshold = v;
49 mMinChargeToAccount = v * frac2Account;
50 if (mMinChargeToAccount < 0 || mMinChargeToAccount > mChargeThreshold) {
51 mMinChargeToAccount = mChargeThreshold;
52 }
53 LOG(info) << "Set Alpide charge threshold to " << mChargeThreshold
54 << ", single hit will be accounted from " << mMinChargeToAccount
55 << " electrons";
56}
57
58//______________________________________________
60{
61 // print settings
62 printf("Alpide digitization params:\n");
63 printf("Continuous readout : %s\n", mIsContinuous ? "ON" : "OFF");
64 printf("Readout Frame Length(ns) : %f\n", mROFrameLength);
65 printf("Strobe delay (ns) : %f\n", mStrobeDelay);
66 printf("Strobe length (ns) : %f\n", mStrobeLength);
67 printf("Threshold (N electrons) : %d\n", mChargeThreshold);
68 printf("Min N electrons to account : %d\n", mMinChargeToAccount);
69 printf("Number of charge sharing steps : %d\n", mNSimSteps);
70 printf("ELoss to N electrons factor : %e\n", mEnergyToNElectrons);
71 printf("Noise level per pixel : %e\n", mNoisePerPixel);
72 printf("Charge time-response:\n");
73 mSignalShape.print();
74}
Simulation parameters for the ALIPIDE chip.
ClassImp(o2::itsmft::DigiParams)
void setChargeThreshold(int v, float frac2Account=0.1)
void setROFrameLength(float ns)
const GLdouble * v
Definition glcorearb.h:832
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"