/* * bcal2nt - an simple program for accessing the bcal information * of events stored in a hddm file, and storing them in * a paw ntuple. * * Richard Jones * GlueX collaboration * May 15, 2005 * */ #include #include #include "hddm_s.h" struct bcalnt_struct { int module; int layer; int sector; int nup; float tup[200]; float Eup[200]; int ndown; float tdown[200]; float Edown[200]; } bcalnt; #define BCALNT_FORM "module:i,layer:i,sector:i,nup[0,200]:i,tup(nup):r,Eup(nup):r,ndown[0,200]:i,tdown(ndown):r,Edown(ndown):r" #define PAWC_SIZE 1000000 struct pawc_struct { float iq[PAWC_SIZE]; } pawc_; void hlimit(int size) { void hlimit_(int *words); hlimit_(&size); } void hropen(int lun, char *name, char*filename, char*status, int *lrec, int *istat) { void hropen_(int *,char *,char *,char *,int *,int *,int,int,int); hropen_(&lun, name, filename, status, lrec, istat, strlen(name), strlen(filename), strlen(status)); } void hbnt(int id,char*chtitle,char*chopt) { void hbnt_(int *id ,char* name, char* chmod,int ,int); hbnt_(&id,chtitle,chopt,strlen(chtitle),strlen(chopt)); } void hbname(int id,char*chblok,void*variable,char*chform) { void hbname_(int *id, char* chblok, void*variable, char*chform, int,int); hbname_(&id,chblok,variable,chform,strlen(chblok),strlen(chform)); } void hfnt(int id) { void hfnt_(int*id); hfnt_(&id); } void hrend(char*filename) { void hrend_(char *,int); hrend_(filename, strlen(filename)); return; } void hrout(int num, int icycle, char*opt) { void hrout_(int *,int *,char *,int); hrout_(&num, &icycle, opt, strlen(opt)); } int main(int argc, char **argv) { s_HDDM_t *thisInputEvent = 0; s_iostream_t *thisInputFile = 0; int input; int lrec=1024; int status; int cycle; hlimit(PAWC_SIZE); hropen(50,"RZfile","bcal2nt.hbook","N",&lrec,&status); hbnt(1,"BCal diagnostic ntuple"," "); hbname(1,"bcalnt",&bcalnt,BCALNT_FORM); for (input=1; inputphysicsEvents->in[0].hitView) == HDDM_NULL) { fprintf(stderr,"no hits information in this file, quitting!\n"); exit(1); } if (hits->barrelEMcal != HDDM_NULL) { s_BcalCells_t *cells = hits->barrelEMcal->bcalCells; int cell; int nup, ndown; nup = ndown = 0; for (cell=0; cell < cells->mult; cell++) { s_BcalUpstreamHits_t *hitsup = cells->in[cell].bcalUpstreamHits; s_BcalDownstreamHits_t *hitsdown = cells->in[cell].bcalDownstreamHits; int hit; bcalnt.module = cells->in[cell].module; bcalnt.layer = cells->in[cell].layer; bcalnt.sector = cells->in[cell].sector; for (hit=0; hit < hitsup->mult; hit++,nup++) { bcalnt.tup[nup] = hitsup->in[hit].t; bcalnt.Eup[nup] = hitsup->in[hit].E; } for (hit=0; hit < hitsdown->mult; hit++,ndown++) { bcalnt.tdown[ndown] = hitsdown->in[hit].t; bcalnt.Edown[ndown] = hitsdown->in[hit].E; } bcalnt.nup = nup; bcalnt.ndown = ndown; hfnt(1); } return 1; } else { return 0; } }