Last change
on this file since 2346 was 552, checked in by ansari, 26 years ago |
namespace changed to SOPHYA cmv 5/11/99
|
File size:
1.6 KB
|
Rev | Line | |
---|
[528] | 1 | // This may look like C code, but it is really -*- C++ -*-
|
---|
| 2 | #ifndef TOD_H_SEEN
|
---|
| 3 | #define TOD_H_SEEN
|
---|
| 4 |
|
---|
| 5 | #include "machdefs.h"
|
---|
| 6 | #include "spherepos.h"
|
---|
| 7 | #include "misstime.h"
|
---|
| 8 |
|
---|
[552] | 9 | namespace SOPHYA {
|
---|
[528] | 10 | template<class T>
|
---|
| 11 | class TOD
|
---|
| 12 | {
|
---|
| 13 | public:
|
---|
| 14 | TOD(SphereCoordSys* cs = NULL)
|
---|
| 15 | { if (cs) cs_ = cs; else cs = new SphereCoordSys; }
|
---|
| 16 | virtual ~TOD()
|
---|
| 17 | { if (cs_) delete cs_; }
|
---|
| 18 |
|
---|
| 19 | // Set/Change/Get the coordinate system
|
---|
| 20 | virtual void SetCoordSys(SphereCoordSys* cs)
|
---|
| 21 | { if (cs) { delete cs_; cs_ = cs; } }
|
---|
| 22 | inline SphereCoordSys* GetCoordSys() const { return(cs_); }
|
---|
| 23 |
|
---|
| 24 | // Return the size / number of sample
|
---|
| 25 | virtual int_8 size() const = 0;
|
---|
| 26 | inline int_8 NbSample() const { return(size()); }
|
---|
| 27 |
|
---|
| 28 | // Start/End time
|
---|
| 29 | virtual MissionTime StartTime();
|
---|
| 30 | virtual MissionTime EndTime();
|
---|
| 31 |
|
---|
| 32 | // Sample time
|
---|
[541] | 33 | virtual const MissionTime& SampleTime(int k) const = 0;
|
---|
| 34 | virtual MissionTime& SampleTime(int k) = 0;
|
---|
[528] | 35 |
|
---|
[541] | 36 | // Time to sample number - return the closest sample to time t
|
---|
| 37 | virtual int_8 IndexFromTime(MissionTime const & t) const = 0;
|
---|
| 38 |
|
---|
[528] | 39 | // Sample value
|
---|
[541] | 40 | virtual const T& SampleValue(int_8 k) const = 0;
|
---|
| 41 | virtual T& SampleValue(int_8 k) = 0;
|
---|
| 42 | virtual const T& ValueAtTime(MissionTime const & t) const
|
---|
| 43 | { return SampleValue(IndexFromTime(t)); }
|
---|
[528] | 44 |
|
---|
| 45 | // Sample direction
|
---|
[541] | 46 | virtual const UnitVector& SamplePointing(int_8 k) const = 0;
|
---|
| 47 | virtual UnitVector& SamplePointing(int_8 k) = 0;
|
---|
| 48 | // Pointing at time t
|
---|
| 49 | virtual const UnitVector& PointingAtTime(MissionTime const & t ) const
|
---|
| 50 | { return SamplePointing(IndexFromTime(t)); }
|
---|
[528] | 51 |
|
---|
| 52 | };
|
---|
| 53 |
|
---|
| 54 | } // Fin du namespace
|
---|
| 55 |
|
---|
| 56 | #endif
|
---|
Note:
See
TracBrowser
for help on using the repository browser.