| 1 | //////////////////////////////////////////////////////////////
|
|---|
| 2 | //Functions for FPulsetemplate to write template Pulse to csv
|
|---|
| 3 | //////////////////////////////////////////////////////////////
|
|---|
| 4 |
|
|---|
| 5 | #include "SaveToCsv.h"
|
|---|
| 6 | #include <TROOT.h>
|
|---|
| 7 | #include <TH1F.h>
|
|---|
| 8 | #include <TString.h>
|
|---|
| 9 |
|
|---|
| 10 | TString
|
|---|
| 11 | BuildPath(
|
|---|
| 12 | TString path,
|
|---|
| 13 | const char* csv_file_name,
|
|---|
| 14 | int pixel
|
|---|
| 15 | )
|
|---|
| 16 | {
|
|---|
| 17 | path += csv_file_name;
|
|---|
| 18 | path += "_";
|
|---|
| 19 |
|
|---|
| 20 | if (pixel = -1)
|
|---|
| 21 | path += "AllPixel";
|
|---|
| 22 | else
|
|---|
| 23 | path += pixel;
|
|---|
| 24 | path += ".csv";
|
|---|
| 25 |
|
|---|
| 26 | return path;
|
|---|
| 27 | }
|
|---|
| 28 |
|
|---|
| 29 |
|
|---|
| 30 | void
|
|---|
| 31 | WritePixelTemplateToCsv(
|
|---|
| 32 | TH1* phInputHistogram,
|
|---|
| 33 | TString path,
|
|---|
| 34 | const char* csv_file_name,
|
|---|
| 35 | const char* overlay_method,
|
|---|
| 36 | int pixel,
|
|---|
| 37 | int verbosityLevel
|
|---|
| 38 | )
|
|---|
| 39 | {
|
|---|
| 40 | path = BuildPath(path, csv_file_name, pixel); //if want to write ALL pixel= -1
|
|---|
| 41 |
|
|---|
| 42 | Int_t nbins = phInputHistogram->GetXaxis()->GetNbins();
|
|---|
| 43 |
|
|---|
| 44 | if (verbosityLevel > 0)
|
|---|
| 45 | {
|
|---|
| 46 | cout << "writing point-set to csv file: " ;
|
|---|
| 47 | cout << path << endl;
|
|---|
| 48 | cout << "...opening file" << endl;
|
|---|
| 49 | }
|
|---|
| 50 | if (verbosityLevel > 2) cout << "...number of bins " << nbins << endl;
|
|---|
| 51 |
|
|---|
| 52 | ofstream out;
|
|---|
| 53 | out.open( path );
|
|---|
| 54 |
|
|---|
| 55 | out << "### point-set of a single photon pulse template" << endl
|
|---|
| 56 | << "### template determined with pulse overlay at: "
|
|---|
| 57 | << overlay_method;
|
|---|
| 58 | if ( pixel = -1 )
|
|---|
| 59 | out << "of all Pixels";
|
|---|
| 60 | else
|
|---|
| 61 | out << endl;
|
|---|
| 62 | out << "### Slice's Amplitude determined by calculating the " << endl
|
|---|
| 63 | << "### value of maximum propability of slice -> Amplitude1 " << endl
|
|---|
| 64 | << "### mean of slice -> Amplitude2 " << endl
|
|---|
| 65 | << "### median of slice -> Amplitude3 " << endl
|
|---|
| 66 | << "### for each slice" << endl
|
|---|
| 67 | << "### Pixel number (CHid): " << pixel << endl
|
|---|
| 68 | << endl
|
|---|
| 69 | << "time [slices],Amplitude1 [mV],Amplitude2 [mV],Amplitude3 [mV]" << endl;
|
|---|
| 70 |
|
|---|
| 71 | for (int TimeSlice=1;TimeSlice<=nbins;TimeSlice++)
|
|---|
| 72 | {
|
|---|
| 73 | out << TimeSlice
|
|---|
| 74 | << "," << phInputHistogram->GetBinContent(TimeSlice);
|
|---|
| 75 | // << "," << hPixelMean[0]->GetBinContent(TimeSlice);
|
|---|
| 76 | // << "," << hPixelMedian[0]->GetBinContent(TimeSlice) << endl;
|
|---|
| 77 | }
|
|---|
| 78 |
|
|---|
| 79 | out.close();
|
|---|
| 80 | if (verbosityLevel > 0) cout << "...file closed" << endl;
|
|---|
| 81 | }
|
|---|
| 82 |
|
|---|