File: doppler.i

package info (click to toggle)
yorick-yutils 1.5.2-1.1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 792 kB
  • sloc: makefile: 82; python: 12
file content (131 lines) | stat: -rw-r--r-- 5,603 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
/*
 * doppler.i
 *
 * $Id: doppler.i,v 1.1 2008-01-04 13:47:48 frigaut Exp $
 * 
 * This file is part of Yutils
 * Copyright (C) 2007  Thibaut Paumard <paumard@users.sourceforge.net>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * $Log: doppler.i,v $
 * Revision 1.1  2008-01-04 13:47:48  frigaut
 * initial import of thibaut's functions
 *
 *
 */

extern LightSpeed;
/* DOCUMENT  LightSpeed
     The  velocity of  light in  vacuum and in m/s.
*/
LightSpeed=299792458;

func voflambda(lambda,lambda0,air=,microns=,coef=,vlsr=) {
/* DOCUMENT voflambda(lambda,lambda0)
   
    Attention: ALL velocities, including VLSR, are in m/s (NOT in km/s).

    Returns   radial   velocity   necessary   to   Doppler-shift   lambda0   to
    lambda. Wavelengths  are in vacuum  unless AIR is  set to non void  and non
    null. If AIR is specified, wavelengths  must be in angstroms, or MICRONS or
    COEF must be specified too (see  airvac and vacair). Velocities are in m/s.
    VLSR keyword can be  used to shift the returned value: VLSR  must be set to
    the real velocity  in the local standard of rest of  an object which radial
    velocity relative  to the earth  is zero at  the time of  observations.  In
    that case, VOFLAMBDA  returns velocities in the local  standard of rest. If
    not, it returns velocities relative to the observer.

   SEE ALSO: lambdaofv
*/
    if (is_void(vlsr)) vlsr=0.;
    if (air) {
        lambda=airvac(lambda,microns=microns,coef=coef);
        lambda0=airvac(lambda0,microns=microns,coef=coef);
    }
    lolc2=(lambda/lambda0)^2;
    return LightSpeed*(lolc2-1)/(lolc2+1)+vlsr;
}
func lambdaofv(v,lambda0,air=,microns=,coef=,vlsr=) {
/* DOCUMENT lambdaofv(v,lambda0)
   
    Returns observed  wavelength corresponding to  lambda0 Doppler-shifted with
    velocity v.  Wavelength are in vacuum unless AIR is set to non void and non
    null. If AIR is specified, wavelengths  must be in angstroms, or MICRONS or
    COEF must be specified too (see airvac and vacair). Velocities are in m/s.
    If VLSR keyword is  set to the real velocity in the  local standard of rest
    of an  object which radial  velocity relative to  the earth is zero  at the
    time of observations, V is considered a velocities in the local standard of
    rest and apparent wavelengths at  the time of observations are computed. If
    not, V  should not  be in the  local standard  of rest but  at the  time of
    observations for the return wavelengths to be accurate.

    Example:

    say you have a spectrum of  an object, which velocity in the local standard
    of rest is 0 but at the time of observations, an observed velocity of 0m/s
    would indeed  correspond to  a velocity  in the local  standard of  rest of
    VLSR(m/s).   AXIS contains  the  observed wavelength  in  micron for  this
    spectrum.   Then, lambdaofv(voflambda(AXIS,vlsr=VLSR),vlsr=0)  would return
    the axis, corrected for the earth's  motion. Now, if radial velocity of the
    object in the LSR is not 0,  but Vobj, then the axis corrected for both the
    earth's       and       object's       motions      is       given       by
    lambdaofv(voflambda(AXIS,vlsr=VLSR),vlsr=-Vobj). (Note:  don't trust me, at
    the time I'm writing these lines, I'm quite tired...)

   SEE ALSO: voflambda
*/
    if (is_void(vlsr)) vlsr=0.;
    if (air) lambda0=airvac(lambda0,microns=microns,coef=coef);
    b=(v-vlsr)/LightSpeed;
    lambda=lambda0*sqrt((1+b)/(1-b));
    if (air) lambda=vacair(lambda,microns=microns,coef=coef);
    return lambda;
}

func vacair(VAC,microns=,coef=){
/* DOCUMENT airwl=vacair(vacwl)
    Compute air wavelength from vacuum wavelength in Angstroms.
    Information found in;
    http://www-obs.univ-lyon1.fr/hypercat/pleinpot/imdwaxisc1.html

    "The IAU standard for conversion from air to vacuum wavelengths is given in
    Morton (1991,  ApJS, 77, 119).  For vacuum wavelengths (VAC)  in Angstroms,
    convert  to air wavelength  (AIR) via:
    AIR =  VAC /  (1.0 +  2.735182E-4 + 131.4182 / VAC^2 + 2.76249E8 / VAC^4)"
*/
    if (is_void(coef)) coef=1.;
    if (microns) coef=10000.;
    VAC=VAC*coef;
    AIR = VAC / (1.0 + 2.735182E-4 + 131.4182 / VAC^2 + 2.76249E8 / VAC^4);
    return AIR/coef;
}
func airvac(AIR,microns=,coef=){
/* DOCUMENT vacwl=airvac(airwl)
    Compute vacuum wavelength from air wavelength in Angstroms.
    Information found in;
    http://www-obs.univ-lyon1.fr/hypercat/pleinpot/imdwaxisc1.html

    "The IAU standard for conversion from air to vacuum wavelengths is given in
    Morton (1991,  ApJS, 77, 119).  For vacuum wavelengths (VAC)  in Angstroms,
    convert  to air wavelength  (AIR) via:
    AIR =  VAC /  (1.0 +  2.735182E-4 + 131.4182 / VAC^2 + 2.76249E8 / VAC^4)"
*/
    if (is_void(coef)) coef=1.;
    if (microns) coef=10000.;
    AIR=AIR*coef;
    VAC = AIR * (1.0 + 2.735182E-4 + 131.4182 / AIR^2 + 2.76249E8 / AIR^4);
    return VAC/coef;
}