source: Sophya/trunk/SophyaLib/SkyT/specresp.h@ 2381

Last change on this file since 2381 was 2322, checked in by cmv, 23 years ago
  • passage xxstream.h en xxstream
  • compile avec gcc_3.2, gcc_2.96 et cxx En 3.2 le seek from ::end semble marcher (voir Eval/COS/pbseekios.cc)

rz+cmv 11/2/2003

File size: 2.0 KB
RevLine 
[601]1// This may look like C code, but it is really -*- C++ -*-
2//--------------------------------------------------------------------------
3// File and Version Information:
[2322]4// $Id: specresp.h,v 1.5 2003-02-11 15:31:07 cmv Exp $
[601]5//
6// Description:
7//
8// History (add to end):
9// Sophie Oct, 1999 - creation
10//
11//------------------------------------------------------------------------
12#ifndef SPECRESP_H_SEEN
13#define SPECRESP_H_SEEN
14
15#include "machdefs.h"
[668]16#include "anydataobj.h"
[2322]17#include <iostream>
[601]18//------------------------------------
19// Collaborating Class Declarations --
20//------------------------------------
21
22// ---------------------
23// -- Class Interface --
24// ---------------------
25
26// ***IMPORTANT*** All frequencies are expressed in GHz (10^9 Hz)
[668]27namespace SOPHYA {
28
29 class SpectralResponse : public AnyDataObj
30 {
31
32 public:
33 //Constructor
34 SpectralResponse(double numin=0., double numax=1.);
35
36 // destructor
37 virtual ~SpectralResponse();
38
39 //
40 // Member Functions
41 //
42
43 // The transmission() function is virtual:
44 virtual double transmission(double nu) const =0 ;
45
46 inline double operator() (double nu) const { return(transmission(nu)); }
47
48 virtual void Print(ostream& os) const;
49
50 virtual double minFreq() const;
51 virtual double maxFreq() const;
52 virtual double meanFreq() const;
53 virtual double peakFreq() const;
54 virtual double peakTransmission() const;
[601]55
[668]56 // For changing the min/max frequency
57 virtual void setMinMaxFreq(double numin, double numax);
[601]58
[668]59 virtual double IntegratedSpect(double numin, double numax) const ;
60 virtual double logIntegratedSpect(double numin, double numax) const ;
61 virtual double IntegratedSpect() const ;
62 virtual double logIntegratedSpect() const ;
63
64 protected:
65 double _numin;
66 double _numax;
67 };
68
69
70 // definition of the << operator
71 inline ostream& operator << (ostream& s, SpectralResponse const & sr)
72 { sr.Print(s); return(s); }
73
74
75
[831]76}
[601]77
[668]78#endif
[601]79
80
81
82
Note: See TracBrowser for help on using the repository browser.