| 
            Last change
 on this file since 3933 was             3829, checked in by ansari, 15 years ago           | 
        
        
          | 
             
Adaptation programme srcat2cube.cc pour utilisation catalogue North20cm avec indice spectral, Reza 03/08/2010 
 
           | 
        
        
          | 
            File size:
            1.2 KB
           | 
        
      
      
| Line |   | 
|---|
| 1 | #include "radutil.h"
 | 
|---|
| 2 | 
 | 
|---|
| 3 | double H21Conversions::SpeedOfLight_Cst = 2.99792458e8;  // metres/sec
 | 
|---|
| 4 | double H21Conversions::Freq021cm_Cst = 1420.4;  // MHz 
 | 
|---|
| 5 | double H21Conversions::k_Boltzman_Cst = 1.3806503e-23;  // Boltzman constant SI (J K^-1)
 | 
|---|
| 6 | 
 | 
|---|
| 7 | H21Conversions::H21Conversions(double freq, double opix)
 | 
|---|
| 8 | {
 | 
|---|
| 9 |   if (freq<1.e-6)  freq=Freq021cm_Cst;
 | 
|---|
| 10 |   setFrequency(freq);
 | 
|---|
| 11 |   setOmegaPix(opix);
 | 
|---|
| 12 |   setCosmoParam();
 | 
|---|
| 13 | }
 | 
|---|
| 14 | 
 | 
|---|
| 15 | void H21Conversions::setFrequency(double nu)
 | 
|---|
| 16 | {
 | 
|---|
| 17 |   freq_=nu;
 | 
|---|
| 18 |   z_=Freq021cm_Cst/freq_-1.;
 | 
|---|
| 19 |   lambda_=SpeedOfLight_Cst/freq_/1.e6;
 | 
|---|
| 20 | }
 | 
|---|
| 21 | 
 | 
|---|
| 22 | double H21Conversions::toJansky(double temp)
 | 
|---|
| 23 | {
 | 
|---|
| 24 |   return 2.*k_Boltzman_Cst*temp/lambda_/lambda_ * omegapix_ * 1.e26;
 | 
|---|
| 25 | }
 | 
|---|
| 26 | 
 | 
|---|
| 27 | double H21Conversions::toKelvin(double jy)
 | 
|---|
| 28 | {
 | 
|---|
| 29 |   return jy*1e-26 / omegapix_ * lambda_ * lambda_ / 2. / k_Boltzman_Cst ;
 | 
|---|
| 30 | }
 | 
|---|
| 31 | 
 | 
|---|
| 32 | 
 | 
|---|
| 33 | double H21Conversions::setCosmoParam(double omegamatter, double omegabaryon, double h100, double fracHI)
 | 
|---|
| 34 | {
 | 
|---|
| 35 |   OmegaMatter_=omegamatter;
 | 
|---|
| 36 |   OmegaBaryons_=omegabaryon;
 | 
|---|
| 37 |   h100_=h100;
 | 
|---|
| 38 |   fracHI_=fracHI;
 | 
|---|
| 39 |   OmegaLambda_=1.-OmegaMatter_;  // Je neglige OmegaRadiation
 | 
|---|
| 40 |   return OmegaLambda_;
 | 
|---|
| 41 | }
 | 
|---|
| 42 | 
 | 
|---|
| 43 | double H21Conversions::Mean21cmTemperature_mK()
 | 
|---|
| 44 | {
 | 
|---|
| 45 |   double zz = 1.+z_;
 | 
|---|
| 46 |   double cc=zz*zz/sqrt(OmegaMatter_*zz*zz*zz+OmegaLambda_);
 | 
|---|
| 47 |   cc *= ((h100_/0.7)*(OmegaBaryons_/0.04)*(fracHI_/0.1));
 | 
|---|
| 48 |   return (cc*0.57);
 | 
|---|
| 49 | }
 | 
|---|
       
      
  Note:
 See   
TracBrowser
 for help on using the repository browser.