Geant4 11.4.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4FieldUtils.hh
Go to the documentation of this file.
1// ********************************************************************
2// * License and Disclaimer *
3// * *
4// * The Geant4 software is copyright of the Copyright Holders of *
5// * the Geant4 Collaboration. It is provided under the terms and *
6// * conditions of the Geant4 Software License, included in the file *
7// * LICENSE and available at http://cern.ch/geant4/license . These *
8// * include a list of copyright holders. *
9// * *
10// * Neither the authors of this software system, nor their employing *
11// * institutes,nor the agencies providing financial support for this *
12// * work make any representation or warranty, express or implied, *
13// * regarding this software system or assume any liability for its *
14// * use. Please see the license in the file LICENSE and URL above *
15// * for the full disclaimer and the limitation of liability. *
16// * *
17// * This code implementation is the result of the scientific and *
18// * technical work of the GEANT4 collaboration. *
19// * By using, copying, modifying or distributing the software (or *
20// * any work based on the software) you agree to acknowledge its *
21// * use in resulting scientific publications, and indicate your *
22// * acceptance of all terms of the Geant4 Software license. *
23// ********************************************************************
24//
25// Helper namespace field_utils
26//
27// Description:
28//
29// Simple methods to extract vectors from arrays in conventions of
30// the magnetic field integration.
31
32// Author: Dmitry Sorokin (CERN, Google Summer of Code 2017), 13.10.2017
33// Supervision: John Apostolakis (CERN)
34// --------------------------------------------------------------------
35#ifndef G4FIELD_UTILS_HH
36#define G4FIELD_UTILS_HH
37
38#include "G4FieldTrack.hh"
39#include "G4Types.hh"
40#include "G4ThreeVector.hh"
41
42/**
43 * @brief field_utils is a helper namespace, including simple methods to extract
44 * vectors from arrays in conventions of the magnetic field integration.
45 */
46
47namespace field_utils
48{
50
51 template <unsigned int N>
53
54 enum class Value3D
55 {
58 Spin = 9
59 };
60
61 enum class Value1D
62 {
66 };
67
68 template <typename ArrayType>
69 G4double getValue(const ArrayType& array, Value1D value);
70
71 template <typename ArrayType>
72 G4double getValue2(const ArrayType& array, Value1D value);
73
74 template <typename ArrayType>
75 G4double getValue(const ArrayType& array, Value3D value);
76
77 template <typename ArrayType>
78 G4double getValue2(const ArrayType& array, Value3D value);
79
80 template <typename ArrayType>
81 G4ThreeVector makeVector(const ArrayType& array, Value3D value);
82
84 const G4double y[],
85 const G4double yerr[],
86 G4double hstep);
87
89 const G4double y[],
90 const G4double yerr[],
91 G4double hstep,
92 G4double errorTolerance);
93
95 const G4double y[],
96 const G4double yerr[],
97 G4double hstep,
98 G4double errorTolerance);
99
100 template <typename SourceArray, typename TargetArray>
101 void setValue(const SourceArray& src, Value1D value, TargetArray& trg);
102
103 template <typename SourceArray, typename TargetArray, typename ...TargetArrays>
104 void setValue(const SourceArray& src, Value1D value,
105 TargetArray& trg, TargetArrays&... trgs);
106
107 void copy(G4double dst[], const G4double src[],
108 std::size_t size = G4FieldTrack::ncompSVEC);
109
111 G4double momentum, G4double BField);
112
113 template <typename T>
114 T clamp(T value, T lo, T hi);
115}
116
117#include "G4FieldUtils.icc"
118
119#endif
CLHEP::Hep3Vector G4ThreeVector
double G4double
Definition G4Types.hh:83
#define N
Definition crc32.c:57
field_utils is a helper namespace, including simple methods to extract vectors from arrays in convent...
G4double relativeError(const G4double y[], const G4double yerr[], G4double hstep, G4double errorTolerance)
G4double absoluteError(const G4double y[], const G4double yerr[], G4double hstep)
G4double relativeError2(const G4double y[], const G4double yerr[], G4double hstep, G4double errorTolerance)
G4double inverseCurvatureRadius(G4double particleCharge, G4double momentum, G4double BField)
G4double getValue(const ArrayType &array, Value1D value)
G4ThreeVector makeVector(const ArrayType &array, Value3D value)
G4double[G4FieldTrack::ncompSVEC] State
G4double getValue2(const ArrayType &array, Value1D value)
T clamp(T value, T lo, T hi)
void copy(G4double dst[], const G4double src[], std::size_t size=G4FieldTrack::ncompSVEC)
void setValue(const SourceArray &src, Value1D value, TargetArray &trg)
G4double[N] ShortState