34#ifndef G4FSALINTEGRATIONDRIVER_HH
35#define G4FSALINTEGRATIONDRIVER_HH
48 G4int numberOfComponents = 6,
49 G4int statisticsVerbosity = 1);
133 G4int fNoQuickAvanceCalls{0};
134 G4int fNoAccurateAdvanceCalls{0};
135 G4int fNoAccurateAdvanceBadSteps{0};
136 G4int fNoAccurateAdvanceGoodSteps{0};
142#include "G4FSALIntegrationDriver.icc"
G4int GetVerboseLevel() const override
void StreamInfo(std::ostream &os) const override
void OnComputeStep(const G4FieldTrack *=nullptr) override
G4FSALIntegrationDriver(const G4FSALIntegrationDriver &)=delete
void OnStartTracking() override
G4double GetSmallestFraction() const
~G4FSALIntegrationDriver() override
G4double AdvanceChordLimited(G4FieldTrack &track, G4double hstep, G4double eps, G4double chordDistance) override
G4bool DoesReIntegrate() const override
void SetMinimumStep(G4double newval)
G4double GetMinimumStep() const
void IncrementQuickAdvanceCalls()
G4FSALIntegrationDriver & operator=(const G4FSALIntegrationDriver &)=delete
G4FSALIntegrationDriver(G4double hminimum, T *stepper, G4int numberOfComponents=6, G4int statisticsVerbosity=1)
void OneGoodStep(G4double y[], G4double dydx[], G4double &curveLength, G4double htry, G4double eps, G4double &hdid, G4double &hnext)
void SetSmallestFraction(G4double val)
G4bool QuickAdvance(G4FieldTrack &fieldTrack, const G4double dydx[], G4double hstep, G4double &dchord_step, G4double &dyerr) override
void SetVerboseLevel(G4int newLevel) override
G4bool AccurateAdvance(G4FieldTrack &track, G4double hstep, G4double eps, G4double hinitial=0.0) override