9 #include <framework/dataobjects/RelationElement.h>
10 #include <svd/simulation/SVDWaveform.h>
11 #include <gtest/gtest.h>
30 vector<double> charges;
31 charges.push_back(10);
32 charges.push_back(11);
33 charges.push_back(30);
35 for (
int i = 0; i < 3; ++i) times.push_back(i * 15.0e-9);
36 vector<RelationElement::index_type> mcParticles;
37 for (
int i = 0; i < 3; ++i) mcParticles.push_back(3 * i);
38 vector<RelationElement::index_type> trueHits;
39 for (
int i = 0; i < 3; ++i) trueHits.push_back(7 * i);
40 const float tau = 25.0e-9;
42 for (
int i = 0; i < 3; ++i) waveform.
add(times.at(i), charges.at(i), tau, mcParticles.at(i), trueHits.at(i));
44 double totalcharge = 0;
45 for (
int i = 0; i < 3; ++i) totalcharge += charges.at(i);
46 EXPECT_EQ(waveform.
getCharge(), totalcharge);
49 for (
int i = 0; i < 3; ++i) {
50 EXPECT_EQ(functions.at(i).m_initTime, times.at(i));
51 EXPECT_EQ(functions.at(i).m_charge, charges.at(i));
52 EXPECT_EQ(functions.at(i).m_tau, tau);
53 EXPECT_EQ(functions.at(i).m_particle, mcParticles.at(i));
54 EXPECT_EQ(functions.at(i).m_truehit, trueHits.at(i));
62 vector<double> charges;
63 charges.push_back(10);
64 charges.push_back(11);
65 charges.push_back(30);
67 for (
int i = 0; i < 3; ++i) times.push_back(i * 15.0e-9);
68 vector<RelationElement::index_type> mcParticles;
69 for (
int i = 0; i < 3; ++i) mcParticles.push_back(3 * i);
70 vector<RelationElement::index_type> trueHits;
71 for (
int i = 0; i < 3; ++i) trueHits.push_back(7 * i);
72 const float tau = 25.0e-9;
74 for (
int i = 0; i < 3; ++i) waveform.
add(times.at(i), charges.at(i), tau, mcParticles.at(i), trueHits.at(i));
77 double totalcharge = 0;
78 for (
int i = 0; i < 3; ++i) totalcharge += charges.at(i);
79 EXPECT_EQ(waveform2.
getCharge(), totalcharge);
82 size_t n = functions.size();
84 for (
int i = 0; i < 3; ++i) {
85 EXPECT_EQ(functions.at(i).m_initTime, times.at(i));
86 EXPECT_EQ(functions.at(i).m_charge, charges.at(i));
87 EXPECT_EQ(functions.at(i).m_tau, tau);
88 EXPECT_EQ(functions.at(i).m_particle, mcParticles.at(i));
89 EXPECT_EQ(functions.at(i).m_truehit, trueHits.at(i));
97 vector<double> charges;
98 charges.push_back(10);
99 charges.push_back(11);
100 charges.push_back(30);
101 vector<double> times;
102 for (
int i = 0; i < 3; ++i) times.push_back(i * 15.0e-9);
103 vector<RelationElement::index_type> mcParticles;
104 for (
int i = 0; i < 3; ++i) mcParticles.push_back(3 * i);
105 vector<RelationElement::index_type> trueHits;
106 for (
int i = 0; i < 3; ++i) trueHits.push_back(7 * i);
107 const float tau = 25.0e-9;
109 for (
int i = 0; i < 3; ++i) waveform.
add(times.at(i), charges.at(i), tau, mcParticles.at(i), trueHits.at(i));
112 double totalcharge = 0;
113 for (
int i = 0; i < 3; ++i) totalcharge += charges.at(i);
114 EXPECT_EQ(waveform2.
getCharge(), totalcharge);
117 for (
int i = 0; i < 3; ++i) {
118 EXPECT_EQ(functions.at(i).m_initTime, times.at(i));
119 EXPECT_EQ(functions.at(i).m_charge, charges.at(i));
120 EXPECT_EQ(functions.at(i).m_tau, tau);
121 EXPECT_EQ(functions.at(i).m_particle, mcParticles.at(i));
122 EXPECT_EQ(functions.at(i).m_truehit, trueHits.at(i));
130 vector<double> charges;
131 charges.push_back(10);
132 charges.push_back(11);
133 charges.push_back(30);
134 vector<double> times;
135 for (
int i = 0; i < 3; ++i) times.push_back(i * 15.0e-9);
136 vector<RelationElement::index_type> mcParticles;
137 for (
int i = 0; i < 3; ++i) mcParticles.push_back(3 * i);
138 vector<RelationElement::index_type> trueHits;
139 for (
int i = 0; i < 3; ++i) trueHits.push_back(7 * i);
140 const float tau = 25.0e-9;
142 for (
int i = 0; i < 3; ++i) waveform.
add(times.at(i), charges.at(i), tau, mcParticles.at(i), trueHits.at(i));
144 double time = 40.0e-9;
146 double expected_value = 0;
148 double value = waveform.
waveform(time, wave);
149 expected_value += value;
151 double function_value = waveform(time);
152 EXPECT_EQ(function_value, expected_value);
159 vector<double> charges;
160 charges.push_back(10);
161 charges.push_back(11);
162 charges.push_back(30);
163 vector<double> times;
164 for (
int i = 0; i < 3; ++i) times.push_back(i * 15.0e-9);
165 vector<RelationElement::index_type> mcParticles;
166 for (
int i = 0; i < 3; ++i) mcParticles.push_back(3 * i);
167 vector<RelationElement::index_type> trueHits;
168 for (
int i = 0; i < 3; ++i) trueHits.push_back(7 * i);
169 const float tau = 50.0e-9;
171 for (
int i = 0; i < 3; ++i) waveform.
add(times.at(i), charges.at(i), tau, mcParticles.at(i), trueHits.at(i));
172 std::ostringstream os;
173 for (
int i = 0; i < 3; ++i)
174 os << i + 1 <<
'\t' << times.at(i) <<
'\t' << charges.at(i) <<
'\t' << tau << std::endl;
175 EXPECT_EQ(waveform.
toString(), os.str());
TEST(TestgetDetectorRegion, TestgetDetectorRegion)
Test Constructors.
Abstract base class for different kinds of events.