| 1 |  | 
|---|
| 2 | Int_t fBending(Int_t zd) | 
|---|
| 3 | { | 
|---|
| 4 | return zd-1592; | 
|---|
| 5 | } | 
|---|
| 6 |  | 
|---|
| 7 | Int_t GetSePos(Int_t p0, Int_t p1) | 
|---|
| 8 | { | 
|---|
| 9 | return (p0-p1)/2; | 
|---|
| 10 | } | 
|---|
| 11 |  | 
|---|
| 12 | void analse() | 
|---|
| 13 | { | 
|---|
| 14 | TH2F hist1("Diff", "Difference of SE values", 201, -90, 110, 25, -12, 12); | 
|---|
| 15 | hist1.SetXTitle("ZA [\\circ]"); | 
|---|
| 16 | hist1.SetYTitle("\\Delta SE"); | 
|---|
| 17 |  | 
|---|
| 18 | // ifstream fin("log/shaftencoder_slow_singleside.log"); | 
|---|
| 19 | //ifstream fin("log/shaftencoder_fast.log"); | 
|---|
| 20 | ifstream fin("log/shaftencoder.log"); | 
|---|
| 21 |  | 
|---|
| 22 | Int_t offset = 999999; | 
|---|
| 23 |  | 
|---|
| 24 | Int_t turn[2], pos[2]={999999, 999999}; | 
|---|
| 25 | while (!fin.eof()) | 
|---|
| 26 | { | 
|---|
| 27 | Int_t id; | 
|---|
| 28 | fin >> id; | 
|---|
| 29 |  | 
|---|
| 30 | fin >> turn[id-4] >> pos[id-4]; | 
|---|
| 31 |  | 
|---|
| 32 | if (offset==999999 && pos[0]!=999999 && pos[1]!=999999) | 
|---|
| 33 | offset = pos[1]+pos[0]; | 
|---|
| 34 |  | 
|---|
| 35 | if (offset==999999) | 
|---|
| 36 | continue; | 
|---|
| 37 |  | 
|---|
| 38 | hist1.Fill(fBending(GetSePos(pos[0], pos[1]))*360/16384, | 
|---|
| 39 | pos[0]+pos[1]-offset); | 
|---|
| 40 | } | 
|---|
| 41 |  | 
|---|
| 42 | TCanvas *c=new TCanvas("c1", "", 1000, 1000); | 
|---|
| 43 | c->Divide(1,2); | 
|---|
| 44 |  | 
|---|
| 45 | c->cd(1); | 
|---|
| 46 | TH2 *h=hist1.DrawCopy(); | 
|---|
| 47 |  | 
|---|
| 48 | TProfile *p = h->ProfileX("_pfx", -1, 9999, "s"); | 
|---|
| 49 | p->SetLineColor(kBlue); | 
|---|
| 50 | p->Draw("same"); | 
|---|
| 51 | p->SetBit(kCanDelete); | 
|---|
| 52 |  | 
|---|
| 53 | c->cd(2); | 
|---|
| 54 | TH1F p2("spread", "Spread of the differences", hist1.GetNbinsX(), hist1.GetBinLowEdge(1), | 
|---|
| 55 | hist1.GetBinLowEdge(hist1.GetNbinsX()+1)); | 
|---|
| 56 | p2.SetXTitle("ZA [\\circ]"); | 
|---|
| 57 | for (int i=0; i<hist1.GetNbinsX(); i++) | 
|---|
| 58 | p2.SetBinError(i, p->GetBinError(i)); | 
|---|
| 59 | p2.SetLineColor(kRed); | 
|---|
| 60 | p2.SetStats(0); | 
|---|
| 61 | p2.DrawCopy(); | 
|---|
| 62 | } | 
|---|