Deprecated: Array and string offset access syntax with curly braces is deprecated in /mnt/hep_web/hep_web/member/n-kota/dokuwiki/inc/init.php on line 542
ja:root:ttree [GiriWiki]

ユーザ用ツール

サイト用ツール


ja:root:ttree

差分

この文書の現在のバージョンと選択したバージョンの差分を表示します。

この比較画面にリンクする

両方とも前のリビジョン 前のリビジョン
次のリビジョン
前のリビジョン
ja:root:ttree [2015/04/01 07:09]
kota
ja:root:ttree [2017/08/19 09:27] (現在)
kota [読み込むBranchを限定する]
ライン 6: ライン 6:
  
 === 方法1 --- SetBranchStatus ​ === === 方法1 --- SetBranchStatus ​ ===
-デフォルトではGetEntryすると、SetBranchAddressで指定されていないBranchまでも読みにいく(らし。 +デフォルトではGetEntryすると、SetBranchAddressで指定されていないBranchまでも読みにいく。\\ 
-treeに多数のBranchが入っていて、その一部だけを使う場合、これは非常に無駄になる+うかすべてのbranchのデータをメモリに乗せるが、SetBranchAddressすると 
 +そのbranchに対応するメモリのポインタが指定した変数に割り当てられる 
 + 
 +treeに多数のBranchが入っていて、その一部だけを使う場合、毎回全branchをメモリ乗せるのは無駄。
 Branchを読み込む・読み込まないを指定するメソッドが、SetBranchStatus である。 Branchを読み込む・読み込まないを指定するメソッドが、SetBranchStatus である。
  
ライン 16: ライン 19:
 </​code>​ </​code>​
  
-このとき、先に0番目のEntryをGetEntryしてやらなければならないらしい。http://​root.cern.ch/​root/​roottalk/​roottalk03/​4900.html+このとき、先にGetEntryを呼んでやらなくてはならないらしい。http://​root.cern.ch/​root/​roottalk/​roottalk03/​4900.html 
 +(GetEntryの前にSetBranchAddressを呼んでやっておく必要があるっぽい)
  
-理由は不明+理由はあまりよくわからない
 具体的には以下のようにする。 具体的には以下のようにする。
 <code c_mac> <code c_mac>
ライン 38: ライン 42:
  
 === 方法2 --- TBranch::​GetEntry=== === 方法2 --- TBranch::​GetEntry===
 +TBranch のGetEntryを用いることで、Branch毎に読み込むことができる。\\
 +ただし、TChainを用いている時、気をつけなければならないことが1つ。\\
 +TBranch::​GetEntryは、引数として”当該イベントが含まれているTree内でのEntry Number”を取らなくてはならない。\\
 +具体的には次のようにする。
 +<code c>
 +TChain *chain = ...;
 +Long64_t localEntry = chain->​LoadTree(entry);​
 +branch->​GetEntry(localEntry);​
 +</​code>​
  
 +Long64_t TChain::​LoadTree(Long64_t entry)は
 +TChainで結びつけられたTreeの全エントリにつけられた通し番号(entry)を引数にとり、
 +そのentryが含まれるTreeをCurrent Treeとし、
 +Current Tree内でのEntry Numberを返り値とする関数。\\
 +Errorがあると-1~-4の値を返すので、 if( localEntry < 0 ) でError判定ができる。
 +
 +==== 元treeから条件を満たすイベントの、必要なbranchだけを抽出したtreeを作る ====
 +
 +
 +  TTree* TTree::​CopyTree(const char *selection, Option_t *option="",​ Long64_t nentries=kMaxEntries,​ Long64_t firstentry=0)
 +を用いる。
 +さらに
 +  void TTree::​SetBranchStatus (const char *bname, Bool_t status=1, UInt_t *found=0)
 +を用いることで、必要なbranchだけを取り出してくることができる。
 +
 +こんな感じで使う:
 +<code c_mac>
 +  TChain* chain = new TChain("​T"​);//​上の話はTChainでも同じ
 +  chain->​Add(....);​
 +  ​
 +  std::string branchname[] = {"​brA","​br2","​br3",​...};//​抜き出すbranchをリストアップ
 +  const Int_t nBranch = sizeof(branchname)/​sizeof(branchname[0]);​
 +  chain->​SetBranchStatus("​*",​0);//​一旦全てのbranchをdeactiveに
 +  for(Int_t iBranch = 0 ; iBranch < nBranch ; ++iBranch)
 +    chain->​SetBranchStatus(branchname[iBranch].c_str(),​1);//​リストされたbranchだけをactiveにしていく
 +
 +  TFile* ofile = new TFile("​file.root","​RECREATE"​);​
 +  TTree* newtree = chain->​CopyTree("​(SelectBit&​0x4)>​0"​);//​ とある変数"​SelectBit"​の0x4 Bitが立っていることを要求
 +
 +  ofile->​cd();​
 +  newtree->​Write();​
 +  ofile->​Close();​
 +</​code>​
ja/root/ttree.1427872170.txt.gz · 最終更新: 2015/04/01 07:09 by kota