home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Collection of Education
/
collectionofeducationcarat1997.iso
/
SCIENCE
/
AA_51.ZIP
/
FK4FK5.C
< prev
next >
Wrap
C/C++ Source or Header
|
1993-02-09
|
3KB
|
122 lines
/* Convert FK4 B1950.0 catalogue coordinates
* to FK5 J2000.0 coordinates.
* AA page B58.
*/
#include "kep.h"
/* Factors to eliminate E terms of aberration
*/
static double A[3] = {-1.62557e-6, -3.1919e-7, - 1.3843e-7};
static double Ad[3] = {1.244e-3, -1.579e-3, -6.60e-4};
/* Transformation matrix for unit direction vector,
* and motion vector in arc seconds per century
*/
static double Mat[36] = {
0.9999256782, -0.0111820611, -4.8579477e-3,
2.42395018e-6, -2.710663e-8, -1.177656e-8,
0.0111820610, 0.9999374784, -2.71765e-5,
2.710663e-8, 2.42397878e-6, -6.587e-11,
4.8579479e-3, -2.71474e-5, 0.9999881997,
1.177656e-8, -6.582e-11, 2.42410173e-6,
-5.51e-4, -0.238565, 0.435739,
0.99994704, -0.01118251, -4.85767e-3,
0.238514, -2.667e-3, -8.541e-3,
0.01118251, 0.99995883, -2.718e-5,
-0.435623, 0.012254, 2.117e-3,
4.85767e-3, -2.714e-5, 1.00000956
};
int fk4fk5( p, m, el )
double p[], m[];
struct star *el;
{
double a, b, c;
double *u, *v;
double R[6];
int i, j;
printf( "Converting to FK5 system\n" );
/* Note the direction vector and motion vector
* are already supplied by rstar.c.
*/
a = 0.0;
b = 0.0;
for( i=0; i<3; i++ )
{
m[i] *= RTS; /* motion must be in arc seconds per century */
a += A[i] * p[i];
b += Ad[i] * p[i];
}
/* Remove E terms of aberration from FK4
*/
for( i=0; i<3; i++ )
{
R[i] = p[i] - A[i] + a * p[i];
R[i+3] = m[i] - Ad[i] + b * p[i];
}
/* Perform matrix multiplication
*/
v = &Mat[0];
for( i=0; i<6; i++ )
{
a = 0.0;
u = &R[0];
for( j=0; j<6; j++ )
a += *u++ * *v++;
if( i < 3 )
p[i] = a;
else
m[i-3] = a;
}
/* Transform the answers into J2000 catalogue entries
* in radian measure.
*/
b = p[0]*p[0] + p[1]*p[1];
a = b + p[2]*p[2];
c = a;
a = sqrt(a);
el->ra = zatan2( p[0], p[1] );
el->dec = asin( p[2]/a );
/* Note motion converted back to radians per (Julian) century */
el->mura = (p[0]*m[1] - p[1]*m[0])/(RTS*b);
el->mudec = (m[2]*b - p[2]*(p[0]*m[0] + p[1]*m[1]) )/(RTS*c*sqrt(b));
if( el->px > 0.0 )
{
c = 0.0;
for( i=0; i<3; i++ )
c += p[i] * m[i];
/* divide by RTS to deconvert m (and therefore c)
* from arc seconds back to radians
*/
el->v = c/(21.094952663 * el->px * RTS * a);
}
el->px = el->px/a; /* a is dimensionless */
el->epoch = J2000;
#if DEBUG
/* Display the computed J2000 catalogue entries
*/
hms( el->ra );
dms( el->dec );
u = (double *)&el->px;
for( i=0; i<3; i++ )
printf( " %.4lf ", *u++ * RTS );
printf( "\n" );
#endif
return(0);
}