Skip to content

Commit

Permalink
Merge branch 'main' into normal-imprv-only
Browse files Browse the repository at this point in the history
  • Loading branch information
kodiakhq[bot] authored Sep 25, 2023
2 parents ca1f7bd + 86033d0 commit f120883
Show file tree
Hide file tree
Showing 20 changed files with 181 additions and 135 deletions.
8 changes: 4 additions & 4 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ build_exatrkx:
-DACTS_EXATRKX_ENABLE_ONNX=ON
-DACTS_BUILD_EXAMPLES_PYTHON_BINDINGS=ON
-DACTS_ENABLE_LOG_FAILURE_THRESHOLD=ON
- cmake --build build -- -j$(nproc)
- cmake --build build -- -j3

test_exatrkx_unittests:
stage: test
Expand Down Expand Up @@ -179,7 +179,7 @@ build_linux_ubuntu:
-DACTS_BUILD_PLUGIN_ACTSVG=ON
- ccache -z
- cmake --build build -- -j$(nproc)
- cmake --build build -- -j3
- ccache -s

linux_test_examples:
Expand Down Expand Up @@ -290,7 +290,7 @@ linux_physmon:
-DACTS_BUILD_PLUGIN_ACTSVG=ON
- ccache -z
- cmake --build build -- -j$(nproc)
- cmake --build build -- -j3
- ccache -s

- ctest --test-dir build -j$(nproc)
Expand Down Expand Up @@ -407,7 +407,7 @@ linux_ubuntu_2204_clang:
-DACTS_BUILD_PLUGIN_ACTSVG=ON
- ccache -z
- cmake --build build -- -j$(nproc)
- cmake --build build -- -j3
- ccache -s

- ctest --test-dir build -j$(nproc)
Expand Down
Binary file modified CI/physmon/reference/performance_gsf.root
Binary file not shown.
3 changes: 3 additions & 0 deletions Core/include/Acts/Detector/MultiWireStructureBuilder.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ class MultiWireStructureBuilder {
/// The surfaces of the Multi Wire
std::vector<std::shared_ptr<Acts::Surface>> mlSurfaces = {};

/// The transform of the Multi Wire
Transform3 transform = Transform3::Identity();

/// The bounds of the multi-wire volume
std::vector<ActsScalar> mlBounds = {};

Expand Down
2 changes: 1 addition & 1 deletion Core/include/Acts/EventData/ParticleHypothesis.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ class SinglyChargedParticleHypothesis
return SinglyChargedParticleHypothesis(PdgParticle::ePionPlus);
}
static SinglyChargedParticleHypothesis electron() {
return SinglyChargedParticleHypothesis(PdgParticle::ePionPlus);
return SinglyChargedParticleHypothesis(PdgParticle::eElectron);
}

static SinglyChargedParticleHypothesis chargedGeantino() {
Expand Down
11 changes: 8 additions & 3 deletions Core/include/Acts/Vertexing/AdaptiveMultiVertexFitter.ipp
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,11 @@ Acts::Result<void> Acts::
const VertexingOptions<input_track_t>& vertexingOptions) const {
for (auto vtx : state.vertexCollection) {
VertexInfo<input_track_t>& currentVtxInfo = state.vtxInfoMap[vtx];

const std::shared_ptr<PerigeeSurface> vtxPerigeeSurface =
Surface::makeShared<PerigeeSurface>(
VectorHelpers::position(state.vtxInfoMap[vtx].oldPosition));

for (const auto& trk : currentVtxInfo.trackLinks) {
auto& trkAtVtx = state.tracksAtVerticesMap.at(std::make_pair(trk, vtx));

Expand All @@ -270,9 +275,9 @@ Acts::Result<void> Acts::
// Check if linearization state exists or need to be relinearized
if (not trkAtVtx.isLinearized || state.vtxInfoMap[vtx].relinearize) {
auto result = linearizer.linearizeTrack(
m_extractParameters(*trk), state.vtxInfoMap[vtx].oldPosition,
vertexingOptions.geoContext, vertexingOptions.magFieldContext,
state.linearizerState);
m_extractParameters(*trk), state.vtxInfoMap[vtx].oldPosition[3],
*vtxPerigeeSurface, vertexingOptions.geoContext,
vertexingOptions.magFieldContext, state.linearizerState);
if (!result.ok()) {
return result.error();
}
Expand Down
11 changes: 9 additions & 2 deletions Core/include/Acts/Vertexing/FullBilloirVertexFitter.ipp
Original file line number Diff line number Diff line change
Expand Up @@ -101,15 +101,22 @@ Acts::FullBilloirVertexFitter<input_track_t, linearizer_t>::fit(
double newChi2 = 0;
BilloirVertex billoirVertex;

Vector3 linPointPos = VectorHelpers::position(linPoint);
// Make Perigee surface at linPointPos, transverse plane of Perigee
// corresponds the global x-y plane
const std::shared_ptr<PerigeeSurface> perigeeSurface =
Surface::makeShared<PerigeeSurface>(linPointPos);

// iterate over all tracks
for (std::size_t iTrack = 0; iTrack < nTracks; ++iTrack) {
const input_track_t* trackContainer = paramVector[iTrack];

const auto& trackParams = extractParameters(*trackContainer);

auto result = linearizer.linearizeTrack(
trackParams, linPoint, vertexingOptions.geoContext,
vertexingOptions.magFieldContext, state.linearizerState);
trackParams, linPoint[3], *perigeeSurface,
vertexingOptions.geoContext, vertexingOptions.magFieldContext,
state.linearizerState);
if (!result.ok()) {
return result.error();
}
Expand Down
6 changes: 4 additions & 2 deletions Core/include/Acts/Vertexing/HelicalTrackLinearizer.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -100,16 +100,18 @@ class HelicalTrackLinearizer {
/// the PCA to a given Perigee surface
///
/// @param params Parameters to linearize
/// @param linPoint Point which defines the Perigee.
/// @param linPointTime Time associated to the linearization point
/// @note Transverse plane of the Perigee corresponding to @p linPoint is
/// parallel to the global x-y plane
/// @param perigeeSurface Perigee surface belonging to @p linPoint
/// @param gctx Geometry context
/// @param mctx Magnetic field context
/// @param state Linearizer state object
///
/// @return Linearized track
Result<LinearizedTrack> linearizeTrack(const BoundTrackParameters& params,
const Vector4& linPoint,
double linPointTime,
const Surface& perigeeSurface,
const Acts::GeometryContext& gctx,
const Acts::MagneticFieldContext& mctx,
State& state) const;
Expand Down
28 changes: 13 additions & 15 deletions Core/include/Acts/Vertexing/HelicalTrackLinearizer.ipp
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,9 @@
template <typename propagator_t, typename propagator_options_t>
Acts::Result<Acts::LinearizedTrack> Acts::
HelicalTrackLinearizer<propagator_t, propagator_options_t>::linearizeTrack(
const BoundTrackParameters& params, const Vector4& linPoint,
const Acts::GeometryContext& gctx,
const BoundTrackParameters& params, double linPointTime,
const Surface& perigeeSurface, const Acts::GeometryContext& gctx,
const Acts::MagneticFieldContext& mctx, State& state) const {
// Make Perigee surface at linPointPos, transverse plane of Perigee
// corresponds the global x-y plane
Vector3 linPointPos = VectorHelpers::position(linPoint);
const std::shared_ptr<PerigeeSurface> perigeeSurface =
Surface::makeShared<PerigeeSurface>(linPointPos);

// Create propagator options
propagator_options_t pOptions(gctx, mctx);

Expand All @@ -34,7 +28,7 @@ Acts::Result<Acts::LinearizedTrack> Acts::
// forward or backward to arrive at the PCA.
auto intersection =
perigeeSurface
->intersect(gctx, params.position(gctx), params.direction(), false)
.intersect(gctx, params.position(gctx), params.direction(), false)
.closest();

// Setting the propagation direction using the intersection length from
Expand All @@ -44,14 +38,14 @@ Acts::Result<Acts::LinearizedTrack> Acts::
pOptions.direction =
Direction::fromScalarZeroAsPositive(intersection.pathLength());

// Propagate to the PCA of linPointPos
auto result = m_cfg.propagator->propagate(params, *perigeeSurface, pOptions);
// Propagate to the PCA of the reference point
auto result = m_cfg.propagator->propagate(params, perigeeSurface, pOptions);
if (not result.ok()) {
return result.error();
}

// Extracting the track parameters at said PCA - this corresponds to the
// Perigee representation of the track wrt linPointPos
// Perigee representation of the track wrt the reference point
const auto& endParams = *result->endParameters;
BoundVector paramsAtPCA = endParams.parameters();

Expand Down Expand Up @@ -143,10 +137,10 @@ Acts::Result<Acts::LinearizedTrack> Acts::
ActsScalar h = (rho < 0.) ? -1 : 1;

// Quantities from Eq. 5.34 in Ref. (1) (see .hpp)
ActsScalar X = pca(0) - linPointPos.x() + rho * sinPhi;
ActsScalar Y = pca(1) - linPointPos.y() - rho * cosPhi;
ActsScalar X = pca(0) - perigeeSurface.center(gctx).x() + rho * sinPhi;
ActsScalar Y = pca(1) - perigeeSurface.center(gctx).y() - rho * cosPhi;
ActsScalar S2 = (X * X + Y * Y);
// S is the 2D distance from the helix center to linPointPos
// S is the 2D distance from the helix center to the reference point
// in the x-y plane
ActsScalar S = std::sqrt(S2);

Expand Down Expand Up @@ -204,6 +198,10 @@ Acts::Result<Acts::LinearizedTrack> Acts::
// The parameter weight
BoundSquareMatrix weightAtPCA = parCovarianceAtPCA.inverse();

Vector4 linPoint;
linPoint.head<3>() = perigeeSurface.center(gctx);
linPoint[3] = linPointTime;

return LinearizedTrack(paramsAtPCA, parCovarianceAtPCA, weightAtPCA, linPoint,
positionJacobian, momentumJacobian, pca, momentumAtPCA,
constTerm);
Expand Down
2 changes: 2 additions & 0 deletions Core/include/Acts/Vertexing/IterativeVertexFinder.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -200,10 +200,12 @@ class IterativeVertexFinder {
///
/// @param params Track parameters
/// @param vertex The vertex
/// @param perigeeSurface The perigee surface at vertex position
/// @param vertexingOptions Vertexing options
/// @param state The state object
Result<double> getCompatibility(
const BoundTrackParameters& params, const Vertex<InputTrack_t>& vertex,
const Surface& perigeeSurface,
const VertexingOptions<InputTrack_t>& vertexingOptions,
State& state) const;

Expand Down
27 changes: 22 additions & 5 deletions Core/include/Acts/Vertexing/IterativeVertexFinder.ipp
Original file line number Diff line number Diff line change
Expand Up @@ -220,12 +220,14 @@ template <typename vfitter_t, typename sfinder_t>
Acts::Result<double>
Acts::IterativeVertexFinder<vfitter_t, sfinder_t>::getCompatibility(
const BoundTrackParameters& params, const Vertex<InputTrack_t>& vertex,
const Surface& perigeeSurface,
const VertexingOptions<InputTrack_t>& vertexingOptions,
State& state) const {
// Linearize track
auto result = m_cfg.linearizer.linearizeTrack(
params, vertex.fullPosition(), vertexingOptions.geoContext,
vertexingOptions.magFieldContext, state.linearizerState);
params, vertex.fullPosition()[3], perigeeSurface,
vertexingOptions.geoContext, vertexingOptions.magFieldContext,
state.linearizerState);
if (!result.ok()) {
return result.error();
}
Expand Down Expand Up @@ -301,10 +303,15 @@ Acts::IterativeVertexFinder<vfitter_t, sfinder_t>::removeUsedCompatibleTracks(
// m_cfg.cutOffTrackWeight threshold and are hence outliers
ACTS_DEBUG("Number of outliers: " << perigeesToFit.size());

const std::shared_ptr<PerigeeSurface> myVertexPerigeeSurface =
Surface::makeShared<PerigeeSurface>(
VectorHelpers::position(myVertex.fullPosition()));

for (const auto& myPerigeeToFit : perigeesToFit) {
// calculate chi2 w.r.t. last fitted vertex
auto result = getCompatibility(m_extractParameters(*myPerigeeToFit),
myVertex, vertexingOptions, state);
auto result =
getCompatibility(m_extractParameters(*myPerigeeToFit), myVertex,
*myVertexPerigeeSurface, vertexingOptions, state);

if (!result.ok()) {
return result.error();
Expand Down Expand Up @@ -428,6 +435,10 @@ Acts::IterativeVertexFinder<vfitter_t, sfinder_t>::reassignTracksToNewVertex(
State& state) const {
int numberOfAddedTracks = 0;

const std::shared_ptr<PerigeeSurface> currentVertexPerigeeSurface =
Surface::makeShared<PerigeeSurface>(
VectorHelpers::position(currentVertex.fullPosition()));

// iterate over all vertices and check if tracks need to be reassigned
// to new (current) vertex
for (auto& vertexIt : vertexCollection) {
Expand All @@ -436,6 +447,10 @@ Acts::IterativeVertexFinder<vfitter_t, sfinder_t>::reassignTracksToNewVertex(
auto tracksBegin = tracksAtVertex.begin();
auto tracksEnd = tracksAtVertex.end();

const std::shared_ptr<PerigeeSurface> vertexItPerigeeSurface =
Surface::makeShared<PerigeeSurface>(
VectorHelpers::position(vertexIt.fullPosition()));

for (auto tracksIter = tracksBegin; tracksIter != tracksEnd;) {
// consider only tracks that are not too tightly assigned to other
// vertex
Expand All @@ -449,14 +464,16 @@ Acts::IterativeVertexFinder<vfitter_t, sfinder_t>::reassignTracksToNewVertex(

// compute compatibility
auto resultNew = getCompatibility(trackPerigee, currentVertex,
*currentVertexPerigeeSurface,
vertexingOptions, state);
if (!resultNew.ok()) {
return Result<bool>::failure(resultNew.error());
}
double chi2NewVtx = *resultNew;

auto resultOld =
getCompatibility(trackPerigee, vertexIt, vertexingOptions, state);
getCompatibility(trackPerigee, vertexIt, *vertexItPerigeeSurface,
vertexingOptions, state);
if (!resultOld.ok()) {
return Result<bool>::failure(resultOld.error());
}
Expand Down
5 changes: 3 additions & 2 deletions Core/include/Acts/Vertexing/LinearizerConcept.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -35,11 +35,12 @@ METHOD_TRAIT(linTrack_t, linearizeTrack);

constexpr static bool linTrack_exists = has_method<const S, Result<LinearizedTrack>,
linTrack_t, const BoundTrackParameters&,
const Vector4&,
double,
const Surface&,
const Acts::GeometryContext&,
const Acts::MagneticFieldContext&,
typename S::State&>;

static_assert(linTrack_exists, "linearizeTrack method not found");

constexpr static bool propagator_exists = exists<propagator_t, S>;
Expand Down
6 changes: 4 additions & 2 deletions Core/include/Acts/Vertexing/NumericalTrackLinearizer.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -116,15 +116,17 @@ class NumericalTrackLinearizer {
/// the PCA to a given Perigee surface
///
/// @param params Parameters to linearize
/// @param linPoint Point which defines the Perigee.
/// @param linPointTime Time associated to the linearization point
/// @note Transverse plane of the Perigee corresponding to @p linPoint is
/// parallel to the global x-y plane
/// @param perigeeSurface Perigee surface belonging to @p linPoint
/// @param gctx Geometry context
/// @param mctx Magnetic field context
///
/// @return Linearized track
Result<LinearizedTrack> linearizeTrack(const BoundTrackParameters& params,
const Vector4& linPoint,
double linPointTime,
const Surface& perigeeSurface,
const Acts::GeometryContext& gctx,
const Acts::MagneticFieldContext& mctx,
State& /*state*/) const;
Expand Down
Loading

0 comments on commit f120883

Please sign in to comment.