Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Synching ALERT fork with main branch #378

Closed
wants to merge 105 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
105 commits
Select commit Hold shift + click to select a range
87011e4
Changed the data bank to process the hits in AHDCEngine:
efuchey Feb 16, 2024
3863e74
Merge branch 'JeffersonLab:development' into development
efuchey Feb 22, 2024
10559cd
reversed the change in AHDCEngine.
efuchey Feb 29, 2024
8ac4238
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Mar 1, 2024
e9377c4
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Mar 18, 2024
81b637e
Merge branch 'JeffersonLab:development' into development
efuchey Apr 12, 2024
4046143
Merge branch 'JeffersonLab:development' into development
efuchey Apr 22, 2024
08cd675
Reverted (again???) the hit type to be read in AHDC reconstruction fr…
efuchey Apr 22, 2024
10f0972
changed AHDC bank back to ADC only
mpaolone Apr 23, 2024
acde32e
Merge branch 'JeffersonLab:development' into development
efuchey May 14, 2024
9440e21
remove redundant checks
baltzell May 22, 2024
c95e068
remove unused objects
baltzell May 22, 2024
11d6954
cleanup
baltzell May 22, 2024
3420bb9
leave internal indexing at zero, output at 1
baltzell May 22, 2024
d6fd779
cleanup
baltzell May 22, 2024
46e33d0
remove redundant checks
baltzell May 22, 2024
268c239
leave internal indexing from zero, output from 1
baltzell May 22, 2024
4a9647f
simplicy logic
baltzell May 22, 2024
481795d
use s/l/c/o indexing starting from 1
baltzell May 23, 2024
04571a1
Merge pull request #1 from JeffersonLab/iss272-alert-indexing
mpaolone Jun 3, 2024
082ae77
merge post Nathan's indexing update
mpaolone Jun 4, 2024
f137c4f
Merge branch 'JeffersonLab:development' into development
efuchey Jun 14, 2024
7c6593a
Merge branch 'JeffersonLab:development' into development
efuchey Jun 17, 2024
f10c09e
Merge pull request #1 from mpaolone/development
efuchey Jun 18, 2024
2e86a66
fixed a merge error that slipped through the cracks.
efuchey Jun 18, 2024
7514d48
Merge branch 'JeffersonLab:development' into development
efuchey Jul 1, 2024
5ae48d4
Merge pull request #2 from efuchey/development
mpaolone Jul 2, 2024
85dbe45
Modified the reference layer index for the "OtherCluster" in the
efuchey Jul 9, 2024
e14c464
Modified the hardcoded lookup superlayer/layer indices to fill the pe…
efuchey Jul 9, 2024
4b3603b
Merge pull request #4 from efuchey/development
mpaolone Jul 9, 2024
06b8f90
Declared upfront the hardcoded variables for cluster z calculation in…
efuchey Jul 17, 2024
dad3cdd
Merge branch 'JeffersonLab:development' into development
efuchey Aug 19, 2024
230b1b1
Added printouts to debug kalman filter.
efuchey Sep 16, 2024
c8eeecf
Merge branch 'JeffersonLab:development' into development
efuchey Sep 16, 2024
5e4020e
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Sep 16, 2024
66afda9
Merge pull request #2 from mpaolone/development
efuchey Sep 17, 2024
62544e7
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Sep 17, 2024
abbb742
Revert "Merge branch 'development' of github.com:efuchey/coatjava int…
efuchey Sep 17, 2024
c9f73b0
Reapply "Merge branch 'development' of github.com:efuchey/coatjava in…
efuchey Sep 17, 2024
8a5ba10
Adjusted the AHDC gas parameters in alert KalmanFilter.java
efuchey Sep 17, 2024
e0559c1
Merge branch 'JeffersonLab:development' into development
efuchey Sep 18, 2024
fa4bd27
Merge branch 'JeffersonLab:development' into development
efuchey Oct 7, 2024
09cad74
Completed commit 3420bb9 by modifying output index of atof paddle sta…
efuchey Oct 7, 2024
fa23226
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Oct 7, 2024
906f0b4
Merge pull request #5 from efuchey/development
mpaolone Oct 8, 2024
a8e69c4
Added comments about units quantities.
efuchey Oct 8, 2024
3c1234c
Merge branch 'JeffersonLab:development' into development
efuchey Oct 8, 2024
e3486e4
Merge pull request #3 from mpaolone/development
efuchey Oct 8, 2024
130ad45
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Oct 8, 2024
d32a3b7
Merge branch 'JeffersonLab:development' into development
efuchey Oct 10, 2024
2b39ea9
export BMT waveform
baltzell Oct 21, 2024
fb5a235
cleanup
baltzell Oct 21, 2024
f8226e5
Fixed the calculation of the hit wire position in Hit/Hit.java and Ka…
efuchey Oct 21, 2024
ebea531
add NamedEntry
baltzell Oct 21, 2024
71d5584
Apparently, changing the wire indexing was not desirable, at least fo…
efuchey Oct 21, 2024
b2eff24
refactor
baltzell Oct 21, 2024
c4359cb
add bank link
baltzell Oct 21, 2024
27a4c21
refactor
baltzell Oct 21, 2024
d1e0e95
preserve index
baltzell Oct 24, 2024
89d0175
tested, cleaned up
baltzell Oct 24, 2024
05b2108
cleanup, add a mode-7
baltzell Oct 24, 2024
39a126e
docs, examples
baltzell Oct 24, 2024
4687e8c
Verified and updated the calculations of the wire ends positions.
efuchey Oct 28, 2024
be8c645
Merge branch 'JeffersonLab:development' into development
mpaolone Oct 28, 2024
bcb34f1
Merge pull request #6 from JeffersonLab/baltzell-wf
mpaolone Oct 28, 2024
2b4f081
Fixed B field direction in Kalman filter (anywhere else that it's wro…
efuchey Oct 28, 2024
2d513b9
Implementation of a new mode of extraction
Nov 6, 2024
65395cb
Update time calculations in ModeAHDC.java
Nov 8, 2024
544216d
Merge pull request #1 from ftouchte/test/extractor
ftouchte Nov 8, 2024
5f6d07c
Reduce indentation
Nov 18, 2024
cd0ba16
Merge pull request #21 from ftouchte/development
mpaolone Nov 25, 2024
4dd148f
* Fixed the magnetic field direction and the calculation of the wire …
efuchey Dec 2, 2024
9c7d06d
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Dec 2, 2024
4143a25
Added additional functions called "getMeasurementNoise_simple", "getV…
efuchey Dec 3, 2024
7fe0c41
Merge pull request #4 from mpaolone/development
efuchey Dec 3, 2024
f379279
Merge branch 'development' of github.com:efuchey/coatjava into develo…
efuchey Dec 3, 2024
5dd9fe4
Duplicated the measurement matrices functions: one in cylindrical sys…
efuchey Dec 9, 2024
0723c15
For pull request only: commented out the line in AHDCEngine that gath…
efuchey Dec 9, 2024
506e888
Merge pull request #22 from efuchey/development
mpaolone Dec 9, 2024
9abc31a
Merge branch 'development' into development
baltzell Dec 10, 2024
3867efe
fix bad merge conflict
baltzell Dec 10, 2024
baf1185
Updated atof geometry. The index for sector/layer/component matches t…
N-Plx Dec 11, 2024
8a16989
Merge pull request #389 from JeffersonLab/387-update-atof-geometry-se…
N-Plx Dec 11, 2024
a25a4d1
Merge pull request #23 from baltzell/development
mpaolone Dec 12, 2024
5636a1a
changed ModeAHDC to be dumber and threadsafe, changed PreClusterFinde…
mpaolone Dec 12, 2024
d6adcd8
AHDC::wf must be defined
baltzell Dec 13, 2024
0bd4108
actually use the new ahdc pulse extractor
baltzell Dec 13, 2024
48eaa66
Merge pull request #24 from baltzell/development
mpaolone Dec 16, 2024
3521313
Add AI for ALERT trackfinding
Dec 16, 2024
eb503d3
build(deps): bump org.apache.commons:commons-text from 1.12.0 to 1.13.0
dependabot[bot] Dec 16, 2024
bd001db
Revert "leave internal indexing at zero, output at 1"
baltzell Dec 16, 2024
212f2bf
ci: test with latest `groovy` version (#394)
c-dilks Dec 17, 2024
e2acd07
Merge pull request #26 from baltzell/development
mpaolone Dec 18, 2024
88b1dd8
Merge pull request #25 from mathieuouillon/AI_for_ALERT
mpaolone Dec 18, 2024
128282c
added new AI-assisted networks for Spring28
raffaelladevita Dec 19, 2024
d6204d2
bg-merger: using true order to inialize DetectorDescriptor
raffaelladevita Nov 6, 2024
f117001
one more switch between labbeledOrder and true order
raffaelladevita Nov 7, 2024
f155c51
moved bg engine functionality to reuse bg events to common tools
raffaelladevita Nov 7, 2024
86dc443
added functionality to merge multiple bg events
raffaelladevita Nov 8, 2024
da9f4d8
added functionality to merge background for individual DC regions, pl…
raffaelladevita Nov 14, 2024
f770076
bug fixes
raffaelladevita Dec 6, 2024
3896b8f
changed bg-merger default for detector list to be ALL
raffaelladevita Dec 16, 2024
9fb1b2e
simple truth efficiency calculator (#396)
baltzell Jan 2, 2025
639cb66
Merge branch 'big_merge' into dumb_merge
Jan 2, 2025
c251ca3
Better names for constant fraction variables
Jan 2, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/maven.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ defaults:
env:
java_version: 17
java_distribution: zulu
groovy_version: 4.0.3
groovy_version: 4.x

jobs:

Expand Down
10 changes: 10 additions & 0 deletions bin/trutheff
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/bin/bash

. `dirname $0`/../libexec/env.sh

export MALLOC_ARENA_MAX=1

java -Xmx1536m -Xms1024m -XX:+UseSerialGC \
-cp "$CLAS12DIR/lib/clas/*:$CLAS12DIR/lib/services/*:$CLAS12DIR/lib/utils/*" \
org.jlab.analysis.efficiency.Truth \
$*
2 changes: 1 addition & 1 deletion common-tools/clara-io/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-text</artifactId>
<version>1.12.0</version>
<version>1.13.0</version>
</dependency>

</dependencies>
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,183 @@
package org.jlab.analysis.efficiency;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.TreeMap;
import org.jlab.jnp.hipo4.data.Bank;
import org.jlab.jnp.hipo4.data.Event;
import org.jlab.jnp.hipo4.data.Schema;
import org.jlab.jnp.hipo4.data.SchemaFactory;
import org.jlab.jnp.hipo4.io.HipoReader;
import org.jlab.jnp.utils.json.JsonArray;
import org.jlab.jnp.utils.json.JsonObject;
import org.jlab.utils.options.OptionParser;

/**
* Efficiency matrix calculator based solely on the MC::GenMatch truth-matching
* bank (which is purely hit-based), and a pid assignment match in MC::Particle
* and REC::Particle.
*
* @author baltzell
*/
public class Truth {

static final int UDF = 0;
static final List<Integer> NEGATIVES = Arrays.asList(11, -211, -321, -2212);
static final List<Integer> POSITIVES = Arrays.asList(-11, 211, 321, 2212, 45);
static final List<Integer> NEUTRALS = Arrays.asList(22, 2112);

List<Integer> validPids;
Schema mcGenMatch;
Schema mcParticle;
Schema recParticle;
long[][] recTallies;
long[] mcTallies;

public static void main(String[] args) {
OptionParser o = new OptionParser("trutheff");
o.setRequiresInputList(true);
o.parse(args);
Truth t = new Truth(o.getInputList().get(0));
t.add(o.getInputList());
System.out.println(t.toTable());
System.out.println(t.toJson());
}

public Truth(SchemaFactory s) {
init(s);
}

public Truth(HipoReader r) {
init(r.getSchemaFactory());
}

public Truth(String filename) {
HipoReader r = new HipoReader();
r.open(filename);
init(r.getSchemaFactory());
}

private void init(SchemaFactory schema) {
validPids = new ArrayList(NEGATIVES);
validPids.addAll(POSITIVES);
validPids.addAll(NEUTRALS);
validPids.add(UDF);
mcTallies = new long[validPids.size()];
recTallies = new long[validPids.size()][validPids.size()];
mcGenMatch = schema.getSchema("MC::GenMatch");
mcParticle = schema.getSchema("MC::Particle");
recParticle = schema.getSchema("REC::Particle");
}

/**
* Get one element of the efficiency matrix.
* @param truth true PID
* @param rec reconstructed PID
* @return probability
*/
public float get(int truth, int rec) {
long sum = mcTallies[validPids.indexOf(truth)];
return sum>0 ? ((float)recTallies[validPids.indexOf(truth)][validPids.indexOf(rec)])/sum : 0;
}

/**
* Add an event in the form of truth and reconstructed particle species.
* @param truth truth PID
* @param rec reconstructed PID
*/
public synchronized void add(int truth, int rec) {
final int t = validPids.indexOf(truth);
if (t < 0) return;
final int r = validPids.indexOf(rec);
mcTallies[t]++;
if (r < 0) recTallies[t][UDF]++;
else recTallies[t][r]++;
}

/**
* Add a HIPO event.
* @param e
*/
public void add(Event e) {
Bank bm = new Bank(mcParticle);
Bank br = new Bank(recParticle);
e.read(bm);
e.read(br);
TreeMap<Short,Short> good = getMapping(e);
for (short row=0; row<bm.getRows(); ++row) {
if (!good.containsKey(row)) add(bm.getInt("pid",row), UDF);
else add(bm.getInt("pid",row), br.getInt("pid",good.get(row)));
}
}

/**
* Add input HIPO files by path.
* @param filenames
*/
public void add(List<String> filenames) {
Event e = new Event();
for (String f : filenames) {
HipoReader r = new HipoReader();
r.open(f);
while (r.hasNext()) {
r.nextEvent(e);
add(e);
}
}
}

/**
* Truth-matching banks contain pointers to MC::Particle and REC::Particle,
* and here we cache that mapping to avoid nested loops.
*/
private TreeMap getMapping(Event e) {
Bank b = new Bank(mcGenMatch);
e.read(b);
TreeMap<Short,Short> m = new TreeMap<>();
for (int row=0; row<b.getRows(); ++row)
m.put(b.getShort("mcindex", row), b.getShort("pindex",row));
return m;
}

/**
* Get efficiencies as a human-readable table.
* @return
*/
public String toTable() {
StringBuilder s = new StringBuilder();
s.append(" ");
for (int i=0; i<validPids.size(); ++i) {
s.append(String.format("%7d",validPids.get(i)));
if (validPids.size()==i+1) s.append("\n");
}
for (int i=0; i<validPids.size(); ++i) {
s.append(String.format("%6d",validPids.get(i)));
for (int j=0; j<validPids.size(); ++j) {
s.append(String.format("%7.4f",get(validPids.get(i),validPids.get(j))));
if (validPids.size()==j+1) s.append("\n");
}
}
return s.toString();
}

/**
* Get efficiencies as a JSON object.
* @return
*/
public JsonObject toJson() {
JsonObject effs = new JsonObject();
JsonArray pids = new JsonArray();
for (int i=0; i<validPids.size(); ++i) {
pids.add(validPids.get(i));
JsonArray a = new JsonArray();
for (int j=0; j<validPids.size(); ++j)
a.add(get(validPids.get(i),validPids.get(j)));
effs.add(Integer.toString(validPids.get(i)),a);
}
JsonObject ret = new JsonObject();
ret.add("pids", pids);
ret.add("effs", effs);
return ret;
}
}
Loading
Loading