{
"cells": [
{
"cell_type": "markdown",
"id": "9bdb71ff",
"metadata": {},
"source": [
"# hvector\n",
"Write and read STL vectors in a tree.\n",
"\n",
"\n",
"\n",
"\n",
"**Author:** The ROOT Team \n",
"This notebook tutorial was automatically generated with ROOTBOOK-izer from the macro found in the ROOT repository on Tuesday, March 19, 2024 at 07:21 PM."
]
},
{
"cell_type": "markdown",
"id": "874a1d37",
"metadata": {},
"source": [
" Definition of a helper function: "
]
},
{
"cell_type": "code",
"execution_count": 1,
"id": "2857bab8",
"metadata": {
"collapsed": false,
"execution": {
"iopub.execute_input": "2024-03-19T19:21:41.642505Z",
"iopub.status.busy": "2024-03-19T19:21:41.642008Z",
"iopub.status.idle": "2024-03-19T19:21:41.737585Z",
"shell.execute_reply": "2024-03-19T19:21:41.736485Z"
}
},
"outputs": [],
"source": [
"%%cpp -d\n",
"\n",
"#include \n",
"\n",
"#include \"TFile.h\"\n",
"#include \"TTree.h\"\n",
"#include \"TCanvas.h\"\n",
"#include \"TFrame.h\"\n",
"#include \"TH1F.h\"\n",
"#include \"TBenchmark.h\"\n",
"#include \"TRandom.h\"\n",
"#include \"TSystem.h\"\n",
"\n",
"void write()\n",
"{\n",
"\n",
" TFile *f = TFile::Open(\"hvector.root\",\"RECREATE\");\n",
"\n",
" if (!f) { return; }\n",
"\n",
" // Create one histograms\n",
" TH1F *hpx = new TH1F(\"hpx\",\"This is the px distribution\",100,-4,4);\n",
" hpx->SetFillColor(48);\n",
"\n",
" std::vector vpx;\n",
" std::vector vpy;\n",
" std::vector vpz;\n",
" std::vector vrand;\n",
"\n",
" // Create a TTree\n",
" TTree *t = new TTree(\"tvec\",\"Tree with vectors\");\n",
" t->Branch(\"vpx\",&vpx);\n",
" t->Branch(\"vpy\",&vpy);\n",
" t->Branch(\"vpz\",&vpz);\n",
" t->Branch(\"vrand\",&vrand);\n",
"\n",
" // Create a new canvas.\n",
" TCanvas *c1 = new TCanvas(\"c1\",\"Dynamic Filling Example\",200,10,700,500);\n",
"\n",
" gRandom->SetSeed();\n",
" const Int_t kUPDATE = 1000;\n",
" for (Int_t i = 0; i < 25000; i++) {\n",
" Int_t npx = (Int_t)(gRandom->Rndm(1)*15);\n",
"\n",
" vpx.clear();\n",
" vpy.clear();\n",
" vpz.clear();\n",
" vrand.clear();\n",
"\n",
" for (Int_t j = 0; j < npx; ++j) {\n",
"\n",
" Float_t px,py,pz;\n",
" gRandom->Rannor(px,py);\n",
" pz = px*px + py*py;\n",
" Float_t random = gRandom->Rndm(1);\n",
"\n",
" hpx->Fill(px);\n",
"\n",
" vpx.emplace_back(px);\n",
" vpy.emplace_back(py);\n",
" vpz.emplace_back(pz);\n",
" vrand.emplace_back(random);\n",
"\n",
" }\n",
" if (i && (i%kUPDATE) == 0) {\n",
" if (i == kUPDATE) hpx->Draw();\n",
" c1->Modified();\n",
" c1->Update();\n",
" if (gSystem->ProcessEvents())\n",
" break;\n",
" }\n",
" t->Fill();\n",
" }\n",
" f->Write();\n",
"\n",
" delete f;\n",
"}"
]
},
{
"cell_type": "markdown",
"id": "5435e8f0",
"metadata": {},
"source": [
" Definition of a helper function: "
]
},
{
"cell_type": "code",
"execution_count": 2,
"id": "63e00070",
"metadata": {
"collapsed": false,
"execution": {
"iopub.execute_input": "2024-03-19T19:21:41.752716Z",
"iopub.status.busy": "2024-03-19T19:21:41.752340Z",
"iopub.status.idle": "2024-03-19T19:21:41.822753Z",
"shell.execute_reply": "2024-03-19T19:21:41.819464Z"
}
},
"outputs": [],
"source": [
"%%cpp -d\n",
"void read()\n",
"{\n",
"\n",
" TFile *f = TFile::Open(\"hvector.root\",\"READ\");\n",
"\n",
" if (!f) { return; }\n",
"\n",
" TTree *t; f->GetObject(\"tvec\",t);\n",
"\n",
" std::vector *vpx = nullptr;\n",
"\n",
" // Create a new canvas.\n",
" TCanvas *c1 = new TCanvas(\"c1\",\"Dynamic Filling Example\",200,10,700,500);\n",
"\n",
" const Int_t kUPDATE = 1000;\n",
"\n",
" TBranch *bvpx = nullptr;\n",
" t->SetBranchAddress(\"vpx\",&vpx,&bvpx);\n",
"\n",
"\n",
" // Create one histograms\n",
" TH1F *h = new TH1F(\"h\",\"This is the px distribution\",100,-4,4);\n",
" h->SetFillColor(48);\n",
"\n",
" for (Int_t i = 0; i < 25000; i++) {\n",
"\n",
" Long64_t tentry = t->LoadTree(i);\n",
" bvpx->GetEntry(tentry);\n",
"\n",
" for (UInt_t j = 0; j < vpx->size(); ++j) {\n",
"\n",
" h->Fill(vpx->at(j));\n",
"\n",
" }\n",
" if (i && (i%kUPDATE) == 0) {\n",
" if (i == kUPDATE) h->Draw();\n",
" c1->Modified();\n",
" c1->Update();\n",
" if (gSystem->ProcessEvents())\n",
" break;\n",
" }\n",
" }\n",
"\n",
" // Since we passed the address of a local variable we need\n",
" // to remove it.\n",
" t->ResetBranchAddresses();\n",
"}"
]
},
{
"cell_type": "code",
"execution_count": 3,
"id": "eaaaf67b",
"metadata": {
"collapsed": false,
"execution": {
"iopub.execute_input": "2024-03-19T19:21:41.843929Z",
"iopub.status.busy": "2024-03-19T19:21:41.843544Z",
"iopub.status.idle": "2024-03-19T19:21:44.636908Z",
"shell.execute_reply": "2024-03-19T19:21:44.629077Z"
}
},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
""
]
},
"metadata": {},
"output_type": "display_data"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"hvector : Real Time = 0.97 seconds Cpu Time = 0.81 seconds\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"Warning in : Deleting canvas with same name: c1\n"
]
}
],
"source": [
"gBenchmark->Start(\"hvector\");\n",
"\n",
"write();\n",
"read();\n",
"\n",
"gBenchmark->Show(\"hvector\");"
]
},
{
"cell_type": "markdown",
"id": "18400274",
"metadata": {},
"source": [
"Draw all canvases "
]
},
{
"cell_type": "code",
"execution_count": 4,
"id": "fd20d7d3",
"metadata": {
"collapsed": false,
"execution": {
"iopub.execute_input": "2024-03-19T19:21:44.645958Z",
"iopub.status.busy": "2024-03-19T19:21:44.645577Z",
"iopub.status.idle": "2024-03-19T19:21:44.887714Z",
"shell.execute_reply": "2024-03-19T19:21:44.886336Z"
}
},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
""
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"gROOT->GetListOfCanvases()->Draw()"
]
}
],
"metadata": {
"kernelspec": {
"display_name": "ROOT C++",
"language": "c++",
"name": "root"
},
"language_info": {
"codemirror_mode": "text/x-c++src",
"file_extension": ".C",
"mimetype": " text/x-c++src",
"name": "c++"
}
},
"nbformat": 4,
"nbformat_minor": 5
}