BDSIM
BDSIM is a Geant4 extension toolkit for simulation of particle transport in accelerator beamlines.
Public Member Functions | Protected Member Functions | Private Member Functions
BDSInterpolator2DCubic Class Reference

Cubic interpolation over 2d array. More...

#include <BDSInterpolator2DCubic.hh>

Inheritance diagram for BDSInterpolator2DCubic:
Inheritance graph
Collaboration diagram for BDSInterpolator2DCubic:
Collaboration graph

Public Member Functions

 BDSInterpolator2DCubic (BDSArray2DCoords *arrayIn)
 
- Public Member Functions inherited from BDSInterpolator2D
 BDSInterpolator2D (BDSArray2DCoords *arrayIn)
 
G4ThreeVector GetInterpolatedValue (G4double x, G4double y) const
 Public interface to a 2D interpolator. Returns Geant4 type as that's what will be needed. More...
 
const BDSArray2DCoordsArray () const
 
BDSDimensionType FirstDimension () const
 Accessor for the active dimension this represents (first). More...
 
BDSDimensionType SecondDimension () const
 Accessor for the active dimension this represents (second). More...
 
virtual BDSExtent Extent () const
 Extent of field. More...
 
- Public Member Functions inherited from BDSInterpolator
 BDSInterpolator (BDSArray4DCoords *arrayIn=nullptr)
 
virtual BDSExtent Extent () const =0
 Interface each derived class must provide. More...
 
G4double SmallestSpatialStep () const
 

Protected Member Functions

virtual BDSFieldValue GetInterpolatedValueT (G4double x, G4double y) const
 
virtual BDSFieldValue GetInterpolatedValueT (G4double x, G4double y) const =0
 

Private Member Functions

 BDSInterpolator2DCubic ()=delete
 Private default constructor to force use of provided one.
 

Additional Inherited Members

- Protected Attributes inherited from BDSInterpolator2D
BDSArray2DCoordsarray
 The field data. More...
 
- Protected Attributes inherited from BDSInterpolator
G4double smallestSpatialStep
 

Detailed Description

Cubic interpolation over 2d array.

Does not own array - so multiple interpolators could be used on same data.

This uses a bicubic algorithm to interpolate a 2d array and return the value at any arbitrary point. If the point lies outside the array the default value for the templated parameter is returned (typically 0). Therefore, the field drops to 0 outside the specified region.

Author
Laurie Nevay

Definition at line 42 of file BDSInterpolator2DCubic.hh.

Constructor & Destructor Documentation

◆ BDSInterpolator2DCubic()

BDSInterpolator2DCubic::BDSInterpolator2DCubic ( BDSArray2DCoords arrayIn)
explicit

Definition at line 26 of file BDSInterpolator2DCubic.cc.

◆ ~BDSInterpolator2DCubic()

BDSInterpolator2DCubic::~BDSInterpolator2DCubic ( )
virtual

Definition at line 30 of file BDSInterpolator2DCubic.cc.

Member Function Documentation

◆ GetInterpolatedValueT()

BDSFieldValue BDSInterpolator2DCubic::GetInterpolatedValueT ( G4double  x,
G4double  y 
) const
protectedvirtual

Each derived class should implement this function. Note T suffix (was templated) to distinguish it from GetInterpolatedValue which returns Geant4 types and is the main interface to should have the clean name.

Implements BDSInterpolator2D.

Definition at line 33 of file BDSInterpolator2DCubic.cc.

References BDSInterpolator2D::array, BDS::Cubic2D(), and BDSArray2DCoords::ExtractSection4x4().

Here is the call graph for this function:

The documentation for this class was generated from the following files: