ROOT(cern) чтение файла +TGraph работает нормально, но TGraphErrors не хочет

Проблема заключается в следующем: я прочитал мои данные из файла в массив. Построение графика работает без проблем. Но TGraphErrors не хочет ничего делать. Рут говорит

Ошибка: Невозможно вызвать TGraphErrors::SetPoint(i, Данные [0][i], Данные [1][i], Данные [2][i], Данные [2][i]) в текущем графике области действия2.C:85: Возможные кандидаты... (в TGraphErrors) (в TGraph) /usr/local/Cellar/root/5.34.26/lib/root/libHist.so -1: -1 0 public: virtual void TGraph:: SetPoint (Int_t i, Double_t x, Double_t y); * Устранена ошибка интерпретатора *"

Код ниже:

    void plot2(char* fin1){
    const int VAR_N=20,NPOINTS=10000;
    Double_t Data[VAR_N][NPOINTS];
   int counts,N1;
   float E,E1,dE;
   FILE* fin12;
    printf("%s \n",fin1);
    fin12 = fopen(fin1,"r");
      if (fin12 == NULL){
        printf("Can't open input file: %s !\n",fin1);
    }
    else{
        counts=0; 
        while (!feof(fin12)) {
            fscanf(fin12, "%f %f %f \n",&E,&E1,&dE);
            printf("%f %f %f \n",E,E1,dE);
                Data[0][counts] =   E;
                Data[1][counts] =   E1;
                Data[2][counts] =   dE;  }
        N1=counts;
        printf("NP1=%d ",N1);
        fclose(fin12);
    }
   TGraph* V_Graph = new TGraph(N1);
    TGraphErrors* V_GraphErrors = new TGraphErrors(N1);
    for(int i=0;i<N1;i++){
       V_Graph->SetPoint(i,Data[0][i],Data[1][i]);
     } 
   for(int i=0;i<N1;i++){
   V_GraphErrors->SetPoint(i,Data[0][i],Data[1][i],Data[2][i],Data[2][i]);
  }

TCanvas *c1 = new TCanvas("c1", "c1", 1200, 1000);
  c1->cd(1);
   TString VName="+Errors";
   V_Graph->SetTitle(VName);
   V_Graph->SetMarkerStyle(21);
   V_Graph->SetMarkerSize(1);
   V_Graph->SetMarkerColor(kBlue);
    V_Graph->GetXaxis()->SetTitle("x");
    V_Graph->GetYaxis()->SetTitle("y");
    V_Graph->GetXaxis()->SetLimits(4.,25.);
    V_Graph->GetYaxis()->SetRangeUser(10.,80.);
    V_Graph->Draw("APL");

    V_GraphErrors->SetMarkerStyle(21);
    V_GraphErrors->SetMarkerSize(1);
    V_GraphErrors->SetMarkerColor(kGreen);
    //V_Graph->GetXaxis()->SetLimits(4.,11.);
    //V_Graph->GetYaxis()->SetRangeUser(45.,80.);
    V_GraphErrors->Draw("C*");
}

Я новичок в использовании root. Вероятно, я сделал что-то глупое и не заметил этого. Так что я сделал не так? заранее спасибо
Olka

1 ответ

Проблема в том, что нет SetPointError метод с подписью, которую вы пытаетесь использовать (int, Double_t, Double_t, Double_t, Double_t), Чтобы установить ошибки, вы должны использовать SetPointError(Double_t ex, Double_t ey) метод. Например, в приведенном выше коде вы должны сделать что-то вроде:

V_GraphErrors->SetPoint(i,Data[0][i],Data[1][i]]);
V_GraphErrors->SetPointError(i,Data[2][i],Data[2][i]);

Хотя, вероятно, было бы легче передать arrys непосредственно в конструкторе:

V_GraphErrors(N1, Data[0], Data[1], Data[2], Data[2]);

Кстати, это установит одинаковые ошибки x и y. Я не уверен, что это то, что вы хотели.

См. https://root.cern.ch/root/html/TGraphErrors.html для получения подробной информации о методах, доступных в TGraphErrors

Другие вопросы по тегам