src/loaders/jsroot-event-loader.ts
PhoenixLoader for processing and loading an event from ".root".
Properties |
|
Methods |
|
constructor(rootFileURL: string)
|
||||||||
Defined in src/loaders/jsroot-event-loader.ts:11
|
||||||||
Constructor for the JSRoot event loader.
Parameters :
|
Private fileEventData |
Type : any
|
Defined in src/loaders/jsroot-event-loader.ts:9
|
Event data inside the file. |
Private rootFileURL |
Type : any
|
Defined in src/loaders/jsroot-event-loader.ts:11
|
URL of the ".root" file to be processed. |
Protected eventData |
Type : any
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:27
|
Event data processed by the loader. |
Private graphicsLibrary |
Type : ThreeManager
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:23
|
ThreeService to perform three.js related functions. |
Protected labelsObject |
Type : literal type
|
Default value : {}
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:33
|
Object containing event object labels. |
Protected loadingManager |
Type : LoadingManager
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:29
|
Loading manager for loadable resources |
Protected stateManager |
Type : StateManager
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:31
|
Loading manager for loadable resources |
Private ui |
Type : UIManager
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:25
|
UIService to perform UI related functions. |
Public getEventData | ||||||||||||
getEventData(objects: string[], onEventData: (eventData: any) => void)
|
||||||||||||
Defined in src/loaders/jsroot-event-loader.ts:35
|
||||||||||||
Get event data of the given objects (e.g ['tracks;1', 'hits;1']) from the currently loaded ".root" file.
Parameters :
Returns :
void
|
Private getHit | ||||||||
getHit(hit: any)
|
||||||||
Defined in src/loaders/jsroot-event-loader.ts:175
|
||||||||
Process and get the Hit in phoenix format.
Parameters :
Returns :
any
Hit in phoenix format. |
Private getTEveTrack | ||||||||
getTEveTrack(track: any)
|
||||||||
Defined in src/loaders/jsroot-event-loader.ts:145
|
||||||||
Process and get the TEveTrack in phoenix format.
Parameters :
Returns :
any
Track object in the phoenix format. |
Private getTGeoTrack | ||||||||
getTGeoTrack(track: any)
|
||||||||
Defined in src/loaders/jsroot-event-loader.ts:122
|
||||||||
Process and get the TGeoTrack in phoenix format.
Parameters :
Returns :
any
Track object in the phoenix format. |
Private processItemsList | ||||||||
processItemsList(obj: any)
|
||||||||
Defined in src/loaders/jsroot-event-loader.ts:69
|
||||||||
Process the list of items inside the JSROOT files for relevant event data.
Parameters :
Returns :
void
|
Private addCollection | ||||||||||||||||||||||||||||
addCollection(objectCollection: any, collectionName: string, getObject: (object: any,typeName: string) => void, typeName: string, objectGroup: Group, concatonateObjs: boolean)
|
||||||||||||||||||||||||||||
Inherited from
PhoenixLoader
|
||||||||||||||||||||||||||||
Defined in
PhoenixLoader:516
|
||||||||||||||||||||||||||||
Adds to the event display all the objects inside a collection.
Parameters :
Returns :
void
|
Public addLabelToEventObject | ||||||||||||||||
addLabelToEventObject(label: string, collection: string, indexInCollection: number)
|
||||||||||||||||
Inherited from
PhoenixLoader
|
||||||||||||||||
Defined in
PhoenixLoader:733
|
||||||||||||||||
Add label of event object to the labels object.
Parameters :
Returns :
string
A unique label ID string. |
Protected addObjectType | |||||||||||||||||||||||||||||||||||
addObjectType(object: any, getObject: any, typeName: string, concatonateObjs: boolean, cuts?: Cut[], extendEventDataTypeUI?: (typeFolder?: GUI,typeFolderPM?: PhoenixMenuNode) => void)
|
|||||||||||||||||||||||||||||||||||
Inherited from
PhoenixLoader
|
|||||||||||||||||||||||||||||||||||
Defined in
PhoenixLoader:448
|
|||||||||||||||||||||||||||||||||||
Adds to the event display all collections of a given object type.
Parameters :
Returns :
void
|
Public addScaleOptions | ||||||||||||||||
addScaleOptions(configKey: string, configLabel: string, scaleFunction: (value: number) => void)
|
||||||||||||||||
Inherited from
PhoenixLoader
|
||||||||||||||||
Defined in
PhoenixLoader:770
|
||||||||||||||||
Get function to add options to scale event object type by.
Parameters :
Function which adds scale options to Phoenix menu and dat.GUI menu. |
Public buildEventData | ||||||||||||||||||||
buildEventData(eventData: any, graphicsLibrary: ThreeManager, ui: UIManager, infoLogger: InfoLogger)
|
||||||||||||||||||||
Inherited from
PhoenixLoader
|
||||||||||||||||||||
Defined in
PhoenixLoader:51
|
||||||||||||||||||||
Takes an object that represents ONE event and takes care of adding the different objects to the graphics library and the UI controls.
Parameters :
Returns :
void
|
Public getCollection | ||||||||
getCollection(collectionName: string)
|
||||||||
Inherited from
PhoenixLoader
|
||||||||
Defined in
PhoenixLoader:127
|
||||||||
Get the collection with the given collection name from the event data.
Parameters :
Returns :
any
An object containing the collection. |
Public getCollections |
getCollections()
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:103
|
Get list of collections in the event data.
Returns :
string[]
List of all collection names. |
Protected getCompound | |||||||||||||||||||||||||
getCompound(params: any, name: string, objectIsTrack: boolean, objectIsCluster: boolean)
|
|||||||||||||||||||||||||
Inherited from
PhoenixLoader
|
|||||||||||||||||||||||||
Defined in
PhoenixLoader:581
|
|||||||||||||||||||||||||
Process the compound object (e.g. Muon, Electron, Photon) from the given parameters and get it as a group. FIXME. This is currently here and not in PhoenixObjects because we need to handle linked objects.
Parameters :
Returns :
Object3D
Muon group containing Clusters and Tracks. |
Protected getCompoundCluster |
getCompoundCluster(params: any, name: string)
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:571
|
Process the compound object of cluster type (e.g. Photon, ..) from the given parameters and get it as a group.
Returns :
Object3D
|
Protected getCompoundTrack |
getCompoundTrack(params: any, name: string)
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:565
|
Process the compound object of track type (e.g. Muon, Electron, ..) from the given parameters and get it as a group.
Returns :
Object3D
|
getEventMetadata |
getEventMetadata()
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:679
|
Get metadata associated to the event (experiment info, time, run, event...).
Returns :
any[]
Metadata of the event. |
Public getEventsList | ||||||||
getEventsList(eventsData: any)
|
||||||||
Inherited from
PhoenixLoader
|
||||||||
Defined in
PhoenixLoader:87
|
||||||||
Get the list of event names from the event data.
Parameters :
Returns :
string[]
List of event names. |
Public getLabelsObject |
getLabelsObject()
|
Inherited from
PhoenixLoader
|
Defined in
PhoenixLoader:759
|
Get the object containing labels.
Returns :
literal type
The labels object. |
Private getObjectTypeCollections | ||||||||
getObjectTypeCollections(object: any)
|
||||||||
Inherited from
PhoenixLoader
|
||||||||
Defined in
PhoenixLoader:551
|
||||||||
Get collection names of a given object type.
Parameters :
Returns :
string[]
List of collection names of an object type (Tracks, Jets, CaloClusters etc.). |
Protected loadObjectTypes | ||||||||
loadObjectTypes(eventData: any)
|
||||||||
Inherited from
PhoenixLoader
|
||||||||
Defined in
PhoenixLoader:148
|
||||||||
Receives an object containing the data from an event and parses it to reconstruct the different collections of physics objects.
Parameters :
Returns :
void
|
import { PhoenixLoader } from './phoenix-loader';
import { openFile } from 'jsroot';
/**
* PhoenixLoader for processing and loading an event from ".root".
*/
export class JSRootEventLoader extends PhoenixLoader {
/** Event data inside the file. */
private fileEventData: any;
/** URL of the ".root" file to be processed. */
private rootFileURL: any;
/**
* Constructor for the JSRoot event loader.
* @param rootFileURL URL of the ".root" file to be processed.
*/
constructor(rootFileURL: string) {
super();
this.rootFileURL = rootFileURL;
this.fileEventData = {
Hits: {},
Tracks: {},
Jets: {},
CaloClusters: {},
};
}
/**
* Get event data of the given objects (e.g ['tracks;1', 'hits;1'])
* from the currently loaded ".root" file.
* @param objects An array identifying objects inside the ".root" file.
* @param onEventData Callback when event data is extracted and available for use.
*/
public getEventData(
objects: string[],
onEventData: (eventData: any) => void,
) {
openFile(this.rootFileURL).then((file: any) => {
let i = 0;
for (const objectName of objects) {
file.readObject(objectName).then((object: any) => {
i++;
if (object) {
this.processItemsList(object);
}
if (i === objects.length) {
for (const objectType of [
'Hits',
'Tracks',
'Jets',
'CaloClusters',
]) {
if (Object.keys(this.fileEventData[objectType]).length === 0) {
this.fileEventData[objectType] = undefined;
}
}
onEventData(this.fileEventData);
}
});
}
});
}
/**
* Process the list of items inside the JSROOT files for relevant event data.
* @param obj Object containing the event data in the form of JSROOT classes.
*/
private processItemsList(obj: any) {
if (obj._typename === 'TObjArray' || obj._typename === 'TList') {
if (!obj.arr) return;
for (let n = 0; n < obj.arr.length; ++n) {
const sobj = obj.arr[n];
this.processItemsList(sobj);
}
} else if (obj._typename === 'THREE.Mesh') {
// Three.js object - we only want event data
} else if (obj._typename === 'TGeoTrack') {
if (!this.fileEventData.Tracks['TGeoTracks']) {
this.fileEventData.Tracks['TGeoTracks'] = [];
}
const tGeoTrack = this.getTGeoTrack(obj);
if (tGeoTrack) {
this.fileEventData.Tracks['TGeoTracks'].push(tGeoTrack);
}
} else if (
obj._typename === 'TEveTrack' ||
obj._typename === 'ROOT::Experimental::TEveTrack'
) {
if (!this.fileEventData.Tracks[obj._typename + '(s)']) {
this.fileEventData.Tracks[obj._typename + '(s)'] = [];
}
const tEveTrack = this.getTEveTrack(obj);
if (tEveTrack) {
this.fileEventData.Tracks[obj._typename + '(s)'].push(tEveTrack);
}
} else if (
obj._typename === 'TEvePointSet' ||
obj._typename === 'ROOT::Experimental::TEvePointSet' ||
obj._typename === 'TPolyMarker3D'
) {
if (!this.fileEventData.Hits[obj._typename + '(s)']) {
this.fileEventData.Hits[obj._typename + '(s)'] = [];
}
const hit = this.getHit(obj);
if (hit) {
this.fileEventData.Hits[obj._typename + '(s)'].push(hit);
}
} else if (
obj._typename === 'TEveGeoShapeExtract' ||
obj._typename === 'ROOT::Experimental::TEveGeoShapeExtract'
) {
// Some extra shape - we only want event data
}
}
/**
* Process and get the TGeoTrack in phoenix format.
* @param track Track object containing the track information.
* @returns Track object in the phoenix format.
*/
private getTGeoTrack(track: any): any {
if (!track || !track.fNpoints) return false;
const npoints = Math.round(track.fNpoints / 4);
const positions = [];
for (let k = 0; k < npoints - 1; ++k) {
positions.push([
track.fPoints[k * 4],
track.fPoints[k * 4 + 1],
track.fPoints[k * 4 + 2],
]);
}
return {
pos: positions,
};
}
/**
* Process and get the TEveTrack in phoenix format.
* @param track Track object containing the track information.
* @returns Track object in the phoenix format.
*/
private getTEveTrack(track: any): any {
if (!track || track.fN <= 0) return false;
const trackObj: { [key: string]: any } = {};
const positions = [];
for (let i = 0; i < track.fN - 1; i++) {
positions.push([
track.fP[i * 3],
track.fP[i * 3 + 1],
track.fP[i * 3 + 2],
]);
}
for (const trackParamLine of track.fTitle.split('\n')) {
for (const trackParam of trackParamLine.split(/(?!\(.*), (?!.*\))/g)) {
const trackParamData = trackParam.split('=');
trackObj[trackParamData[0]] = trackParamData[1];
}
}
trackObj['pos'] = positions;
return trackObj;
}
/**
* Process and get the Hit in phoenix format.
* @param hit Hit object containing the hit information.
* @returns Hit in phoenix format.
*/
private getHit(hit: any): any {
if (!hit || !hit.fN || hit.fN < 0) return false;
const hitArray = [];
for (let i = 0; i < hit.fN; i += 3) {
hitArray.push([hit.fP[i * 3], hit.fP[i * 3 + 1], hit.fP[i * 3 + 2]]);
}
return hitArray;
}
}