From 5a468217bb4778164e67a627428968ca39faebc3 Mon Sep 17 00:00:00 2001 From: abrudana_cp Date: Tue, 23 May 2017 20:41:45 +0000 Subject: [PATCH] AA --- WorldWideAstronomy/SOFA/a2af.c | 6 +- WorldWideAstronomy/SOFA/a2tf.c | 6 +- WorldWideAstronomy/SOFA/ab.c | 6 +- WorldWideAstronomy/SOFA/af2a.c | 6 +- WorldWideAstronomy/SOFA/anp.c | 6 +- WorldWideAstronomy/SOFA/anpm.c | 6 +- WorldWideAstronomy/SOFA/apcg.c | 6 +- WorldWideAstronomy/SOFA/apcg13.c | 6 +- WorldWideAstronomy/SOFA/apci.c | 6 +- WorldWideAstronomy/SOFA/apci13.c | 6 +- WorldWideAstronomy/SOFA/apco.c | 6 +- WorldWideAstronomy/SOFA/apco13.c | 6 +- WorldWideAstronomy/SOFA/apcs.c | 10 +- WorldWideAstronomy/SOFA/apcs13.c | 6 +- WorldWideAstronomy/SOFA/aper.c | 6 +- WorldWideAstronomy/SOFA/aper13.c | 6 +- WorldWideAstronomy/SOFA/apio.c | 6 +- WorldWideAstronomy/SOFA/apio13.c | 6 +- WorldWideAstronomy/SOFA/atci13.c | 12 +- WorldWideAstronomy/SOFA/atciq.c | 6 +- WorldWideAstronomy/SOFA/atciqn.c | 6 +- WorldWideAstronomy/SOFA/atciqz.c | 6 +- WorldWideAstronomy/SOFA/atco13.c | 6 +- WorldWideAstronomy/SOFA/atic13.c | 6 +- WorldWideAstronomy/SOFA/aticq.c | 6 +- WorldWideAstronomy/SOFA/aticqn.c | 6 +- WorldWideAstronomy/SOFA/atio13.c | 6 +- WorldWideAstronomy/SOFA/atioq.c | 6 +- WorldWideAstronomy/SOFA/atoc13.c | 6 +- WorldWideAstronomy/SOFA/atoi13.c | 6 +- WorldWideAstronomy/SOFA/atoiq.c | 6 +- WorldWideAstronomy/SOFA/bi00.c | 6 +- WorldWideAstronomy/SOFA/bp00.c | 6 +- WorldWideAstronomy/SOFA/bp06.c | 6 +- WorldWideAstronomy/SOFA/bpn2xy.c | 6 +- WorldWideAstronomy/SOFA/c2i00a.c | 6 +- WorldWideAstronomy/SOFA/c2i00b.c | 6 +- WorldWideAstronomy/SOFA/c2i06a.c | 6 +- WorldWideAstronomy/SOFA/c2ibpn.c | 6 +- WorldWideAstronomy/SOFA/c2ixy.c | 6 +- WorldWideAstronomy/SOFA/c2ixys.c | 6 +- WorldWideAstronomy/SOFA/c2s.c | 6 +- WorldWideAstronomy/SOFA/c2t00a.c | 6 +- WorldWideAstronomy/SOFA/c2t00b.c | 6 +- WorldWideAstronomy/SOFA/c2t06a.c | 6 +- WorldWideAstronomy/SOFA/c2tcio.c | 6 +- WorldWideAstronomy/SOFA/c2teqx.c | 6 +- WorldWideAstronomy/SOFA/c2tpe.c | 6 +- WorldWideAstronomy/SOFA/c2txy.c | 6 +- WorldWideAstronomy/SOFA/cal2jd.c | 6 +- WorldWideAstronomy/SOFA/cp.c | 6 +- WorldWideAstronomy/SOFA/cpv.c | 6 +- WorldWideAstronomy/SOFA/cr.c | 6 +- WorldWideAstronomy/SOFA/d2dtf.c | 6 +- WorldWideAstronomy/SOFA/d2tf.c | 6 +- WorldWideAstronomy/SOFA/dat.c | 12 +- WorldWideAstronomy/SOFA/dtdb.c | 6 +- WorldWideAstronomy/SOFA/dtf2d.c | 6 +- WorldWideAstronomy/SOFA/eceq06.c | 6 +- WorldWideAstronomy/SOFA/ecm06.c | 6 +- WorldWideAstronomy/SOFA/ee00.c | 6 +- WorldWideAstronomy/SOFA/ee00a.c | 6 +- WorldWideAstronomy/SOFA/ee00b.c | 6 +- WorldWideAstronomy/SOFA/ee06a.c | 6 +- WorldWideAstronomy/SOFA/eect00.c | 6 +- WorldWideAstronomy/SOFA/eform.c | 6 +- WorldWideAstronomy/SOFA/eo06a.c | 6 +- WorldWideAstronomy/SOFA/eors.c | 6 +- WorldWideAstronomy/SOFA/epb.c | 6 +- WorldWideAstronomy/SOFA/epb2jd.c | 6 +- WorldWideAstronomy/SOFA/epj.c | 6 +- WorldWideAstronomy/SOFA/epj2jd.c | 6 +- WorldWideAstronomy/SOFA/epv00.c | 16 +- WorldWideAstronomy/SOFA/eqec06.c | 6 +- WorldWideAstronomy/SOFA/eqeq94.c | 6 +- WorldWideAstronomy/SOFA/era00.c | 6 +- WorldWideAstronomy/SOFA/fad03.c | 6 +- WorldWideAstronomy/SOFA/fae03.c | 6 +- WorldWideAstronomy/SOFA/faf03.c | 6 +- WorldWideAstronomy/SOFA/faju03.c | 6 +- WorldWideAstronomy/SOFA/fal03.c | 6 +- WorldWideAstronomy/SOFA/falp03.c | 6 +- WorldWideAstronomy/SOFA/fama03.c | 6 +- WorldWideAstronomy/SOFA/fame03.c | 6 +- WorldWideAstronomy/SOFA/fane03.c | 6 +- WorldWideAstronomy/SOFA/faom03.c | 6 +- WorldWideAstronomy/SOFA/fapa03.c | 6 +- WorldWideAstronomy/SOFA/fasa03.c | 6 +- WorldWideAstronomy/SOFA/faur03.c | 6 +- WorldWideAstronomy/SOFA/fave03.c | 6 +- WorldWideAstronomy/SOFA/fk52h.c | 6 +- WorldWideAstronomy/SOFA/fk5hip.c | 6 +- WorldWideAstronomy/SOFA/fk5hz.c | 6 +- WorldWideAstronomy/SOFA/fw2m.c | 6 +- WorldWideAstronomy/SOFA/fw2xy.c | 6 +- WorldWideAstronomy/SOFA/g2icrs.c | 6 +- WorldWideAstronomy/SOFA/gc2gd.c | 6 +- WorldWideAstronomy/SOFA/gc2gde.c | 6 +- WorldWideAstronomy/SOFA/gd2gc.c | 6 +- WorldWideAstronomy/SOFA/gd2gce.c | 6 +- WorldWideAstronomy/SOFA/gmst00.c | 6 +- WorldWideAstronomy/SOFA/gmst06.c | 6 +- WorldWideAstronomy/SOFA/gmst82.c | 6 +- WorldWideAstronomy/SOFA/gst00a.c | 6 +- WorldWideAstronomy/SOFA/gst00b.c | 6 +- WorldWideAstronomy/SOFA/gst06.c | 6 +- WorldWideAstronomy/SOFA/gst06a.c | 6 +- WorldWideAstronomy/SOFA/gst94.c | 6 +- WorldWideAstronomy/SOFA/h2fk5.c | 6 +- WorldWideAstronomy/SOFA/hfk5z.c | 6 +- WorldWideAstronomy/SOFA/icrs2g.c | 6 +- WorldWideAstronomy/SOFA/ir.c | 6 +- WorldWideAstronomy/SOFA/jd2cal.c | 10 +- WorldWideAstronomy/SOFA/jdcalf.c | 6 +- WorldWideAstronomy/SOFA/ld.c | 6 +- WorldWideAstronomy/SOFA/ldn.c | 10 +- WorldWideAstronomy/SOFA/ldsun.c | 6 +- WorldWideAstronomy/SOFA/lteceq.c | 6 +- WorldWideAstronomy/SOFA/ltecm.c | 6 +- WorldWideAstronomy/SOFA/lteqec.c | 6 +- WorldWideAstronomy/SOFA/ltp.c | 6 +- WorldWideAstronomy/SOFA/ltpb.c | 6 +- WorldWideAstronomy/SOFA/ltpecl.c | 6 +- WorldWideAstronomy/SOFA/ltpequ.c | 6 +- WorldWideAstronomy/SOFA/num00a.c | 6 +- WorldWideAstronomy/SOFA/num00b.c | 6 +- WorldWideAstronomy/SOFA/num06a.c | 6 +- WorldWideAstronomy/SOFA/numat.c | 6 +- WorldWideAstronomy/SOFA/nut00a.c | 6 +- WorldWideAstronomy/SOFA/nut00b.c | 6 +- WorldWideAstronomy/SOFA/nut06a.c | 6 +- WorldWideAstronomy/SOFA/nut80.c | 6 +- WorldWideAstronomy/SOFA/nutm80.c | 6 +- WorldWideAstronomy/SOFA/obl06.c | 6 +- WorldWideAstronomy/SOFA/obl80.c | 6 +- WorldWideAstronomy/SOFA/p06e.c | 6 +- WorldWideAstronomy/SOFA/p2pv.c | 6 +- WorldWideAstronomy/SOFA/p2s.c | 6 +- WorldWideAstronomy/SOFA/pap.c | 6 +- WorldWideAstronomy/SOFA/pas.c | 6 +- WorldWideAstronomy/SOFA/pb06.c | 6 +- WorldWideAstronomy/SOFA/pdp.c | 6 +- WorldWideAstronomy/SOFA/pfw06.c | 6 +- WorldWideAstronomy/SOFA/plan94.c | 22 +- WorldWideAstronomy/SOFA/pm.c | 6 +- WorldWideAstronomy/SOFA/pmat00.c | 6 +- WorldWideAstronomy/SOFA/pmat06.c | 6 +- WorldWideAstronomy/SOFA/pmat76.c | 6 +- WorldWideAstronomy/SOFA/pmp.c | 6 +- WorldWideAstronomy/SOFA/pmpx.c | 6 +- WorldWideAstronomy/SOFA/pmsafe.c | 6 +- WorldWideAstronomy/SOFA/pn.c | 6 +- WorldWideAstronomy/SOFA/pn00.c | 6 +- WorldWideAstronomy/SOFA/pn00a.c | 6 +- WorldWideAstronomy/SOFA/pn00b.c | 6 +- WorldWideAstronomy/SOFA/pn06.c | 6 +- WorldWideAstronomy/SOFA/pn06a.c | 6 +- WorldWideAstronomy/SOFA/pnm00a.c | 6 +- WorldWideAstronomy/SOFA/pnm00b.c | 6 +- WorldWideAstronomy/SOFA/pnm06a.c | 6 +- WorldWideAstronomy/SOFA/pnm80.c | 6 +- WorldWideAstronomy/SOFA/pom00.c | 6 +- WorldWideAstronomy/SOFA/ppp.c | 6 +- WorldWideAstronomy/SOFA/ppsp.c | 6 +- WorldWideAstronomy/SOFA/pr00.c | 6 +- WorldWideAstronomy/SOFA/prec76.c | 6 +- WorldWideAstronomy/SOFA/pv2p.c | 6 +- WorldWideAstronomy/SOFA/pv2s.c | 6 +- WorldWideAstronomy/SOFA/pvdpv.c | 6 +- WorldWideAstronomy/SOFA/pvm.c | 6 +- WorldWideAstronomy/SOFA/pvmpv.c | 6 +- WorldWideAstronomy/SOFA/pvppv.c | 6 +- WorldWideAstronomy/SOFA/pvstar.c | 24 +- WorldWideAstronomy/SOFA/pvtob.c | 6 +- WorldWideAstronomy/SOFA/pvu.c | 6 +- WorldWideAstronomy/SOFA/pvup.c | 6 +- WorldWideAstronomy/SOFA/pvxpv.c | 6 +- WorldWideAstronomy/SOFA/pxp.c | 6 +- WorldWideAstronomy/SOFA/refco.c | 6 +- WorldWideAstronomy/SOFA/rm2v.c | 6 +- WorldWideAstronomy/SOFA/rv2m.c | 6 +- WorldWideAstronomy/SOFA/rx.c | 6 +- WorldWideAstronomy/SOFA/rxp.c | 6 +- WorldWideAstronomy/SOFA/rxpv.c | 6 +- WorldWideAstronomy/SOFA/rxr.c | 6 +- WorldWideAstronomy/SOFA/ry.c | 6 +- WorldWideAstronomy/SOFA/rz.c | 6 +- WorldWideAstronomy/SOFA/s00.c | 6 +- WorldWideAstronomy/SOFA/s00a.c | 6 +- WorldWideAstronomy/SOFA/s00b.c | 6 +- WorldWideAstronomy/SOFA/s06.c | 6 +- WorldWideAstronomy/SOFA/s06a.c | 6 +- WorldWideAstronomy/SOFA/s2c.c | 6 +- WorldWideAstronomy/SOFA/s2p.c | 6 +- WorldWideAstronomy/SOFA/s2pv.c | 6 +- WorldWideAstronomy/SOFA/s2xpv.c | 6 +- WorldWideAstronomy/SOFA/sepp.c | 6 +- WorldWideAstronomy/SOFA/seps.c | 6 +- WorldWideAstronomy/SOFA/sofa.h | 6 +- WorldWideAstronomy/SOFA/sofam.h | 18 +- WorldWideAstronomy/SOFA/sp00.c | 6 +- WorldWideAstronomy/SOFA/starpm.c | 6 +- WorldWideAstronomy/SOFA/starpv.c | 24 +- WorldWideAstronomy/SOFA/sxp.c | 6 +- WorldWideAstronomy/SOFA/sxpv.c | 6 +- WorldWideAstronomy/SOFA/t_sofa_c.c | 19557 ++++++++-------- WorldWideAstronomy/SOFA/taitt.c | 6 +- WorldWideAstronomy/SOFA/taiut1.c | 6 +- WorldWideAstronomy/SOFA/taiutc.c | 6 +- WorldWideAstronomy/SOFA/tcbtdb.c | 6 +- WorldWideAstronomy/SOFA/tcgtt.c | 6 +- WorldWideAstronomy/SOFA/tdbtcb.c | 6 +- WorldWideAstronomy/SOFA/tdbtt.c | 6 +- WorldWideAstronomy/SOFA/tf2a.c | 6 +- WorldWideAstronomy/SOFA/tf2d.c | 6 +- WorldWideAstronomy/SOFA/tr.c | 6 +- WorldWideAstronomy/SOFA/trxp.c | 6 +- WorldWideAstronomy/SOFA/trxpv.c | 6 +- WorldWideAstronomy/SOFA/tttai.c | 6 +- WorldWideAstronomy/SOFA/tttcg.c | 6 +- WorldWideAstronomy/SOFA/tttdb.c | 6 +- WorldWideAstronomy/SOFA/ttut1.c | 6 +- WorldWideAstronomy/SOFA/ut1tai.c | 6 +- WorldWideAstronomy/SOFA/ut1tt.c | 6 +- WorldWideAstronomy/SOFA/ut1utc.c | 6 +- WorldWideAstronomy/SOFA/utctai.c | 6 +- WorldWideAstronomy/SOFA/utcut1.c | 6 +- WorldWideAstronomy/SOFA/xy06.c | 6 +- WorldWideAstronomy/SOFA/xys00a.c | 6 +- WorldWideAstronomy/SOFA/xys00b.c | 6 +- WorldWideAstronomy/SOFA/xys06a.c | 6 +- WorldWideAstronomy/SOFA/zp.c | 6 +- WorldWideAstronomy/SOFA/zpv.c | 6 +- WorldWideAstronomy/SOFA/zr.c | 6 +- .../WWA/Astronomy/SpaceMotion/pvstar.cs | 14 +- WorldWideAstronomy/WWA/wwa.cs | 8 +- WorldWideAstronomy/WWATest/Program.cs | 451 +- 237 files changed, 10859 insertions(+), 10667 deletions(-) diff --git a/WorldWideAstronomy/SOFA/a2af.c b/WorldWideAstronomy/SOFA/a2af.c index 1d8b6bc..cdd8d29 100644 --- a/WorldWideAstronomy/SOFA/a2af.c +++ b/WorldWideAstronomy/SOFA/a2af.c @@ -58,9 +58,9 @@ void iauA2af(int ndp, double angle, char *sign, int idmsf[4]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Hours to degrees * radians to turns */ @@ -74,7 +74,7 @@ void iauA2af(int ndp, double angle, char *sign, int idmsf[4]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/a2tf.c b/WorldWideAstronomy/SOFA/a2tf.c index 73df5d8..d6f7ab4 100644 --- a/WorldWideAstronomy/SOFA/a2tf.c +++ b/WorldWideAstronomy/SOFA/a2tf.c @@ -58,9 +58,9 @@ void iauA2tf(int ndp, double angle, char *sign, int ihmsf[4]) ** ** This revision: 2013 July 31 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Scale then use days to h,m,s function. */ @@ -70,7 +70,7 @@ void iauA2tf(int ndp, double angle, char *sign, int ihmsf[4]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ab.c b/WorldWideAstronomy/SOFA/ab.c index 2d6d7b5..3575e28 100644 --- a/WorldWideAstronomy/SOFA/ab.c +++ b/WorldWideAstronomy/SOFA/ab.c @@ -55,9 +55,9 @@ void iauAb(double pnat[3], double v[3], double s, double bm1, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int i; @@ -82,7 +82,7 @@ void iauAb(double pnat[3], double v[3], double s, double bm1, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/af2a.c b/WorldWideAstronomy/SOFA/af2a.c index b91e4e8..cb540fb 100644 --- a/WorldWideAstronomy/SOFA/af2a.c +++ b/WorldWideAstronomy/SOFA/af2a.c @@ -41,9 +41,9 @@ int iauAf2a(char s, int ideg, int iamin, double asec, double *rad) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -61,7 +61,7 @@ int iauAf2a(char s, int ideg, int iamin, double asec, double *rad) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/anp.c b/WorldWideAstronomy/SOFA/anp.c index 4324874..c4c06b0 100644 --- a/WorldWideAstronomy/SOFA/anp.c +++ b/WorldWideAstronomy/SOFA/anp.c @@ -21,9 +21,9 @@ double iauAnp(double a) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double w; @@ -36,7 +36,7 @@ double iauAnp(double a) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/anpm.c b/WorldWideAstronomy/SOFA/anpm.c index aa7922b..7ecf3a7 100644 --- a/WorldWideAstronomy/SOFA/anpm.c +++ b/WorldWideAstronomy/SOFA/anpm.c @@ -21,9 +21,9 @@ double iauAnpm(double a) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double w; @@ -36,7 +36,7 @@ double iauAnpm(double a) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apcg.c b/WorldWideAstronomy/SOFA/apcg.c index 653bc53..71d99f0 100644 --- a/WorldWideAstronomy/SOFA/apcg.c +++ b/WorldWideAstronomy/SOFA/apcg.c @@ -109,9 +109,9 @@ void iauApcg(double date1, double date2, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Geocentric observer */ @@ -126,7 +126,7 @@ void iauApcg(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apcg13.c b/WorldWideAstronomy/SOFA/apcg13.c index 98105ea..412ccbe 100644 --- a/WorldWideAstronomy/SOFA/apcg13.c +++ b/WorldWideAstronomy/SOFA/apcg13.c @@ -111,9 +111,9 @@ void iauApcg13(double date1, double date2, iauASTROM *astrom) ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double ehpv[2][3], ebpv[2][3]; @@ -129,7 +129,7 @@ void iauApcg13(double date1, double date2, iauASTROM *astrom) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apci.c b/WorldWideAstronomy/SOFA/apci.c index 6e38e4e..46a80b1 100644 --- a/WorldWideAstronomy/SOFA/apci.c +++ b/WorldWideAstronomy/SOFA/apci.c @@ -119,9 +119,9 @@ void iauApci(double date1, double date2, ** ** This revision: 2013 September 25 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -135,7 +135,7 @@ void iauApci(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apci13.c b/WorldWideAstronomy/SOFA/apci13.c index 6364a2c..ab9d679 100644 --- a/WorldWideAstronomy/SOFA/apci13.c +++ b/WorldWideAstronomy/SOFA/apci13.c @@ -117,9 +117,9 @@ void iauApci13(double date1, double date2, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double ehpv[2][3], ebpv[2][3], r[3][3], x, y, s; @@ -147,7 +147,7 @@ void iauApci13(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apco.c b/WorldWideAstronomy/SOFA/apco.c index 890379d..9b3041b 100644 --- a/WorldWideAstronomy/SOFA/apco.c +++ b/WorldWideAstronomy/SOFA/apco.c @@ -159,9 +159,9 @@ void iauApco(double date1, double date2, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double sl, cl, r[3][3], pvc[2][3], pv[2][3]; @@ -209,7 +209,7 @@ void iauApco(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apco13.c b/WorldWideAstronomy/SOFA/apco13.c index f43a990..d3a9c22 100644 --- a/WorldWideAstronomy/SOFA/apco13.c +++ b/WorldWideAstronomy/SOFA/apco13.c @@ -180,9 +180,9 @@ int iauApco13(double utc1, double utc2, double dut1, ** ** This revision: 2013 December 5 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -232,7 +232,7 @@ int iauApco13(double utc1, double utc2, double dut1, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apcs.c b/WorldWideAstronomy/SOFA/apcs.c index 78bea18..b44a6df 100644 --- a/WorldWideAstronomy/SOFA/apcs.c +++ b/WorldWideAstronomy/SOFA/apcs.c @@ -127,17 +127,17 @@ void iauApcs(double date1, double date2, double pv[2][3], ** iauPn decompose p-vector into modulus and direction ** iauIr initialize r-matrix to identity ** -** This revision: 2013 October 9 +** This revision: 2017 March 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* au/d to m/s */ const double AUDMS = DAU/DAYSEC; -/* Light time for 1 AU (day) */ +/* Light time for 1 au (day) */ const double CR = AULT/DAYSEC; int i; @@ -178,7 +178,7 @@ void iauApcs(double date1, double date2, double pv[2][3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apcs13.c b/WorldWideAstronomy/SOFA/apcs13.c index 07bf8b3..f172b58 100644 --- a/WorldWideAstronomy/SOFA/apcs13.c +++ b/WorldWideAstronomy/SOFA/apcs13.c @@ -118,9 +118,9 @@ void iauApcs13(double date1, double date2, double pv[2][3], ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double ehpv[2][3], ebpv[2][3]; @@ -136,7 +136,7 @@ void iauApcs13(double date1, double date2, double pv[2][3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/aper.c b/WorldWideAstronomy/SOFA/aper.c index 9f2424b..dcd5874 100644 --- a/WorldWideAstronomy/SOFA/aper.c +++ b/WorldWideAstronomy/SOFA/aper.c @@ -96,9 +96,9 @@ void iauAper(double theta, iauASTROM *astrom) ** ** This revision: 2013 September 25 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { astrom->eral = theta + astrom->along; @@ -107,7 +107,7 @@ void iauAper(double theta, iauASTROM *astrom) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/aper13.c b/WorldWideAstronomy/SOFA/aper13.c index cb5174e..0384678 100644 --- a/WorldWideAstronomy/SOFA/aper13.c +++ b/WorldWideAstronomy/SOFA/aper13.c @@ -115,9 +115,9 @@ void iauAper13(double ut11, double ut12, iauASTROM *astrom) ** ** This revision: 2013 September 25 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauAper(iauEra00(ut11,ut12), astrom); @@ -126,7 +126,7 @@ void iauAper13(double ut11, double ut12, iauASTROM *astrom) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apio.c b/WorldWideAstronomy/SOFA/apio.c index 99e9363..9081506 100644 --- a/WorldWideAstronomy/SOFA/apio.c +++ b/WorldWideAstronomy/SOFA/apio.c @@ -120,9 +120,9 @@ void iauApio(double sp, double theta, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double sl, cl, pv[2][3]; @@ -158,7 +158,7 @@ void iauApio(double sp, double theta, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/apio13.c b/WorldWideAstronomy/SOFA/apio13.c index db189e1..05692f0 100644 --- a/WorldWideAstronomy/SOFA/apio13.c +++ b/WorldWideAstronomy/SOFA/apio13.c @@ -169,9 +169,9 @@ int iauApio13(double utc1, double utc2, double dut1, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -204,7 +204,7 @@ int iauApio13(double utc1, double utc2, double dut1, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atci13.c b/WorldWideAstronomy/SOFA/atci13.c index 70c1a54..c318c99 100644 --- a/WorldWideAstronomy/SOFA/atci13.c +++ b/WorldWideAstronomy/SOFA/atci13.c @@ -40,12 +40,12 @@ void iauAtci13(double rc, double dc, ** ** 3) The TDB date date1+date2 is a Julian Date, apportioned in any ** convenient way between the two arguments. For example, -** JD(TDB)=2450123.8g could be expressed in any of these ways, among +** JD(TDB)=2450123.7 could be expressed in any of these ways, among ** others: ** ** date1 date2 ** -** 2450123.8g 0.0 (JD method) +** 2450123.7 0.0 (JD method) ** 2451545.0 -1421.3 (J2000 method) ** 2400000.5 50123.2 (MJD method) ** 2450123.5 0.2 (date & time method) @@ -83,11 +83,11 @@ void iauAtci13(double rc, double dc, ** iauApci13 astrometry parameters, ICRS-CIRS, 2013 ** iauAtciq quick ICRS to CIRS ** -** This revision: 2013 October 9 +** This revision: 2017 March 12 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Star-independent astrometry parameters */ @@ -104,7 +104,7 @@ void iauAtci13(double rc, double dc, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atciq.c b/WorldWideAstronomy/SOFA/atciq.c index fdde225..c72bd33 100644 --- a/WorldWideAstronomy/SOFA/atciq.c +++ b/WorldWideAstronomy/SOFA/atciq.c @@ -71,9 +71,9 @@ void iauAtciq(double rc, double dc, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double pco[3], pnat[3], ppr[3], pi[3], w; @@ -99,7 +99,7 @@ void iauAtciq(double rc, double dc, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atciqn.c b/WorldWideAstronomy/SOFA/atciqn.c index aef9859..02a9ccc 100644 --- a/WorldWideAstronomy/SOFA/atciqn.c +++ b/WorldWideAstronomy/SOFA/atciqn.c @@ -108,9 +108,9 @@ void iauAtciqn(double rc, double dc, double pr, double pd, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double pco[3], pnat[3], ppr[3], pi[3], w; @@ -136,7 +136,7 @@ void iauAtciqn(double rc, double dc, double pr, double pd, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atciqz.c b/WorldWideAstronomy/SOFA/atciqz.c index ef36c8e..70584b3 100644 --- a/WorldWideAstronomy/SOFA/atciqz.c +++ b/WorldWideAstronomy/SOFA/atciqz.c @@ -70,9 +70,9 @@ void iauAtciqz(double rc, double dc, iauASTROM *astrom, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double pco[3], pnat[3], ppr[3], pi[3], w; @@ -98,7 +98,7 @@ void iauAtciqz(double rc, double dc, iauASTROM *astrom, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atco13.c b/WorldWideAstronomy/SOFA/atco13.c index 9be4260..39d0245 100644 --- a/WorldWideAstronomy/SOFA/atco13.c +++ b/WorldWideAstronomy/SOFA/atco13.c @@ -158,9 +158,9 @@ int iauAtco13(double rc, double dc, ** ** This revision: 2016 February 2 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -188,7 +188,7 @@ int iauAtco13(double rc, double dc, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atic13.c b/WorldWideAstronomy/SOFA/atic13.c index e2435a5..d519e6e 100644 --- a/WorldWideAstronomy/SOFA/atic13.c +++ b/WorldWideAstronomy/SOFA/atic13.c @@ -78,9 +78,9 @@ void iauAtic13(double ri, double di, double date1, double date2, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Star-independent astrometry parameters */ @@ -97,7 +97,7 @@ void iauAtic13(double ri, double di, double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/aticq.c b/WorldWideAstronomy/SOFA/aticq.c index 4a74969..7e3a04a 100644 --- a/WorldWideAstronomy/SOFA/aticq.c +++ b/WorldWideAstronomy/SOFA/aticq.c @@ -66,9 +66,9 @@ void iauAticq(double ri, double di, iauASTROM *astrom, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j, i; @@ -144,7 +144,7 @@ void iauAticq(double ri, double di, iauASTROM *astrom, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/aticqn.c b/WorldWideAstronomy/SOFA/aticqn.c index 77027e6..5863fb8 100644 --- a/WorldWideAstronomy/SOFA/aticqn.c +++ b/WorldWideAstronomy/SOFA/aticqn.c @@ -104,9 +104,9 @@ void iauAticqn(double ri, double di, iauASTROM *astrom, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j, i; @@ -182,7 +182,7 @@ void iauAticqn(double ri, double di, iauASTROM *astrom, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atio13.c b/WorldWideAstronomy/SOFA/atio13.c index 07c4f3c..3eb949f 100644 --- a/WorldWideAstronomy/SOFA/atio13.c +++ b/WorldWideAstronomy/SOFA/atio13.c @@ -141,9 +141,9 @@ int iauAtio13(double ri, double di, ** ** This revision: 2016 February 2 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -167,7 +167,7 @@ int iauAtio13(double ri, double di, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atioq.c b/WorldWideAstronomy/SOFA/atioq.c index 5bb4820..bfd8129 100644 --- a/WorldWideAstronomy/SOFA/atioq.c +++ b/WorldWideAstronomy/SOFA/atioq.c @@ -102,9 +102,9 @@ void iauAtioq(double ri, double di, iauASTROM *astrom, ** ** This revision: 2016 March 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Minimum cos(alt) and sin(alt) for refraction purposes */ @@ -188,7 +188,7 @@ void iauAtioq(double ri, double di, iauASTROM *astrom, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atoc13.c b/WorldWideAstronomy/SOFA/atoc13.c index a5909c8..06796fc 100644 --- a/WorldWideAstronomy/SOFA/atoc13.c +++ b/WorldWideAstronomy/SOFA/atoc13.c @@ -148,9 +148,9 @@ int iauAtoc13(const char *type, double ob1, double ob2, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -178,7 +178,7 @@ int iauAtoc13(const char *type, double ob1, double ob2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atoi13.c b/WorldWideAstronomy/SOFA/atoi13.c index a68c5d0..af68be2 100644 --- a/WorldWideAstronomy/SOFA/atoi13.c +++ b/WorldWideAstronomy/SOFA/atoi13.c @@ -147,9 +147,9 @@ int iauAtoi13(const char *type, double ob1, double ob2, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -173,7 +173,7 @@ int iauAtoi13(const char *type, double ob1, double ob2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/atoiq.c b/WorldWideAstronomy/SOFA/atoiq.c index 29e12a0..4951712 100644 --- a/WorldWideAstronomy/SOFA/atoiq.c +++ b/WorldWideAstronomy/SOFA/atoiq.c @@ -92,9 +92,9 @@ void iauAtoiq(const char *type, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int c; @@ -202,7 +202,7 @@ void iauAtoiq(const char *type, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/bi00.c b/WorldWideAstronomy/SOFA/bi00.c index da9012f..e62c76d 100644 --- a/WorldWideAstronomy/SOFA/bi00.c +++ b/WorldWideAstronomy/SOFA/bi00.c @@ -48,9 +48,9 @@ void iauBi00(double *dpsibi, double *depsbi, double *dra) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* The frame bias corrections in longitude and obliquity */ @@ -70,7 +70,7 @@ void iauBi00(double *dpsibi, double *depsbi, double *dra) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/bp00.c b/WorldWideAstronomy/SOFA/bp00.c index 9661fcd..88d9816 100644 --- a/WorldWideAstronomy/SOFA/bp00.c +++ b/WorldWideAstronomy/SOFA/bp00.c @@ -77,9 +77,9 @@ void iauBp00(double date1, double date2, ** ** This revision: 2013 August 21 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* J2000.0 obliquity (Lieske et al. 1977) */ @@ -126,7 +126,7 @@ void iauBp00(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/bp06.c b/WorldWideAstronomy/SOFA/bp06.c index 9fa14e2..c694b57 100644 --- a/WorldWideAstronomy/SOFA/bp06.c +++ b/WorldWideAstronomy/SOFA/bp06.c @@ -71,9 +71,9 @@ void iauBp06(double date1, double date2, ** ** This revision: 2013 August 21 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gamb, phib, psib, epsa, rbpw[3][3], rbt[3][3]; @@ -97,7 +97,7 @@ void iauBp06(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/bpn2xy.c b/WorldWideAstronomy/SOFA/bpn2xy.c index 73e6940..d4ff38e 100644 --- a/WorldWideAstronomy/SOFA/bpn2xy.c +++ b/WorldWideAstronomy/SOFA/bpn2xy.c @@ -41,9 +41,9 @@ void iauBpn2xy(double rbpn[3][3], double *x, double *y) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Extract the X,Y coordinates. */ @@ -54,7 +54,7 @@ void iauBpn2xy(double rbpn[3][3], double *x, double *y) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2i00a.c b/WorldWideAstronomy/SOFA/c2i00a.c index 4f7123c..65eb3bf 100644 --- a/WorldWideAstronomy/SOFA/c2i00a.c +++ b/WorldWideAstronomy/SOFA/c2i00a.c @@ -75,9 +75,9 @@ void iauC2i00a(double date1, double date2, double rc2i[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3]; @@ -93,7 +93,7 @@ void iauC2i00a(double date1, double date2, double rc2i[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2i00b.c b/WorldWideAstronomy/SOFA/c2i00b.c index ee02607..ef8f95d 100644 --- a/WorldWideAstronomy/SOFA/c2i00b.c +++ b/WorldWideAstronomy/SOFA/c2i00b.c @@ -75,9 +75,9 @@ void iauC2i00b(double date1, double date2, double rc2i[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3]; @@ -93,7 +93,7 @@ void iauC2i00b(double date1, double date2, double rc2i[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2i06a.c b/WorldWideAstronomy/SOFA/c2i06a.c index 76dab81..ec90069 100644 --- a/WorldWideAstronomy/SOFA/c2i06a.c +++ b/WorldWideAstronomy/SOFA/c2i06a.c @@ -66,9 +66,9 @@ void iauC2i06a(double date1, double date2, double rc2i[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3], x, y, s; @@ -90,7 +90,7 @@ void iauC2i06a(double date1, double date2, double rc2i[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2ibpn.c b/WorldWideAstronomy/SOFA/c2ibpn.c index b315f34..603e099 100644 --- a/WorldWideAstronomy/SOFA/c2ibpn.c +++ b/WorldWideAstronomy/SOFA/c2ibpn.c @@ -78,9 +78,9 @@ void iauC2ibpn(double date1, double date2, double rbpn[3][3], ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double x, y; @@ -96,7 +96,7 @@ void iauC2ibpn(double date1, double date2, double rbpn[3][3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2ixy.c b/WorldWideAstronomy/SOFA/c2ixy.c index 31674ee..5a967e2 100644 --- a/WorldWideAstronomy/SOFA/c2ixy.c +++ b/WorldWideAstronomy/SOFA/c2ixy.c @@ -72,9 +72,9 @@ void iauC2ixy(double date1, double date2, double x, double y, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -85,7 +85,7 @@ void iauC2ixy(double date1, double date2, double x, double y, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2ixys.c b/WorldWideAstronomy/SOFA/c2ixys.c index 4cf05a9..a124de0 100644 --- a/WorldWideAstronomy/SOFA/c2ixys.c +++ b/WorldWideAstronomy/SOFA/c2ixys.c @@ -54,9 +54,9 @@ void iauC2ixys(double x, double y, double s, double rc2i[3][3]) ** ** This revision: 2014 November 7 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double r2, e, d; @@ -77,7 +77,7 @@ void iauC2ixys(double x, double y, double s, double rc2i[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2s.c b/WorldWideAstronomy/SOFA/c2s.c index b87cb6d..e1f6dd4 100644 --- a/WorldWideAstronomy/SOFA/c2s.c +++ b/WorldWideAstronomy/SOFA/c2s.c @@ -30,9 +30,9 @@ void iauC2s(double p[3], double *theta, double *phi) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double x, y, z, d2; @@ -50,7 +50,7 @@ void iauC2s(double p[3], double *theta, double *phi) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2t00a.c b/WorldWideAstronomy/SOFA/c2t00a.c index a2ced86..fce9a8e 100644 --- a/WorldWideAstronomy/SOFA/c2t00a.c +++ b/WorldWideAstronomy/SOFA/c2t00a.c @@ -81,9 +81,9 @@ void iauC2t00a(double tta, double ttb, double uta, double utb, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rc2i[3][3], era, sp, rpom[3][3]; @@ -108,7 +108,7 @@ void iauC2t00a(double tta, double ttb, double uta, double utb, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2t00b.c b/WorldWideAstronomy/SOFA/c2t00b.c index f367ad8..f7314a4 100644 --- a/WorldWideAstronomy/SOFA/c2t00b.c +++ b/WorldWideAstronomy/SOFA/c2t00b.c @@ -80,9 +80,9 @@ void iauC2t00b(double tta, double ttb, double uta, double utb, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rc2i[3][3], era, rpom[3][3]; @@ -104,7 +104,7 @@ void iauC2t00b(double tta, double ttb, double uta, double utb, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2t06a.c b/WorldWideAstronomy/SOFA/c2t06a.c index 25c633e..fec8675 100644 --- a/WorldWideAstronomy/SOFA/c2t06a.c +++ b/WorldWideAstronomy/SOFA/c2t06a.c @@ -79,9 +79,9 @@ void iauC2t06a(double tta, double ttb, double uta, double utb, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rc2i[3][3], era, sp, rpom[3][3]; @@ -106,7 +106,7 @@ void iauC2t06a(double tta, double ttb, double uta, double utb, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2tcio.c b/WorldWideAstronomy/SOFA/c2tcio.c index 4bd80bd..84b1083 100644 --- a/WorldWideAstronomy/SOFA/c2tcio.c +++ b/WorldWideAstronomy/SOFA/c2tcio.c @@ -59,9 +59,9 @@ void iauC2tcio(double rc2i[3][3], double era, double rpom[3][3], ** ** This revision: 2013 August 24 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double r[3][3]; @@ -76,7 +76,7 @@ void iauC2tcio(double rc2i[3][3], double era, double rpom[3][3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2teqx.c b/WorldWideAstronomy/SOFA/c2teqx.c index fa7bb3e..be27393 100644 --- a/WorldWideAstronomy/SOFA/c2teqx.c +++ b/WorldWideAstronomy/SOFA/c2teqx.c @@ -59,9 +59,9 @@ void iauC2teqx(double rbpn[3][3], double gst, double rpom[3][3], ** ** This revision: 2013 August 24 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double r[3][3]; @@ -76,7 +76,7 @@ void iauC2teqx(double rbpn[3][3], double gst, double rpom[3][3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2tpe.c b/WorldWideAstronomy/SOFA/c2tpe.c index ed714b9..a86d483 100644 --- a/WorldWideAstronomy/SOFA/c2tpe.c +++ b/WorldWideAstronomy/SOFA/c2tpe.c @@ -90,9 +90,9 @@ void iauC2tpe(double tta, double ttb, double uta, double utb, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double epsa, rb[3][3], rp[3][3], rbp[3][3], rn[3][3], @@ -121,7 +121,7 @@ void iauC2tpe(double tta, double ttb, double uta, double utb, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/c2txy.c b/WorldWideAstronomy/SOFA/c2txy.c index eb135fa..8cbf250 100644 --- a/WorldWideAstronomy/SOFA/c2txy.c +++ b/WorldWideAstronomy/SOFA/c2txy.c @@ -86,9 +86,9 @@ void iauC2txy(double tta, double ttb, double uta, double utb, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rc2i[3][3], era, sp, rpom[3][3]; @@ -113,7 +113,7 @@ void iauC2txy(double tta, double ttb, double uta, double utb, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/cal2jd.c b/WorldWideAstronomy/SOFA/cal2jd.c index a46d937..4e0a653 100644 --- a/WorldWideAstronomy/SOFA/cal2jd.c +++ b/WorldWideAstronomy/SOFA/cal2jd.c @@ -50,9 +50,9 @@ int iauCal2jd(int iy, int im, int id, double *djm0, double *djm) ** ** This revision: 2013 August 7 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j, ly, my; @@ -93,7 +93,7 @@ int iauCal2jd(int iy, int im, int id, double *djm0, double *djm) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/cp.c b/WorldWideAstronomy/SOFA/cp.c index c3f22f8..b204736 100644 --- a/WorldWideAstronomy/SOFA/cp.c +++ b/WorldWideAstronomy/SOFA/cp.c @@ -21,9 +21,9 @@ void iauCp(double p[3], double c[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { c[0] = p[0]; @@ -34,7 +34,7 @@ void iauCp(double p[3], double c[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/cpv.c b/WorldWideAstronomy/SOFA/cpv.c index 42c1704..198ec49 100644 --- a/WorldWideAstronomy/SOFA/cpv.c +++ b/WorldWideAstronomy/SOFA/cpv.c @@ -24,9 +24,9 @@ void iauCpv(double pv[2][3], double c[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauCp(pv[0], c[0]); @@ -36,7 +36,7 @@ void iauCpv(double pv[2][3], double c[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/cr.c b/WorldWideAstronomy/SOFA/cr.c index 4c9cfcd..e796a54 100644 --- a/WorldWideAstronomy/SOFA/cr.c +++ b/WorldWideAstronomy/SOFA/cr.c @@ -24,9 +24,9 @@ void iauCr(double r[3][3], double c[3][3]) ** ** This revision: 2016 May 19 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauCp(r[0], c[0]); @@ -37,7 +37,7 @@ void iauCr(double r[3][3], double c[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/d2dtf.c b/WorldWideAstronomy/SOFA/d2dtf.c index 5cfe494..6cd942f 100644 --- a/WorldWideAstronomy/SOFA/d2dtf.c +++ b/WorldWideAstronomy/SOFA/d2dtf.c @@ -78,9 +78,9 @@ int iauD2dtf(const char *scale, int ndp, double d1, double d2, ** ** This revision: 2014 February 15 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int leap; @@ -190,7 +190,7 @@ int iauD2dtf(const char *scale, int ndp, double d1, double d2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/d2tf.c b/WorldWideAstronomy/SOFA/d2tf.c index ba5fc6b..2c26897 100644 --- a/WorldWideAstronomy/SOFA/d2tf.c +++ b/WorldWideAstronomy/SOFA/d2tf.c @@ -55,9 +55,9 @@ void iauD2tf(int ndp, double days, char *sign, int ihmsf[4]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int nrs, n; @@ -114,7 +114,7 @@ void iauD2tf(int ndp, double days, char *sign, int ihmsf[4]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/dat.c b/WorldWideAstronomy/SOFA/dat.c index 23a68ba..daa6408 100644 --- a/WorldWideAstronomy/SOFA/dat.c +++ b/WorldWideAstronomy/SOFA/dat.c @@ -82,9 +82,9 @@ int iauDat(int iy, int im, int id, double fd, double *deltat ) ** so early that JD could not be computed. ** ** 2) If the specified date is for a day which ends with a leap second, -** the UTC-TAI value returned is for the period leading up to the +** the TAI-UTC value returned is for the period leading up to the ** leap second. If the date is for a day which begins as a leap -** second ends, the UTC-TAI returned is for the period following the +** second ends, the TAI-UTC returned is for the period following the ** leap second. ** ** 3) The day number must be in the normal calendar range, for example @@ -120,11 +120,11 @@ int iauDat(int iy, int im, int id, double fd, double *deltat ) ** Called: ** iauCal2jd Gregorian calendar to JD ** -** This revision: 2016 July 7 +** This revision: 2017 April 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Release year for this version of iauDat */ @@ -251,7 +251,7 @@ int iauDat(int iy, int im, int id, double fd, double *deltat ) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/dtdb.c b/WorldWideAstronomy/SOFA/dtdb.c index b52d99d..0c34bf5 100644 --- a/WorldWideAstronomy/SOFA/dtdb.c +++ b/WorldWideAstronomy/SOFA/dtdb.c @@ -164,9 +164,9 @@ double iauDtdb(double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, tsol, w, elsun, emsun, d, elj, els, wt, w0, w1, w2, w3, w4, @@ -1167,7 +1167,7 @@ double iauDtdb(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/dtf2d.c b/WorldWideAstronomy/SOFA/dtf2d.c index 14f89db..5cc2422 100644 --- a/WorldWideAstronomy/SOFA/dtf2d.c +++ b/WorldWideAstronomy/SOFA/dtf2d.c @@ -82,9 +82,9 @@ int iauDtf2d(const char *scale, int iy, int im, int id, ** ** This revision: 2013 July 26 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int js, iy2, im2, id2; @@ -157,7 +157,7 @@ int iauDtf2d(const char *scale, int iy, int im, int id, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/eceq06.c b/WorldWideAstronomy/SOFA/eceq06.c index 7307145..b1d4469 100644 --- a/WorldWideAstronomy/SOFA/eceq06.c +++ b/WorldWideAstronomy/SOFA/eceq06.c @@ -60,9 +60,9 @@ void iauEceq06(double date1, double date2, double dl, double db, ** ** This revision: 2016 February 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rm[3][3], v1[3], v2[3], a, b; @@ -86,7 +86,7 @@ void iauEceq06(double date1, double date2, double dl, double db, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ecm06.c b/WorldWideAstronomy/SOFA/ecm06.c index f3ac986..41cc5f4 100644 --- a/WorldWideAstronomy/SOFA/ecm06.c +++ b/WorldWideAstronomy/SOFA/ecm06.c @@ -66,9 +66,9 @@ void iauEcm06(double date1, double date2, double rm[3][3]) ** ** This revision: 2015 December 11 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double ob, bp[3][3], e[3][3]; @@ -89,7 +89,7 @@ void iauEcm06(double date1, double date2, double rm[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ee00.c b/WorldWideAstronomy/SOFA/ee00.c index d4f41fa..1aedc29 100644 --- a/WorldWideAstronomy/SOFA/ee00.c +++ b/WorldWideAstronomy/SOFA/ee00.c @@ -67,9 +67,9 @@ double iauEe00(double date1, double date2, double epsa, double dpsi) ** ** This revision: 2008 May 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double ee; @@ -82,7 +82,7 @@ double iauEe00(double date1, double date2, double epsa, double dpsi) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ee00a.c b/WorldWideAstronomy/SOFA/ee00a.c index 3b9f2ab..952dca2 100644 --- a/WorldWideAstronomy/SOFA/ee00a.c +++ b/WorldWideAstronomy/SOFA/ee00a.c @@ -65,9 +65,9 @@ double iauEe00a(double date1, double date2) ** ** This revision: 2008 May 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsipr, depspr, epsa, dpsi, deps, ee; @@ -89,7 +89,7 @@ double iauEe00a(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ee00b.c b/WorldWideAstronomy/SOFA/ee00b.c index df74113..303c9a9 100644 --- a/WorldWideAstronomy/SOFA/ee00b.c +++ b/WorldWideAstronomy/SOFA/ee00b.c @@ -71,9 +71,9 @@ double iauEe00b(double date1, double date2) ** ** This revision: 2008 May 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsipr, depspr, epsa, dpsi, deps, ee; @@ -95,7 +95,7 @@ double iauEe00b(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ee06a.c b/WorldWideAstronomy/SOFA/ee06a.c index 37f5bc4..c235962 100644 --- a/WorldWideAstronomy/SOFA/ee06a.c +++ b/WorldWideAstronomy/SOFA/ee06a.c @@ -57,9 +57,9 @@ double iauEe06a(double date1, double date2) ** ** This revision: 2008 May 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gst06a, gmst06, ee; @@ -76,7 +76,7 @@ double iauEe06a(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/eect00.c b/WorldWideAstronomy/SOFA/eect00.c index e9aa7df..bcffd55 100644 --- a/WorldWideAstronomy/SOFA/eect00.c +++ b/WorldWideAstronomy/SOFA/eect00.c @@ -98,9 +98,9 @@ double iauEect00(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Time since J2000.0, in Julian centuries */ @@ -236,7 +236,7 @@ double iauEect00(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/eform.c b/WorldWideAstronomy/SOFA/eform.c index 12f17f3..2cce11a 100644 --- a/WorldWideAstronomy/SOFA/eform.c +++ b/WorldWideAstronomy/SOFA/eform.c @@ -62,9 +62,9 @@ int iauEform ( int n, double *a, double *f ) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -100,7 +100,7 @@ int iauEform ( int n, double *a, double *f ) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/eo06a.c b/WorldWideAstronomy/SOFA/eo06a.c index 459585f..f969d67 100644 --- a/WorldWideAstronomy/SOFA/eo06a.c +++ b/WorldWideAstronomy/SOFA/eo06a.c @@ -61,9 +61,9 @@ double iauEo06a(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double r[3][3], x, y, s, eo; @@ -85,7 +85,7 @@ double iauEo06a(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/eors.c b/WorldWideAstronomy/SOFA/eors.c index fd00cf5..91599b4 100644 --- a/WorldWideAstronomy/SOFA/eors.c +++ b/WorldWideAstronomy/SOFA/eors.c @@ -40,9 +40,9 @@ double iauEors(double rnpb[3][3], double s) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double x, ax, xs, ys, zs, p, q, eo; @@ -62,7 +62,7 @@ double iauEors(double rnpb[3][3], double s) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/epb.c b/WorldWideAstronomy/SOFA/epb.c index d8606a8..59220da 100644 --- a/WorldWideAstronomy/SOFA/epb.c +++ b/WorldWideAstronomy/SOFA/epb.c @@ -33,9 +33,9 @@ double iauEpb(double dj1, double dj2) ** ** This revision: 2013 August 21 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* J2000.0-B1900.0 (2415019.81352) in days */ @@ -45,7 +45,7 @@ double iauEpb(double dj1, double dj2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/epb2jd.c b/WorldWideAstronomy/SOFA/epb2jd.c index 437a35d..436c72d 100644 --- a/WorldWideAstronomy/SOFA/epb2jd.c +++ b/WorldWideAstronomy/SOFA/epb2jd.c @@ -33,9 +33,9 @@ void iauEpb2jd(double epb, double *djm0, double *djm) ** ** This revision: 2013 August 13 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { *djm0 = DJM0; @@ -45,7 +45,7 @@ void iauEpb2jd(double epb, double *djm0, double *djm) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/epj.c b/WorldWideAstronomy/SOFA/epj.c index 1816bee..e4de369 100644 --- a/WorldWideAstronomy/SOFA/epj.c +++ b/WorldWideAstronomy/SOFA/epj.c @@ -33,9 +33,9 @@ double iauEpj(double dj1, double dj2) ** ** This revision: 2013 August 7 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double epj; @@ -47,7 +47,7 @@ double iauEpj(double dj1, double dj2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/epj2jd.c b/WorldWideAstronomy/SOFA/epj2jd.c index e6cc779..4cb6955 100644 --- a/WorldWideAstronomy/SOFA/epj2jd.c +++ b/WorldWideAstronomy/SOFA/epj2jd.c @@ -33,9 +33,9 @@ void iauEpj2jd(double epj, double *djm0, double *djm) ** ** This revision: 2013 August 7 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { *djm0 = DJM0; @@ -45,7 +45,7 @@ void iauEpj2jd(double epj, double *djm0, double *djm) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/epv00.c b/WorldWideAstronomy/SOFA/epv00.c index 3376bc9..a6a6e7a 100644 --- a/WorldWideAstronomy/SOFA/epv00.c +++ b/WorldWideAstronomy/SOFA/epv00.c @@ -55,19 +55,19 @@ int iauEpv00(double date1, double date2, ** 2) On return, the arrays pvh and pvb contain the following: ** ** pvh[0][0] x } -** pvh[0][1] y } heliocentric position, AU +** pvh[0][1] y } heliocentric position, au ** pvh[0][2] z } ** ** pvh[1][0] xdot } -** pvh[1][1] ydot } heliocentric velocity, AU/d +** pvh[1][1] ydot } heliocentric velocity, au/d ** pvh[1][2] zdot } ** ** pvb[0][0] x } -** pvb[0][1] y } barycentric position, AU +** pvb[0][1] y } barycentric position, au ** pvb[0][2] z } ** ** pvb[1][0] xdot } -** pvb[1][1] ydot } barycentric velocity, AU/d +** pvb[1][1] ydot } barycentric velocity, au/d ** pvb[1][2] zdot } ** ** The vectors are with respect to the Barycentric Celestial @@ -99,11 +99,11 @@ int iauEpv00(double date1, double date2, ** 5) It is permissible to use the same array for pvh and pvb, which ** will receive the barycentric values. ** -** This revision: 2013 June 18 +** This revision: 2017 March 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* @@ -2543,7 +2543,7 @@ int iauEpv00(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/eqec06.c b/WorldWideAstronomy/SOFA/eqec06.c index 1e36441..f525825 100644 --- a/WorldWideAstronomy/SOFA/eqec06.c +++ b/WorldWideAstronomy/SOFA/eqec06.c @@ -61,9 +61,9 @@ void iauEqec06(double date1, double date2, double dr, double dd, ** ** This revision: 2016 February 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rm[3][3], v1[3], v2[3], a, b; @@ -87,7 +87,7 @@ void iauEqec06(double date1, double date2, double dr, double dd, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/eqeq94.c b/WorldWideAstronomy/SOFA/eqeq94.c index 75c8024..3f332b9 100644 --- a/WorldWideAstronomy/SOFA/eqeq94.c +++ b/WorldWideAstronomy/SOFA/eqeq94.c @@ -58,9 +58,9 @@ double iauEqeq94(double date1, double date2) ** ** This revision: 2013 August 31 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, om, dpsi, deps, eps0, ee; @@ -86,7 +86,7 @@ double iauEqeq94(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/era00.c b/WorldWideAstronomy/SOFA/era00.c index 691455f..e41ac7f 100644 --- a/WorldWideAstronomy/SOFA/era00.c +++ b/WorldWideAstronomy/SOFA/era00.c @@ -61,9 +61,9 @@ double iauEra00(double dj1, double dj2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double d1, d2, t, f, theta; @@ -90,7 +90,7 @@ double iauEra00(double dj1, double dj2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fad03.c b/WorldWideAstronomy/SOFA/fad03.c index 1f31952..afa5ccf 100644 --- a/WorldWideAstronomy/SOFA/fad03.c +++ b/WorldWideAstronomy/SOFA/fad03.c @@ -38,9 +38,9 @@ double iauFad03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -57,7 +57,7 @@ double iauFad03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fae03.c b/WorldWideAstronomy/SOFA/fae03.c index 9a4cfdb..b90310d 100644 --- a/WorldWideAstronomy/SOFA/fae03.c +++ b/WorldWideAstronomy/SOFA/fae03.c @@ -41,9 +41,9 @@ double iauFae03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -56,7 +56,7 @@ double iauFae03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/faf03.c b/WorldWideAstronomy/SOFA/faf03.c index ca571ad..7a52eba 100644 --- a/WorldWideAstronomy/SOFA/faf03.c +++ b/WorldWideAstronomy/SOFA/faf03.c @@ -39,9 +39,9 @@ double iauFaf03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -60,7 +60,7 @@ double iauFaf03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/faju03.c b/WorldWideAstronomy/SOFA/faju03.c index 72bdf4c..fa383cb 100644 --- a/WorldWideAstronomy/SOFA/faju03.c +++ b/WorldWideAstronomy/SOFA/faju03.c @@ -41,9 +41,9 @@ double iauFaju03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -56,7 +56,7 @@ double iauFaju03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fal03.c b/WorldWideAstronomy/SOFA/fal03.c index 4499dc9..e54e2bb 100644 --- a/WorldWideAstronomy/SOFA/fal03.c +++ b/WorldWideAstronomy/SOFA/fal03.c @@ -38,9 +38,9 @@ double iauFal03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -57,7 +57,7 @@ double iauFal03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/falp03.c b/WorldWideAstronomy/SOFA/falp03.c index 635f297..2acecc5 100644 --- a/WorldWideAstronomy/SOFA/falp03.c +++ b/WorldWideAstronomy/SOFA/falp03.c @@ -38,9 +38,9 @@ double iauFalp03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -57,7 +57,7 @@ double iauFalp03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fama03.c b/WorldWideAstronomy/SOFA/fama03.c index 6d1340f..e133aba 100644 --- a/WorldWideAstronomy/SOFA/fama03.c +++ b/WorldWideAstronomy/SOFA/fama03.c @@ -41,9 +41,9 @@ double iauFama03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -56,7 +56,7 @@ double iauFama03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fame03.c b/WorldWideAstronomy/SOFA/fame03.c index 78eafed..11e0d6c 100644 --- a/WorldWideAstronomy/SOFA/fame03.c +++ b/WorldWideAstronomy/SOFA/fame03.c @@ -41,9 +41,9 @@ double iauFame03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -56,7 +56,7 @@ double iauFame03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fane03.c b/WorldWideAstronomy/SOFA/fane03.c index 9152d4b..c2430e6 100644 --- a/WorldWideAstronomy/SOFA/fane03.c +++ b/WorldWideAstronomy/SOFA/fane03.c @@ -38,9 +38,9 @@ double iauFane03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -53,7 +53,7 @@ double iauFane03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/faom03.c b/WorldWideAstronomy/SOFA/faom03.c index 82cfd23..839644b 100644 --- a/WorldWideAstronomy/SOFA/faom03.c +++ b/WorldWideAstronomy/SOFA/faom03.c @@ -38,9 +38,9 @@ double iauFaom03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -58,7 +58,7 @@ double iauFaom03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fapa03.c b/WorldWideAstronomy/SOFA/fapa03.c index eb0d1fe..e920996 100644 --- a/WorldWideAstronomy/SOFA/fapa03.c +++ b/WorldWideAstronomy/SOFA/fapa03.c @@ -42,9 +42,9 @@ double iauFapa03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -57,7 +57,7 @@ double iauFapa03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fasa03.c b/WorldWideAstronomy/SOFA/fasa03.c index 118a323..3192a1a 100644 --- a/WorldWideAstronomy/SOFA/fasa03.c +++ b/WorldWideAstronomy/SOFA/fasa03.c @@ -41,9 +41,9 @@ double iauFasa03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -56,7 +56,7 @@ double iauFasa03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/faur03.c b/WorldWideAstronomy/SOFA/faur03.c index 32b6cd3..9fbb447 100644 --- a/WorldWideAstronomy/SOFA/faur03.c +++ b/WorldWideAstronomy/SOFA/faur03.c @@ -38,9 +38,9 @@ double iauFaur03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -53,7 +53,7 @@ double iauFaur03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fave03.c b/WorldWideAstronomy/SOFA/fave03.c index f63a43d..93d09aa 100644 --- a/WorldWideAstronomy/SOFA/fave03.c +++ b/WorldWideAstronomy/SOFA/fave03.c @@ -41,9 +41,9 @@ double iauFave03(double t) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double a; @@ -56,7 +56,7 @@ double iauFave03(double t) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fk52h.c b/WorldWideAstronomy/SOFA/fk52h.c index 934757a..dd1a937 100644 --- a/WorldWideAstronomy/SOFA/fk52h.c +++ b/WorldWideAstronomy/SOFA/fk52h.c @@ -60,9 +60,9 @@ void iauFk52h(double r5, double d5, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int i; @@ -97,7 +97,7 @@ void iauFk52h(double r5, double d5, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fk5hip.c b/WorldWideAstronomy/SOFA/fk5hip.c index e875c43..c95e9a6 100644 --- a/WorldWideAstronomy/SOFA/fk5hip.c +++ b/WorldWideAstronomy/SOFA/fk5hip.c @@ -43,9 +43,9 @@ void iauFk5hip(double r5h[3][3], double s5h[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double v[3]; @@ -80,7 +80,7 @@ void iauFk5hip(double r5h[3][3], double s5h[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fk5hz.c b/WorldWideAstronomy/SOFA/fk5hz.c index 2bb211d..99a446b 100644 --- a/WorldWideAstronomy/SOFA/fk5hz.c +++ b/WorldWideAstronomy/SOFA/fk5hz.c @@ -76,9 +76,9 @@ void iauFk5hz(double r5, double d5, double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, p5e[3], r5h[3][3], s5h[3], vst[3], rst[3][3], p5[3], @@ -114,7 +114,7 @@ void iauFk5hz(double r5, double d5, double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fw2m.c b/WorldWideAstronomy/SOFA/fw2m.c index 526732b..9b377a6 100644 --- a/WorldWideAstronomy/SOFA/fw2m.c +++ b/WorldWideAstronomy/SOFA/fw2m.c @@ -72,9 +72,9 @@ void iauFw2m(double gamb, double phib, double psi, double eps, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Construct the matrix. */ @@ -88,7 +88,7 @@ void iauFw2m(double gamb, double phib, double psi, double eps, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/fw2xy.c b/WorldWideAstronomy/SOFA/fw2xy.c index c7620e0..ce7299c 100644 --- a/WorldWideAstronomy/SOFA/fw2xy.c +++ b/WorldWideAstronomy/SOFA/fw2xy.c @@ -57,9 +57,9 @@ void iauFw2xy(double gamb, double phib, double psi, double eps, ** ** This revision: 2013 September 2 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double r[3][3]; @@ -75,7 +75,7 @@ void iauFw2xy(double gamb, double phib, double psi, double eps, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/g2icrs.c b/WorldWideAstronomy/SOFA/g2icrs.c index 04a3c0c..f7627ed 100644 --- a/WorldWideAstronomy/SOFA/g2icrs.c +++ b/WorldWideAstronomy/SOFA/g2icrs.c @@ -68,9 +68,9 @@ void iauG2icrs ( double dl, double db, double *dr, double *dd ) ** ** This revision: 2015 January 20 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double v1[3], v2[3]; @@ -115,7 +115,7 @@ void iauG2icrs ( double dl, double db, double *dr, double *dd ) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gc2gd.c b/WorldWideAstronomy/SOFA/gc2gd.c index 3a8a9a9..3267135 100644 --- a/WorldWideAstronomy/SOFA/gc2gd.c +++ b/WorldWideAstronomy/SOFA/gc2gd.c @@ -58,9 +58,9 @@ int iauGc2gd ( int n, double xyz[3], ** ** This revision: 2013 September 1 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -88,7 +88,7 @@ int iauGc2gd ( int n, double xyz[3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gc2gde.c b/WorldWideAstronomy/SOFA/gc2gde.c index d9dae22..80d48dc 100644 --- a/WorldWideAstronomy/SOFA/gc2gde.c +++ b/WorldWideAstronomy/SOFA/gc2gde.c @@ -63,9 +63,9 @@ int iauGc2gde ( double a, double f, double xyz[3], ** ** This revision: 2014 November 7 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double aeps2, e2, e4t, ec2, ec, b, x, y, z, p2, absz, p, s0, pn, zc, @@ -153,7 +153,7 @@ int iauGc2gde ( double a, double f, double xyz[3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gd2gc.c b/WorldWideAstronomy/SOFA/gd2gc.c index 3f6e74f..6a81e93 100644 --- a/WorldWideAstronomy/SOFA/gd2gc.c +++ b/WorldWideAstronomy/SOFA/gd2gc.c @@ -61,9 +61,9 @@ int iauGd2gc ( int n, double elong, double phi, double height, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j; @@ -87,7 +87,7 @@ int iauGd2gc ( int n, double elong, double phi, double height, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gd2gce.c b/WorldWideAstronomy/SOFA/gd2gce.c index 6cd1d66..7b3b9e0 100644 --- a/WorldWideAstronomy/SOFA/gd2gce.c +++ b/WorldWideAstronomy/SOFA/gd2gce.c @@ -62,9 +62,9 @@ int iauGd2gce ( double a, double f, double elong, double phi, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double sp, cp, w, d, ac, as, r; @@ -91,7 +91,7 @@ int iauGd2gce ( double a, double f, double elong, double phi, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gmst00.c b/WorldWideAstronomy/SOFA/gmst00.c index 88730a8..443ade6 100644 --- a/WorldWideAstronomy/SOFA/gmst00.c +++ b/WorldWideAstronomy/SOFA/gmst00.c @@ -75,9 +75,9 @@ double iauGmst00(double uta, double utb, double tta, double ttb) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, gmst; @@ -99,7 +99,7 @@ double iauGmst00(double uta, double utb, double tta, double ttb) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gmst06.c b/WorldWideAstronomy/SOFA/gmst06.c index 713e9c0..6c039db 100644 --- a/WorldWideAstronomy/SOFA/gmst06.c +++ b/WorldWideAstronomy/SOFA/gmst06.c @@ -65,9 +65,9 @@ double iauGmst06(double uta, double utb, double tta, double ttb) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, gmst; @@ -90,7 +90,7 @@ double iauGmst06(double uta, double utb, double tta, double ttb) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gmst82.c b/WorldWideAstronomy/SOFA/gmst82.c index 55cd871..a736f3c 100644 --- a/WorldWideAstronomy/SOFA/gmst82.c +++ b/WorldWideAstronomy/SOFA/gmst82.c @@ -67,9 +67,9 @@ double iauGmst82(double dj1, double dj2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Coefficients of IAU 1982 GMST-UT1 model */ @@ -105,7 +105,7 @@ double iauGmst82(double dj1, double dj2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gst00a.c b/WorldWideAstronomy/SOFA/gst00a.c index 1637f99..8240e66 100644 --- a/WorldWideAstronomy/SOFA/gst00a.c +++ b/WorldWideAstronomy/SOFA/gst00a.c @@ -76,9 +76,9 @@ double iauGst00a(double uta, double utb, double tta, double ttb) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gmst00, ee00a, gst; @@ -92,7 +92,7 @@ double iauGst00a(double uta, double utb, double tta, double ttb) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gst00b.c b/WorldWideAstronomy/SOFA/gst00b.c index ccd9b5b..93114f3 100644 --- a/WorldWideAstronomy/SOFA/gst00b.c +++ b/WorldWideAstronomy/SOFA/gst00b.c @@ -84,9 +84,9 @@ double iauGst00b(double uta, double utb) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gmst00, ee00b, gst; @@ -100,7 +100,7 @@ double iauGst00b(double uta, double utb) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gst06.c b/WorldWideAstronomy/SOFA/gst06.c index e198428..84ab799 100644 --- a/WorldWideAstronomy/SOFA/gst06.c +++ b/WorldWideAstronomy/SOFA/gst06.c @@ -71,9 +71,9 @@ double iauGst06(double uta, double utb, double tta, double ttb, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double x, y, s, era, eors, gst; @@ -94,7 +94,7 @@ double iauGst06(double uta, double utb, double tta, double ttb, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gst06a.c b/WorldWideAstronomy/SOFA/gst06a.c index 8e133dc..406ba9c 100644 --- a/WorldWideAstronomy/SOFA/gst06a.c +++ b/WorldWideAstronomy/SOFA/gst06a.c @@ -67,9 +67,9 @@ double iauGst06a(double uta, double utb, double tta, double ttb) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rnpb[3][3], gst; @@ -85,7 +85,7 @@ double iauGst06a(double uta, double utb, double tta, double ttb) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/gst94.c b/WorldWideAstronomy/SOFA/gst94.c index b1d82d2..495a9f5 100644 --- a/WorldWideAstronomy/SOFA/gst94.c +++ b/WorldWideAstronomy/SOFA/gst94.c @@ -69,9 +69,9 @@ double iauGst94(double uta, double utb) ** ** This revision: 2008 May 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gmst82, eqeq94, gst; @@ -85,7 +85,7 @@ double iauGst94(double uta, double utb) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/h2fk5.c b/WorldWideAstronomy/SOFA/h2fk5.c index 98be656..ef68fc2 100644 --- a/WorldWideAstronomy/SOFA/h2fk5.c +++ b/WorldWideAstronomy/SOFA/h2fk5.c @@ -62,9 +62,9 @@ void iauH2fk5(double rh, double dh, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int i; @@ -102,7 +102,7 @@ void iauH2fk5(double rh, double dh, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/hfk5z.c b/WorldWideAstronomy/SOFA/hfk5z.c index ed084ed..79c7199 100644 --- a/WorldWideAstronomy/SOFA/hfk5z.c +++ b/WorldWideAstronomy/SOFA/hfk5z.c @@ -81,9 +81,9 @@ void iauHfk5z(double rh, double dh, double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, ph[3], r5h[3][3], s5h[3], sh[3], vst[3], @@ -129,7 +129,7 @@ void iauHfk5z(double rh, double dh, double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/icrs2g.c b/WorldWideAstronomy/SOFA/icrs2g.c index 8f1301a..9f80376 100644 --- a/WorldWideAstronomy/SOFA/icrs2g.c +++ b/WorldWideAstronomy/SOFA/icrs2g.c @@ -68,9 +68,9 @@ void iauIcrs2g ( double dr, double dd, double *dl, double *db ) ** ** This revision: 2015 January 20 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double v1[3], v2[3]; @@ -115,7 +115,7 @@ void iauIcrs2g ( double dr, double dd, double *dl, double *db ) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ir.c b/WorldWideAstronomy/SOFA/ir.c index 40cc5b9..d76a2b5 100644 --- a/WorldWideAstronomy/SOFA/ir.c +++ b/WorldWideAstronomy/SOFA/ir.c @@ -18,9 +18,9 @@ void iauIr(double r[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { r[0][0] = 1.0; @@ -37,7 +37,7 @@ void iauIr(double r[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/jd2cal.c b/WorldWideAstronomy/SOFA/jd2cal.c index e1411af..1401b29 100644 --- a/WorldWideAstronomy/SOFA/jd2cal.c +++ b/WorldWideAstronomy/SOFA/jd2cal.c @@ -26,7 +26,7 @@ int iauJd2cal(double dj1, double dj2, ** Returned (function value): ** int status: ** 0 = OK -** -1 = unacceptable date (Note 3) +** -1 = unacceptable date (Note 1) ** ** Notes: ** @@ -55,11 +55,11 @@ int iauJd2cal(double dj1, double dj2, ** P. Kenneth Seidelmann (ed), University Science Books (1992), ** Section 12.92 (p604). ** -** This revision: 2016 December 2 +** This revision: 2017 January 12 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Minimum and maximum allowed JD */ @@ -109,7 +109,7 @@ int iauJd2cal(double dj1, double dj2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/jdcalf.c b/WorldWideAstronomy/SOFA/jdcalf.c index 3def279..11c5aa9 100644 --- a/WorldWideAstronomy/SOFA/jdcalf.c +++ b/WorldWideAstronomy/SOFA/jdcalf.c @@ -62,9 +62,9 @@ int iauJdcalf(int ndp, double dj1, double dj2, int iymdf[4]) ** ** This revision: 2016 December 2 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int j, js; @@ -115,7 +115,7 @@ int iauJdcalf(int ndp, double dj1, double dj2, int iymdf[4]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ld.c b/WorldWideAstronomy/SOFA/ld.c index 22717e5..83dd189 100644 --- a/WorldWideAstronomy/SOFA/ld.c +++ b/WorldWideAstronomy/SOFA/ld.c @@ -75,9 +75,9 @@ void iauLd(double bm, double p[3], double q[3], double e[3], ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int i; @@ -106,7 +106,7 @@ void iauLd(double bm, double p[3], double q[3], double e[3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ldn.c b/WorldWideAstronomy/SOFA/ldn.c index 60756b6..ee5db32 100644 --- a/WorldWideAstronomy/SOFA/ldn.c +++ b/WorldWideAstronomy/SOFA/ldn.c @@ -83,14 +83,14 @@ void iauLdn(int n, iauLDBODY b[], double ob[3], double sc[3], ** iauPn decompose p-vector into modulus and direction ** iauLd light deflection by a solar-system body ** -** This revision: 2013 October 9 +** This revision: 2017 March 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { -/* Light time for 1 AU (days) */ +/* Light time for 1 au (days) */ const double CR = AULT/DAYSEC; int i; @@ -128,7 +128,7 @@ void iauLdn(int n, iauLDBODY b[], double ob[3], double sc[3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ldsun.c b/WorldWideAstronomy/SOFA/ldsun.c index 5884ead..b3a49fc 100644 --- a/WorldWideAstronomy/SOFA/ldsun.c +++ b/WorldWideAstronomy/SOFA/ldsun.c @@ -40,9 +40,9 @@ void iauLdsun(double p[3], double e[3], double em, double p1[3]) ** ** This revision: 2016 June 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double em2, dlim; @@ -60,7 +60,7 @@ void iauLdsun(double p[3], double e[3], double em, double p1[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/lteceq.c b/WorldWideAstronomy/SOFA/lteceq.c index 5af7665..83efe70 100644 --- a/WorldWideAstronomy/SOFA/lteceq.c +++ b/WorldWideAstronomy/SOFA/lteceq.c @@ -57,9 +57,9 @@ void iauLteceq(double epj, double dl, double db, double *dr, double *dd) ** ** This revision: 2016 February 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rm[3][3], v1[3], v2[3], a, b; @@ -83,7 +83,7 @@ void iauLteceq(double epj, double dl, double db, double *dr, double *dd) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ltecm.c b/WorldWideAstronomy/SOFA/ltecm.c index 4457fa7..d0518f0 100644 --- a/WorldWideAstronomy/SOFA/ltecm.c +++ b/WorldWideAstronomy/SOFA/ltecm.c @@ -63,9 +63,9 @@ void iauLtecm(double epj, double rm[3][3]) ** ** This revision: 2015 December 6 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Frame bias (IERS Conventions 2010, Eqs. 5.21 and 5.33) */ @@ -102,7 +102,7 @@ void iauLtecm(double epj, double rm[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/lteqec.c b/WorldWideAstronomy/SOFA/lteqec.c index 1bec7e4..19b632b 100644 --- a/WorldWideAstronomy/SOFA/lteqec.c +++ b/WorldWideAstronomy/SOFA/lteqec.c @@ -58,9 +58,9 @@ void iauLteqec(double epj, double dr, double dd, double *dl, double *db) ** ** This revision: 2016 February 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rm[3][3], v1[3], v2[3], a, b; @@ -84,7 +84,7 @@ void iauLteqec(double epj, double dr, double dd, double *dl, double *db) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ltp.c b/WorldWideAstronomy/SOFA/ltp.c index 1230cc7..ab7e537 100644 --- a/WorldWideAstronomy/SOFA/ltp.c +++ b/WorldWideAstronomy/SOFA/ltp.c @@ -54,9 +54,9 @@ void iauLtp(double epj, double rp[3][3]) ** ** This revision: 2015 December 6 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int i; @@ -85,7 +85,7 @@ void iauLtp(double epj, double rp[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ltpb.c b/WorldWideAstronomy/SOFA/ltpb.c index ab6b75f..0d14105 100644 --- a/WorldWideAstronomy/SOFA/ltpb.c +++ b/WorldWideAstronomy/SOFA/ltpb.c @@ -52,9 +52,9 @@ void iauLtpb(double epj, double rpb[3][3]) ** ** This revision: 2015 December 6 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Frame bias (IERS Conventions 2010, Eqs. 5.21 and 5.33) */ @@ -78,7 +78,7 @@ void iauLtpb(double epj, double rpb[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ltpecl.c b/WorldWideAstronomy/SOFA/ltpecl.c index 309d08f..7f10c40 100644 --- a/WorldWideAstronomy/SOFA/ltpecl.c +++ b/WorldWideAstronomy/SOFA/ltpecl.c @@ -43,9 +43,9 @@ void iauLtpecl(double epj, double vec[3]) ** ** This revision: 2016 February 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Obliquity at J2000.0 (radians). */ @@ -122,7 +122,7 @@ void iauLtpecl(double epj, double vec[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ltpequ.c b/WorldWideAstronomy/SOFA/ltpequ.c index 0dbdf70..4d2196d 100644 --- a/WorldWideAstronomy/SOFA/ltpequ.c +++ b/WorldWideAstronomy/SOFA/ltpequ.c @@ -43,9 +43,9 @@ void iauLtpequ(double epj, double veq[3]) ** ** This revision: 2016 February 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Polynomial coefficients */ @@ -122,7 +122,7 @@ void iauLtpequ(double epj, double veq[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/num00a.c b/WorldWideAstronomy/SOFA/num00a.c index d6ebbf3..66b68be 100644 --- a/WorldWideAstronomy/SOFA/num00a.c +++ b/WorldWideAstronomy/SOFA/num00a.c @@ -59,9 +59,9 @@ void iauNum00a(double date1, double date2, double rmatn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsi, deps, epsa, rb[3][3], rp[3][3], rbp[3][3], rbpn[3][3]; @@ -75,7 +75,7 @@ void iauNum00a(double date1, double date2, double rmatn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/num00b.c b/WorldWideAstronomy/SOFA/num00b.c index 2fc8588..e18c912 100644 --- a/WorldWideAstronomy/SOFA/num00b.c +++ b/WorldWideAstronomy/SOFA/num00b.c @@ -59,9 +59,9 @@ void iauNum00b(double date1, double date2, double rmatn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsi, deps, epsa, rb[3][3], rp[3][3], rbp[3][3], rbpn[3][3]; @@ -75,7 +75,7 @@ void iauNum00b(double date1, double date2, double rmatn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/num06a.c b/WorldWideAstronomy/SOFA/num06a.c index cfebd6f..b82d327 100644 --- a/WorldWideAstronomy/SOFA/num06a.c +++ b/WorldWideAstronomy/SOFA/num06a.c @@ -58,9 +58,9 @@ void iauNum06a(double date1, double date2, double rmatn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double eps, dp, de; @@ -79,7 +79,7 @@ void iauNum06a(double date1, double date2, double rmatn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/numat.c b/WorldWideAstronomy/SOFA/numat.c index cfa4272..a857d83 100644 --- a/WorldWideAstronomy/SOFA/numat.c +++ b/WorldWideAstronomy/SOFA/numat.c @@ -48,9 +48,9 @@ void iauNumat(double epsa, double dpsi, double deps, double rmatn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Build the rotation matrix. */ @@ -63,7 +63,7 @@ void iauNumat(double epsa, double dpsi, double deps, double rmatn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/nut00a.c b/WorldWideAstronomy/SOFA/nut00a.c index 0d6b9d4..560c33f 100644 --- a/WorldWideAstronomy/SOFA/nut00a.c +++ b/WorldWideAstronomy/SOFA/nut00a.c @@ -155,9 +155,9 @@ void iauNut00a(double date1, double date2, double *dpsi, double *deps) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int i; @@ -2001,7 +2001,7 @@ void iauNut00a(double date1, double date2, double *dpsi, double *deps) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/nut00b.c b/WorldWideAstronomy/SOFA/nut00b.c index b0c52a2..1249158 100644 --- a/WorldWideAstronomy/SOFA/nut00b.c +++ b/WorldWideAstronomy/SOFA/nut00b.c @@ -123,9 +123,9 @@ void iauNut00b(double date1, double date2, double *dpsi, double *deps) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, el, elp, f, d, om, arg, dp, de, sarg, carg, @@ -326,7 +326,7 @@ void iauNut00b(double date1, double date2, double *dpsi, double *deps) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/nut06a.c b/WorldWideAstronomy/SOFA/nut06a.c index 9e28a27..968cfa7 100644 --- a/WorldWideAstronomy/SOFA/nut06a.c +++ b/WorldWideAstronomy/SOFA/nut06a.c @@ -79,9 +79,9 @@ void iauNut06a(double date1, double date2, double *dpsi, double *deps) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, fj2, dp, de; @@ -104,7 +104,7 @@ void iauNut06a(double date1, double date2, double *dpsi, double *deps) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/nut80.c b/WorldWideAstronomy/SOFA/nut80.c index d242855..793134f 100644 --- a/WorldWideAstronomy/SOFA/nut80.c +++ b/WorldWideAstronomy/SOFA/nut80.c @@ -55,9 +55,9 @@ void iauNut80(double date1, double date2, double *dpsi, double *deps) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, el, elp, f, d, om, dp, de, arg, s, c; @@ -279,7 +279,7 @@ void iauNut80(double date1, double date2, double *dpsi, double *deps) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/nutm80.c b/WorldWideAstronomy/SOFA/nutm80.c index fe28285..edad3e0 100644 --- a/WorldWideAstronomy/SOFA/nutm80.c +++ b/WorldWideAstronomy/SOFA/nutm80.c @@ -52,9 +52,9 @@ void iauNutm80(double date1, double date2, double rmatn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsi, deps, epsa; @@ -71,7 +71,7 @@ void iauNutm80(double date1, double date2, double rmatn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/obl06.c b/WorldWideAstronomy/SOFA/obl06.c index 53afc34..147763a 100644 --- a/WorldWideAstronomy/SOFA/obl06.c +++ b/WorldWideAstronomy/SOFA/obl06.c @@ -49,9 +49,9 @@ double iauObl06(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, eps0; @@ -72,7 +72,7 @@ double iauObl06(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/obl80.c b/WorldWideAstronomy/SOFA/obl80.c index acedeec..2a872b2 100644 --- a/WorldWideAstronomy/SOFA/obl80.c +++ b/WorldWideAstronomy/SOFA/obl80.c @@ -51,9 +51,9 @@ double iauObl80(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, eps0; @@ -72,7 +72,7 @@ double iauObl80(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/p06e.c b/WorldWideAstronomy/SOFA/p06e.c index fe221ce..7abe044 100644 --- a/WorldWideAstronomy/SOFA/p06e.c +++ b/WorldWideAstronomy/SOFA/p06e.c @@ -127,9 +127,9 @@ void iauP06e(double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t; @@ -275,7 +275,7 @@ void iauP06e(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/p2pv.c b/WorldWideAstronomy/SOFA/p2pv.c index 7bd098b..9c65d01 100644 --- a/WorldWideAstronomy/SOFA/p2pv.c +++ b/WorldWideAstronomy/SOFA/p2pv.c @@ -25,9 +25,9 @@ void iauP2pv(double p[3], double pv[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauCp(p, pv[0]); @@ -37,7 +37,7 @@ void iauP2pv(double p[3], double pv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/p2s.c b/WorldWideAstronomy/SOFA/p2s.c index d5ab4fe..3fbe91a 100644 --- a/WorldWideAstronomy/SOFA/p2s.c +++ b/WorldWideAstronomy/SOFA/p2s.c @@ -33,9 +33,9 @@ void iauP2s(double p[3], double *theta, double *phi, double *r) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauC2s(p, theta, phi); @@ -45,7 +45,7 @@ void iauP2s(double p[3], double *theta, double *phi, double *r) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pap.c b/WorldWideAstronomy/SOFA/pap.c index b125856..6cf99ef 100644 --- a/WorldWideAstronomy/SOFA/pap.c +++ b/WorldWideAstronomy/SOFA/pap.c @@ -44,9 +44,9 @@ double iauPap(double a[3], double b[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double am, au[3], bm, st, ct, xa, ya, za, eta[3], xi[3], a2b[3], pa; @@ -93,7 +93,7 @@ double iauPap(double a[3], double b[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pas.c b/WorldWideAstronomy/SOFA/pas.c index 0054522..8748bdb 100644 --- a/WorldWideAstronomy/SOFA/pas.c +++ b/WorldWideAstronomy/SOFA/pas.c @@ -33,9 +33,9 @@ double iauPas(double al, double ap, double bl, double bp) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dl, x, y, pa; @@ -50,7 +50,7 @@ double iauPas(double al, double ap, double bl, double bp) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pb06.c b/WorldWideAstronomy/SOFA/pb06.c index 32d71d0..ad11d25 100644 --- a/WorldWideAstronomy/SOFA/pb06.c +++ b/WorldWideAstronomy/SOFA/pb06.c @@ -70,9 +70,9 @@ void iauPb06(double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double r[3][3], r31, r32; @@ -98,7 +98,7 @@ void iauPb06(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pdp.c b/WorldWideAstronomy/SOFA/pdp.c index 217a270..e47a09b 100644 --- a/WorldWideAstronomy/SOFA/pdp.c +++ b/WorldWideAstronomy/SOFA/pdp.c @@ -22,9 +22,9 @@ double iauPdp(double a[3], double b[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double w; @@ -38,7 +38,7 @@ double iauPdp(double a[3], double b[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pfw06.c b/WorldWideAstronomy/SOFA/pfw06.c index c1483ab..8b34e6d 100644 --- a/WorldWideAstronomy/SOFA/pfw06.c +++ b/WorldWideAstronomy/SOFA/pfw06.c @@ -80,9 +80,9 @@ void iauPfw06(double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t; @@ -119,7 +119,7 @@ void iauPfw06(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/plan94.c b/WorldWideAstronomy/SOFA/plan94.c index b7b767d..8ab265e 100644 --- a/WorldWideAstronomy/SOFA/plan94.c +++ b/WorldWideAstronomy/SOFA/plan94.c @@ -22,7 +22,7 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) ** 5=Jupiter, 6=Saturn, 7=Uranus, 8=Neptune) ** ** Returned (argument): -** pv double[2][3] planet p,v (heliocentric, J2000.0, AU,AU/d) +** pv double[2][3] planet p,v (heliocentric, J2000.0, au,au/d) ** ** Returned (function value): ** int status: -1 = illegal NP (outside 1-8) @@ -63,11 +63,11 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) ** 4) On successful return, the array pv contains the following: ** ** pv[0][0] x } -** pv[0][1] y } heliocentric position, AU +** pv[0][1] y } heliocentric position, au ** pv[0][2] z } ** ** pv[1][0] xdot } -** pv[1][1] ydot } heliocentric velocity, AU/d +** pv[1][1] ydot } heliocentric velocity, au/d ** pv[1][2] zdot } ** ** The reference frame is equatorial and is with respect to the @@ -162,11 +162,11 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) ** Chapront-Touze, M., Francou, G., and Laskar, J., ** Astron. Astrophys. 282, 663 (1994). ** -** This revision: 2013 June 18 +** This revision: 2017 March 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Gaussian constant */ @@ -197,7 +197,7 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) /* ** Tables giving the mean Keplerian elements, limited to t^2 terms: ** -** a semi-major axis (AU) +** a semi-major axis (au) ** dlm mean longitude (degree and arcsecond) ** e eccentricity ** pi longitude of the perihelion (degree and arcsecond) @@ -424,7 +424,7 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) at = 2.0 * atan2(sqrt((1.0 + de) / (1.0 - de)) * sin(ae2), cos(ae2)); - /* Distance (AU) and speed (radians per day). */ + /* Distance (au) and speed (radians per day). */ r = da * (1.0 - de * cos(ae)); v = GK * sqrt((1.0 + 1.0 / amas[np]) / (da * da * da)); @@ -441,7 +441,7 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) xmc = (de * cos(dp) + xcw) * xf; xpxq2 = 2 * xp * xq; - /* Position (J2000.0 ecliptic x,y,z in AU). */ + /* Position (J2000.0 ecliptic x,y,z in au). */ x = r * (xcw - xm2 * xp); y = r * (xsw + xm2 * xq); z = r * (-xm2 * ci2); @@ -451,7 +451,7 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) pv[0][1] = y * COSEPS - z * SINEPS; pv[0][2] = y * SINEPS + z * COSEPS; - /* Velocity (J2000.0 ecliptic xdot,ydot,zdot in AU/d). */ + /* Velocity (J2000.0 ecliptic xdot,ydot,zdot in au/d). */ x = v * (( -1.0 + 2.0 * xp * xp) * xms + xpxq2 * xmc); y = v * (( 1.0 - 2.0 * xq * xq) * xmc - xpxq2 * xms); z = v * (2.0 * ci2 * (xp * xms + xq * xmc)); @@ -468,7 +468,7 @@ int iauPlan94(double date1, double date2, int np, double pv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pm.c b/WorldWideAstronomy/SOFA/pm.c index fa23ba7..3c6a928 100644 --- a/WorldWideAstronomy/SOFA/pm.c +++ b/WorldWideAstronomy/SOFA/pm.c @@ -21,16 +21,16 @@ double iauPm(double p[3]) ** ** This revision: 2013 August 7 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { return sqrt( p[0]*p[0] + p[1]*p[1] + p[2]*p[2] ); /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pmat00.c b/WorldWideAstronomy/SOFA/pmat00.c index ce170a1..61e1534 100644 --- a/WorldWideAstronomy/SOFA/pmat00.c +++ b/WorldWideAstronomy/SOFA/pmat00.c @@ -57,9 +57,9 @@ void iauPmat00(double date1, double date2, double rbp[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rb[3][3], rp[3][3]; @@ -72,7 +72,7 @@ void iauPmat00(double date1, double date2, double rbp[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pmat06.c b/WorldWideAstronomy/SOFA/pmat06.c index 8ede2f7..552998c 100644 --- a/WorldWideAstronomy/SOFA/pmat06.c +++ b/WorldWideAstronomy/SOFA/pmat06.c @@ -58,9 +58,9 @@ void iauPmat06(double date1, double date2, double rbp[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gamb, phib, psib, epsa; @@ -76,7 +76,7 @@ void iauPmat06(double date1, double date2, double rbp[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pmat76.c b/WorldWideAstronomy/SOFA/pmat76.c index 3cc9ae6..758fda9 100644 --- a/WorldWideAstronomy/SOFA/pmat76.c +++ b/WorldWideAstronomy/SOFA/pmat76.c @@ -73,9 +73,9 @@ void iauPmat76(double date1, double date2, double rmatp[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double zeta, z, theta, wmat[3][3]; @@ -95,7 +95,7 @@ void iauPmat76(double date1, double date2, double rmatp[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pmp.c b/WorldWideAstronomy/SOFA/pmp.c index a191e6e..5eb2af9 100644 --- a/WorldWideAstronomy/SOFA/pmp.c +++ b/WorldWideAstronomy/SOFA/pmp.c @@ -26,9 +26,9 @@ void iauPmp(double a[3], double b[3], double amb[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { amb[0] = a[0] - b[0]; @@ -39,7 +39,7 @@ void iauPmp(double a[3], double b[3], double amb[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pmpx.c b/WorldWideAstronomy/SOFA/pmpx.c index 1c5fd78..bddd0c3 100644 --- a/WorldWideAstronomy/SOFA/pmpx.c +++ b/WorldWideAstronomy/SOFA/pmpx.c @@ -53,9 +53,9 @@ void iauPmpx(double rc, double dc, double pr, double pd, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Km/s to au/year */ @@ -98,7 +98,7 @@ void iauPmpx(double rc, double dc, double pr, double pd, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pmsafe.c b/WorldWideAstronomy/SOFA/pmsafe.c index 7d3d22b..e4c627b 100644 --- a/WorldWideAstronomy/SOFA/pmsafe.c +++ b/WorldWideAstronomy/SOFA/pmsafe.c @@ -112,9 +112,9 @@ int iauPmsafe(double ra1, double dec1, double pmr1, double pmd1, ** ** This revision: 2014 July 1 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -151,7 +151,7 @@ int iauPmsafe(double ra1, double dec1, double pmr1, double pmd1, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pn.c b/WorldWideAstronomy/SOFA/pn.c index e3c51e4..6e97286 100644 --- a/WorldWideAstronomy/SOFA/pn.c +++ b/WorldWideAstronomy/SOFA/pn.c @@ -35,9 +35,9 @@ void iauPn(double p[3], double *r, double u[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double w; @@ -63,7 +63,7 @@ void iauPn(double p[3], double *r, double u[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pn00.c b/WorldWideAstronomy/SOFA/pn00.c index a335e02..296a934 100644 --- a/WorldWideAstronomy/SOFA/pn00.c +++ b/WorldWideAstronomy/SOFA/pn00.c @@ -102,9 +102,9 @@ void iauPn00(double date1, double date2, double dpsi, double deps, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsipr, depspr, rbpw[3][3], rnw[3][3]; @@ -131,7 +131,7 @@ void iauPn00(double date1, double date2, double dpsi, double deps, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pn00a.c b/WorldWideAstronomy/SOFA/pn00a.c index 92159dd..f152910 100644 --- a/WorldWideAstronomy/SOFA/pn00a.c +++ b/WorldWideAstronomy/SOFA/pn00a.c @@ -102,9 +102,9 @@ void iauPn00a(double date1, double date2, ** ** This revision: 2013 November 14 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Nutation. */ @@ -117,7 +117,7 @@ void iauPn00a(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pn00b.c b/WorldWideAstronomy/SOFA/pn00b.c index a6955ab..71d6cf7 100644 --- a/WorldWideAstronomy/SOFA/pn00b.c +++ b/WorldWideAstronomy/SOFA/pn00b.c @@ -102,9 +102,9 @@ void iauPn00b(double date1, double date2, ** ** This revision: 2013 November 13 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Nutation. */ @@ -117,7 +117,7 @@ void iauPn00b(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pn06.c b/WorldWideAstronomy/SOFA/pn06.c index 18aa18e..8ca412d 100644 --- a/WorldWideAstronomy/SOFA/pn06.c +++ b/WorldWideAstronomy/SOFA/pn06.c @@ -100,9 +100,9 @@ void iauPn06(double date1, double date2, double dpsi, double deps, ** ** This revision: 2013 November 14 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gamb, phib, psib, eps, r1[3][3], r2[3][3], rt[3][3]; @@ -141,7 +141,7 @@ void iauPn06(double date1, double date2, double dpsi, double deps, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pn06a.c b/WorldWideAstronomy/SOFA/pn06a.c index 05ba3ce..ca2e512 100644 --- a/WorldWideAstronomy/SOFA/pn06a.c +++ b/WorldWideAstronomy/SOFA/pn06a.c @@ -92,9 +92,9 @@ void iauPn06a(double date1, double date2, ** ** This revision: 2013 November 13 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Nutation. */ @@ -107,7 +107,7 @@ void iauPn06a(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pnm00a.c b/WorldWideAstronomy/SOFA/pnm00a.c index c11deed..cf75ad7 100644 --- a/WorldWideAstronomy/SOFA/pnm00a.c +++ b/WorldWideAstronomy/SOFA/pnm00a.c @@ -60,9 +60,9 @@ void iauPnm00a(double date1, double date2, double rbpn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsi, deps, epsa, rb[3][3], rp[3][3], rbp[3][3], rn[3][3]; @@ -75,7 +75,7 @@ void iauPnm00a(double date1, double date2, double rbpn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pnm00b.c b/WorldWideAstronomy/SOFA/pnm00b.c index 7a49255..33c07c1 100644 --- a/WorldWideAstronomy/SOFA/pnm00b.c +++ b/WorldWideAstronomy/SOFA/pnm00b.c @@ -60,9 +60,9 @@ void iauPnm00b(double date1, double date2, double rbpn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dpsi, deps, epsa, rb[3][3], rp[3][3], rbp[3][3], rn[3][3]; @@ -75,7 +75,7 @@ void iauPnm00b(double date1, double date2, double rbpn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pnm06a.c b/WorldWideAstronomy/SOFA/pnm06a.c index ffa8c64..2a4d3fe 100644 --- a/WorldWideAstronomy/SOFA/pnm06a.c +++ b/WorldWideAstronomy/SOFA/pnm06a.c @@ -57,9 +57,9 @@ void iauPnm06a(double date1, double date2, double rnpb[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double gamb, phib, psib, epsa, dp, de; @@ -78,7 +78,7 @@ void iauPnm06a(double date1, double date2, double rnpb[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pnm80.c b/WorldWideAstronomy/SOFA/pnm80.c index 2b4a41d..4219d2f 100644 --- a/WorldWideAstronomy/SOFA/pnm80.c +++ b/WorldWideAstronomy/SOFA/pnm80.c @@ -59,9 +59,9 @@ void iauPnm80(double date1, double date2, double rmatpn[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rmatp[3][3], rmatn[3][3]; @@ -80,7 +80,7 @@ void iauPnm80(double date1, double date2, double rmatpn[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pom00.c b/WorldWideAstronomy/SOFA/pom00.c index d9c8ab7..301eb0e 100644 --- a/WorldWideAstronomy/SOFA/pom00.c +++ b/WorldWideAstronomy/SOFA/pom00.c @@ -53,9 +53,9 @@ void iauPom00(double xp, double yp, double sp, double rpom[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -69,7 +69,7 @@ void iauPom00(double xp, double yp, double sp, double rpom[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ppp.c b/WorldWideAstronomy/SOFA/ppp.c index 86c0551..bfc18f4 100644 --- a/WorldWideAstronomy/SOFA/ppp.c +++ b/WorldWideAstronomy/SOFA/ppp.c @@ -26,9 +26,9 @@ void iauPpp(double a[3], double b[3], double apb[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { apb[0] = a[0] + b[0]; @@ -39,7 +39,7 @@ void iauPpp(double a[3], double b[3], double apb[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ppsp.c b/WorldWideAstronomy/SOFA/ppsp.c index 44c64fb..70db81a 100644 --- a/WorldWideAstronomy/SOFA/ppsp.c +++ b/WorldWideAstronomy/SOFA/ppsp.c @@ -30,9 +30,9 @@ void iauPpsp(double a[3], double s, double b[3], double apsb[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double sb[3]; @@ -48,7 +48,7 @@ void iauPpsp(double a[3], double s, double b[3], double apsb[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pr00.c b/WorldWideAstronomy/SOFA/pr00.c index 3446173..b00ea09 100644 --- a/WorldWideAstronomy/SOFA/pr00.c +++ b/WorldWideAstronomy/SOFA/pr00.c @@ -73,9 +73,9 @@ void iauPr00(double date1, double date2, double *dpsipr, double *depspr) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t; @@ -96,7 +96,7 @@ void iauPr00(double date1, double date2, double *dpsipr, double *depspr) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/prec76.c b/WorldWideAstronomy/SOFA/prec76.c index 84f782c..477c50c 100644 --- a/WorldWideAstronomy/SOFA/prec76.c +++ b/WorldWideAstronomy/SOFA/prec76.c @@ -73,9 +73,9 @@ void iauPrec76(double date01, double date02, double date11, double date12, ** ** This revision: 2013 November 19 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t0, t, tas2r, w; @@ -102,7 +102,7 @@ void iauPrec76(double date01, double date02, double date11, double date12, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pv2p.c b/WorldWideAstronomy/SOFA/pv2p.c index bf6d7ab..86bd791 100644 --- a/WorldWideAstronomy/SOFA/pv2p.c +++ b/WorldWideAstronomy/SOFA/pv2p.c @@ -24,9 +24,9 @@ void iauPv2p(double pv[2][3], double p[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauCp(pv[0], p); @@ -35,7 +35,7 @@ void iauPv2p(double pv[2][3], double p[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pv2s.c b/WorldWideAstronomy/SOFA/pv2s.c index e4355ca..18c21b5 100644 --- a/WorldWideAstronomy/SOFA/pv2s.c +++ b/WorldWideAstronomy/SOFA/pv2s.c @@ -41,9 +41,9 @@ void iauPv2s(double pv[2][3], ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double x, y, z, xd, yd, zd, rxy2, rxy, r2, rtrue, rw, xyp; @@ -98,7 +98,7 @@ void iauPv2s(double pv[2][3], /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvdpv.c b/WorldWideAstronomy/SOFA/pvdpv.c index 05362b6..7fffb3d 100644 --- a/WorldWideAstronomy/SOFA/pvdpv.c +++ b/WorldWideAstronomy/SOFA/pvdpv.c @@ -32,9 +32,9 @@ void iauPvdpv(double a[2][3], double b[2][3], double adb[2]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double adbd, addb; @@ -56,7 +56,7 @@ void iauPvdpv(double a[2][3], double b[2][3], double adb[2]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvm.c b/WorldWideAstronomy/SOFA/pvm.c index 82b29e7..412516b 100644 --- a/WorldWideAstronomy/SOFA/pvm.c +++ b/WorldWideAstronomy/SOFA/pvm.c @@ -25,9 +25,9 @@ void iauPvm(double pv[2][3], double *r, double *s) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Distance. */ @@ -40,7 +40,7 @@ void iauPvm(double pv[2][3], double *r, double *s) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvmpv.c b/WorldWideAstronomy/SOFA/pvmpv.c index c63be51..74de87a 100644 --- a/WorldWideAstronomy/SOFA/pvmpv.c +++ b/WorldWideAstronomy/SOFA/pvmpv.c @@ -29,9 +29,9 @@ void iauPvmpv(double a[2][3], double b[2][3], double amb[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauPmp(a[0], b[0], amb[0]); @@ -41,7 +41,7 @@ void iauPvmpv(double a[2][3], double b[2][3], double amb[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvppv.c b/WorldWideAstronomy/SOFA/pvppv.c index 879156a..2980e45 100644 --- a/WorldWideAstronomy/SOFA/pvppv.c +++ b/WorldWideAstronomy/SOFA/pvppv.c @@ -29,9 +29,9 @@ void iauPvppv(double a[2][3], double b[2][3], double apb[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauPpp(a[0], b[0], apb[0]); @@ -41,7 +41,7 @@ void iauPvppv(double a[2][3], double b[2][3], double apb[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvstar.c b/WorldWideAstronomy/SOFA/pvstar.c index ad7f08b..90097e9 100644 --- a/WorldWideAstronomy/SOFA/pvstar.c +++ b/WorldWideAstronomy/SOFA/pvstar.c @@ -15,7 +15,7 @@ int iauPvstar(double pv[2][3], double *ra, double *dec, ** Status: support function. ** ** Given (Note 1): -** pv double[2][3] pv-vector (AU, AU/day) +** pv double[2][3] pv-vector (au, au/day) ** ** Returned (Note 2): ** ra double right ascension (radians) @@ -70,7 +70,7 @@ int iauPvstar(double pv[2][3], double *ra, double *dec, ** 3) Care is needed with units. The star coordinates are in radians ** and the proper motions in radians per Julian year, but the ** parallax is in arcseconds; the radial velocity is in km/s, but -** the pv-vector result is in AU and AU/day. +** the pv-vector result is in au and au/day. ** ** 4) The proper motions are the rate of change of the right ascension ** and declination at the catalog epoch and are in radians per Julian @@ -98,23 +98,23 @@ int iauPvstar(double pv[2][3], double *ra, double *dec, ** ** Stumpff, P., 1985, Astron.Astrophys. 144, 232-240. ** -** This revision: 2013 June 18 +** This revision: 2017 March 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double r, x[3], vr, ur[3], vt, ut[3], bett, betr, d, w, del, usr[3], ust[3], a, rad, decd, rd; -/* Isolate the radial component of the velocity (AU/day, inertial). */ +/* Isolate the radial component of the velocity (au/day, inertial). */ iauPn(pv[0], &r, x); vr = iauPdp(x, pv[1]); iauSxp(vr, x, ur); -/* Isolate the transverse component of the velocity (AU/day, inertial). */ +/* Isolate the transverse component of the velocity (au/day, inertial). */ iauPmp(pv[1], ur, ut); vt = iauPm(ut); @@ -124,9 +124,9 @@ int iauPvstar(double pv[2][3], double *ra, double *dec, /* The inertial-to-observed correction terms. */ d = 1.0 + betr; - w = 1.0 - betr*betr - bett*bett; - if (d == 0.0 || w < 0) return -1; - del = sqrt(w) - 1.0; + w = betr*betr + bett*bett; + if (d == 0.0 || w > 1.0) return -1; + del = - w / (sqrt(1.0-w) + 1.0); /* Apply relativistic correction factor to radial velocity component. */ w = (betr != 0) ? (betr - del) / (betr * d) : 1.0; @@ -136,7 +136,7 @@ int iauPvstar(double pv[2][3], double *ra, double *dec, /* component. */ iauSxp(1.0/d, ut, ust); -/* Combine the two to obtain the observed velocity vector (AU/day). */ +/* Combine the two to obtain the observed velocity vector (au/day). */ iauPpp(usr, ust, pv[1]); /* Cartesian to spherical. */ @@ -161,7 +161,7 @@ int iauPvstar(double pv[2][3], double *ra, double *dec, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvtob.c b/WorldWideAstronomy/SOFA/pvtob.c index 06c1621..b7ceae9 100644 --- a/WorldWideAstronomy/SOFA/pvtob.c +++ b/WorldWideAstronomy/SOFA/pvtob.c @@ -68,9 +68,9 @@ void iauPvtob(double elong, double phi, double hm, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Earth rotation rate in radians per UT1 second */ @@ -107,7 +107,7 @@ void iauPvtob(double elong, double phi, double hm, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvu.c b/WorldWideAstronomy/SOFA/pvu.c index 7e5bea2..2f9e341 100644 --- a/WorldWideAstronomy/SOFA/pvu.c +++ b/WorldWideAstronomy/SOFA/pvu.c @@ -35,9 +35,9 @@ void iauPvu(double dt, double pv[2][3], double upv[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauPpsp(pv[0], dt, pv[1], upv[0]); @@ -47,7 +47,7 @@ void iauPvu(double dt, double pv[2][3], double upv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvup.c b/WorldWideAstronomy/SOFA/pvup.c index 5bd6a43..bdd4260 100644 --- a/WorldWideAstronomy/SOFA/pvup.c +++ b/WorldWideAstronomy/SOFA/pvup.c @@ -29,9 +29,9 @@ void iauPvup(double dt, double pv[2][3], double p[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { p[0] = pv[0][0] + dt * pv[1][0]; @@ -42,7 +42,7 @@ void iauPvup(double dt, double pv[2][3], double p[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pvxpv.c b/WorldWideAstronomy/SOFA/pvxpv.c index 2af53a1..e4b8708 100644 --- a/WorldWideAstronomy/SOFA/pvxpv.c +++ b/WorldWideAstronomy/SOFA/pvxpv.c @@ -37,9 +37,9 @@ void iauPvxpv(double a[2][3], double b[2][3], double axb[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double wa[2][3], wb[2][3], axbd[3], adxb[3]; @@ -61,7 +61,7 @@ void iauPvxpv(double a[2][3], double b[2][3], double axb[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/pxp.c b/WorldWideAstronomy/SOFA/pxp.c index 723e080..546c1cb 100644 --- a/WorldWideAstronomy/SOFA/pxp.c +++ b/WorldWideAstronomy/SOFA/pxp.c @@ -26,9 +26,9 @@ void iauPxp(double a[3], double b[3], double axb[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double xa, ya, za, xb, yb, zb; @@ -48,7 +48,7 @@ void iauPxp(double a[3], double b[3], double axb[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/refco.c b/WorldWideAstronomy/SOFA/refco.c index dd079f8..fc63ec5 100644 --- a/WorldWideAstronomy/SOFA/refco.c +++ b/WorldWideAstronomy/SOFA/refco.c @@ -152,9 +152,9 @@ void iauRefco(double phpa, double tc, double rh, double wl, ** ** This revision: 2013 October 9 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int optic; @@ -207,7 +207,7 @@ void iauRefco(double phpa, double tc, double rh, double wl, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/rm2v.c b/WorldWideAstronomy/SOFA/rm2v.c index 70e6365..4ac8c22 100644 --- a/WorldWideAstronomy/SOFA/rm2v.c +++ b/WorldWideAstronomy/SOFA/rm2v.c @@ -36,9 +36,9 @@ void iauRm2v(double r[3][3], double w[3]) ** ** This revision: 2015 January 30 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double x, y, z, s2, c2, phi, f; @@ -65,7 +65,7 @@ void iauRm2v(double r[3][3], double w[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/rv2m.c b/WorldWideAstronomy/SOFA/rv2m.c index 5ab96d9..2ab0e6d 100644 --- a/WorldWideAstronomy/SOFA/rv2m.c +++ b/WorldWideAstronomy/SOFA/rv2m.c @@ -33,9 +33,9 @@ void iauRv2m(double w[3], double r[3][3]) ** ** This revision: 2015 January 30 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double x, y, z, phi, s, c, f; @@ -72,7 +72,7 @@ void iauRv2m(double w[3], double r[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/rx.c b/WorldWideAstronomy/SOFA/rx.c index 1a0c657..601c7b3 100644 --- a/WorldWideAstronomy/SOFA/rx.c +++ b/WorldWideAstronomy/SOFA/rx.c @@ -35,9 +35,9 @@ void iauRx(double phi, double r[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double s, c, a10, a11, a12, a20, a21, a22; @@ -64,7 +64,7 @@ void iauRx(double phi, double r[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/rxp.c b/WorldWideAstronomy/SOFA/rxp.c index 506b2fa..0888709 100644 --- a/WorldWideAstronomy/SOFA/rxp.c +++ b/WorldWideAstronomy/SOFA/rxp.c @@ -28,9 +28,9 @@ void iauRxp(double r[3][3], double p[3], double rp[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double w, wrp[3]; @@ -53,7 +53,7 @@ void iauRxp(double r[3][3], double p[3], double rp[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/rxpv.c b/WorldWideAstronomy/SOFA/rxpv.c index 4f22247..2a17369 100644 --- a/WorldWideAstronomy/SOFA/rxpv.c +++ b/WorldWideAstronomy/SOFA/rxpv.c @@ -28,9 +28,9 @@ void iauRxpv(double r[3][3], double pv[2][3], double rpv[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauRxp(r, pv[0], rpv[0]); @@ -40,7 +40,7 @@ void iauRxpv(double r[3][3], double pv[2][3], double rpv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/rxr.c b/WorldWideAstronomy/SOFA/rxr.c index eb934f3..84f74b3 100644 --- a/WorldWideAstronomy/SOFA/rxr.c +++ b/WorldWideAstronomy/SOFA/rxr.c @@ -29,9 +29,9 @@ void iauRxr(double a[3][3], double b[3][3], double atb[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int i, j, k; @@ -53,7 +53,7 @@ void iauRxr(double a[3][3], double b[3][3], double atb[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ry.c b/WorldWideAstronomy/SOFA/ry.c index a164d87..1221ae9 100644 --- a/WorldWideAstronomy/SOFA/ry.c +++ b/WorldWideAstronomy/SOFA/ry.c @@ -35,9 +35,9 @@ void iauRy(double theta, double r[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double s, c, a00, a01, a02, a20, a21, a22; @@ -64,7 +64,7 @@ void iauRy(double theta, double r[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/rz.c b/WorldWideAstronomy/SOFA/rz.c index 70d4aac..5d95457 100644 --- a/WorldWideAstronomy/SOFA/rz.c +++ b/WorldWideAstronomy/SOFA/rz.c @@ -35,9 +35,9 @@ void iauRz(double psi, double r[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double s, c, a00, a01, a02, a10, a11, a12; @@ -64,7 +64,7 @@ void iauRz(double psi, double r[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s00.c b/WorldWideAstronomy/SOFA/s00.c index ba5fac6..1e01613 100644 --- a/WorldWideAstronomy/SOFA/s00.c +++ b/WorldWideAstronomy/SOFA/s00.c @@ -83,9 +83,9 @@ double iauS00(double date1, double date2, double x, double y) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Time since J2000.0, in Julian centuries */ @@ -325,7 +325,7 @@ double iauS00(double date1, double date2, double x, double y) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s00a.c b/WorldWideAstronomy/SOFA/s00a.c index 115586b..15f50ee 100644 --- a/WorldWideAstronomy/SOFA/s00a.c +++ b/WorldWideAstronomy/SOFA/s00a.c @@ -76,9 +76,9 @@ double iauS00a(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3], x, y, s; @@ -97,7 +97,7 @@ double iauS00a(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s00b.c b/WorldWideAstronomy/SOFA/s00b.c index ddf61e8..c8a2a32 100644 --- a/WorldWideAstronomy/SOFA/s00b.c +++ b/WorldWideAstronomy/SOFA/s00b.c @@ -76,9 +76,9 @@ double iauS00b(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3], x, y, s; @@ -97,7 +97,7 @@ double iauS00b(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s06.c b/WorldWideAstronomy/SOFA/s06.c index 34fad71..fac8c0a 100644 --- a/WorldWideAstronomy/SOFA/s06.c +++ b/WorldWideAstronomy/SOFA/s06.c @@ -80,9 +80,9 @@ double iauS06(double date1, double date2, double x, double y) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Time since J2000.0, in Julian centuries */ @@ -322,7 +322,7 @@ double iauS06(double date1, double date2, double x, double y) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s06a.c b/WorldWideAstronomy/SOFA/s06a.c index 6f77afd..759380e 100644 --- a/WorldWideAstronomy/SOFA/s06a.c +++ b/WorldWideAstronomy/SOFA/s06a.c @@ -78,9 +78,9 @@ double iauS06a(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rnpb[3][3], x, y, s; @@ -99,7 +99,7 @@ double iauS06a(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s2c.c b/WorldWideAstronomy/SOFA/s2c.c index 3fda172..ab3c678 100644 --- a/WorldWideAstronomy/SOFA/s2c.c +++ b/WorldWideAstronomy/SOFA/s2c.c @@ -22,9 +22,9 @@ void iauS2c(double theta, double phi, double c[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double cp; @@ -39,7 +39,7 @@ void iauS2c(double theta, double phi, double c[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s2p.c b/WorldWideAstronomy/SOFA/s2p.c index 827a7a6..7285c35 100644 --- a/WorldWideAstronomy/SOFA/s2p.c +++ b/WorldWideAstronomy/SOFA/s2p.c @@ -27,9 +27,9 @@ void iauS2p(double theta, double phi, double r, double p[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double u[3]; @@ -42,7 +42,7 @@ void iauS2p(double theta, double phi, double r, double p[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s2pv.c b/WorldWideAstronomy/SOFA/s2pv.c index 8aef68f..43dfa3b 100644 --- a/WorldWideAstronomy/SOFA/s2pv.c +++ b/WorldWideAstronomy/SOFA/s2pv.c @@ -28,9 +28,9 @@ void iauS2pv(double theta, double phi, double r, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double st, ct, sp, cp, rcp, x, y, rpd, w; @@ -57,7 +57,7 @@ void iauS2pv(double theta, double phi, double r, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/s2xpv.c b/WorldWideAstronomy/SOFA/s2xpv.c index 07f412f..3f33f68 100644 --- a/WorldWideAstronomy/SOFA/s2xpv.c +++ b/WorldWideAstronomy/SOFA/s2xpv.c @@ -29,9 +29,9 @@ void iauS2xpv(double s1, double s2, double pv[2][3], double spv[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauSxp(s1, pv[0], spv[0]); @@ -41,7 +41,7 @@ void iauS2xpv(double s1, double s2, double pv[2][3], double spv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/sepp.c b/WorldWideAstronomy/SOFA/sepp.c index f5d9a0f..d1e496e 100644 --- a/WorldWideAstronomy/SOFA/sepp.c +++ b/WorldWideAstronomy/SOFA/sepp.c @@ -37,9 +37,9 @@ double iauSepp(double a[3], double b[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double axb[3], ss, cs, s; @@ -59,7 +59,7 @@ double iauSepp(double a[3], double b[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/seps.c b/WorldWideAstronomy/SOFA/seps.c index 361485c..52377c3 100644 --- a/WorldWideAstronomy/SOFA/seps.c +++ b/WorldWideAstronomy/SOFA/seps.c @@ -28,9 +28,9 @@ double iauSeps(double al, double ap, double bl, double bp) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double ac[3], bc[3], s; @@ -47,7 +47,7 @@ double iauSeps(double al, double ap, double bl, double bp) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/sofa.h b/WorldWideAstronomy/SOFA/sofa.h index ad39609..0af1cc8 100644 --- a/WorldWideAstronomy/SOFA/sofa.h +++ b/WorldWideAstronomy/SOFA/sofa.h @@ -13,9 +13,9 @@ ** ** This revision: 2016 March 10 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ #include "sofam.h" @@ -460,7 +460,7 @@ void iauSxpv(double s, double pv[2][3], double spv[2][3]); /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/sofam.h b/WorldWideAstronomy/SOFA/sofam.h index d2c3e19..5143665 100644 --- a/WorldWideAstronomy/SOFA/sofam.h +++ b/WorldWideAstronomy/SOFA/sofam.h @@ -15,11 +15,11 @@ ** the context of the SOFA software, and have no other official IAU ** status. In addition, self consistency is not guaranteed. ** -** This revision: 2013 August 27 +** This revision: 2017 March 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ /* Star-independent astrometry parameters */ @@ -108,17 +108,17 @@ typedef struct { /* TT minus TAI (s) */ #define TTMTAI (32.184) -/* Astronomical unit (m) */ -#define DAU (149597870e3) +/* Astronomical unit (m, IAU 2012) */ +#define DAU (149597870.7e3) /* Speed of light (m/s) */ #define CMPS 299792458.0 /* Light time for 1 au (s) */ -#define AULT 499.004782 +#define AULT (DAU/CMPS) -/* Speed of light (AU per day) */ -#define DC (DAYSEC / AULT) +/* Speed of light (au per day) */ +#define DC (DAYSEC/AULT) /* L_G = 1 - d(TT)/d(TCG) */ #define ELG (6.969290134e-10) @@ -155,7 +155,7 @@ typedef struct { /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/sp00.c b/WorldWideAstronomy/SOFA/sp00.c index 12dd736..28015c2 100644 --- a/WorldWideAstronomy/SOFA/sp00.c +++ b/WorldWideAstronomy/SOFA/sp00.c @@ -54,9 +54,9 @@ double iauSp00(double date1, double date2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double t, sp; @@ -72,7 +72,7 @@ double iauSp00(double date1, double date2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/starpm.c b/WorldWideAstronomy/SOFA/starpm.c index 46bf8ec..8396c3a 100644 --- a/WorldWideAstronomy/SOFA/starpm.c +++ b/WorldWideAstronomy/SOFA/starpm.c @@ -113,9 +113,9 @@ int iauStarpm(double ra1, double dec1, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double pv1[2][3], tl1, dt, pv[2][3], r2, rdv, v2, c2mv2, tl2, @@ -159,7 +159,7 @@ int iauStarpm(double ra1, double dec1, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/starpv.c b/WorldWideAstronomy/SOFA/starpv.c index 0dfd5b6..a623190 100644 --- a/WorldWideAstronomy/SOFA/starpv.c +++ b/WorldWideAstronomy/SOFA/starpv.c @@ -24,7 +24,7 @@ int iauStarpv(double ra, double dec, ** rv double radial velocity (km/s, positive = receding) ** ** Returned (Note 2): -** pv double[2][3] pv-vector (AU, AU/day) +** pv double[2][3] pv-vector (au, au/day) ** ** Returned (function value): ** int status: @@ -58,7 +58,7 @@ int iauStarpv(double ra, double dec, ** direction", where the object was located at the catalog epoch, be ** required, it may be obtained by calculating the magnitude of the ** position vector pv[0][0-2] dividing by the speed of light in -** AU/day to give the light-time, and then multiplying the space +** au/day to give the light-time, and then multiplying the space ** velocity pv[1][0-2] by this light-time and adding the result to ** pv[0][0-2]. ** @@ -77,7 +77,7 @@ int iauStarpv(double ra, double dec, ** 3) Care is needed with units. The star coordinates are in radians ** and the proper motions in radians per Julian year, but the ** parallax is in arcseconds; the radial velocity is in km/s, but -** the pv-vector result is in AU and AU/day. +** the pv-vector result is in au and au/day. ** ** 4) The RA proper motion is in terms of coordinate angle, not true ** angle. If the catalog uses arcseconds for both RA and Dec proper @@ -118,11 +118,11 @@ int iauStarpv(double ra, double dec, ** ** Stumpff, P., 1985, Astron.Astrophys. 144, 232-240. ** -** This revision: 2016 December 8 +** This revision: 2017 March 16 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { /* Smallest allowed parallax */ @@ -143,7 +143,7 @@ int iauStarpv(double ra, double dec, od = 0.0, odel = 0.0; /* warnings */ -/* Distance (AU). */ +/* Distance (au). */ if (px >= PXMIN) { w = px; iwarn = 0; @@ -153,14 +153,14 @@ int iauStarpv(double ra, double dec, } r = DR2AS / w; -/* Radial velocity (AU/day). */ +/* Radial velocity (au/day). */ rd = DAYSEC * rv * 1e3 / DAU; /* Proper motion (radian/day). */ rad = pmr / DJY; decd = pmd / DJY; -/* To pv-vector (AU,AU/day). */ +/* To pv-vector (au,au/day). */ iauS2pv(ra, dec, r, rad, decd, rd, pv); /* If excessive velocity, arbitrarily set it to zero. */ @@ -170,12 +170,12 @@ int iauStarpv(double ra, double dec, iwarn += 2; } -/* Isolate the radial component of the velocity (AU/day). */ +/* Isolate the radial component of the velocity (au/day). */ iauPn(pv[0], &w, x); vsr = iauPdp(x, pv[1]); iauSxp(vsr, x, usr); -/* Isolate the transverse component of the velocity (AU/day). */ +/* Isolate the transverse component of the velocity (au/day). */ iauPmp(pv[1], usr, ust); vst = iauPm(ust); @@ -219,7 +219,7 @@ int iauStarpv(double ra, double dec, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/sxp.c b/WorldWideAstronomy/SOFA/sxp.c index 9cd8540..5fca8d7 100644 --- a/WorldWideAstronomy/SOFA/sxp.c +++ b/WorldWideAstronomy/SOFA/sxp.c @@ -25,9 +25,9 @@ void iauSxp(double s, double p[3], double sp[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { sp[0] = s * p[0]; @@ -38,7 +38,7 @@ void iauSxp(double s, double p[3], double sp[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/sxpv.c b/WorldWideAstronomy/SOFA/sxpv.c index 2181f40..f96e838 100644 --- a/WorldWideAstronomy/SOFA/sxpv.c +++ b/WorldWideAstronomy/SOFA/sxpv.c @@ -28,9 +28,9 @@ void iauSxpv(double s, double pv[2][3], double spv[2][3]) ** ** This revision: 2013 August 7 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauS2xpv(s, s, pv, spv); @@ -39,7 +39,7 @@ void iauSxpv(double s, double pv[2][3], double spv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/t_sofa_c.c b/WorldWideAstronomy/SOFA/t_sofa_c.c index 0f989d8..6cd355b 100644 --- a/WorldWideAstronomy/SOFA/t_sofa_c.c +++ b/WorldWideAstronomy/SOFA/t_sofa_c.c @@ -1,9779 +1,9778 @@ -#include -#include - -static int verbose = 0; - -/* -** - - - - - - - - - -** t _ s o f a _ c -** - - - - - - - - - -** -** Validate the SOFA C functions. -** -** Each SOFA function is at least called and a usually quite basic test -** is performed. Successful completion is signalled by a confirming -** message. Failure of a given function or group of functions results -** in error messages. -** -** All messages go to stdout. -** -** This revision: 2016 December 22 -** -** SOFA release 2016-05-03 -** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. -*/ - -static void viv(int ival, int ivalok, - const char *func, const char *test, int *status) -/* -** - - - - -** v i v -** - - - - -** -** Validate an integer result. -** -** Internal function used by t_sofa_c program. -** -** Given: -** ival int value computed by function under test -** ivalok int correct value -** func char[] name of function under test -** test char[] name of individual test -** -** Given and returned: -** status int set to TRUE if test fails -** -** This revision: 2013 August 7 -*/ -{ - if (ival != ivalok) { - *status = 1; - printf("%s failed: %s want %d got %d\n", - func, test, ivalok, ival); - } else if (verbose) { - printf("%s passed: %s want %d got %d\n", - func, test, ivalok, ival); - } - -} - -static void vvd(double val, double valok, double dval, - const char *func, const char *test, int *status) -/* -** - - - - -** v v d -** - - - - -** -** Validate a double result. -** -** Internal function used by t_sofa_c program. -** -** Given: -** val double value computed by function under test -** valok double expected value -** dval double maximum allowable error -** func char[] name of function under test -** test char[] name of individual test -** -** Given and returned: -** status int set to TRUE if test fails -** -** This revision: 2016 April 21 -*/ -{ - double a, f; /* absolute and fractional error */ - - - a = val - valok; - if (a != 0.0 && fabs(a) > fabs(dval)) { - f = fabs(valok / a); - *status = 1; - printf("%s failed: %s want %.20g got %.20g (1/%.3g)\n", - func, test, valok, val, f); - } else if (verbose) { - printf("%s passed: %s want %.20g got %.20g\n", - func, test, valok, val); - } - -} - -static void t_a2af(int *status) -/* -** - - - - - - - -** t _ a 2 a f -** - - - - - - - -** -** Test iauA2af function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauA2af, viv -** -** This revision: 2013 August 7 -*/ -{ - int idmsf[4]; - char s; - - - iauA2af(4, 2.345, &s, idmsf); - - viv(s, '+', "iauA2af", "s", status); - - viv(idmsf[0], 134, "iauA2af", "0", status); - viv(idmsf[1], 21, "iauA2af", "1", status); - viv(idmsf[2], 30, "iauA2af", "2", status); - viv(idmsf[3], 9706, "iauA2af", "3", status); - -} - -static void t_a2tf(int *status) -/* -** - - - - - - - -** t _ a 2 t f -** - - - - - - - -** -** Test iauA2tf function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauA2tf, viv -** -** This revision: 2013 August 7 -*/ -{ - int ihmsf[4]; - char s; - - - iauA2tf(4, -3.01234, &s, ihmsf); - - viv((int)s, '-', "iauA2tf", "s", status); - - viv(ihmsf[0], 11, "iauA2tf", "0", status); - viv(ihmsf[1], 30, "iauA2tf", "1", status); - viv(ihmsf[2], 22, "iauA2tf", "2", status); - viv(ihmsf[3], 6484, "iauA2tf", "3", status); - -} - -static void t_ab(int *status) -/* -** - - - - - -** t _ a b -** - - - - - -** -** Test iauAb function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAb, vvd -** -** This revision: 2013 October 1 -*/ -{ - double pnat[3], v[3], s, bm1, ppr[3]; - - - pnat[0] = -0.76321968546737951; - pnat[1] = -0.60869453983060384; - pnat[2] = -0.21676408580639883; - v[0] = 2.1044018893653786e-5; - v[1] = -8.9108923304429319e-5; - v[2] = -3.8633714797716569e-5; - s = 0.99980921395708788; - bm1 = 0.99999999506209258; - - iauAb(pnat, v, s, bm1, ppr); - - vvd(ppr[0], -0.7631631094219556269, 1e-12, "iauAb", "1", status); - vvd(ppr[1], -0.6087553082505590832, 1e-12, "iauAb", "2", status); - vvd(ppr[2], -0.2167926269368471279, 1e-12, "iauAb", "3", status); - -} - -static void t_af2a(int *status) -/* -** - - - - - - - -** t _ a f 2 a -** - - - - - - - -** -** Test iauAf2a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAf2a, viv -** -** This revision: 2013 August 7 -*/ -{ - double a; - int j; - - - j = iauAf2a('-', 45, 13, 27.2, &a); - - vvd(a, -0.7893115794313644842, 1e-12, "iauAf2a", "a", status); - viv(j, 0, "iauAf2a", "j", status); - -} - -static void t_anp(int *status) -/* -** - - - - - - -** t _ a n p -** - - - - - - -** -** Test iauAnp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAnp, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauAnp(-0.1), 6.183185307179586477, 1e-12, "iauAnp", "", status); -} - -static void t_anpm(int *status) -/* -** - - - - - - - -** t _ a n p m -** - - - - - - - -** -** Test iauAnpm function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAnpm, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauAnpm(-4.0), 2.283185307179586477, 1e-12, "iauAnpm", "", status); -} - -static void t_apcg(int *status) -/* -** - - - - - - - -** t _ a p c g -** - - - - - - - -** -** Test iauApcg function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApcg, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, ebpv[2][3], ehp[3]; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - ebpv[0][0] = 0.901310875; - ebpv[0][1] = -0.417402664; - ebpv[0][2] = -0.180982288; - ebpv[1][0] = 0.00742727954; - ebpv[1][1] = 0.0140507459; - ebpv[1][2] = 0.00609045792; - ehp[0] = 0.903358544; - ehp[1] = -0.415395237; - ehp[2] = -0.180084014; - - iauApcg(date1, date2, ebpv, ehp, &astrom); - - vvd(astrom.pmt, 12.65133794027378508, 1e-11, - "iauApcg", "pmt", status); - vvd(astrom.eb[0], 0.901310875, 1e-12, - "iauApcg", "eb(1)", status); - vvd(astrom.eb[1], -0.417402664, 1e-12, - "iauApcg", "eb(2)", status); - vvd(astrom.eb[2], -0.180982288, 1e-12, - "iauApcg", "eb(3)", status); - vvd(astrom.eh[0], 0.8940025429324143045, 1e-12, - "iauApcg", "eh(1)", status); - vvd(astrom.eh[1], -0.4110930268679817955, 1e-12, - "iauApcg", "eh(2)", status); - vvd(astrom.eh[2], -0.1782189004872870264, 1e-12, - "iauApcg", "eh(3)", status); - vvd(astrom.em, 1.010465295811013146, 1e-12, - "iauApcg", "em", status); - vvd(astrom.v[0], 0.4289638897813379954e-4, 1e-16, - "iauApcg", "v(1_", status); - vvd(astrom.v[1], 0.8115034021720941898e-4, 1e-16, - "iauApcg", "v(2)", status); - vvd(astrom.v[2], 0.3517555123437237778e-4, 1e-16, - "iauApcg", "v(3)", status); - vvd(astrom.bm1, 0.9999999951686013336, 1e-12, - "iauApcg", "bm1", status); - vvd(astrom.bpn[0][0], 1.0, 0.0, - "iauApcg", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0.0, 0.0, - "iauApcg", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0.0, 0.0, - "iauApcg", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], 0.0, 0.0, - "iauApcg", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 1.0, 0.0, - "iauApcg", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], 0.0, 0.0, - "iauApcg", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], 0.0, 0.0, - "iauApcg", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0.0, 0.0, - "iauApcg", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 1.0, 0.0, - "iauApcg", "bpn(3,3)", status); - -} - -static void t_apcg13(int *status) -/* -** - - - - - - - - - -** t _ a p c g 1 3 -** - - - - - - - - - -** -** Test iauApcg13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApcg13, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - - iauApcg13(date1, date2, &astrom); - - vvd(astrom.pmt, 12.65133794027378508, 1e-11, - "iauApcg13", "pmt", status); - vvd(astrom.eb[0], 0.9013108747340644755, 1e-12, - "iauApcg13", "eb(1)", status); - vvd(astrom.eb[1], -0.4174026640406119957, 1e-12, - "iauApcg13", "eb(2)", status); - vvd(astrom.eb[2], -0.1809822877867817771, 1e-12, - "iauApcg13", "eb(3)", status); - vvd(astrom.eh[0], 0.8940025429255499549, 1e-12, - "iauApcg13", "eh(1)", status); - vvd(astrom.eh[1], -0.4110930268331896318, 1e-12, - "iauApcg13", "eh(2)", status); - vvd(astrom.eh[2], -0.1782189006019749850, 1e-12, - "iauApcg13", "eh(3)", status); - vvd(astrom.em, 1.010465295964664178, 1e-12, - "iauApcg13", "em", status); - vvd(astrom.v[0], 0.4289638897157027528e-4, 1e-16, - "iauApcg13", "v(1)", status); - vvd(astrom.v[1], 0.8115034002544663526e-4, 1e-16, - "iauApcg13", "v(2)", status); - vvd(astrom.v[2], 0.3517555122593144633e-4, 1e-16, - "iauApcg13", "v(3)", status); - vvd(astrom.bm1, 0.9999999951686013498, 1e-12, - "iauApcg13", "bm1", status); - vvd(astrom.bpn[0][0], 1.0, 0.0, - "iauApcg13", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0.0, 0.0, - "iauApcg13", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0.0, 0.0, - "iauApcg13", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], 0.0, 0.0, - "iauApcg13", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 1.0, 0.0, - "iauApcg13", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], 0.0, 0.0, - "iauApcg13", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], 0.0, 0.0, - "iauApcg13", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0.0, 0.0, - "iauApcg13", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 1.0, 0.0, - "iauApcg13", "bpn(3,3)", status); - -} - -static void t_apci(int *status) -/* -** - - - - - - - -** t _ a p c i -** - - - - - - - -** -** Test iauApci function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApci, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, ebpv[2][3], ehp[3], x, y, s; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - ebpv[0][0] = 0.901310875; - ebpv[0][1] = -0.417402664; - ebpv[0][2] = -0.180982288; - ebpv[1][0] = 0.00742727954; - ebpv[1][1] = 0.0140507459; - ebpv[1][2] = 0.00609045792; - ehp[0] = 0.903358544; - ehp[1] = -0.415395237; - ehp[2] = -0.180084014; - x = 0.0013122272; - y = -2.92808623e-5; - s = 3.05749468e-8; - - iauApci(date1, date2, ebpv, ehp, x, y, s, &astrom); - - vvd(astrom.pmt, 12.65133794027378508, 1e-11, - "iauApci", "pmt", status); - vvd(astrom.eb[0], 0.901310875, 1e-12, - "iauApci", "eb(1)", status); - vvd(astrom.eb[1], -0.417402664, 1e-12, - "iauApci", "eb(2)", status); - vvd(astrom.eb[2], -0.180982288, 1e-12, - "iauApci", "eb(3)", status); - vvd(astrom.eh[0], 0.8940025429324143045, 1e-12, - "iauApci", "eh(1)", status); - vvd(astrom.eh[1], -0.4110930268679817955, 1e-12, - "iauApci", "eh(2)", status); - vvd(astrom.eh[2], -0.1782189004872870264, 1e-12, - "iauApci", "eh(3)", status); - vvd(astrom.em, 1.010465295811013146, 1e-12, - "iauApci", "em", status); - vvd(astrom.v[0], 0.4289638897813379954e-4, 1e-16, - "iauApci", "v(1)", status); - vvd(astrom.v[1], 0.8115034021720941898e-4, 1e-16, - "iauApci", "v(2)", status); - vvd(astrom.v[2], 0.3517555123437237778e-4, 1e-16, - "iauApci", "v(3)", status); - vvd(astrom.bm1, 0.9999999951686013336, 1e-12, - "iauApci", "bm1", status); - vvd(astrom.bpn[0][0], 0.9999991390295159156, 1e-12, - "iauApci", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0.4978650072505016932e-7, 1e-12, - "iauApci", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0.1312227200000000000e-2, 1e-12, - "iauApci", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], -0.1136336653771609630e-7, 1e-12, - "iauApci", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 0.9999999995713154868, 1e-12, - "iauApci", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], -0.2928086230000000000e-4, 1e-12, - "iauApci", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], -0.1312227200895260194e-2, 1e-12, - "iauApci", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0.2928082217872315680e-4, 1e-12, - "iauApci", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 0.9999991386008323373, 1e-12, - "iauApci", "bpn(3,3)", status); - -} - -static void t_apci13(int *status) -/* -** - - - - - - - - - -** t _ a p c i 1 3 -** - - - - - - - - - -** -** Test iauApci13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApci13, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, eo; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - - iauApci13(date1, date2, &astrom, &eo); - - vvd(astrom.pmt, 12.65133794027378508, 1e-11, - "iauApci13", "pmt", status); - vvd(astrom.eb[0], 0.9013108747340644755, 1e-12, - "iauApci13", "eb(1)", status); - vvd(astrom.eb[1], -0.4174026640406119957, 1e-12, - "iauApci13", "eb(2)", status); - vvd(astrom.eb[2], -0.1809822877867817771, 1e-12, - "iauApci13", "eb(3)", status); - vvd(astrom.eh[0], 0.8940025429255499549, 1e-12, - "iauApci13", "eh(1)", status); - vvd(astrom.eh[1], -0.4110930268331896318, 1e-12, - "iauApci13", "eh(2)", status); - vvd(astrom.eh[2], -0.1782189006019749850, 1e-12, - "iauApci13", "eh(3)", status); - vvd(astrom.em, 1.010465295964664178, 1e-12, - "iauApci13", "em", status); - vvd(astrom.v[0], 0.4289638897157027528e-4, 1e-16, - "iauApci13", "v(1)", status); - vvd(astrom.v[1], 0.8115034002544663526e-4, 1e-16, - "iauApci13", "v(2)", status); - vvd(astrom.v[2], 0.3517555122593144633e-4, 1e-16, - "iauApci13", "v(3)", status); - vvd(astrom.bm1, 0.9999999951686013498, 1e-12, - "iauApci13", "bm1", status); - vvd(astrom.bpn[0][0], 0.9999992060376761710, 1e-12, - "iauApci13", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0.4124244860106037157e-7, 1e-12, - "iauApci13", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0.1260128571051709670e-2, 1e-12, - "iauApci13", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], -0.1282291987222130690e-7, 1e-12, - "iauApci13", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 0.9999999997456835325, 1e-12, - "iauApci13", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], -0.2255288829420524935e-4, 1e-12, - "iauApci13", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], -0.1260128571661374559e-2, 1e-12, - "iauApci13", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0.2255285422953395494e-4, 1e-12, - "iauApci13", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 0.9999992057833604343, 1e-12, - "iauApci13", "bpn(3,3)", status); - vvd(eo, -0.2900618712657375647e-2, 1e-12, - "iauApci13", "eo", status); - -} - -static void t_apco(int *status) -/* -** - - - - - - - -** t _ a p c o -** - - - - - - - -** -** Test iauApco function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApco, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, ebpv[2][3], ehp[3], x, y, s, - theta, elong, phi, hm, xp, yp, sp, refa, refb; - iauASTROM astrom; - - - date1 = 2456384.5; - date2 = 0.970031644; - ebpv[0][0] = -0.974170438; - ebpv[0][1] = -0.211520082; - ebpv[0][2] = -0.0917583024; - ebpv[1][0] = 0.00364365824; - ebpv[1][1] = -0.0154287319; - ebpv[1][2] = -0.00668922024; - ehp[0] = -0.973458265; - ehp[1] = -0.209215307; - ehp[2] = -0.0906996477; - x = 0.0013122272; - y = -2.92808623e-5; - s = 3.05749468e-8; - theta = 3.14540971; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - sp = -3.01974337e-11; - refa = 0.000201418779; - refb = -2.36140831e-7; - - iauApco(date1, date2, ebpv, ehp, x, y, s, - theta, elong, phi, hm, xp, yp, sp, - refa, refb, &astrom); - - vvd(astrom.pmt, 13.25248468622587269, 1e-11, - "iauApco", "pmt", status); - vvd(astrom.eb[0], -0.9741827110630897003, 1e-12, - "iauApco", "eb(1)", status); - vvd(astrom.eb[1], -0.2115130190135014340, 1e-12, - "iauApco", "eb(2)", status); - vvd(astrom.eb[2], -0.09179840186968295686, 1e-12, - "iauApco", "eb(3)", status); - vvd(astrom.eh[0], -0.9736425571689670428, 1e-12, - "iauApco", "eh(1)", status); - vvd(astrom.eh[1], -0.2092452125848862201, 1e-12, - "iauApco", "eh(2)", status); - vvd(astrom.eh[2], -0.09075578152261439954, 1e-12, - "iauApco", "eh(3)", status); - vvd(astrom.em, 0.9998233241710617934, 1e-12, - "iauApco", "em", status); - vvd(astrom.v[0], 0.2078704985147609823e-4, 1e-16, - "iauApco", "v(1)", status); - vvd(astrom.v[1], -0.8955360074407552709e-4, 1e-16, - "iauApco", "v(2)", status); - vvd(astrom.v[2], -0.3863338980073114703e-4, 1e-16, - "iauApco", "v(3)", status); - vvd(astrom.bm1, 0.9999999950277561600, 1e-12, - "iauApco", "bm1", status); - vvd(astrom.bpn[0][0], 0.9999991390295159156, 1e-12, - "iauApco", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0.4978650072505016932e-7, 1e-12, - "iauApco", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0.1312227200000000000e-2, 1e-12, - "iauApco", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], -0.1136336653771609630e-7, 1e-12, - "iauApco", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 0.9999999995713154868, 1e-12, - "iauApco", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], -0.2928086230000000000e-4, 1e-12, - "iauApco", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], -0.1312227200895260194e-2, 1e-12, - "iauApco", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0.2928082217872315680e-4, 1e-12, - "iauApco", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 0.9999991386008323373, 1e-12, - "iauApco", "bpn(3,3)", status); - vvd(astrom.along, -0.5278008060301974337, 1e-12, - "iauApco", "along", status); - vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, - "iauApco", "xpl", status); - vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, - "iauApco", "ypl", status); - vvd(astrom.sphi, -0.9440115679003211329, 1e-12, - "iauApco", "sphi", status); - vvd(astrom.cphi, 0.3299123514971474711, 1e-12, - "iauApco", "cphi", status); - vvd(astrom.diurab, 0, 0, - "iauApco", "diurab", status); - vvd(astrom.eral, 2.617608903969802566, 1e-12, - "iauApco", "eral", status); - vvd(astrom.refa, 0.2014187790000000000e-3, 1e-15, - "iauApco", "refa", status); - vvd(astrom.refb, -0.2361408310000000000e-6, 1e-18, - "iauApco", "refb", status); - -} - -static void t_apco13(int *status) -/* -** - - - - - - - - - -** t _ a p c o 1 3 -** - - - - - - - - - -** -** Test iauApco13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApco13, vvd, viv -** -** This revision: 2013 October 4 -*/ -{ - double utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, eo; - iauASTROM astrom; - int j; - - - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - - j = iauApco13(utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, &astrom, &eo); - - vvd(astrom.pmt, 13.25248468622475727, 1e-11, - "iauApco13", "pmt", status); - vvd(astrom.eb[0], -0.9741827107321449445, 1e-12, - "iauApco13", "eb(1)", status); - vvd(astrom.eb[1], -0.2115130190489386190, 1e-12, - "iauApco13", "eb(2)", status); - vvd(astrom.eb[2], -0.09179840189515518726, 1e-12, - "iauApco13", "eb(3)", status); - vvd(astrom.eh[0], -0.9736425572586866640, 1e-12, - "iauApco13", "eh(1)", status); - vvd(astrom.eh[1], -0.2092452121602867431, 1e-12, - "iauApco13", "eh(2)", status); - vvd(astrom.eh[2], -0.09075578153903832650, 1e-12, - "iauApco13", "eh(3)", status); - vvd(astrom.em, 0.9998233240914558422, 1e-12, - "iauApco13", "em", status); - vvd(astrom.v[0], 0.2078704986751370303e-4, 1e-16, - "iauApco13", "v(1)", status); - vvd(astrom.v[1], -0.8955360100494469232e-4, 1e-16, - "iauApco13", "v(2)", status); - vvd(astrom.v[2], -0.3863338978840051024e-4, 1e-16, - "iauApco13", "v(3)", status); - vvd(astrom.bm1, 0.9999999950277561368, 1e-12, - "iauApco13", "bm1", status); - vvd(astrom.bpn[0][0], 0.9999991390295147999, 1e-12, - "iauApco13", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0.4978650075315529277e-7, 1e-12, - "iauApco13", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0.001312227200850293372, 1e-12, - "iauApco13", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], -0.1136336652812486604e-7, 1e-12, - "iauApco13", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 0.9999999995713154865, 1e-12, - "iauApco13", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], -0.2928086230975367296e-4, 1e-12, - "iauApco13", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], -0.001312227201745553566, 1e-12, - "iauApco13", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0.2928082218847679162e-4, 1e-12, - "iauApco13", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 0.9999991386008312212, 1e-12, - "iauApco13", "bpn(3,3)", status); - vvd(astrom.along, -0.5278008060301974337, 1e-12, - "iauApco13", "along", status); - vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, - "iauApco13", "xpl", status); - vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, - "iauApco13", "ypl", status); - vvd(astrom.sphi, -0.9440115679003211329, 1e-12, - "iauApco13", "sphi", status); - vvd(astrom.cphi, 0.3299123514971474711, 1e-12, - "iauApco13", "cphi", status); - vvd(astrom.diurab, 0, 0, - "iauApco13", "diurab", status); - vvd(astrom.eral, 2.617608909189066140, 1e-12, - "iauApco13", "eral", status); - vvd(astrom.refa, 0.2014187785940396921e-3, 1e-15, - "iauApco13", "refa", status); - vvd(astrom.refb, -0.2361408314943696227e-6, 1e-18, - "iauApco13", "refb", status); - vvd(eo, -0.003020548354802412839, 1e-14, - "iauApco13", "eo", status); - viv(j, 0, "iauApco13", "j", status); - -} - -static void t_apcs(int *status) -/* -** - - - - - - - -** t _ a p c s -** - - - - - - - -** -** Test iauApcs function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApcs, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, pv[2][3], ebpv[2][3], ehp[3]; - iauASTROM astrom; - - - date1 = 2456384.5; - date2 = 0.970031644; - pv[0][0] = -1836024.09; - pv[0][1] = 1056607.72; - pv[0][2] = -5998795.26; - pv[1][0] = -77.0361767; - pv[1][1] = -133.310856; - pv[1][2] = 0.0971855934; - ebpv[0][0] = -0.974170438; - ebpv[0][1] = -0.211520082; - ebpv[0][2] = -0.0917583024; - ebpv[1][0] = 0.00364365824; - ebpv[1][1] = -0.0154287319; - ebpv[1][2] = -0.00668922024; - ehp[0] = -0.973458265; - ehp[1] = -0.209215307; - ehp[2] = -0.0906996477; - - iauApcs(date1, date2, pv, ebpv, ehp, &astrom); - - vvd(astrom.pmt, 13.25248468622587269, 1e-11, - "iauApcs", "pmt", status); - vvd(astrom.eb[0], -0.9741827110630456169, 1e-12, - "iauApcs", "eb(1)", status); - vvd(astrom.eb[1], -0.2115130190136085494, 1e-12, - "iauApcs", "eb(2)", status); - vvd(astrom.eb[2], -0.09179840186973175487, 1e-12, - "iauApcs", "eb(3)", status); - vvd(astrom.eh[0], -0.9736425571689386099, 1e-12, - "iauApcs", "eh(1)", status); - vvd(astrom.eh[1], -0.2092452125849967195, 1e-12, - "iauApcs", "eh(2)", status); - vvd(astrom.eh[2], -0.09075578152266466572, 1e-12, - "iauApcs", "eh(3)", status); - vvd(astrom.em, 0.9998233241710457140, 1e-12, - "iauApcs", "em", status); - vvd(astrom.v[0], 0.2078704985513566571e-4, 1e-16, - "iauApcs", "v(1)", status); - vvd(astrom.v[1], -0.8955360074245006073e-4, 1e-16, - "iauApcs", "v(2)", status); - vvd(astrom.v[2], -0.3863338980073572719e-4, 1e-16, - "iauApcs", "v(3)", status); - vvd(astrom.bm1, 0.9999999950277561601, 1e-12, - "iauApcs", "bm1", status); - vvd(astrom.bpn[0][0], 1, 0, - "iauApcs", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0, 0, - "iauApcs", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0, 0, - "iauApcs", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], 0, 0, - "iauApcs", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 1, 0, - "iauApcs", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], 0, 0, - "iauApcs", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], 0, 0, - "iauApcs", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0, 0, - "iauApcs", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 1, 0, - "iauApcs", "bpn(3,3)", status); - -} - -static void t_apcs13(int *status) -/* -** - - - - - - - - - -** t _ a p c s 1 3 -** - - - - - - - - - -** -** Test iauApcs13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApcs13, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, pv[2][3]; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - pv[0][0] = -6241497.16; - pv[0][1] = 401346.896; - pv[0][2] = -1251136.04; - pv[1][0] = -29.264597; - pv[1][1] = -455.021831; - pv[1][2] = 0.0266151194; - - iauApcs13(date1, date2, pv, &astrom); - - vvd(astrom.pmt, 12.65133794027378508, 1e-11, - "iauApcs13", "pmt", status); - vvd(astrom.eb[0], 0.9012691529023298391, 1e-12, - "iauApcs13", "eb(1)", status); - vvd(astrom.eb[1], -0.4173999812023068781, 1e-12, - "iauApcs13", "eb(2)", status); - vvd(astrom.eb[2], -0.1809906511146821008, 1e-12, - "iauApcs13", "eb(3)", status); - vvd(astrom.eh[0], 0.8939939101759726824, 1e-12, - "iauApcs13", "eh(1)", status); - vvd(astrom.eh[1], -0.4111053891734599955, 1e-12, - "iauApcs13", "eh(2)", status); - vvd(astrom.eh[2], -0.1782336880637689334, 1e-12, - "iauApcs13", "eh(3)", status); - vvd(astrom.em, 1.010428384373318379, 1e-12, - "iauApcs13", "em", status); - vvd(astrom.v[0], 0.4279877278327626511e-4, 1e-16, - "iauApcs13", "v(1)", status); - vvd(astrom.v[1], 0.7963255057040027770e-4, 1e-16, - "iauApcs13", "v(2)", status); - vvd(astrom.v[2], 0.3517564000441374759e-4, 1e-16, - "iauApcs13", "v(3)", status); - vvd(astrom.bm1, 0.9999999952947981330, 1e-12, - "iauApcs13", "bm1", status); - vvd(astrom.bpn[0][0], 1, 0, - "iauApcs13", "bpn(1,1)", status); - vvd(astrom.bpn[1][0], 0, 0, - "iauApcs13", "bpn(2,1)", status); - vvd(astrom.bpn[2][0], 0, 0, - "iauApcs13", "bpn(3,1)", status); - vvd(astrom.bpn[0][1], 0, 0, - "iauApcs13", "bpn(1,2)", status); - vvd(astrom.bpn[1][1], 1, 0, - "iauApcs13", "bpn(2,2)", status); - vvd(astrom.bpn[2][1], 0, 0, - "iauApcs13", "bpn(3,2)", status); - vvd(astrom.bpn[0][2], 0, 0, - "iauApcs13", "bpn(1,3)", status); - vvd(astrom.bpn[1][2], 0, 0, - "iauApcs13", "bpn(2,3)", status); - vvd(astrom.bpn[2][2], 1, 0, - "iauApcs13", "bpn(3,3)", status); - -} - -static void t_aper(int *status) -/* -** - - - - - - - -** t _ a p e r -** - - - - - - - -* -** Test iauAper function. -* -** Returned: -** status int FALSE = success, TRUE = fail -* -** Called: iauAper, vvd -* -** This revision: 2013 October 3 -*/ -{ - double theta; - iauASTROM astrom; - - - astrom.along = 1.234; - theta = 5.678; - - iauAper(theta, &astrom); - - vvd(astrom.eral, 6.912000000000000000, 1e-12, - "iauAper", "pmt", status); - -} - -static void t_aper13(int *status) -/* -** - - - - - - - - - -** t _ a p e r 1 3 -** - - - - - - - - - -** -** Test iauAper13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAper13, vvd -** -** This revision: 2013 October 3 -*/ -{ - double ut11, ut12; - iauASTROM astrom; - - - astrom.along = 1.234; - ut11 = 2456165.5; - ut12 = 0.401182685; - - iauAper13(ut11, ut12, &astrom); - - vvd(astrom.eral, 3.316236661789694933, 1e-12, - "iauAper13", "pmt", status); - -} - -static void t_apio(int *status) -/* -** - - - - - - - -** t _ a p i o -** - - - - - - - -** -** Test iauApio function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApio, vvd -** -** This revision: 2013 October 3 -*/ -{ - double sp, theta, elong, phi, hm, xp, yp, refa, refb; - iauASTROM astrom; - - - sp = -3.01974337e-11; - theta = 3.14540971; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - refa = 0.000201418779; - refb = -2.36140831e-7; - - iauApio(sp, theta, elong, phi, hm, xp, yp, refa, refb, &astrom); - - vvd(astrom.along, -0.5278008060301974337, 1e-12, - "iauApio", "along", status); - vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, - "iauApio", "xpl", status); - vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, - "iauApio", "ypl", status); - vvd(astrom.sphi, -0.9440115679003211329, 1e-12, - "iauApio", "sphi", status); - vvd(astrom.cphi, 0.3299123514971474711, 1e-12, - "iauApio", "cphi", status); - vvd(astrom.diurab, 0.5135843661699913529e-6, 1e-12, - "iauApio", "diurab", status); - vvd(astrom.eral, 2.617608903969802566, 1e-12, - "iauApio", "eral", status); - vvd(astrom.refa, 0.2014187790000000000e-3, 1e-15, - "iauApio", "refa", status); - vvd(astrom.refb, -0.2361408310000000000e-6, 1e-18, - "iauApio", "refb", status); - -} - -static void t_apio13(int *status) -/* -** - - - - - - - - - -** t _ a p i o 1 3 -** - - - - - - - - - -** -** Test iauApio13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApio13, vvd, viv -** -** This revision: 2013 October 4 -*/ -{ - double utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl; - int j; - iauASTROM astrom; - - - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - - j = iauApio13(utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, &astrom); - - vvd(astrom.along, -0.5278008060301974337, 1e-12, - "iauApio13", "along", status); - vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, - "iauApio13", "xpl", status); - vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, - "iauApio13", "ypl", status); - vvd(astrom.sphi, -0.9440115679003211329, 1e-12, - "iauApio13", "sphi", status); - vvd(astrom.cphi, 0.3299123514971474711, 1e-12, - "iauApio13", "cphi", status); - vvd(astrom.diurab, 0.5135843661699913529e-6, 1e-12, - "iauApio13", "diurab", status); - vvd(astrom.eral, 2.617608909189066140, 1e-12, - "iauApio13", "eral", status); - vvd(astrom.refa, 0.2014187785940396921e-3, 1e-15, - "iauApio13", "refa", status); - vvd(astrom.refb, -0.2361408314943696227e-6, 1e-18, - "iauApio13", "refb", status); - viv(j, 0, "iauApio13", "j", status); - -} - -static void t_atci13(int *status) -/* -** - - - - - - - - - -** t _ a t c i 1 3 -** - - - - - - - - - -** -** Test iauAtci13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAtci13, vvd -** -** This revision: 2013 October 3 -*/ -{ - double rc, dc, pr, pd, px, rv, date1, date2, ri, di, eo; - - - rc = 2.71; - dc = 0.174; - pr = 1e-5; - pd = 5e-6; - px = 0.1; - rv = 55.0; - date1 = 2456165.5; - date2 = 0.401182685; - - iauAtci13(rc, dc, pr, pd, px, rv, date1, date2, &ri, &di, &eo); - - vvd(ri, 2.710121572969038991, 1e-12, - "iauAtci13", "ri", status); - vvd(di, 0.1729371367218230438, 1e-12, - "iauAtci13", "di", status); - vvd(eo, -0.002900618712657375647, 1e-14, - "iauAtci13", "eo", status); - -} - -static void t_atciq(int *status) -/* -** - - - - - - - - -** t _ a t c i q -** - - - - - - - - -** -** Test iauAtciq function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApci13, iauAtciq, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, eo, rc, dc, pr, pd, px, rv, ri, di; - iauASTROM astrom; - - date1 = 2456165.5; - date2 = 0.401182685; - iauApci13(date1, date2, &astrom, &eo); - rc = 2.71; - dc = 0.174; - pr = 1e-5; - pd = 5e-6; - px = 0.1; - rv = 55.0; - - iauAtciq(rc, dc, pr, pd, px, rv, &astrom, &ri, &di); - - vvd(ri, 2.710121572969038991, 1e-12, "iauAtciq", "ri", status); - vvd(di, 0.1729371367218230438, 1e-12, "iauAtciq", "di", status); - -} - -static void t_atciqn(int *status) -/* -** - - - - - - - - - -** t _ a t c i q n -** - - - - - - - - - -** -** Test iauAtciqn function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApci13, iauAtciqn, vvd -** -** This revision: 2013 October 3 -*/ -{ - iauLDBODY b[3]; - double date1, date2, eo, rc, dc, pr, pd, px, rv, ri, di; - iauASTROM astrom; - - date1 = 2456165.5; - date2 = 0.401182685; - iauApci13(date1, date2, &astrom, &eo); - rc = 2.71; - dc = 0.174; - pr = 1e-5; - pd = 5e-6; - px = 0.1; - rv = 55.0; - b[0].bm = 0.00028574; - b[0].dl = 3e-10; - b[0].pv[0][0] = -7.81014427; - b[0].pv[0][1] = -5.60956681; - b[0].pv[0][2] = -1.98079819; - b[0].pv[1][0] = 0.0030723249; - b[0].pv[1][1] = -0.00406995477; - b[0].pv[1][2] = -0.00181335842; - b[1].bm = 0.00095435; - b[1].dl = 3e-9; - b[1].pv[0][0] = 0.738098796; - b[1].pv[0][1] = 4.63658692; - b[1].pv[0][2] = 1.9693136; - b[1].pv[1][0] = -0.00755816922; - b[1].pv[1][1] = 0.00126913722; - b[1].pv[1][2] = 0.000727999001; - b[2].bm = 1.0; - b[2].dl = 6e-6; - b[2].pv[0][0] = -0.000712174377; - b[2].pv[0][1] = -0.00230478303; - b[2].pv[0][2] = -0.00105865966; - b[2].pv[1][0] = 6.29235213e-6; - b[2].pv[1][1] = -3.30888387e-7; - b[2].pv[1][2] = -2.96486623e-7; - - iauAtciqn ( rc, dc, pr, pd, px, rv, &astrom, 3, b, &ri, &di); - - vvd(ri, 2.710122008105325582, 1e-12, "iauAtciqn", "ri", status); - vvd(di, 0.1729371916491459122, 1e-12, "iauAtciqn", "di", status); - -} - -static void t_atciqz(int *status) -/* -** - - - - - - - - - -** t _ a t c i q z -** - - - - - - - - - -** -** Test iauAtciqz function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApci13, iauAtciqz, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, eo, rc, dc, ri, di; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - iauApci13(date1, date2, &astrom, &eo); - rc = 2.71; - dc = 0.174; - - iauAtciqz(rc, dc, &astrom, &ri, &di); - - vvd(ri, 2.709994899247599271, 1e-12, "iauAtciqz", "ri", status); - vvd(di, 0.1728740720983623469, 1e-12, "iauAtciqz", "di", status); - -} - -static void t_atco13(int *status) -/* -** - - - - - - - - - -** t _ a t c o 1 3 -** - - - - - - - - - -** -** Test iauAtco13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAtco13, vvd, viv -** -** This revision: 2013 October 4 -*/ -{ - double rc, dc, pr, pd, px, rv, utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - aob, zob, hob, dob, rob, eo; - int j; - - - rc = 2.71; - dc = 0.174; - pr = 1e-5; - pd = 5e-6; - px = 0.1; - rv = 55.0; - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - - j = iauAtco13(rc, dc, pr, pd, px, rv, - utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, - &aob, &zob, &hob, &dob, &rob, &eo); - - vvd(aob, 0.09251774485358230653, 1e-12, "iauAtco13", "aob", status); - vvd(zob, 1.407661405256767021, 1e-12, "iauAtco13", "zob", status); - vvd(hob, -0.09265154431403157925, 1e-12, "iauAtco13", "hob", status); - vvd(dob, 0.1716626560075591655, 1e-12, "iauAtco13", "dob", status); - vvd(rob, 2.710260453503097719, 1e-12, "iauAtco13", "rob", status); - vvd(eo, -0.003020548354802412839, 1e-14, "iauAtco13", "eo", status); - viv(j, 0, "iauAtco13", "j", status); - -} - -static void t_atic13(int *status) -/* -** - - - - - - - - - -** t _ a t i c 1 3 -** - - - - - - - - - -** -** Test iauAtic13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAtic13, vvd -** -** This revision: 2013 October 3 -*/ -{ - double ri, di, date1, date2, rc, dc, eo; - - - ri = 2.710121572969038991; - di = 0.1729371367218230438; - date1 = 2456165.5; - date2 = 0.401182685; - - iauAtic13(ri, di, date1, date2, &rc, &dc, &eo); - - vvd(rc, 2.710126504531374930, 1e-12, "iauAtic13", "rc", status); - vvd(dc, 0.1740632537628342320, 1e-12, "iauAtic13", "dc", status); - vvd(eo, -0.002900618712657375647, 1e-14, "iauAtic13", "eo", status); - -} - -static void t_aticq(int *status) -/* -** - - - - - - - - -** t _ a t i c q -** - - - - - - - - -** -** Test iauAticq function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApci13, iauAticq, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, eo, ri, di, rc, dc; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - iauApci13(date1, date2, &astrom, &eo); - ri = 2.710121572969038991; - di = 0.1729371367218230438; - - iauAticq(ri, di, &astrom, &rc, &dc); - - vvd(rc, 2.710126504531374930, 1e-12, "iauAticq", "rc", status); - vvd(dc, 0.1740632537628342320, 1e-12, "iauAticq", "dc", status); - -} - -static void t_aticqn(int *status) -/* -** - - - - - - - - - -** t _ a t i c q n -** - - - - - - - - - -** -** Test iauAticqn function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApci13, iauAticqn, vvd -** -** This revision: 2013 October 3 -*/ -{ - double date1, date2, eo, ri, di, rc, dc; - iauLDBODY b[3]; - iauASTROM astrom; - - - date1 = 2456165.5; - date2 = 0.401182685; - iauApci13(date1, date2, &astrom, &eo); - ri = 2.709994899247599271; - di = 0.1728740720983623469; - b[0].bm = 0.00028574; - b[0].dl = 3e-10; - b[0].pv[0][0] = -7.81014427; - b[0].pv[0][1] = -5.60956681; - b[0].pv[0][2] = -1.98079819; - b[0].pv[1][0] = 0.0030723249; - b[0].pv[1][1] = -0.00406995477; - b[0].pv[1][2] = -0.00181335842; - b[1].bm = 0.00095435; - b[1].dl = 3e-9; - b[1].pv[0][0] = 0.738098796; - b[1].pv[0][1] = 4.63658692; - b[1].pv[0][2] = 1.9693136; - b[1].pv[1][0] = -0.00755816922; - b[1].pv[1][1] = 0.00126913722; - b[1].pv[1][2] = 0.000727999001; - b[2].bm = 1.0; - b[2].dl = 6e-6; - b[2].pv[0][0] = -0.000712174377; - b[2].pv[0][1] = -0.00230478303; - b[2].pv[0][2] = -0.00105865966; - b[2].pv[1][0] = 6.29235213e-6; - b[2].pv[1][1] = -3.30888387e-7; - b[2].pv[1][2] = -2.96486623e-7; - - iauAticqn(ri, di, &astrom, 3, b, &rc, &dc); - - vvd(rc, 2.709999575032685412, 1e-12, "iauAtciqn", "rc", status); - vvd(dc, 0.1739999656317778034, 1e-12, "iauAtciqn", "dc", status); - -} - -static void t_atio13(int *status) -/* -** - - - - - - - - - -** t _ a t i o 1 3 -** - - - - - - - - - -** -** Test iauAtio13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAtio13, vvd, viv -** -** This revision: 2013 October 3 -*/ -{ - double ri, di, utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, aob, zob, hob, dob, rob; - int j; - - - ri = 2.710121572969038991; - di = 0.1729371367218230438; - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - - j = iauAtio13(ri, di, utc1, utc2, dut1, elong, phi, hm, - xp, yp, phpa, tc, rh, wl, - &aob, &zob, &hob, &dob, &rob); - - vvd(aob, 0.09233952224794989993, 1e-12, "iauAtio13", "aob", status); - vvd(zob, 1.407758704513722461, 1e-12, "iauAtio13", "zob", status); - vvd(hob, -0.09247619879782006106, 1e-12, "iauAtio13", "hob", status); - vvd(dob, 0.1717653435758265198, 1e-12, "iauAtio13", "dob", status); - vvd(rob, 2.710085107986886201, 1e-12, "iauAtio13", "rob", status); - viv(j, 0, "iauAtio13", "j", status); - -} - -static void t_atioq(int *status) -/* -** - - - - - - - - -** t _ a t i o q -** - - - - - - - - -** -** Test iauAtioq function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauApio13, iauAtioq, vvd, viv -** -** This revision: 2013 October 4 -*/ -{ - double utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, ri, di, aob, zob, hob, dob, rob; - iauASTROM astrom; - - - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - (void) iauApio13(utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, &astrom); - ri = 2.710121572969038991; - di = 0.1729371367218230438; - - iauAtioq(ri, di, &astrom, &aob, &zob, &hob, &dob, &rob); - - vvd(aob, 0.09233952224794989993, 1e-12, "iauAtioq", "aob", status); - vvd(zob, 1.407758704513722461, 1e-12, "iauAtioq", "zob", status); - vvd(hob, -0.09247619879782006106, 1e-12, "iauAtioq", "hob", status); - vvd(dob, 0.1717653435758265198, 1e-12, "iauAtioq", "dob", status); - vvd(rob, 2.710085107986886201, 1e-12, "iauAtioq", "rob", status); - -} - -static void t_atoc13(int *status) -/* -** - - - - - - - - - -** t _ a t o c 1 3 -** - - - - - - - - - -** -** Test iauAtoc13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAtoc13, vvd, viv -** -** This revision: 2013 October 3 -*/ -{ - double utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - ob1, ob2, rc, dc; - int j; - - - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - - ob1 = 2.710085107986886201; - ob2 = 0.1717653435758265198; - j = iauAtoc13 ( "R", ob1, ob2, utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - &rc, &dc); - vvd(rc, 2.709956744661000609, 1e-12, "iauAtoc13", "R/rc", status); - vvd(dc, 0.1741696500895398562, 1e-12, "iauAtoc13", "R/dc", status); - viv(j, 0, "iauAtoc13", "R/j", status); - - ob1 = -0.09247619879782006106; - ob2 = 0.1717653435758265198; - j = iauAtoc13 ( "H", ob1, ob2, utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - &rc, &dc); - vvd(rc, 2.709956744661000609, 1e-12, "iauAtoc13", "H/rc", status); - vvd(dc, 0.1741696500895398562, 1e-12, "iauAtoc13", "H/dc", status); - viv(j, 0, "iauAtoc13", "H/j", status); - - ob1 = 0.09233952224794989993; - ob2 = 1.407758704513722461; - j = iauAtoc13 ( "A", ob1, ob2, utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - &rc, &dc); - vvd(rc, 2.709956744661000609, 1e-12, "iauAtoc13", "A/rc", status); - vvd(dc, 0.1741696500895398565, 1e-12, "iauAtoc13", "A/dc", status); - viv(j, 0, "iauAtoc13", "A/j", status); - -} - -static void t_atoi13(int *status) -/* -** - - - - - - - - - -** t _ a t o i 1 3 -** - - - - - - - - - -** -** Test iauAtoi13 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauAtoi13, vvd, viv -** -** This revision: 2013 October 3 -*/ -{ - double utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl, - ob1, ob2, ri, di; - int j; - - - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - - ob1 = 2.710085107986886201; - ob2 = 0.1717653435758265198; - j = iauAtoi13 ( "R", ob1, ob2, utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - &ri, &di); - vvd(ri, 2.710121574449135955, 1e-12, "iauAtoi13", "R/ri", status); - vvd(di, 0.1729371839114567725, 1e-12, "iauAtoi13", "R/di", status); - viv(j, 0, "iauAtoi13", "R/J", status); - - ob1 = -0.09247619879782006106; - ob2 = 0.1717653435758265198; - j = iauAtoi13 ( "H", ob1, ob2, utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - &ri, &di); - vvd(ri, 2.710121574449135955, 1e-12, "iauAtoi13", "H/ri", status); - vvd(di, 0.1729371839114567725, 1e-12, "iauAtoi13", "H/di", status); - viv(j, 0, "iauAtoi13", "H/J", status); - - ob1 = 0.09233952224794989993; - ob2 = 1.407758704513722461; - j = iauAtoi13 ( "A", ob1, ob2, utc1, utc2, dut1, - elong, phi, hm, xp, yp, phpa, tc, rh, wl, - &ri, &di); - vvd(ri, 2.710121574449135955, 1e-12, "iauAtoi13", "A/ri", status); - vvd(di, 0.1729371839114567728, 1e-12, "iauAtoi13", "A/di", status); - viv(j, 0, "iauAtoi13", "A/J", status); - -} - -static void t_atoiq(int *status) -/* -** - - - - - - - - -** t _ a t o i q -** - - - - - - - - -* -** Test iauAtoiq function. -* -** Returned: -** status int FALSE = success, TRUE = fail -* -** Called: iauApio13, iauAtoiq, vvd -* -** This revision: 2013 October 4 -*/ -{ - double utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl, - ob1, ob2, ri, di; - iauASTROM astrom; - - - utc1 = 2456384.5; - utc2 = 0.969254051; - dut1 = 0.1550675; - elong = -0.527800806; - phi = -1.2345856; - hm = 2738.0; - xp = 2.47230737e-7; - yp = 1.82640464e-6; - phpa = 731.0; - tc = 12.8; - rh = 0.59; - wl = 0.55; - (void) iauApio13(utc1, utc2, dut1, elong, phi, hm, xp, yp, - phpa, tc, rh, wl, &astrom); - - ob1 = 2.710085107986886201; - ob2 = 0.1717653435758265198; - iauAtoiq("R", ob1, ob2, &astrom, &ri, &di); - vvd(ri, 2.710121574449135955, 1e-12, - "iauAtoiq", "R/ri", status); - vvd(di, 0.1729371839114567725, 1e-12, - "iauAtoiq", "R/di", status); - - ob1 = -0.09247619879782006106; - ob2 = 0.1717653435758265198; - iauAtoiq("H", ob1, ob2, &astrom, &ri, &di); - vvd(ri, 2.710121574449135955, 1e-12, - "iauAtoiq", "H/ri", status); - vvd(di, 0.1729371839114567725, 1e-12, - "iauAtoiq", "H/di", status); - - ob1 = 0.09233952224794989993; - ob2 = 1.407758704513722461; - iauAtoiq("A", ob1, ob2, &astrom, &ri, &di); - vvd(ri, 2.710121574449135955, 1e-12, - "iauAtoiq", "A/ri", status); - vvd(di, 0.1729371839114567728, 1e-12, - "iauAtoiq", "A/di", status); - -} - -static void t_bi00(int *status) -/* -** - - - - - - - -** t _ b i 0 0 -** - - - - - - - -** -** Test iauBi00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauBi00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsibi, depsbi, dra; - - iauBi00(&dpsibi, &depsbi, &dra); - - vvd(dpsibi, -0.2025309152835086613e-6, 1e-12, - "iauBi00", "dpsibi", status); - vvd(depsbi, -0.3306041454222147847e-7, 1e-12, - "iauBi00", "depsbi", status); - vvd(dra, -0.7078279744199225506e-7, 1e-12, - "iauBi00", "dra", status); -} - -static void t_bp00(int *status) -/* -** - - - - - - - -** t _ b p 0 0 -** - - - - - - - -** -** Test iauBp00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauBp00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rb[3][3], rp[3][3], rbp[3][3]; - - - iauBp00(2400000.5, 50123.9999, rb, rp, rbp); - - vvd(rb[0][0], 0.9999999999999942498, 1e-12, - "iauBp00", "rb11", status); - vvd(rb[0][1], -0.7078279744199196626e-7, 1e-16, - "iauBp00", "rb12", status); - vvd(rb[0][2], 0.8056217146976134152e-7, 1e-16, - "iauBp00", "rb13", status); - vvd(rb[1][0], 0.7078279477857337206e-7, 1e-16, - "iauBp00", "rb21", status); - vvd(rb[1][1], 0.9999999999999969484, 1e-12, - "iauBp00", "rb22", status); - vvd(rb[1][2], 0.3306041454222136517e-7, 1e-16, - "iauBp00", "rb23", status); - vvd(rb[2][0], -0.8056217380986972157e-7, 1e-16, - "iauBp00", "rb31", status); - vvd(rb[2][1], -0.3306040883980552500e-7, 1e-16, - "iauBp00", "rb32", status); - vvd(rb[2][2], 0.9999999999999962084, 1e-12, - "iauBp00", "rb33", status); - - vvd(rp[0][0], 0.9999995504864048241, 1e-12, - "iauBp00", "rp11", status); - vvd(rp[0][1], 0.8696113836207084411e-3, 1e-14, - "iauBp00", "rp12", status); - vvd(rp[0][2], 0.3778928813389333402e-3, 1e-14, - "iauBp00", "rp13", status); - vvd(rp[1][0], -0.8696113818227265968e-3, 1e-14, - "iauBp00", "rp21", status); - vvd(rp[1][1], 0.9999996218879365258, 1e-12, - "iauBp00", "rp22", status); - vvd(rp[1][2], -0.1690679263009242066e-6, 1e-14, - "iauBp00", "rp23", status); - vvd(rp[2][0], -0.3778928854764695214e-3, 1e-14, - "iauBp00", "rp31", status); - vvd(rp[2][1], -0.1595521004195286491e-6, 1e-14, - "iauBp00", "rp32", status); - vvd(rp[2][2], 0.9999999285984682756, 1e-12, - "iauBp00", "rp33", status); - - vvd(rbp[0][0], 0.9999995505175087260, 1e-12, - "iauBp00", "rbp11", status); - vvd(rbp[0][1], 0.8695405883617884705e-3, 1e-14, - "iauBp00", "rbp12", status); - vvd(rbp[0][2], 0.3779734722239007105e-3, 1e-14, - "iauBp00", "rbp13", status); - vvd(rbp[1][0], -0.8695405990410863719e-3, 1e-14, - "iauBp00", "rbp21", status); - vvd(rbp[1][1], 0.9999996219494925900, 1e-12, - "iauBp00", "rbp22", status); - vvd(rbp[1][2], -0.1360775820404982209e-6, 1e-14, - "iauBp00", "rbp23", status); - vvd(rbp[2][0], -0.3779734476558184991e-3, 1e-14, - "iauBp00", "rbp31", status); - vvd(rbp[2][1], -0.1925857585832024058e-6, 1e-14, - "iauBp00", "rbp32", status); - vvd(rbp[2][2], 0.9999999285680153377, 1e-12, - "iauBp00", "rbp33", status); -} - -static void t_bp06(int *status) -/* -** - - - - - - - -** t _ b p 0 6 -** - - - - - - - -** -** Test iauBp06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauBp06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rb[3][3], rp[3][3], rbp[3][3]; - - - iauBp06(2400000.5, 50123.9999, rb, rp, rbp); - - vvd(rb[0][0], 0.9999999999999942497, 1e-12, - "iauBp06", "rb11", status); - vvd(rb[0][1], -0.7078368960971557145e-7, 1e-14, - "iauBp06", "rb12", status); - vvd(rb[0][2], 0.8056213977613185606e-7, 1e-14, - "iauBp06", "rb13", status); - vvd(rb[1][0], 0.7078368694637674333e-7, 1e-14, - "iauBp06", "rb21", status); - vvd(rb[1][1], 0.9999999999999969484, 1e-12, - "iauBp06", "rb22", status); - vvd(rb[1][2], 0.3305943742989134124e-7, 1e-14, - "iauBp06", "rb23", status); - vvd(rb[2][0], -0.8056214211620056792e-7, 1e-14, - "iauBp06", "rb31", status); - vvd(rb[2][1], -0.3305943172740586950e-7, 1e-14, - "iauBp06", "rb32", status); - vvd(rb[2][2], 0.9999999999999962084, 1e-12, - "iauBp06", "rb33", status); - - vvd(rp[0][0], 0.9999995504864960278, 1e-12, - "iauBp06", "rp11", status); - vvd(rp[0][1], 0.8696112578855404832e-3, 1e-14, - "iauBp06", "rp12", status); - vvd(rp[0][2], 0.3778929293341390127e-3, 1e-14, - "iauBp06", "rp13", status); - vvd(rp[1][0], -0.8696112560510186244e-3, 1e-14, - "iauBp06", "rp21", status); - vvd(rp[1][1], 0.9999996218880458820, 1e-12, - "iauBp06", "rp22", status); - vvd(rp[1][2], -0.1691646168941896285e-6, 1e-14, - "iauBp06", "rp23", status); - vvd(rp[2][0], -0.3778929335557603418e-3, 1e-14, - "iauBp06", "rp31", status); - vvd(rp[2][1], -0.1594554040786495076e-6, 1e-14, - "iauBp06", "rp32", status); - vvd(rp[2][2], 0.9999999285984501222, 1e-12, - "iauBp06", "rp33", status); - - vvd(rbp[0][0], 0.9999995505176007047, 1e-12, - "iauBp06", "rbp11", status); - vvd(rbp[0][1], 0.8695404617348208406e-3, 1e-14, - "iauBp06", "rbp12", status); - vvd(rbp[0][2], 0.3779735201865589104e-3, 1e-14, - "iauBp06", "rbp13", status); - vvd(rbp[1][0], -0.8695404723772031414e-3, 1e-14, - "iauBp06", "rbp21", status); - vvd(rbp[1][1], 0.9999996219496027161, 1e-12, - "iauBp06", "rbp22", status); - vvd(rbp[1][2], -0.1361752497080270143e-6, 1e-14, - "iauBp06", "rbp23", status); - vvd(rbp[2][0], -0.3779734957034089490e-3, 1e-14, - "iauBp06", "rbp31", status); - vvd(rbp[2][1], -0.1924880847894457113e-6, 1e-14, - "iauBp06", "rbp32", status); - vvd(rbp[2][2], 0.9999999285679971958, 1e-12, - "iauBp06", "rbp33", status); -} - -static void t_bpn2xy(int *status) -/* -** - - - - - - - - - -** t _ b p n 2 x y -** - - - - - - - - - -** -** Test iauBpn2xy function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauBpn2xy, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbpn[3][3], x, y; - - - rbpn[0][0] = 9.999962358680738e-1; - rbpn[0][1] = -2.516417057665452e-3; - rbpn[0][2] = -1.093569785342370e-3; - - rbpn[1][0] = 2.516462370370876e-3; - rbpn[1][1] = 9.999968329010883e-1; - rbpn[1][2] = 4.006159587358310e-5; - - rbpn[2][0] = 1.093465510215479e-3; - rbpn[2][1] = -4.281337229063151e-5; - rbpn[2][2] = 9.999994012499173e-1; - - iauBpn2xy(rbpn, &x, &y); - - vvd(x, 1.093465510215479e-3, 1e-12, "iauBpn2xy", "x", status); - vvd(y, -4.281337229063151e-5, 1e-12, "iauBpn2xy", "y", status); - -} - -static void t_c2i00a(int *status) -/* -** - - - - - - - - - -** t _ c 2 i 0 0 a -** - - - - - - - - - -** -** Test iauC2i00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2i00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rc2i[3][3]; - - - iauC2i00a(2400000.5, 53736.0, rc2i); - - vvd(rc2i[0][0], 0.9999998323037165557, 1e-12, - "iauC2i00a", "11", status); - vvd(rc2i[0][1], 0.5581526348992140183e-9, 1e-12, - "iauC2i00a", "12", status); - vvd(rc2i[0][2], -0.5791308477073443415e-3, 1e-12, - "iauC2i00a", "13", status); - - vvd(rc2i[1][0], -0.2384266227870752452e-7, 1e-12, - "iauC2i00a", "21", status); - vvd(rc2i[1][1], 0.9999999991917405258, 1e-12, - "iauC2i00a", "22", status); - vvd(rc2i[1][2], -0.4020594955028209745e-4, 1e-12, - "iauC2i00a", "23", status); - - vvd(rc2i[2][0], 0.5791308472168152904e-3, 1e-12, - "iauC2i00a", "31", status); - vvd(rc2i[2][1], 0.4020595661591500259e-4, 1e-12, - "iauC2i00a", "32", status); - vvd(rc2i[2][2], 0.9999998314954572304, 1e-12, - "iauC2i00a", "33", status); - -} - -static void t_c2i00b(int *status) -/* -** - - - - - - - - - -** t _ c 2 i 0 0 b -** - - - - - - - - - -** -** Test iauC2i00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2i00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rc2i[3][3]; - - - iauC2i00b(2400000.5, 53736.0, rc2i); - - vvd(rc2i[0][0], 0.9999998323040954356, 1e-12, - "iauC2i00b", "11", status); - vvd(rc2i[0][1], 0.5581526349131823372e-9, 1e-12, - "iauC2i00b", "12", status); - vvd(rc2i[0][2], -0.5791301934855394005e-3, 1e-12, - "iauC2i00b", "13", status); - - vvd(rc2i[1][0], -0.2384239285499175543e-7, 1e-12, - "iauC2i00b", "21", status); - vvd(rc2i[1][1], 0.9999999991917574043, 1e-12, - "iauC2i00b", "22", status); - vvd(rc2i[1][2], -0.4020552974819030066e-4, 1e-12, - "iauC2i00b", "23", status); - - vvd(rc2i[2][0], 0.5791301929950208873e-3, 1e-12, - "iauC2i00b", "31", status); - vvd(rc2i[2][1], 0.4020553681373720832e-4, 1e-12, - "iauC2i00b", "32", status); - vvd(rc2i[2][2], 0.9999998314958529887, 1e-12, - "iauC2i00b", "33", status); - -} - -static void t_c2i06a(int *status) -/* -** - - - - - - - - - -** t _ c 2 i 0 6 a -** - - - - - - - - - -** -** Test iauC2i06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2i06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rc2i[3][3]; - - - iauC2i06a(2400000.5, 53736.0, rc2i); - - vvd(rc2i[0][0], 0.9999998323037159379, 1e-12, - "iauC2i06a", "11", status); - vvd(rc2i[0][1], 0.5581121329587613787e-9, 1e-12, - "iauC2i06a", "12", status); - vvd(rc2i[0][2], -0.5791308487740529749e-3, 1e-12, - "iauC2i06a", "13", status); - - vvd(rc2i[1][0], -0.2384253169452306581e-7, 1e-12, - "iauC2i06a", "21", status); - vvd(rc2i[1][1], 0.9999999991917467827, 1e-12, - "iauC2i06a", "22", status); - vvd(rc2i[1][2], -0.4020579392895682558e-4, 1e-12, - "iauC2i06a", "23", status); - - vvd(rc2i[2][0], 0.5791308482835292617e-3, 1e-12, - "iauC2i06a", "31", status); - vvd(rc2i[2][1], 0.4020580099454020310e-4, 1e-12, - "iauC2i06a", "32", status); - vvd(rc2i[2][2], 0.9999998314954628695, 1e-12, - "iauC2i06a", "33", status); - -} - -static void t_c2ibpn(int *status) -/* -** - - - - - - - - - -** t _ c 2 i b p n -** - - - - - - - - - -** -** Test iauC2ibpn function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2ibpn, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbpn[3][3], rc2i[3][3]; - - - rbpn[0][0] = 9.999962358680738e-1; - rbpn[0][1] = -2.516417057665452e-3; - rbpn[0][2] = -1.093569785342370e-3; - - rbpn[1][0] = 2.516462370370876e-3; - rbpn[1][1] = 9.999968329010883e-1; - rbpn[1][2] = 4.006159587358310e-5; - - rbpn[2][0] = 1.093465510215479e-3; - rbpn[2][1] = -4.281337229063151e-5; - rbpn[2][2] = 9.999994012499173e-1; - - iauC2ibpn(2400000.5, 50123.9999, rbpn, rc2i); - - vvd(rc2i[0][0], 0.9999994021664089977, 1e-12, - "iauC2ibpn", "11", status); - vvd(rc2i[0][1], -0.3869195948017503664e-8, 1e-12, - "iauC2ibpn", "12", status); - vvd(rc2i[0][2], -0.1093465511383285076e-2, 1e-12, - "iauC2ibpn", "13", status); - - vvd(rc2i[1][0], 0.5068413965715446111e-7, 1e-12, - "iauC2ibpn", "21", status); - vvd(rc2i[1][1], 0.9999999990835075686, 1e-12, - "iauC2ibpn", "22", status); - vvd(rc2i[1][2], 0.4281334246452708915e-4, 1e-12, - "iauC2ibpn", "23", status); - - vvd(rc2i[2][0], 0.1093465510215479000e-2, 1e-12, - "iauC2ibpn", "31", status); - vvd(rc2i[2][1], -0.4281337229063151000e-4, 1e-12, - "iauC2ibpn", "32", status); - vvd(rc2i[2][2], 0.9999994012499173103, 1e-12, - "iauC2ibpn", "33", status); - -} - -static void t_c2ixy(int *status) -/* -** - - - - - - - - -** t _ c 2 i x y -** - - - - - - - - -** -** Test iauC2ixy function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2ixy, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y, rc2i[3][3]; - - - x = 0.5791308486706011000e-3; - y = 0.4020579816732961219e-4; - - iauC2ixy(2400000.5, 53736, x, y, rc2i); - - vvd(rc2i[0][0], 0.9999998323037157138, 1e-12, - "iauC2ixy", "11", status); - vvd(rc2i[0][1], 0.5581526349032241205e-9, 1e-12, - "iauC2ixy", "12", status); - vvd(rc2i[0][2], -0.5791308491611263745e-3, 1e-12, - "iauC2ixy", "13", status); - - vvd(rc2i[1][0], -0.2384257057469842953e-7, 1e-12, - "iauC2ixy", "21", status); - vvd(rc2i[1][1], 0.9999999991917468964, 1e-12, - "iauC2ixy", "22", status); - vvd(rc2i[1][2], -0.4020579110172324363e-4, 1e-12, - "iauC2ixy", "23", status); - - vvd(rc2i[2][0], 0.5791308486706011000e-3, 1e-12, - "iauC2ixy", "31", status); - vvd(rc2i[2][1], 0.4020579816732961219e-4, 1e-12, - "iauC2ixy", "32", status); - vvd(rc2i[2][2], 0.9999998314954627590, 1e-12, - "iauC2ixy", "33", status); - -} - -static void t_c2ixys(int *status) -/* -** - - - - - - - - - -** t _ c 2 i x y s -** - - - - - - - - - -** -** Test iauC2ixys function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2ixys, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y, s, rc2i[3][3]; - - - x = 0.5791308486706011000e-3; - y = 0.4020579816732961219e-4; - s = -0.1220040848472271978e-7; - - iauC2ixys(x, y, s, rc2i); - - vvd(rc2i[0][0], 0.9999998323037157138, 1e-12, - "iauC2ixys", "11", status); - vvd(rc2i[0][1], 0.5581984869168499149e-9, 1e-12, - "iauC2ixys", "12", status); - vvd(rc2i[0][2], -0.5791308491611282180e-3, 1e-12, - "iauC2ixys", "13", status); - - vvd(rc2i[1][0], -0.2384261642670440317e-7, 1e-12, - "iauC2ixys", "21", status); - vvd(rc2i[1][1], 0.9999999991917468964, 1e-12, - "iauC2ixys", "22", status); - vvd(rc2i[1][2], -0.4020579110169668931e-4, 1e-12, - "iauC2ixys", "23", status); - - vvd(rc2i[2][0], 0.5791308486706011000e-3, 1e-12, - "iauC2ixys", "31", status); - vvd(rc2i[2][1], 0.4020579816732961219e-4, 1e-12, - "iauC2ixys", "32", status); - vvd(rc2i[2][2], 0.9999998314954627590, 1e-12, - "iauC2ixys", "33", status); - -} - -static void t_c2s(int *status) -/* -** - - - - - - -** t _ c 2 s -** - - - - - - -** -** Test iauC2s function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2s, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3], theta, phi; - - - p[0] = 100.0; - p[1] = -50.0; - p[2] = 25.0; - - iauC2s(p, &theta, &phi); - - vvd(theta, -0.4636476090008061162, 1e-14, "iauC2s", "theta", status); - vvd(phi, 0.2199879773954594463, 1e-14, "iauC2s", "phi", status); - -} - -static void t_c2t00a(int *status) -/* -** - - - - - - - - - -** t _ c 2 t 0 0 a -** - - - - - - - - - -** -** Test iauC2t00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2t00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double tta, ttb, uta, utb, xp, yp, rc2t[3][3]; - - - tta = 2400000.5; - uta = 2400000.5; - ttb = 53736.0; - utb = 53736.0; - xp = 2.55060238e-7; - yp = 1.860359247e-6; - - iauC2t00a(tta, ttb, uta, utb, xp, yp, rc2t); - - vvd(rc2t[0][0], -0.1810332128307182668, 1e-12, - "iauC2t00a", "11", status); - vvd(rc2t[0][1], 0.9834769806938457836, 1e-12, - "iauC2t00a", "12", status); - vvd(rc2t[0][2], 0.6555535638688341725e-4, 1e-12, - "iauC2t00a", "13", status); - - vvd(rc2t[1][0], -0.9834768134135984552, 1e-12, - "iauC2t00a", "21", status); - vvd(rc2t[1][1], -0.1810332203649520727, 1e-12, - "iauC2t00a", "22", status); - vvd(rc2t[1][2], 0.5749801116141056317e-3, 1e-12, - "iauC2t00a", "23", status); - - vvd(rc2t[2][0], 0.5773474014081406921e-3, 1e-12, - "iauC2t00a", "31", status); - vvd(rc2t[2][1], 0.3961832391770163647e-4, 1e-12, - "iauC2t00a", "32", status); - vvd(rc2t[2][2], 0.9999998325501692289, 1e-12, - "iauC2t00a", "33", status); - -} - -static void t_c2t00b(int *status) -/* -** - - - - - - - - - -** t _ c 2 t 0 0 b -** - - - - - - - - - -** -** Test iauC2t00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2t00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double tta, ttb, uta, utb, xp, yp, rc2t[3][3]; - - - tta = 2400000.5; - uta = 2400000.5; - ttb = 53736.0; - utb = 53736.0; - xp = 2.55060238e-7; - yp = 1.860359247e-6; - - iauC2t00b(tta, ttb, uta, utb, xp, yp, rc2t); - - vvd(rc2t[0][0], -0.1810332128439678965, 1e-12, - "iauC2t00b", "11", status); - vvd(rc2t[0][1], 0.9834769806913872359, 1e-12, - "iauC2t00b", "12", status); - vvd(rc2t[0][2], 0.6555565082458415611e-4, 1e-12, - "iauC2t00b", "13", status); - - vvd(rc2t[1][0], -0.9834768134115435923, 1e-12, - "iauC2t00b", "21", status); - vvd(rc2t[1][1], -0.1810332203784001946, 1e-12, - "iauC2t00b", "22", status); - vvd(rc2t[1][2], 0.5749793922030017230e-3, 1e-12, - "iauC2t00b", "23", status); - - vvd(rc2t[2][0], 0.5773467471863534901e-3, 1e-12, - "iauC2t00b", "31", status); - vvd(rc2t[2][1], 0.3961790411549945020e-4, 1e-12, - "iauC2t00b", "32", status); - vvd(rc2t[2][2], 0.9999998325505635738, 1e-12, - "iauC2t00b", "33", status); - -} - -static void t_c2t06a(int *status) -/* -** - - - - - - - - - -** t _ c 2 t 0 6 a -** - - - - - - - - - -** -** Test iauC2t06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2t06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double tta, ttb, uta, utb, xp, yp, rc2t[3][3]; - - - tta = 2400000.5; - uta = 2400000.5; - ttb = 53736.0; - utb = 53736.0; - xp = 2.55060238e-7; - yp = 1.860359247e-6; - - iauC2t06a(tta, ttb, uta, utb, xp, yp, rc2t); - - vvd(rc2t[0][0], -0.1810332128305897282, 1e-12, - "iauC2t06a", "11", status); - vvd(rc2t[0][1], 0.9834769806938592296, 1e-12, - "iauC2t06a", "12", status); - vvd(rc2t[0][2], 0.6555550962998436505e-4, 1e-12, - "iauC2t06a", "13", status); - - vvd(rc2t[1][0], -0.9834768134136214897, 1e-12, - "iauC2t06a", "21", status); - vvd(rc2t[1][1], -0.1810332203649130832, 1e-12, - "iauC2t06a", "22", status); - vvd(rc2t[1][2], 0.5749800844905594110e-3, 1e-12, - "iauC2t06a", "23", status); - - vvd(rc2t[2][0], 0.5773474024748545878e-3, 1e-12, - "iauC2t06a", "31", status); - vvd(rc2t[2][1], 0.3961816829632690581e-4, 1e-12, - "iauC2t06a", "32", status); - vvd(rc2t[2][2], 0.9999998325501747785, 1e-12, - "iauC2t06a", "33", status); - -} - -static void t_c2tcio(int *status) -/* -** - - - - - - - - - -** t _ c 2 t c i o -** - - - - - - - - - -** -** Test iauC2tcio function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2tcio, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rc2i[3][3], era, rpom[3][3], rc2t[3][3]; - - - rc2i[0][0] = 0.9999998323037164738; - rc2i[0][1] = 0.5581526271714303683e-9; - rc2i[0][2] = -0.5791308477073443903e-3; - - rc2i[1][0] = -0.2384266227524722273e-7; - rc2i[1][1] = 0.9999999991917404296; - rc2i[1][2] = -0.4020594955030704125e-4; - - rc2i[2][0] = 0.5791308472168153320e-3; - rc2i[2][1] = 0.4020595661593994396e-4; - rc2i[2][2] = 0.9999998314954572365; - - era = 1.75283325530307; - - rpom[0][0] = 0.9999999999999674705; - rpom[0][1] = -0.1367174580728847031e-10; - rpom[0][2] = 0.2550602379999972723e-6; - - rpom[1][0] = 0.1414624947957029721e-10; - rpom[1][1] = 0.9999999999982694954; - rpom[1][2] = -0.1860359246998866338e-5; - - rpom[2][0] = -0.2550602379741215275e-6; - rpom[2][1] = 0.1860359247002413923e-5; - rpom[2][2] = 0.9999999999982369658; - - - iauC2tcio(rc2i, era, rpom, rc2t); - - vvd(rc2t[0][0], -0.1810332128307110439, 1e-12, - "iauC2tcio", "11", status); - vvd(rc2t[0][1], 0.9834769806938470149, 1e-12, - "iauC2tcio", "12", status); - vvd(rc2t[0][2], 0.6555535638685466874e-4, 1e-12, - "iauC2tcio", "13", status); - - vvd(rc2t[1][0], -0.9834768134135996657, 1e-12, - "iauC2tcio", "21", status); - vvd(rc2t[1][1], -0.1810332203649448367, 1e-12, - "iauC2tcio", "22", status); - vvd(rc2t[1][2], 0.5749801116141106528e-3, 1e-12, - "iauC2tcio", "23", status); - - vvd(rc2t[2][0], 0.5773474014081407076e-3, 1e-12, - "iauC2tcio", "31", status); - vvd(rc2t[2][1], 0.3961832391772658944e-4, 1e-12, - "iauC2tcio", "32", status); - vvd(rc2t[2][2], 0.9999998325501691969, 1e-12, - "iauC2tcio", "33", status); - -} - -static void t_c2teqx(int *status) -/* -** - - - - - - - - - -** t _ c 2 t e q x -** - - - - - - - - - -** -** Test iauC2teqx function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2teqx, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbpn[3][3], gst, rpom[3][3], rc2t[3][3]; - - - rbpn[0][0] = 0.9999989440476103608; - rbpn[0][1] = -0.1332881761240011518e-2; - rbpn[0][2] = -0.5790767434730085097e-3; - - rbpn[1][0] = 0.1332858254308954453e-2; - rbpn[1][1] = 0.9999991109044505944; - rbpn[1][2] = -0.4097782710401555759e-4; - - rbpn[2][0] = 0.5791308472168153320e-3; - rbpn[2][1] = 0.4020595661593994396e-4; - rbpn[2][2] = 0.9999998314954572365; - - gst = 1.754166138040730516; - - rpom[0][0] = 0.9999999999999674705; - rpom[0][1] = -0.1367174580728847031e-10; - rpom[0][2] = 0.2550602379999972723e-6; - - rpom[1][0] = 0.1414624947957029721e-10; - rpom[1][1] = 0.9999999999982694954; - rpom[1][2] = -0.1860359246998866338e-5; - - rpom[2][0] = -0.2550602379741215275e-6; - rpom[2][1] = 0.1860359247002413923e-5; - rpom[2][2] = 0.9999999999982369658; - - iauC2teqx(rbpn, gst, rpom, rc2t); - - vvd(rc2t[0][0], -0.1810332128528685730, 1e-12, - "iauC2teqx", "11", status); - vvd(rc2t[0][1], 0.9834769806897685071, 1e-12, - "iauC2teqx", "12", status); - vvd(rc2t[0][2], 0.6555535639982634449e-4, 1e-12, - "iauC2teqx", "13", status); - - vvd(rc2t[1][0], -0.9834768134095211257, 1e-12, - "iauC2teqx", "21", status); - vvd(rc2t[1][1], -0.1810332203871023800, 1e-12, - "iauC2teqx", "22", status); - vvd(rc2t[1][2], 0.5749801116126438962e-3, 1e-12, - "iauC2teqx", "23", status); - - vvd(rc2t[2][0], 0.5773474014081539467e-3, 1e-12, - "iauC2teqx", "31", status); - vvd(rc2t[2][1], 0.3961832391768640871e-4, 1e-12, - "iauC2teqx", "32", status); - vvd(rc2t[2][2], 0.9999998325501691969, 1e-12, - "iauC2teqx", "33", status); - -} - -static void t_c2tpe(int *status) -/* -** - - - - - - - - -** t _ c 2 t p e -** - - - - - - - - -** -** Test iauC2tpe function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2tpe, vvd -** -** This revision: 2013 August 7 -*/ -{ - double tta, ttb, uta, utb, dpsi, deps, xp, yp, rc2t[3][3]; - - - tta = 2400000.5; - uta = 2400000.5; - ttb = 53736.0; - utb = 53736.0; - deps = 0.4090789763356509900; - dpsi = -0.9630909107115582393e-5; - xp = 2.55060238e-7; - yp = 1.860359247e-6; - - iauC2tpe(tta, ttb, uta, utb, dpsi, deps, xp, yp, rc2t); - - vvd(rc2t[0][0], -0.1813677995763029394, 1e-12, - "iauC2tpe", "11", status); - vvd(rc2t[0][1], 0.9023482206891683275, 1e-12, - "iauC2tpe", "12", status); - vvd(rc2t[0][2], -0.3909902938641085751, 1e-12, - "iauC2tpe", "13", status); - - vvd(rc2t[1][0], -0.9834147641476804807, 1e-12, - "iauC2tpe", "21", status); - vvd(rc2t[1][1], -0.1659883635434995121, 1e-12, - "iauC2tpe", "22", status); - vvd(rc2t[1][2], 0.7309763898042819705e-1, 1e-12, - "iauC2tpe", "23", status); - - vvd(rc2t[2][0], 0.1059685430673215247e-2, 1e-12, - "iauC2tpe", "31", status); - vvd(rc2t[2][1], 0.3977631855605078674, 1e-12, - "iauC2tpe", "32", status); - vvd(rc2t[2][2], 0.9174875068792735362, 1e-12, - "iauC2tpe", "33", status); - -} - -static void t_c2txy(int *status) -/* -** - - - - - - - - -** t _ c 2 t x y -** - - - - - - - - -** -** Test iauC2txy function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauC2txy, vvd -** -** This revision: 2013 August 7 -*/ -{ - double tta, ttb, uta, utb, x, y, xp, yp, rc2t[3][3]; - - - tta = 2400000.5; - uta = 2400000.5; - ttb = 53736.0; - utb = 53736.0; - x = 0.5791308486706011000e-3; - y = 0.4020579816732961219e-4; - xp = 2.55060238e-7; - yp = 1.860359247e-6; - - iauC2txy(tta, ttb, uta, utb, x, y, xp, yp, rc2t); - - vvd(rc2t[0][0], -0.1810332128306279253, 1e-12, - "iauC2txy", "11", status); - vvd(rc2t[0][1], 0.9834769806938520084, 1e-12, - "iauC2txy", "12", status); - vvd(rc2t[0][2], 0.6555551248057665829e-4, 1e-12, - "iauC2txy", "13", status); - - vvd(rc2t[1][0], -0.9834768134136142314, 1e-12, - "iauC2txy", "21", status); - vvd(rc2t[1][1], -0.1810332203649529312, 1e-12, - "iauC2txy", "22", status); - vvd(rc2t[1][2], 0.5749800843594139912e-3, 1e-12, - "iauC2txy", "23", status); - - vvd(rc2t[2][0], 0.5773474028619264494e-3, 1e-12, - "iauC2txy", "31", status); - vvd(rc2t[2][1], 0.3961816546911624260e-4, 1e-12, - "iauC2txy", "32", status); - vvd(rc2t[2][2], 0.9999998325501746670, 1e-12, - "iauC2txy", "33", status); - -} - -static void t_cal2jd(int *status) -/* -** - - - - - - - - - -** t _ c a l 2 j d -** - - - - - - - - - -** -** Test iauCal2jd function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauCal2jd, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - int j; - double djm0, djm; - - - j = iauCal2jd(2003, 06, 01, &djm0, &djm); - - vvd(djm0, 2400000.5, 0.0, "iauCal2jd", "djm0", status); - vvd(djm, 52791.0, 0.0, "iauCal2jd", "djm", status); - - viv(j, 0, "iauCal2jd", "j", status); - -} - -static void t_cp(int *status) -/* -** - - - - - -** t _ c p -** - - - - - -** -** Test iauCp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauCp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3], c[3]; - - - p[0] = 0.3; - p[1] = 1.2; - p[2] = -2.5; - - iauCp(p, c); - - vvd(c[0], 0.3, 0.0, "iauCp", "1", status); - vvd(c[1], 1.2, 0.0, "iauCp", "2", status); - vvd(c[2], -2.5, 0.0, "iauCp", "3", status); -} - -static void t_cpv(int *status) -/* -** - - - - - - -** t _ c p v -** - - - - - - -** -** Test iauCpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauCpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3], c[2][3]; - - - pv[0][0] = 0.3; - pv[0][1] = 1.2; - pv[0][2] = -2.5; - - pv[1][0] = -0.5; - pv[1][1] = 3.1; - pv[1][2] = 0.9; - - iauCpv(pv, c); - - vvd(c[0][0], 0.3, 0.0, "iauCpv", "p1", status); - vvd(c[0][1], 1.2, 0.0, "iauCpv", "p2", status); - vvd(c[0][2], -2.5, 0.0, "iauCpv", "p3", status); - - vvd(c[1][0], -0.5, 0.0, "iauCpv", "v1", status); - vvd(c[1][1], 3.1, 0.0, "iauCpv", "v2", status); - vvd(c[1][2], 0.9, 0.0, "iauCpv", "v3", status); - -} - -static void t_cr(int *status) -/* -** - - - - - -** t _ c r -** - - - - - -** -** Test iauCr function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauCr, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3], c[3][3]; - - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - iauCr(r, c); - - vvd(c[0][0], 2.0, 0.0, "iauCr", "11", status); - vvd(c[0][1], 3.0, 0.0, "iauCr", "12", status); - vvd(c[0][2], 2.0, 0.0, "iauCr", "13", status); - - vvd(c[1][0], 3.0, 0.0, "iauCr", "21", status); - vvd(c[1][1], 2.0, 0.0, "iauCr", "22", status); - vvd(c[1][2], 3.0, 0.0, "iauCr", "23", status); - - vvd(c[2][0], 3.0, 0.0, "iauCr", "31", status); - vvd(c[2][1], 4.0, 0.0, "iauCr", "32", status); - vvd(c[2][2], 5.0, 0.0, "iauCr", "33", status); -} - -static void t_d2dtf(int *status ) -/* -** - - - - - - - - -** t _ d 2 d t f -** - - - - - - - - -** -** Test iauD2dtf function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauD2dtf, viv -** -** This revision: 2013 August 7 -*/ -{ - int j, iy, im, id, ihmsf[4]; - - - j = iauD2dtf("UTC", 5, 2400000.5, 49533.99999, &iy, &im, &id, ihmsf); - - viv(iy, 1994, "iauD2dtf", "y", status); - viv(im, 6, "iauD2dtf", "mo", status); - viv(id, 30, "iauD2dtf", "d", status); - viv(ihmsf[0], 23, "iauD2dtf", "h", status); - viv(ihmsf[1], 59, "iauD2dtf", "m", status); - viv(ihmsf[2], 60, "iauD2dtf", "s", status); - viv(ihmsf[3], 13599, "iauD2dtf", "f", status); - viv(j, 0, "iauD2dtf", "j", status); - -} - -static void t_d2tf(int *status) -/* -** - - - - - - - -** t _ d 2 t f -** - - - - - - - -** -** Test iauD2tf function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauD2tf, viv, vvd -** -** This revision: 2013 August 7 -*/ -{ - int ihmsf[4]; - char s; - - - iauD2tf(4, -0.987654321, &s, ihmsf); - - viv((int)s, '-', "iauD2tf", "s", status); - - viv(ihmsf[0], 23, "iauD2tf", "0", status); - viv(ihmsf[1], 42, "iauD2tf", "1", status); - viv(ihmsf[2], 13, "iauD2tf", "2", status); - viv(ihmsf[3], 3333, "iauD2tf", "3", status); - -} - -static void t_dat(int *status) -/* -** - - - - - - -** t _ d a t -** - - - - - - -** -** Test iauDat function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauDat, vvd, viv -** -** This revision: 2016 July 11 -*/ -{ - int j; - double deltat; - - - j = iauDat(2003, 6, 1, 0.0, &deltat); - - vvd(deltat, 32.0, 0.0, "iauDat", "d1", status); - viv(j, 0, "iauDat", "j1", status); - - j = iauDat(2008, 1, 17, 0.0, &deltat); - - vvd(deltat, 33.0, 0.0, "iauDat", "d2", status); - viv(j, 0, "iauDat", "j2", status); - - j = iauDat(2017, 9, 1, 0.0, &deltat); - - vvd(deltat, 37.0, 0.0, "iauDat", "d3", status); - viv(j, 0, "iauDat", "j3", status); - -} - -static void t_dtdb(int *status) -/* -** - - - - - - - -** t _ d t d b -** - - - - - - - -** -** Test iauDtdb function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauDtdb, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dtdb; - - - dtdb = iauDtdb(2448939.5, 0.123, 0.76543, 5.0123, 5525.242, 3190.0); - - vvd(dtdb, -0.1280368005936998991e-2, 1e-15, "iauDtdb", "", status); - -} - -static void t_dtf2d(int *status) -/* -** - - - - - - - - -** t _ d t f 2 d -** - - - - - - - - -** -** Test iauDtf2d function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauDtf2d, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double u1, u2; - int j; - - - j = iauDtf2d("UTC", 1994, 6, 30, 23, 59, 60.13599, &u1, &u2); - - vvd(u1+u2, 2449534.49999, 1e-6, "iauDtf2d", "u", status); - viv(j, 0, "iauDtf2d", "j", status); - -} - -static void t_eceq06(int *status) -/* -** - - - - - -** t _ e c e q 0 6 -** - - - - - -** -** Test iauEceq06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEceq06, vvd -** -** This revision: 2016 March 12 -*/ -{ - double date1, date2, dl, db, dr, dd; - - - date1 = 2456165.5; - date2 = 0.401182685; - dl = 5.1; - db = -0.9; - - iauEceq06(date1, date2, dl, db, &dr, &dd); - - vvd(dr, 5.533459733613627767, 1e-14, "iauEceq06", "dr", status); - vvd(dd, -1.246542932554480576, 1e-14, "iauEceq06", "dd", status); - -} - -static void t_ecm06(int *status) -/* -** - - - - - - - - -** t _ e c m 0 6 -** - - - - - - - - -** -** Test iauEcm06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEcm06, vvd -** -** This revision: 2016 March 12 -*/ -{ - double date1, date2, rm[3][3]; - - - date1 = 2456165.5; - date2 = 0.401182685; - - iauEcm06(date1, date2, rm); - - vvd(rm[0][0], 0.9999952427708701137, 1e-14, - "iauEcm06", "rm11", status); - vvd(rm[0][1], -0.2829062057663042347e-2, 1e-14, - "iauEcm06", "rm12", status); - vvd(rm[0][2], -0.1229163741100017629e-2, 1e-14, - "iauEcm06", "rm13", status); - vvd(rm[1][0], 0.3084546876908653562e-2, 1e-14, - "iauEcm06", "rm21", status); - vvd(rm[1][1], 0.9174891871550392514, 1e-14, - "iauEcm06", "rm22", status); - vvd(rm[1][2], 0.3977487611849338124, 1e-14, - "iauEcm06", "rm23", status); - vvd(rm[2][0], 0.2488512951527405928e-5, 1e-14, - "iauEcm06", "rm31", status); - vvd(rm[2][1], -0.3977506604161195467, 1e-14, - "iauEcm06", "rm32", status); - vvd(rm[2][2], 0.9174935488232863071, 1e-14, - "iauEcm06", "rm33", status); - -} - -static void t_ee00(int *status) -/* -** - - - - - - - -** t _ e e 0 0 -** - - - - - - - -** -** Test iauEe00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEe00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double epsa, dpsi, ee; - - - epsa = 0.4090789763356509900; - dpsi = -0.9630909107115582393e-5; - - ee = iauEe00(2400000.5, 53736.0, epsa, dpsi); - - vvd(ee, -0.8834193235367965479e-5, 1e-18, "iauEe00", "", status); - -} - -static void t_ee00a(int *status) -/* -** - - - - - - - - -** t _ e e 0 0 a -** - - - - - - - - -** -** Test iauEe00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEe00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double ee; - - - ee = iauEe00a(2400000.5, 53736.0); - - vvd(ee, -0.8834192459222588227e-5, 1e-18, "iauEe00a", "", status); - -} - -static void t_ee00b(int *status) -/* -** - - - - - - - - -** t _ e e 0 0 b -** - - - - - - - - -** -** Test iauEe00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEe00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double ee; - - - ee = iauEe00b(2400000.5, 53736.0); - - vvd(ee, -0.8835700060003032831e-5, 1e-18, "iauEe00b", "", status); - -} - -static void t_ee06a(int *status) -/* -** - - - - - - - - -** t _ e e 0 6 a -** - - - - - - - - -** -** Test iauEe06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEe06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double ee; - - - ee = iauEe06a(2400000.5, 53736.0); - - vvd(ee, -0.8834195072043790156e-5, 1e-15, "iauEe06a", "", status); -} - -static void t_eect00(int *status) -/* -** - - - - - - - - - -** t _ e e c t 0 0 -** - - - - - - - - - -** -** Test iauEect00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEect00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double eect; - - - eect = iauEect00(2400000.5, 53736.0); - - vvd(eect, 0.2046085004885125264e-8, 1e-20, "iauEect00", "", status); - -} - -static void t_eform(int *status) -/* -** - - - - - - - - -** t _ e f o r m -** - - - - - - - - -** -** Test iauEform function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEform, viv, vvd -** -** This revision: 2016 March 12 -*/ -{ - int j; - double a, f; - - j = iauEform(0, &a, &f); - - viv(j, -1, "iauEform", "j0", status); - - j = iauEform(WGS84, &a, &f); - - viv(j, 0, "iauEform", "j1", status); - vvd(a, 6378137.0, 1e-10, "iauEform", "a1", status); - vvd(f, 0.3352810664747480720e-2, 1e-18, "iauEform", "f1", status); - - j = iauEform(GRS80, &a, &f); - - viv(j, 0, "iauEform", "j2", status); - vvd(a, 6378137.0, 1e-10, "iauEform", "a2", status); - vvd(f, 0.3352810681182318935e-2, 1e-18, "iauEform", "f2", status); - - j = iauEform(WGS72, &a, &f); - - viv(j, 0, "iauEform", "j2", status); - vvd(a, 6378135.0, 1e-10, "iauEform", "a3", status); - vvd(f, 0.3352779454167504862e-2, 1e-18, "iauEform", "f3", status); - - j = iauEform(4, &a, &f); - viv(j, -1, "iauEform", "j3", status); -} - -static void t_eo06a(int *status) -/* -** - - - - - - - - -** t _ e o 0 6 a -** - - - - - - - - -** -** Test iauEo06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEo06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double eo; - - - eo = iauEo06a(2400000.5, 53736.0); - - vvd(eo, -0.1332882371941833644e-2, 1e-15, "iauEo06a", "", status); - -} - -static void t_eors(int *status) -/* -** - - - - - - - -** t _ e o r s -** - - - - - - - -** -** Test iauEors function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEors, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rnpb[3][3], s, eo; - - - rnpb[0][0] = 0.9999989440476103608; - rnpb[0][1] = -0.1332881761240011518e-2; - rnpb[0][2] = -0.5790767434730085097e-3; - - rnpb[1][0] = 0.1332858254308954453e-2; - rnpb[1][1] = 0.9999991109044505944; - rnpb[1][2] = -0.4097782710401555759e-4; - - rnpb[2][0] = 0.5791308472168153320e-3; - rnpb[2][1] = 0.4020595661593994396e-4; - rnpb[2][2] = 0.9999998314954572365; - - s = -0.1220040848472271978e-7; - - eo = iauEors(rnpb, s); - - vvd(eo, -0.1332882715130744606e-2, 1e-14, "iauEors", "", status); - -} - -static void t_epb(int *status) -/* -** - - - - - - -** t _ e p b -** - - - - - - -** -** Test iauEpb function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEpb, vvd -** -** This revision: 2013 August 7 -*/ -{ - double epb; - - - epb = iauEpb(2415019.8135, 30103.18648); - - vvd(epb, 1982.418424159278580, 1e-12, "iauEpb", "", status); - -} - -static void t_epb2jd(int *status) -/* -** - - - - - - - - - -** t _ e p b 2 j d -** - - - - - - - - - -** -** Test iauEpb2jd function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEpb2jd, vvd -** -** This revision: 2013 August 7 -*/ -{ - double epb, djm0, djm; - - - epb = 1957.3; - - iauEpb2jd(epb, &djm0, &djm); - - vvd(djm0, 2400000.5, 1e-9, "iauEpb2jd", "djm0", status); - vvd(djm, 35948.1915101513, 1e-9, "iauEpb2jd", "mjd", status); - -} - -static void t_epj(int *status) -/* -** - - - - - - -** t _ e p j -** - - - - - - -** -** Test iauEpj function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEpj, vvd -** -** This revision: 2013 August 7 -*/ -{ - double epj; - - - epj = iauEpj(2451545, -7392.5); - - vvd(epj, 1979.760438056125941, 1e-12, "iauEpj", "", status); - -} - -static void t_epj2jd(int *status) -/* -** - - - - - - - - - -** t _ e p j 2 j d -** - - - - - - - - - -** -** Test iauEpj2jd function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEpj2jd, vvd -** -** This revision: 2013 August 7 -*/ -{ - double epj, djm0, djm; - - - epj = 1996.8; - - iauEpj2jd(epj, &djm0, &djm); - - vvd(djm0, 2400000.5, 1e-9, "iauEpj2jd", "djm0", status); - vvd(djm, 50375.7, 1e-9, "iauEpj2jd", "mjd", status); - -} - -static void t_epv00(int *status) -/* -** - - - - - - - - -** t _ e p v 0 0 -** - - - - - - - - -** -** Test iauEpv00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEpv00, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double pvh[2][3], pvb[2][3]; - int j; - - - j = iauEpv00(2400000.5, 53411.52501161, pvh, pvb); - - vvd(pvh[0][0], -0.7757238809297706813, 1e-14, - "iauEpv00", "ph(x)", status); - vvd(pvh[0][1], 0.5598052241363340596, 1e-14, - "iauEpv00", "ph(y)", status); - vvd(pvh[0][2], 0.2426998466481686993, 1e-14, - "iauEpv00", "ph(z)", status); - - vvd(pvh[1][0], -0.1091891824147313846e-1, 1e-15, - "iauEpv00", "vh(x)", status); - vvd(pvh[1][1], -0.1247187268440845008e-1, 1e-15, - "iauEpv00", "vh(y)", status); - vvd(pvh[1][2], -0.5407569418065039061e-2, 1e-15, - "iauEpv00", "vh(z)", status); - - vvd(pvb[0][0], -0.7714104440491111971, 1e-14, - "iauEpv00", "pb(x)", status); - vvd(pvb[0][1], 0.5598412061824171323, 1e-14, - "iauEpv00", "pb(y)", status); - vvd(pvb[0][2], 0.2425996277722452400, 1e-14, - "iauEpv00", "pb(z)", status); - - vvd(pvb[1][0], -0.1091874268116823295e-1, 1e-15, - "iauEpv00", "vb(x)", status); - vvd(pvb[1][1], -0.1246525461732861538e-1, 1e-15, - "iauEpv00", "vb(y)", status); - vvd(pvb[1][2], -0.5404773180966231279e-2, 1e-15, - "iauEpv00", "vb(z)", status); - - viv(j, 0, "iauEpv00", "j", status); - -} - -static void t_eqec06(int *status) -/* -** - - - - - - - - - -** t _ e q e c 0 6 -** - - - - - - - - - -** -** Test iauEqec06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEqec06, vvd -** -** This revision: 2016 March 12 -*/ -{ - double date1, date2, dr, dd, dl, db; - - - date1 = 1234.5; - date2 = 2440000.5; - dr = 1.234; - dd = 0.987; - - iauEqec06(date1, date2, dr, dd, &dl, &db); - - vvd(dl, 1.342509918994654619, 1e-14, "iauEqec06", "dl", status); - vvd(db, 0.5926215259704608132, 1e-14, "iauEqec06", "db", status); - -} - -static void t_eqeq94(int *status) -/* -** - - - - - - - - - -** t _ e q e q 9 4 -** - - - - - - - - - -** -** Test iauEqeq94 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEqeq94, vvd -** -** This revision: 2013 August 7 -*/ -{ - double eqeq; - - - eqeq = iauEqeq94(2400000.5, 41234.0); - - vvd(eqeq, 0.5357758254609256894e-4, 1e-17, "iauEqeq94", "", status); - -} - -static void t_era00(int *status) -/* -** - - - - - - - - -** t _ e r a 0 0 -** - - - - - - - - -** -** Test iauEra00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauEra00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double era00; - - - era00 = iauEra00(2400000.5, 54388.0); - - vvd(era00, 0.4022837240028158102, 1e-12, "iauEra00", "", status); - -} - -static void t_fad03(int *status) -/* -** - - - - - - - - -** t _ f a d 0 3 -** - - - - - - - - -** -** Test iauFad03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFad03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFad03(0.80), 1.946709205396925672, 1e-12, - "iauFad03", "", status); -} - -static void t_fae03(int *status) -/* -** - - - - - - - - -** t _ f a e 0 3 -** - - - - - - - - -** -** Test iauFae03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFae03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFae03(0.80), 1.744713738913081846, 1e-12, - "iauFae03", "", status); -} - -static void t_faf03(int *status) -/* -** - - - - - - - - -** t _ f a f 0 3 -** - - - - - - - - -** -** Test iauFaf03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFaf03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFaf03(0.80), 0.2597711366745499518, 1e-12, - "iauFaf03", "", status); -} - -static void t_faju03(int *status) -/* -** - - - - - - - - - -** t _ f a j u 0 3 -** - - - - - - - - - -** -** Test iauFaju03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFaju03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFaju03(0.80), 5.275711665202481138, 1e-12, - "iauFaju03", "", status); -} - -static void t_fal03(int *status) -/* -** - - - - - - - - -** t _ f a l 0 3 -** - - - - - - - - -** -** Test iauFal03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFal03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFal03(0.80), 5.132369751108684150, 1e-12, - "iauFal03", "", status); -} - -static void t_falp03(int *status) -/* -** - - - - - - - - - -** t _ f a l p 0 3 -** - - - - - - - - - -** -** Test iauFalp03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFalp03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFalp03(0.80), 6.226797973505507345, 1e-12, - "iauFalp03", "", status); -} - -static void t_fama03(int *status) -/* -** - - - - - - - - - -** t _ f a m a 0 3 -** - - - - - - - - - -** -** Test iauFama03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFama03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFama03(0.80), 3.275506840277781492, 1e-12, - "iauFama03", "", status); -} - -static void t_fame03(int *status) -/* -** - - - - - - - - - -** t _ f a m e 0 3 -** - - - - - - - - - -** -** Test iauFame03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFame03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFame03(0.80), 5.417338184297289661, 1e-12, - "iauFame03", "", status); -} - -static void t_fane03(int *status) -/* -** - - - - - - - - - -** t _ f a n e 0 3 -** - - - - - - - - - -** -** Test iauFane03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFane03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFane03(0.80), 2.079343830860413523, 1e-12, - "iauFane03", "", status); -} - -static void t_faom03(int *status) -/* -** - - - - - - - - - -** t _ f a o m 0 3 -** - - - - - - - - - -** -** Test iauFaom03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFaom03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFaom03(0.80), -5.973618440951302183, 1e-12, - "iauFaom03", "", status); -} - -static void t_fapa03(int *status) -/* -** - - - - - - - - - -** t _ f a p a 0 3 -** - - - - - - - - - -** -** Test iauFapa03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFapa03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFapa03(0.80), 0.1950884762240000000e-1, 1e-12, - "iauFapa03", "", status); -} - -static void t_fasa03(int *status) -/* -** - - - - - - - - - -** t _ f a s a 0 3 -** - - - - - - - - - -** -** Test iauFasa03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFasa03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFasa03(0.80), 5.371574539440827046, 1e-12, - "iauFasa03", "", status); -} - -static void t_faur03(int *status) -/* -** - - - - - - - - - -** t _ f a u r 0 3 -** - - - - - - - - - -** -** Test iauFaur03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFaur03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFaur03(0.80), 5.180636450180413523, 1e-12, - "iauFaur03", "", status); -} - -static void t_fave03(int *status) -/* -** - - - - - - - - - -** t _ f a v e 0 3 -** - - - - - - - - - -** -** Test iauFave03 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFave03, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauFave03(0.80), 3.424900460533758000, 1e-12, - "iauFave03", "", status); -} - -static void t_fk52h(int *status) -/* -** - - - - - - - - -** t _ f k 5 2 h -** - - - - - - - - -** -** Test iauFk52h function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFk52h, vvd -** -** This revision: 2016 December 22 -*/ -{ - double r5, d5, dr5, dd5, px5, rv5, rh, dh, drh, ddh, pxh, rvh; - - - r5 = 1.76779433; - d5 = -0.2917517103; - dr5 = -1.91851572e-7; - dd5 = -5.8468475e-6; - px5 = 0.379210; - rv5 = -7.6; - - iauFk52h(r5, d5, dr5, dd5, px5, rv5, - &rh, &dh, &drh, &ddh, &pxh, &rvh); - - vvd(rh, 1.767794226299947632, 1e-14, - "iauFk52h", "ra", status); - vvd(dh, -0.2917516070530391757, 1e-14, - "iauFk52h", "dec", status); - vvd(drh, -0.19618741256057224e-6,1e-19, - "iauFk52h", "dr5", status); - vvd(ddh, -0.58459905176693911e-5, 1e-19, - "iauFk52h", "dd5", status); - vvd(pxh, 0.37921, 1e-14, - "iauFk52h", "px", status); - vvd(rvh, -7.6000000940000254, 1e-10, - "iauFk52h", "rv", status); - -} - -static void t_fk5hip(int *status) -/* -** - - - - - - - - - -** t _ f k 5 h i p -** - - - - - - - - - -** -** Test iauFk5hip function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFk5hip, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r5h[3][3], s5h[3]; - - - iauFk5hip(r5h, s5h); - - vvd(r5h[0][0], 0.9999999999999928638, 1e-14, - "iauFk5hip", "11", status); - vvd(r5h[0][1], 0.1110223351022919694e-6, 1e-17, - "iauFk5hip", "12", status); - vvd(r5h[0][2], 0.4411803962536558154e-7, 1e-17, - "iauFk5hip", "13", status); - vvd(r5h[1][0], -0.1110223308458746430e-6, 1e-17, - "iauFk5hip", "21", status); - vvd(r5h[1][1], 0.9999999999999891830, 1e-14, - "iauFk5hip", "22", status); - vvd(r5h[1][2], -0.9647792498984142358e-7, 1e-17, - "iauFk5hip", "23", status); - vvd(r5h[2][0], -0.4411805033656962252e-7, 1e-17, - "iauFk5hip", "31", status); - vvd(r5h[2][1], 0.9647792009175314354e-7, 1e-17, - "iauFk5hip", "32", status); - vvd(r5h[2][2], 0.9999999999999943728, 1e-14, - "iauFk5hip", "33", status); - vvd(s5h[0], -0.1454441043328607981e-8, 1e-17, - "iauFk5hip", "s1", status); - vvd(s5h[1], 0.2908882086657215962e-8, 1e-17, - "iauFk5hip", "s2", status); - vvd(s5h[2], 0.3393695767766751955e-8, 1e-17, - "iauFk5hip", "s3", status); - -} - -static void t_fk5hz(int *status) -/* -** - - - - - - - - -** t _ f k 5 h z -** - - - - - - - - -** -** Test iauFk5hz function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFk5hz, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r5, d5, rh, dh; - - - r5 = 1.76779433; - d5 = -0.2917517103; - - iauFk5hz(r5, d5, 2400000.5, 54479.0, &rh, &dh); - - vvd(rh, 1.767794191464423978, 1e-12, "iauFk5hz", "ra", status); - vvd(dh, -0.2917516001679884419, 1e-12, "iauFk5hz", "dec", status); - -} - -static void t_fw2m(int *status) -/* -** - - - - - - - -** t _ f w 2 m -** - - - - - - - -** -** Test iauFw2m function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFw2m, vvd -** -** This revision: 2013 August 7 -*/ -{ - double gamb, phib, psi, eps, r[3][3]; - - - gamb = -0.2243387670997992368e-5; - phib = 0.4091014602391312982; - psi = -0.9501954178013015092e-3; - eps = 0.4091014316587367472; - - iauFw2m(gamb, phib, psi, eps, r); - - vvd(r[0][0], 0.9999995505176007047, 1e-12, - "iauFw2m", "11", status); - vvd(r[0][1], 0.8695404617348192957e-3, 1e-12, - "iauFw2m", "12", status); - vvd(r[0][2], 0.3779735201865582571e-3, 1e-12, - "iauFw2m", "13", status); - - vvd(r[1][0], -0.8695404723772016038e-3, 1e-12, - "iauFw2m", "21", status); - vvd(r[1][1], 0.9999996219496027161, 1e-12, - "iauFw2m", "22", status); - vvd(r[1][2], -0.1361752496887100026e-6, 1e-12, - "iauFw2m", "23", status); - - vvd(r[2][0], -0.3779734957034082790e-3, 1e-12, - "iauFw2m", "31", status); - vvd(r[2][1], -0.1924880848087615651e-6, 1e-12, - "iauFw2m", "32", status); - vvd(r[2][2], 0.9999999285679971958, 1e-12, - "iauFw2m", "33", status); - -} - -static void t_fw2xy(int *status) -/* -** - - - - - - - - -** t _ f w 2 x y -** - - - - - - - - -** -** Test iauFw2xy function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauFw2xy, vvd -** -** This revision: 2013 August 7 -*/ -{ - double gamb, phib, psi, eps, x, y; - - - gamb = -0.2243387670997992368e-5; - phib = 0.4091014602391312982; - psi = -0.9501954178013015092e-3; - eps = 0.4091014316587367472; - - iauFw2xy(gamb, phib, psi, eps, &x, &y); - - vvd(x, -0.3779734957034082790e-3, 1e-14, "iauFw2xy", "x", status); - vvd(y, -0.1924880848087615651e-6, 1e-14, "iauFw2xy", "y", status); - -} - -static void t_g2icrs(int *status) -/* -** - - - - - - - - - -** t _ g 2 i c r s -** - - - - - - - - - -** -** Test iauG2icrs function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauG2icrs, vvd -** -** This revision: 2015 January 30 -*/ -{ - double dl, db, dr, dd; - - - dl = 5.5850536063818546461558105; - db = -0.7853981633974483096156608; - iauG2icrs (dl, db, &dr, &dd); - vvd(dr, 5.9338074302227188048671, 1e-14, "iauG2icrs", "R", status); - vvd(dd, -1.1784870613579944551541, 1e-14, "iauG2icrs", "D", status); - } - -static void t_gc2gd(int *status) -/* -** - - - - - - - - -** t _ g c 2 g d -** - - - - - - - - -** -** Test iauGc2gd function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGc2gd, viv, vvd -** -** This revision: 2016 March 12 -*/ -{ - int j; - double xyz[] = {2e6, 3e6, 5.244e6}; - double e, p, h; - - j = iauGc2gd(0, xyz, &e, &p, &h); - - viv(j, -1, "iauGc2gd", "j0", status); - - j = iauGc2gd(WGS84, xyz, &e, &p, &h); - - viv(j, 0, "iauGc2gd", "j1", status); - vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gd", "e1", status); - vvd(p, 0.97160184819075459, 1e-14, "iauGc2gd", "p1", status); - vvd(h, 331.4172461426059892, 1e-8, "iauGc2gd", "h1", status); - - j = iauGc2gd(GRS80, xyz, &e, &p, &h); - - viv(j, 0, "iauGc2gd", "j2", status); - vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gd", "e2", status); - vvd(p, 0.97160184820607853, 1e-14, "iauGc2gd", "p2", status); - vvd(h, 331.41731754844348, 1e-8, "iauGc2gd", "h2", status); - - j = iauGc2gd(WGS72, xyz, &e, &p, &h); - - viv(j, 0, "iauGc2gd", "j3", status); - vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gd", "e3", status); - vvd(p, 0.9716018181101511937, 1e-14, "iauGc2gd", "p3", status); - vvd(h, 333.2770726130318123, 1e-8, "iauGc2gd", "h3", status); - - j = iauGc2gd(4, xyz, &e, &p, &h); - - viv(j, -1, "iauGc2gd", "j4", status); -} - -static void t_gc2gde(int *status) -/* -** - - - - - - - - - -** t _ g c 2 g d e -** - - - - - - - - - -** -** Test iauGc2gde function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGc2gde, viv, vvd -** -** This revision: 2016 March 12 -*/ -{ - int j; - double a = 6378136.0, f = 0.0033528; - double xyz[] = {2e6, 3e6, 5.244e6}; - double e, p, h; - - j = iauGc2gde(a, f, xyz, &e, &p, &h); - - viv(j, 0, "iauGc2gde", "j", status); - vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gde", "e", status); - vvd(p, 0.9716018377570411532, 1e-14, "iauGc2gde", "p", status); - vvd(h, 332.36862495764397, 1e-8, "iauGc2gde", "h", status); -} - -static void t_gd2gc(int *status) -/* -** - - - - - - - - -** t _ g d 2 g c -** - - - - - - - - -** -** Test iauGd2gc function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGd2gc, viv, vvd -** -** This revision: 2016 March 12 -*/ -{ - int j; - double e = 3.1, p = -0.5, h = 2500.0; - double xyz[3]; - - j = iauGd2gc(0, e, p, h, xyz); - - viv(j, -1, "iauGd2gc", "j0", status); - - j = iauGd2gc(WGS84, e, p, h, xyz); - - viv(j, 0, "iauGd2gc", "j1", status); - vvd(xyz[0], -5599000.5577049947, 1e-7, "iauGd2gc", "1/1", status); - vvd(xyz[1], 233011.67223479203, 1e-7, "iauGd2gc", "2/1", status); - vvd(xyz[2], -3040909.4706983363, 1e-7, "iauGd2gc", "3/1", status); - - j = iauGd2gc(GRS80, e, p, h, xyz); - - viv(j, 0, "iauGd2gc", "j2", status); - vvd(xyz[0], -5599000.5577260984, 1e-7, "iauGd2gc", "1/2", status); - vvd(xyz[1], 233011.6722356702949, 1e-7, "iauGd2gc", "2/2", status); - vvd(xyz[2], -3040909.4706095476, 1e-7, "iauGd2gc", "3/2", status); - - j = iauGd2gc(WGS72, e, p, h, xyz); - - viv(j, 0, "iauGd2gc", "j3", status); - vvd(xyz[0], -5598998.7626301490, 1e-7, "iauGd2gc", "1/3", status); - vvd(xyz[1], 233011.5975297822211, 1e-7, "iauGd2gc", "2/3", status); - vvd(xyz[2], -3040908.6861467111, 1e-7, "iauGd2gc", "3/3", status); - - j = iauGd2gc(4, e, p, h, xyz); - - viv(j, -1, "iauGd2gc", "j4", status); -} - -static void t_gd2gce(int *status) -/* -** - - - - - - - - - -** t _ g d 2 g c e -** - - - - - - - - - -** -** Test iauGd2gce function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGd2gce, viv, vvd -** -** This revision: 2016 March 12 -*/ -{ - int j; - double a = 6378136.0, f = 0.0033528; - double e = 3.1, p = -0.5, h = 2500.0; - double xyz[3]; - - j = iauGd2gce(a, f, e, p, h, xyz); - - viv(j, 0, "iauGd2gce", "j", status); - vvd(xyz[0], -5598999.6665116328, 1e-7, "iauGd2gce", "1", status); - vvd(xyz[1], 233011.6351463057189, 1e-7, "iauGd2gce", "2", status); - vvd(xyz[2], -3040909.0517314132, 1e-7, "iauGd2gce", "3", status); -} - -static void t_gmst00(int *status) -/* -** - - - - - - - - - -** t _ g m s t 0 0 -** - - - - - - - - - -** -** Test iauGmst00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGmst00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta; - - - theta = iauGmst00(2400000.5, 53736.0, 2400000.5, 53736.0); - - vvd(theta, 1.754174972210740592, 1e-12, "iauGmst00", "", status); - -} - -static void t_gmst06(int *status) -/* -** - - - - - - - - - -** t _ g m s t 0 6 -** - - - - - - - - - -** -** Test iauGmst06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGmst06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta; - - - theta = iauGmst06(2400000.5, 53736.0, 2400000.5, 53736.0); - - vvd(theta, 1.754174971870091203, 1e-12, "iauGmst06", "", status); - -} - -static void t_gmst82(int *status) -/* -** - - - - - - - - - -** t _ g m s t 8 2 -** - - - - - - - - - -** -** Test iauGmst82 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGmst82, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta; - - - theta = iauGmst82(2400000.5, 53736.0); - - vvd(theta, 1.754174981860675096, 1e-12, "iauGmst82", "", status); - -} - -static void t_gst00a(int *status) -/* -** - - - - - - - - - -** t _ g s t 0 0 a -** - - - - - - - - - -** -** Test iauGst00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGst00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta; - - - theta = iauGst00a(2400000.5, 53736.0, 2400000.5, 53736.0); - - vvd(theta, 1.754166138018281369, 1e-12, "iauGst00a", "", status); - -} - -static void t_gst00b(int *status) -/* -** - - - - - - - - - -** t _ g s t 0 0 b -** - - - - - - - - - -** -** Test iauGst00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGst00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta; - - - theta = iauGst00b(2400000.5, 53736.0); - - vvd(theta, 1.754166136510680589, 1e-12, "iauGst00b", "", status); - -} - -static void t_gst06(int *status) -/* -** - - - - - - - - -** t _ g s t 0 6 -** - - - - - - - - -** -** Test iauGst06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGst06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rnpb[3][3], theta; - - - rnpb[0][0] = 0.9999989440476103608; - rnpb[0][1] = -0.1332881761240011518e-2; - rnpb[0][2] = -0.5790767434730085097e-3; - - rnpb[1][0] = 0.1332858254308954453e-2; - rnpb[1][1] = 0.9999991109044505944; - rnpb[1][2] = -0.4097782710401555759e-4; - - rnpb[2][0] = 0.5791308472168153320e-3; - rnpb[2][1] = 0.4020595661593994396e-4; - rnpb[2][2] = 0.9999998314954572365; - - theta = iauGst06(2400000.5, 53736.0, 2400000.5, 53736.0, rnpb); - - vvd(theta, 1.754166138018167568, 1e-12, "iauGst06", "", status); - -} - -static void t_gst06a(int *status) -/* -** - - - - - - - - - -** t _ g s t 0 6 a -** - - - - - - - - - -** -** Test iauGst06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGst06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta; - - - theta = iauGst06a(2400000.5, 53736.0, 2400000.5, 53736.0); - - vvd(theta, 1.754166137675019159, 1e-12, "iauGst06a", "", status); - -} - -static void t_gst94(int *status) -/* -** - - - - - - - - -** t _ g s t 9 4 -** - - - - - - - - -** -** Test iauGst94 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauGst94, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta; - - - theta = iauGst94(2400000.5, 53736.0); - - vvd(theta, 1.754166136020645203, 1e-12, "iauGst94", "", status); - -} - -static void t_icrs2g(int *status) -/* -** - - - - - - - - - -** t _ i c r s 2 g -** - - - - - - - - - -** -** Test iauIcrs2g function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauIcrs2g, vvd -** -** This revision: 2015 January 30 -*/ -{ - double dr, dd, dl, db; - - dr = 5.9338074302227188048671087; - dd = -1.1784870613579944551540570; - iauIcrs2g (dr, dd, &dl, &db); - vvd(dl, 5.5850536063818546461558, 1e-14, "iauIcrs2g", "L", status); - vvd(db, -0.7853981633974483096157, 1e-14, "iauIcrs2g", "B", status); - } - -static void t_h2fk5(int *status) -/* -** - - - - - - - - -** t _ h 2 f k 5 -** - - - - - - - - -** -** Test iauH2fk5 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauH2fk5, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rh, dh, drh, ddh, pxh, rvh, r5, d5, dr5, dd5, px5, rv5; - - - rh = 1.767794352; - dh = -0.2917512594; - drh = -2.76413026e-6; - ddh = -5.92994449e-6; - pxh = 0.379210; - rvh = -7.6; - - iauH2fk5(rh, dh, drh, ddh, pxh, rvh, - &r5, &d5, &dr5, &dd5, &px5, &rv5); - - vvd(r5, 1.767794455700065506, 1e-13, - "iauH2fk5", "ra", status); - vvd(d5, -0.2917513626469638890, 1e-13, - "iauH2fk5", "dec", status); - vvd(dr5, -0.27597945024511204e-5, 1e-18, - "iauH2fk5", "dr5", status); - vvd(dd5, -0.59308014093262838e-5, 1e-18, - "iauH2fk5", "dd5", status); - vvd(px5, 0.37921, 1e-13, - "iauH2fk5", "px", status); - vvd(rv5, -7.6000001309071126, 1e-10, - "iauH2fk5", "rv", status); - -} - -static void t_hfk5z(int *status) -/* -** - - - - - - - - -** t _ h f k 5 z -** - - - - - - - - -** -** Test iauHfk5z function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauHfk5z, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rh, dh, r5, d5, dr5, dd5; - - - - rh = 1.767794352; - dh = -0.2917512594; - - iauHfk5z(rh, dh, 2400000.5, 54479.0, &r5, &d5, &dr5, &dd5); - - vvd(r5, 1.767794490535581026, 1e-13, - "iauHfk5z", "ra", status); - vvd(d5, -0.2917513695320114258, 1e-14, - "iauHfk5z", "dec", status); - vvd(dr5, 0.4335890983539243029e-8, 1e-22, - "iauHfk5z", "dr5", status); - vvd(dd5, -0.8569648841237745902e-9, 1e-23, - "iauHfk5z", "dd5", status); - -} - -static void t_ir(int *status) -/* -** - - - - - -** t _ i r -** - - - - - -** -** Test iauIr function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauIr, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3]; - - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - iauIr(r); - - vvd(r[0][0], 1.0, 0.0, "iauIr", "11", status); - vvd(r[0][1], 0.0, 0.0, "iauIr", "12", status); - vvd(r[0][2], 0.0, 0.0, "iauIr", "13", status); - - vvd(r[1][0], 0.0, 0.0, "iauIr", "21", status); - vvd(r[1][1], 1.0, 0.0, "iauIr", "22", status); - vvd(r[1][2], 0.0, 0.0, "iauIr", "23", status); - - vvd(r[2][0], 0.0, 0.0, "iauIr", "31", status); - vvd(r[2][1], 0.0, 0.0, "iauIr", "32", status); - vvd(r[2][2], 1.0, 0.0, "iauIr", "33", status); - -} - -static void t_jd2cal(int *status) -/* -** - - - - - - - - - -** t _ j d 2 c a l -** - - - - - - - - - -** -** Test iauJd2cal function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauJd2cal, viv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dj1, dj2, fd; - int iy, im, id, j; - - - dj1 = 2400000.5; - dj2 = 50123.9999; - - j = iauJd2cal(dj1, dj2, &iy, &im, &id, &fd); - - viv(iy, 1996, "iauJd2cal", "y", status); - viv(im, 2, "iauJd2cal", "m", status); - viv(id, 10, "iauJd2cal", "d", status); - vvd(fd, 0.9999, 1e-7, "iauJd2cal", "fd", status); - viv(j, 0, "iauJd2cal", "j", status); - -} - -static void t_jdcalf(int *status) -/* -** - - - - - - - - - -** t _ j d c a l f -** - - - - - - - - - -** -** Test iauJdcalf function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauJdcalf, viv -** -** This revision: 2013 August 7 -*/ -{ - double dj1, dj2; - int iydmf[4], j; - - - dj1 = 2400000.5; - dj2 = 50123.9999; - - j = iauJdcalf(4, dj1, dj2, iydmf); - - viv(iydmf[0], 1996, "iauJdcalf", "y", status); - viv(iydmf[1], 2, "iauJdcalf", "m", status); - viv(iydmf[2], 10, "iauJdcalf", "d", status); - viv(iydmf[3], 9999, "iauJdcalf", "f", status); - - viv(j, 0, "iauJdcalf", "j", status); - -} - -static void t_ld(int *status) -/* -** - - - - - -** t _ l d -** - - - - - -** -** Test iauLd function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLd, vvd -* -** This revision: 2013 October 2 -*/ -{ - double bm, p[3], q[3], e[3], em, dlim, p1[3]; - - - bm = 0.00028574; - p[0] = -0.763276255; - p[1] = -0.608633767; - p[2] = -0.216735543; - q[0] = -0.763276255; - q[1] = -0.608633767; - q[2] = -0.216735543; - e[0] = 0.76700421; - e[1] = 0.605629598; - e[2] = 0.211937094; - em = 8.91276983; - dlim = 3e-10; - - iauLd(bm, p, q, e, em, dlim, p1); - - vvd(p1[0], -0.7632762548968159627, 1e-12, - "iauLd", "1", status); - vvd(p1[1], -0.6086337670823762701, 1e-12, - "iauLd", "2", status); - vvd(p1[2], -0.2167355431320546947, 1e-12, - "iauLd", "3", status); - -} - -static void t_ldn(int *status) -/* -** - - - - - - -** t _ l d n -** - - - - - - -** -** Test iauLdn function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLdn, vvd -** -** This revision: 2013 October 2 -*/ -{ - int n; - iauLDBODY b[3]; - double ob[3], sc[3], sn[3]; - - - n = 3; - b[0].bm = 0.00028574; - b[0].dl = 3e-10; - b[0].pv[0][0] = -7.81014427; - b[0].pv[0][1] = -5.60956681; - b[0].pv[0][2] = -1.98079819; - b[0].pv[1][0] = 0.0030723249; - b[0].pv[1][1] = -0.00406995477; - b[0].pv[1][2] = -0.00181335842; - b[1].bm = 0.00095435; - b[1].dl = 3e-9; - b[1].pv[0][0] = 0.738098796; - b[1].pv[0][1] = 4.63658692; - b[1].pv[0][2] = 1.9693136; - b[1].pv[1][0] = -0.00755816922; - b[1].pv[1][1] = 0.00126913722; - b[1].pv[1][2] = 0.000727999001; - b[2].bm = 1.0; - b[2].dl = 6e-6; - b[2].pv[0][0] = -0.000712174377; - b[2].pv[0][1] = -0.00230478303; - b[2].pv[0][2] = -0.00105865966; - b[2].pv[1][0] = 6.29235213e-6; - b[2].pv[1][1] = -3.30888387e-7; - b[2].pv[1][2] = -2.96486623e-7; - ob[0] = -0.974170437; - ob[1] = -0.2115201; - ob[2] = -0.0917583114; - sc[0] = -0.763276255; - sc[1] = -0.608633767; - sc[2] = -0.216735543; - - iauLdn(n, b, ob, sc, sn); - - vvd(sn[0], -0.7632762579693333866, 1e-12, - "iauLdn", "1", status); - vvd(sn[1], -0.6086337636093002660, 1e-12, - "iauLdn", "2", status); - vvd(sn[2], -0.2167355420646328159, 1e-12, - "iauLdn", "3", status); - -} - -static void t_ldsun(int *status) -/* -** - - - - - - - - -** t _ l d s u n -** - - - - - - - - -** -** Test iauLdsun function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLdsun, vvd -** -** This revision: 2013 October 2 -*/ -{ - double p[3], e[3], em, p1[3]; - - - p[0] = -0.763276255; - p[1] = -0.608633767; - p[2] = -0.216735543; - e[0] = -0.973644023; - e[1] = -0.20925523; - e[2] = -0.0907169552; - em = 0.999809214; - - iauLdsun(p, e, em, p1); - - vvd(p1[0], -0.7632762580731413169, 1e-12, - "iauLdsun", "1", status); - vvd(p1[1], -0.6086337635262647900, 1e-12, - "iauLdsun", "2", status); - vvd(p1[2], -0.2167355419322321302, 1e-12, - "iauLdsun", "3", status); - -} - -static void t_lteceq(int *status) -/* -** - - - - - - - - - -** t _ l t e c e q -** - - - - - - - - - -** -** Test iauLteceq function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLteceq, vvd -** -** This revision: 2016 March 12 -*/ -{ - double epj, dl, db, dr, dd; - - - epj = 2500.0; - dl = 1.5; - db = 0.6; - - iauLteceq(epj, dl, db, &dr, &dd); - - vvd(dr, 1.275156021861921167, 1e-14, "iauLteceq", "dr", status); - vvd(dd, 0.9966573543519204791, 1e-14, "iauLteceq", "dd", status); - -} - -static void t_ltecm(int *status) -/* -** - - - - - - - - -** t _ l t e c m -** - - - - - - - - -** -** Test iauLtecm function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLtecm, vvd -** -** This revision: 2016 March 12 -*/ -{ - double epj, rm[3][3]; - - - epj = -3000.0; - - iauLtecm(epj, rm); - - vvd(rm[0][0], 0.3564105644859788825, 1e-14, - "iauLtecm", "rm11", status); - vvd(rm[0][1], 0.8530575738617682284, 1e-14, - "iauLtecm", "rm12", status); - vvd(rm[0][2], 0.3811355207795060435, 1e-14, - "iauLtecm", "rm13", status); - vvd(rm[1][0], -0.9343283469640709942, 1e-14, - "iauLtecm", "rm21", status); - vvd(rm[1][1], 0.3247830597681745976, 1e-14, - "iauLtecm", "rm22", status); - vvd(rm[1][2], 0.1467872751535940865, 1e-14, - "iauLtecm", "rm23", status); - vvd(rm[2][0], 0.1431636191201167793e-2, 1e-14, - "iauLtecm", "rm31", status); - vvd(rm[2][1], -0.4084222566960599342, 1e-14, - "iauLtecm", "rm32", status); - vvd(rm[2][2], 0.9127919865189030899, 1e-14, - "iauLtecm", "rm33", status); - -} - -static void t_lteqec(int *status) -/* -** - - - - - - - - - -** t _ l t e q e c -** - - - - - - - - - -** -** Test iauLteqec function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLteqec, vvd -** -** This revision: 2016 March 12 -*/ -{ - double epj, dr, dd, dl, db; - - - epj = -1500.0; - dr = 1.234; - dd = 0.987; - - iauLteqec(epj, dr, dd, &dl, &db); - - vvd(dl, 0.5039483649047114859, 1e-14, "iauLteqec", "dl", status); - vvd(db, 0.5848534459726224882, 1e-14, "iauLteqec", "db", status); - -} - -static void t_ltp(int *status) -/* -** - - - - - - -** t _ l t p -** - - - - - - -** -** Test iauLtp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLtp, vvd -** -** This revision: 2016 March 12 -*/ -{ - double epj, rp[3][3]; - - - epj = 1666.666; - - iauLtp(epj, rp); - - vvd(rp[0][0], 0.9967044141159213819, 1e-14, - "iauLtp", "rp11", status); - vvd(rp[0][1], 0.7437801893193210840e-1, 1e-14, - "iauLtp", "rp12", status); - vvd(rp[0][2], 0.3237624409345603401e-1, 1e-14, - "iauLtp", "rp13", status); - vvd(rp[1][0], -0.7437802731819618167e-1, 1e-14, - "iauLtp", "rp21", status); - vvd(rp[1][1], 0.9972293894454533070, 1e-14, - "iauLtp", "rp22", status); - vvd(rp[1][2], -0.1205768842723593346e-2, 1e-14, - "iauLtp", "rp23", status); - vvd(rp[2][0], -0.3237622482766575399e-1, 1e-14, - "iauLtp", "rp31", status); - vvd(rp[2][1], -0.1206286039697609008e-2, 1e-14, - "iauLtp", "rp32", status); - vvd(rp[2][2], 0.9994750246704010914, 1e-14, - "iauLtp", "rp33", status); - -} - -static void t_ltpb(int *status) -/* -** - - - - - - - -** t _ l t p b -** - - - - - - - -** -** Test iauLtpb function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLtpb, vvd -** -** This revision: 2016 March 12 -*/ -{ - double epj, rpb[3][3]; - - - epj = 1666.666; - - iauLtpb(epj, rpb); - - vvd(rpb[0][0], 0.9967044167723271851, 1e-14, - "iauLtpb", "rpb11", status); - vvd(rpb[0][1], 0.7437794731203340345e-1, 1e-14, - "iauLtpb", "rpb12", status); - vvd(rpb[0][2], 0.3237632684841625547e-1, 1e-14, - "iauLtpb", "rpb13", status); - vvd(rpb[1][0], -0.7437795663437177152e-1, 1e-14, - "iauLtpb", "rpb21", status); - vvd(rpb[1][1], 0.9972293947500013666, 1e-14, - "iauLtpb", "rpb22", status); - vvd(rpb[1][2], -0.1205741865911243235e-2, 1e-14, - "iauLtpb", "rpb23", status); - vvd(rpb[2][0], -0.3237630543224664992e-1, 1e-14, - "iauLtpb", "rpb31", status); - vvd(rpb[2][1], -0.1206316791076485295e-2, 1e-14, - "iauLtpb", "rpb32", status); - vvd(rpb[2][2], 0.9994750220222438819, 1e-14, - "iauLtpb", "rpb33", status); - -} - -static void t_ltpecl(int *status) -/* -** - - - - - - - - - -** t _ l t p e c l -** - - - - - - - - - -** -** Test iauLtpecl function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLtpecl, vvd -** -** This revision: 2016 March 12 -*/ -{ - double epj, vec[3]; - - - epj = -1500.0; - - iauLtpecl(epj, vec); - - vvd(vec[0], 0.4768625676477096525e-3, 1e-14, - "iauLtpecl", "vec1", status); - vvd(vec[1], -0.4052259533091875112, 1e-14, - "iauLtpecl", "vec2", status); - vvd(vec[2], 0.9142164401096448012, 1e-14, - "iauLtpecl", "vec3", status); - -} - -static void t_ltpequ(int *status) -/* -** - - - - - - - - - -** t _ l t p e q u -** - - - - - - - - - -** -** Test iauLtpequ function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauLtpequ, vvd -** -** This revision: 2016 March 12 -*/ -{ - double epj, veq[3]; - - - epj = -2500.0; - - iauLtpequ(epj, veq); - - vvd(veq[0], -0.3586652560237326659, 1e-14, - "iauLtpequ", "veq1", status); - vvd(veq[1], -0.1996978910771128475, 1e-14, - "iauLtpequ", "veq2", status); - vvd(veq[2], 0.9118552442250819624, 1e-14, - "iauLtpequ", "veq3", status); - -} - -static void t_num00a(int *status) -/* -** - - - - - - - - - -** t _ n u m 0 0 a -** - - - - - - - - - -** -** Test iauNum00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNum00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rmatn[3][3]; - - - iauNum00a(2400000.5, 53736.0, rmatn); - - vvd(rmatn[0][0], 0.9999999999536227949, 1e-12, - "iauNum00a", "11", status); - vvd(rmatn[0][1], 0.8836238544090873336e-5, 1e-12, - "iauNum00a", "12", status); - vvd(rmatn[0][2], 0.3830835237722400669e-5, 1e-12, - "iauNum00a", "13", status); - - vvd(rmatn[1][0], -0.8836082880798569274e-5, 1e-12, - "iauNum00a", "21", status); - vvd(rmatn[1][1], 0.9999999991354655028, 1e-12, - "iauNum00a", "22", status); - vvd(rmatn[1][2], -0.4063240865362499850e-4, 1e-12, - "iauNum00a", "23", status); - - vvd(rmatn[2][0], -0.3831194272065995866e-5, 1e-12, - "iauNum00a", "31", status); - vvd(rmatn[2][1], 0.4063237480216291775e-4, 1e-12, - "iauNum00a", "32", status); - vvd(rmatn[2][2], 0.9999999991671660338, 1e-12, - "iauNum00a", "33", status); - -} - -static void t_num00b(int *status) -/* -** - - - - - - - - - -** t _ n u m 0 0 b -** - - - - - - - - - -** -** Test iauNum00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNum00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rmatn[3][3]; - - iauNum00b(2400000.5, 53736, rmatn); - - vvd(rmatn[0][0], 0.9999999999536069682, 1e-12, - "iauNum00b", "11", status); - vvd(rmatn[0][1], 0.8837746144871248011e-5, 1e-12, - "iauNum00b", "12", status); - vvd(rmatn[0][2], 0.3831488838252202945e-5, 1e-12, - "iauNum00b", "13", status); - - vvd(rmatn[1][0], -0.8837590456632304720e-5, 1e-12, - "iauNum00b", "21", status); - vvd(rmatn[1][1], 0.9999999991354692733, 1e-12, - "iauNum00b", "22", status); - vvd(rmatn[1][2], -0.4063198798559591654e-4, 1e-12, - "iauNum00b", "23", status); - - vvd(rmatn[2][0], -0.3831847930134941271e-5, 1e-12, - "iauNum00b", "31", status); - vvd(rmatn[2][1], 0.4063195412258168380e-4, 1e-12, - "iauNum00b", "32", status); - vvd(rmatn[2][2], 0.9999999991671806225, 1e-12, - "iauNum00b", "33", status); - -} - -static void t_num06a(int *status) -/* -** - - - - - - - - - -** t _ n u m 0 6 a -** - - - - - - - - - -** -** Test iauNum06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNum06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rmatn[3][3]; - - iauNum06a(2400000.5, 53736, rmatn); - - vvd(rmatn[0][0], 0.9999999999536227668, 1e-12, - "iauNum06a", "11", status); - vvd(rmatn[0][1], 0.8836241998111535233e-5, 1e-12, - "iauNum06a", "12", status); - vvd(rmatn[0][2], 0.3830834608415287707e-5, 1e-12, - "iauNum06a", "13", status); - - vvd(rmatn[1][0], -0.8836086334870740138e-5, 1e-12, - "iauNum06a", "21", status); - vvd(rmatn[1][1], 0.9999999991354657474, 1e-12, - "iauNum06a", "22", status); - vvd(rmatn[1][2], -0.4063240188248455065e-4, 1e-12, - "iauNum06a", "23", status); - - vvd(rmatn[2][0], -0.3831193642839398128e-5, 1e-12, - "iauNum06a", "31", status); - vvd(rmatn[2][1], 0.4063236803101479770e-4, 1e-12, - "iauNum06a", "32", status); - vvd(rmatn[2][2], 0.9999999991671663114, 1e-12, - "iauNum06a", "33", status); - -} - -static void t_numat(int *status) -/* -** - - - - - - - - -** t _ n u m a t -** - - - - - - - - -** -** Test iauNumat function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNumat, vvd -** -** This revision: 2013 August 7 -*/ -{ - double epsa, dpsi, deps, rmatn[3][3]; - - - epsa = 0.4090789763356509900; - dpsi = -0.9630909107115582393e-5; - deps = 0.4063239174001678826e-4; - - iauNumat(epsa, dpsi, deps, rmatn); - - vvd(rmatn[0][0], 0.9999999999536227949, 1e-12, - "iauNumat", "11", status); - vvd(rmatn[0][1], 0.8836239320236250577e-5, 1e-12, - "iauNumat", "12", status); - vvd(rmatn[0][2], 0.3830833447458251908e-5, 1e-12, - "iauNumat", "13", status); - - vvd(rmatn[1][0], -0.8836083657016688588e-5, 1e-12, - "iauNumat", "21", status); - vvd(rmatn[1][1], 0.9999999991354654959, 1e-12, - "iauNumat", "22", status); - vvd(rmatn[1][2], -0.4063240865361857698e-4, 1e-12, - "iauNumat", "23", status); - - vvd(rmatn[2][0], -0.3831192481833385226e-5, 1e-12, - "iauNumat", "31", status); - vvd(rmatn[2][1], 0.4063237480216934159e-4, 1e-12, - "iauNumat", "32", status); - vvd(rmatn[2][2], 0.9999999991671660407, 1e-12, - "iauNumat", "33", status); - -} - -static void t_nut00a(int *status) -/* -** - - - - - - - - - -** t _ n u t 0 0 a -** - - - - - - - - - -** -** Test iauNut00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNut00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps; - - - iauNut00a(2400000.5, 53736.0, &dpsi, &deps); - - vvd(dpsi, -0.9630909107115518431e-5, 1e-13, - "iauNut00a", "dpsi", status); - vvd(deps, 0.4063239174001678710e-4, 1e-13, - "iauNut00a", "deps", status); - -} - -static void t_nut00b(int *status) -/* -** - - - - - - - - - -** t _ n u t 0 0 b -** - - - - - - - - - -** -** Test iauNut00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNut00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps; - - - iauNut00b(2400000.5, 53736.0, &dpsi, &deps); - - vvd(dpsi, -0.9632552291148362783e-5, 1e-13, - "iauNut00b", "dpsi", status); - vvd(deps, 0.4063197106621159367e-4, 1e-13, - "iauNut00b", "deps", status); - -} - -static void t_nut06a(int *status) -/* -** - - - - - - - - - -** t _ n u t 0 6 a -** - - - - - - - - - -** -** Test iauNut06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNut06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps; - - - iauNut06a(2400000.5, 53736.0, &dpsi, &deps); - - vvd(dpsi, -0.9630912025820308797e-5, 1e-13, - "iauNut06a", "dpsi", status); - vvd(deps, 0.4063238496887249798e-4, 1e-13, - "iauNut06a", "deps", status); - -} - -static void t_nut80(int *status) -/* -** - - - - - - - - -** t _ n u t 8 0 -** - - - - - - - - -** -** Test iauNut80 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNut80, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps; - - - iauNut80(2400000.5, 53736.0, &dpsi, &deps); - - vvd(dpsi, -0.9643658353226563966e-5, 1e-13, - "iauNut80", "dpsi", status); - vvd(deps, 0.4060051006879713322e-4, 1e-13, - "iauNut80", "deps", status); - -} - -static void t_nutm80(int *status) -/* -** - - - - - - - - - -** t _ n u t m 8 0 -** - - - - - - - - - -** -** Test iauNutm80 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauNutm80, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rmatn[3][3]; - - - iauNutm80(2400000.5, 53736.0, rmatn); - - vvd(rmatn[0][0], 0.9999999999534999268, 1e-12, - "iauNutm80", "11", status); - vvd(rmatn[0][1], 0.8847935789636432161e-5, 1e-12, - "iauNutm80", "12", status); - vvd(rmatn[0][2], 0.3835906502164019142e-5, 1e-12, - "iauNutm80", "13", status); - - vvd(rmatn[1][0], -0.8847780042583435924e-5, 1e-12, - "iauNutm80", "21", status); - vvd(rmatn[1][1], 0.9999999991366569963, 1e-12, - "iauNutm80", "22", status); - vvd(rmatn[1][2], -0.4060052702727130809e-4, 1e-12, - "iauNutm80", "23", status); - - vvd(rmatn[2][0], -0.3836265729708478796e-5, 1e-12, - "iauNutm80", "31", status); - vvd(rmatn[2][1], 0.4060049308612638555e-4, 1e-12, - "iauNutm80", "32", status); - vvd(rmatn[2][2], 0.9999999991684415129, 1e-12, - "iauNutm80", "33", status); - -} - -static void t_obl06(int *status) -/* -** - - - - - - - - -** t _ o b l 0 6 -** - - - - - - - - -** -** Test iauObl06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauObl06, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauObl06(2400000.5, 54388.0), 0.4090749229387258204, 1e-14, - "iauObl06", "", status); -} - -static void t_obl80(int *status) -/* -** - - - - - - - - -** t _ o b l 8 0 -** - - - - - - - - -** -** Test iauObl80 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauObl80, vvd -** -** This revision: 2013 August 7 -*/ -{ - double eps0; - - - eps0 = iauObl80(2400000.5, 54388.0); - - vvd(eps0, 0.4090751347643816218, 1e-14, "iauObl80", "", status); - -} - -static void t_p06e(int *status) -/* -** - - - - - - - -** t _ p 0 6 e -** - - - - - - - -** -** Test iauP06e function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauP06e, vvd -** -** This revision: 2013 August 7 -*/ -{ - double eps0, psia, oma, bpa, bqa, pia, bpia, - epsa, chia, za, zetaa, thetaa, pa, gam, phi, psi; - - - iauP06e(2400000.5, 52541.0, &eps0, &psia, &oma, &bpa, - &bqa, &pia, &bpia, &epsa, &chia, &za, - &zetaa, &thetaa, &pa, &gam, &phi, &psi); - - vvd(eps0, 0.4090926006005828715, 1e-14, - "iauP06e", "eps0", status); - vvd(psia, 0.6664369630191613431e-3, 1e-14, - "iauP06e", "psia", status); - vvd(oma , 0.4090925973783255982, 1e-14, - "iauP06e", "oma", status); - vvd(bpa, 0.5561149371265209445e-6, 1e-14, - "iauP06e", "bpa", status); - vvd(bqa, -0.6191517193290621270e-5, 1e-14, - "iauP06e", "bqa", status); - vvd(pia, 0.6216441751884382923e-5, 1e-14, - "iauP06e", "pia", status); - vvd(bpia, 3.052014180023779882, 1e-14, - "iauP06e", "bpia", status); - vvd(epsa, 0.4090864054922431688, 1e-14, - "iauP06e", "epsa", status); - vvd(chia, 0.1387703379530915364e-5, 1e-14, - "iauP06e", "chia", status); - vvd(za, 0.2921789846651790546e-3, 1e-14, - "iauP06e", "za", status); - vvd(zetaa, 0.3178773290332009310e-3, 1e-14, - "iauP06e", "zetaa", status); - vvd(thetaa, 0.2650932701657497181e-3, 1e-14, - "iauP06e", "thetaa", status); - vvd(pa, 0.6651637681381016344e-3, 1e-14, - "iauP06e", "pa", status); - vvd(gam, 0.1398077115963754987e-5, 1e-14, - "iauP06e", "gam", status); - vvd(phi, 0.4090864090837462602, 1e-14, - "iauP06e", "phi", status); - vvd(psi, 0.6664464807480920325e-3, 1e-14, - "iauP06e", "psi", status); - -} - -static void t_p2pv(int *status) -/* -** - - - - - - - -** t _ p 2 p v -** - - - - - - - -** -** Test iauP2pv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauP2pv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3], pv[2][3]; - - - p[0] = 0.25; - p[1] = 1.2; - p[2] = 3.0; - - pv[0][0] = 0.3; - pv[0][1] = 1.2; - pv[0][2] = -2.5; - - pv[1][0] = -0.5; - pv[1][1] = 3.1; - pv[1][2] = 0.9; - - iauP2pv(p, pv); - - vvd(pv[0][0], 0.25, 0.0, "iauP2pv", "p1", status); - vvd(pv[0][1], 1.2, 0.0, "iauP2pv", "p2", status); - vvd(pv[0][2], 3.0, 0.0, "iauP2pv", "p3", status); - - vvd(pv[1][0], 0.0, 0.0, "iauP2pv", "v1", status); - vvd(pv[1][1], 0.0, 0.0, "iauP2pv", "v2", status); - vvd(pv[1][2], 0.0, 0.0, "iauP2pv", "v3", status); - -} - -static void t_p2s(int *status) -/* -** - - - - - - -** t _ p 2 s -** - - - - - - -** -** Test iauP2s function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauP2s, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3], theta, phi, r; - - - p[0] = 100.0; - p[1] = -50.0; - p[2] = 25.0; - - iauP2s(p, &theta, &phi, &r); - - vvd(theta, -0.4636476090008061162, 1e-12, "iauP2s", "theta", status); - vvd(phi, 0.2199879773954594463, 1e-12, "iauP2s", "phi", status); - vvd(r, 114.5643923738960002, 1e-9, "iauP2s", "r", status); - -} - -static void t_pap(int *status) -/* -** - - - - - - -** t _ p a p -** - - - - - - -** -** Test iauPap function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPap, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3], b[3], theta; - - - a[0] = 1.0; - a[1] = 0.1; - a[2] = 0.2; - - b[0] = -3.0; - b[1] = 1e-3; - b[2] = 0.2; - - theta = iauPap(a, b); - - vvd(theta, 0.3671514267841113674, 1e-12, "iauPap", "", status); - -} - -static void t_pas(int *status) -/* -** - - - - - - -** t _ p a s -** - - - - - - -** -** Test iauPas function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPas, vvd -** -** This revision: 2013 August 7 -*/ -{ - double al, ap, bl, bp, theta; - - - al = 1.0; - ap = 0.1; - bl = 0.2; - bp = -1.0; - - theta = iauPas(al, ap, bl, bp); - - vvd(theta, -2.724544922932270424, 1e-12, "iauPas", "", status); - -} - -static void t_pb06(int *status) -/* -** - - - - - - - -** t _ p b 0 6 -** - - - - - - - -** -** Test iauPb06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPb06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double bzeta, bz, btheta; - - - iauPb06(2400000.5, 50123.9999, &bzeta, &bz, &btheta); - - vvd(bzeta, -0.5092634016326478238e-3, 1e-12, - "iauPb06", "bzeta", status); - vvd(bz, -0.3602772060566044413e-3, 1e-12, - "iauPb06", "bz", status); - vvd(btheta, -0.3779735537167811177e-3, 1e-12, - "iauPb06", "btheta", status); - -} - -static void t_pdp(int *status) -/* -** - - - - - - -** t _ p d p -** - - - - - - -** -** Test iauPdp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPdp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3], b[3], adb; - - - a[0] = 2.0; - a[1] = 2.0; - a[2] = 3.0; - - b[0] = 1.0; - b[1] = 3.0; - b[2] = 4.0; - - adb = iauPdp(a, b); - - vvd(adb, 20, 1e-12, "iauPdp", "", status); - -} - -static void t_pfw06(int *status) -/* -** - - - - - - - - -** t _ p f w 0 6 -** - - - - - - - - -** -** Test iauPfw06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPfw06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double gamb, phib, psib, epsa; - - - iauPfw06(2400000.5, 50123.9999, &gamb, &phib, &psib, &epsa); - - vvd(gamb, -0.2243387670997995690e-5, 1e-16, - "iauPfw06", "gamb", status); - vvd(phib, 0.4091014602391312808, 1e-12, - "iauPfw06", "phib", status); - vvd(psib, -0.9501954178013031895e-3, 1e-14, - "iauPfw06", "psib", status); - vvd(epsa, 0.4091014316587367491, 1e-12, - "iauPfw06", "epsa", status); - -} - -static void t_plan94(int *status) -/* -** - - - - - - - - - -** t _ p l a n 9 4 -** - - - - - - - - - -** -** Test iauPlan94 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPlan94, vvd, viv -** -** This revision: 2013 October 2 -*/ -{ - double pv[2][3]; - int j; - - - j = iauPlan94(2400000.5, 1e6, 0, pv); - - vvd(pv[0][0], 0.0, 0.0, "iauPlan94", "x 1", status); - vvd(pv[0][1], 0.0, 0.0, "iauPlan94", "y 1", status); - vvd(pv[0][2], 0.0, 0.0, "iauPlan94", "z 1", status); - - vvd(pv[1][0], 0.0, 0.0, "iauPlan94", "xd 1", status); - vvd(pv[1][1], 0.0, 0.0, "iauPlan94", "yd 1", status); - vvd(pv[1][2], 0.0, 0.0, "iauPlan94", "zd 1", status); - - viv(j, -1, "iauPlan94", "j 1", status); - - j = iauPlan94(2400000.5, 1e6, 10, pv); - - viv(j, -1, "iauPlan94", "j 2", status); - - j = iauPlan94(2400000.5, -320000, 3, pv); - - vvd(pv[0][0], 0.9308038666832975759, 1e-11, - "iauPlan94", "x 3", status); - vvd(pv[0][1], 0.3258319040261346000, 1e-11, - "iauPlan94", "y 3", status); - vvd(pv[0][2], 0.1422794544481140560, 1e-11, - "iauPlan94", "z 3", status); - - vvd(pv[1][0], -0.6429458958255170006e-2, 1e-11, - "iauPlan94", "xd 3", status); - vvd(pv[1][1], 0.1468570657704237764e-1, 1e-11, - "iauPlan94", "yd 3", status); - vvd(pv[1][2], 0.6406996426270981189e-2, 1e-11, - "iauPlan94", "zd 3", status); - - viv(j, 1, "iauPlan94", "j 3", status); - - j = iauPlan94(2400000.5, 43999.9, 1, pv); - - vvd(pv[0][0], 0.2945293959257430832, 1e-11, - "iauPlan94", "x 4", status); - vvd(pv[0][1], -0.2452204176601049596, 1e-11, - "iauPlan94", "y 4", status); - vvd(pv[0][2], -0.1615427700571978153, 1e-11, - "iauPlan94", "z 4", status); - - vvd(pv[1][0], 0.1413867871404614441e-1, 1e-11, - "iauPlan94", "xd 4", status); - vvd(pv[1][1], 0.1946548301104706582e-1, 1e-11, - "iauPlan94", "yd 4", status); - vvd(pv[1][2], 0.8929809783898904786e-2, 1e-11, - "iauPlan94", "zd 4", status); - - viv(j, 0, "iauPlan94", "j 4", status); - -} - -static void t_pmat00(int *status) -/* -** - - - - - - - - - -** t _ p m a t 0 0 -** - - - - - - - - - -** -** Test iauPmat00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPmat00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbp[3][3]; - - - iauPmat00(2400000.5, 50123.9999, rbp); - - vvd(rbp[0][0], 0.9999995505175087260, 1e-12, - "iauPmat00", "11", status); - vvd(rbp[0][1], 0.8695405883617884705e-3, 1e-14, - "iauPmat00", "12", status); - vvd(rbp[0][2], 0.3779734722239007105e-3, 1e-14, - "iauPmat00", "13", status); - - vvd(rbp[1][0], -0.8695405990410863719e-3, 1e-14, - "iauPmat00", "21", status); - vvd(rbp[1][1], 0.9999996219494925900, 1e-12, - "iauPmat00", "22", status); - vvd(rbp[1][2], -0.1360775820404982209e-6, 1e-14, - "iauPmat00", "23", status); - - vvd(rbp[2][0], -0.3779734476558184991e-3, 1e-14, - "iauPmat00", "31", status); - vvd(rbp[2][1], -0.1925857585832024058e-6, 1e-14, - "iauPmat00", "32", status); - vvd(rbp[2][2], 0.9999999285680153377, 1e-12, - "iauPmat00", "33", status); - -} - -static void t_pmat06(int *status) -/* -** - - - - - - - - - -** t _ p m a t 0 6 -** - - - - - - - - - -** -** Test iauPmat06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPmat06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbp[3][3]; - - - iauPmat06(2400000.5, 50123.9999, rbp); - - vvd(rbp[0][0], 0.9999995505176007047, 1e-12, - "iauPmat06", "11", status); - vvd(rbp[0][1], 0.8695404617348208406e-3, 1e-14, - "iauPmat06", "12", status); - vvd(rbp[0][2], 0.3779735201865589104e-3, 1e-14, - "iauPmat06", "13", status); - - vvd(rbp[1][0], -0.8695404723772031414e-3, 1e-14, - "iauPmat06", "21", status); - vvd(rbp[1][1], 0.9999996219496027161, 1e-12, - "iauPmat06", "22", status); - vvd(rbp[1][2], -0.1361752497080270143e-6, 1e-14, - "iauPmat06", "23", status); - - vvd(rbp[2][0], -0.3779734957034089490e-3, 1e-14, - "iauPmat06", "31", status); - vvd(rbp[2][1], -0.1924880847894457113e-6, 1e-14, - "iauPmat06", "32", status); - vvd(rbp[2][2], 0.9999999285679971958, 1e-12, - "iauPmat06", "33", status); - -} - -static void t_pmat76(int *status) -/* -** - - - - - - - - - -** t _ p m a t 7 6 -** - - - - - - - - - -** -** Test iauPmat76 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPmat76, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rmatp[3][3]; - - - iauPmat76(2400000.5, 50123.9999, rmatp); - - vvd(rmatp[0][0], 0.9999995504328350733, 1e-12, - "iauPmat76", "11", status); - vvd(rmatp[0][1], 0.8696632209480960785e-3, 1e-14, - "iauPmat76", "12", status); - vvd(rmatp[0][2], 0.3779153474959888345e-3, 1e-14, - "iauPmat76", "13", status); - - vvd(rmatp[1][0], -0.8696632209485112192e-3, 1e-14, - "iauPmat76", "21", status); - vvd(rmatp[1][1], 0.9999996218428560614, 1e-12, - "iauPmat76", "22", status); - vvd(rmatp[1][2], -0.1643284776111886407e-6, 1e-14, - "iauPmat76", "23", status); - - vvd(rmatp[2][0], -0.3779153474950335077e-3, 1e-14, - "iauPmat76", "31", status); - vvd(rmatp[2][1], -0.1643306746147366896e-6, 1e-14, - "iauPmat76", "32", status); - vvd(rmatp[2][2], 0.9999999285899790119, 1e-12, - "iauPmat76", "33", status); - -} - -static void t_pm(int *status) -/* -** - - - - - -** t _ p m -** - - - - - -** -** Test iauPm function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPm, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3], r; - - - p[0] = 0.3; - p[1] = 1.2; - p[2] = -2.5; - - r = iauPm(p); - - vvd(r, 2.789265136196270604, 1e-12, "iauPm", "", status); - -} - -static void t_pmp(int *status) -/* -** - - - - - - -** t _ p m p -** - - - - - - -** -** Test iauPmp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPmp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3], b[3], amb[3]; - - - a[0] = 2.0; - a[1] = 2.0; - a[2] = 3.0; - - b[0] = 1.0; - b[1] = 3.0; - b[2] = 4.0; - - iauPmp(a, b, amb); - - vvd(amb[0], 1.0, 1e-12, "iauPmp", "0", status); - vvd(amb[1], -1.0, 1e-12, "iauPmp", "1", status); - vvd(amb[2], -1.0, 1e-12, "iauPmp", "2", status); - -} - -static void t_pmpx(int *status) -/* -** - - - - - - - -** t _ p m p x -** - - - - - - - -** -** Test iauPmpx function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPmpx, vvd -** -** This revision: 2013 October 2 -*/ -{ - double rc, dc, pr, pd, px, rv, pmt, pob[3], pco[3]; - - - rc = 1.234; - dc = 0.789; - pr = 1e-5; - pd = -2e-5; - px = 1e-2; - rv = 10.0; - pmt = 8.75; - pob[0] = 0.9; - pob[1] = 0.4; - pob[2] = 0.1; - - iauPmpx(rc, dc, pr, pd, px, rv, pmt, pob, pco); - - vvd(pco[0], 0.2328137623960308440, 1e-12, - "iauPmpx", "1", status); - vvd(pco[1], 0.6651097085397855317, 1e-12, - "iauPmpx", "2", status); - vvd(pco[2], 0.7095257765896359847, 1e-12, - "iauPmpx", "3", status); - -} - -static void t_pmsafe(int *status) -/* -** - - - - - - - - - -** t _ p m s a f e -** - - - - - - - - - -** -** Test iauPmsafe function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPmsafe, vvd, viv -** -** This revision: 2013 October 2 -*/ -{ - int j; - double ra1, dec1, pmr1, pmd1, px1, rv1, ep1a, ep1b, ep2a, ep2b, - ra2, dec2, pmr2, pmd2, px2, rv2; - - - ra1 = 1.234; - dec1 = 0.789; - pmr1 = 1e-5; - pmd1 = -2e-5; - px1 = 1e-2; - rv1 = 10.0; - ep1a = 2400000.5; - ep1b = 48348.5625; - ep2a = 2400000.5; - ep2b = 51544.5; - - j = iauPmsafe(ra1, dec1, pmr1, pmd1, px1, rv1, - ep1a, ep1b, ep2a, ep2b, - &ra2, &dec2, &pmr2, &pmd2, &px2, &rv2); - - vvd(ra2, 1.234087484501017061, 1e-12, - "iauPmsafe", "ra2", status); - vvd(dec2, 0.7888249982450468574, 1e-12, - "iauPmsafe", "dec2", status); - vvd(pmr2, 0.9996457663586073988e-5, 1e-12, - "iauPmsafe", "pmr2", status); - vvd(pmd2, -0.2000040085106737816e-4, 1e-16, - "iauPmsafe", "pmd2", status); - vvd(px2, 0.9999997295356765185e-2, 1e-12, - "iauPmsafe", "px2", status); - vvd(rv2, 10.38468380113917014, 1e-10, - "iauPmsafe", "rv2", status); - viv ( j, 0, "iauPmsafe", "j", status); - -} - -static void t_pn(int *status) -/* -** - - - - - -** t _ p n -** - - - - - -** -** Test iauPn function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPn, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3], r, u[3]; - - - p[0] = 0.3; - p[1] = 1.2; - p[2] = -2.5; - - iauPn(p, &r, u); - - vvd(r, 2.789265136196270604, 1e-12, "iauPn", "r", status); - - vvd(u[0], 0.1075552109073112058, 1e-12, "iauPn", "u1", status); - vvd(u[1], 0.4302208436292448232, 1e-12, "iauPn", "u2", status); - vvd(u[2], -0.8962934242275933816, 1e-12, "iauPn", "u3", status); - -} - -static void t_pn00(int *status) -/* -** - - - - - - - -** t _ p n 0 0 -** - - - - - - - -** -** Test iauPn00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPn00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps, epsa, - rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; - - - dpsi = -0.9632552291149335877e-5; - deps = 0.4063197106621141414e-4; - - iauPn00(2400000.5, 53736.0, dpsi, deps, - &epsa, rb, rp, rbp, rn, rbpn); - - vvd(epsa, 0.4090791789404229916, 1e-12, "iauPn00", "epsa", status); - - vvd(rb[0][0], 0.9999999999999942498, 1e-12, - "iauPn00", "rb11", status); - vvd(rb[0][1], -0.7078279744199196626e-7, 1e-18, - "iauPn00", "rb12", status); - vvd(rb[0][2], 0.8056217146976134152e-7, 1e-18, - "iauPn00", "rb13", status); - - vvd(rb[1][0], 0.7078279477857337206e-7, 1e-18, - "iauPn00", "rb21", status); - vvd(rb[1][1], 0.9999999999999969484, 1e-12, - "iauPn00", "rb22", status); - vvd(rb[1][2], 0.3306041454222136517e-7, 1e-18, - "iauPn00", "rb23", status); - - vvd(rb[2][0], -0.8056217380986972157e-7, 1e-18, - "iauPn00", "rb31", status); - vvd(rb[2][1], -0.3306040883980552500e-7, 1e-18, - "iauPn00", "rb32", status); - vvd(rb[2][2], 0.9999999999999962084, 1e-12, - "iauPn00", "rb33", status); - - vvd(rp[0][0], 0.9999989300532289018, 1e-12, - "iauPn00", "rp11", status); - vvd(rp[0][1], -0.1341647226791824349e-2, 1e-14, - "iauPn00", "rp12", status); - vvd(rp[0][2], -0.5829880927190296547e-3, 1e-14, - "iauPn00", "rp13", status); - - vvd(rp[1][0], 0.1341647231069759008e-2, 1e-14, - "iauPn00", "rp21", status); - vvd(rp[1][1], 0.9999990999908750433, 1e-12, - "iauPn00", "rp22", status); - vvd(rp[1][2], -0.3837444441583715468e-6, 1e-14, - "iauPn00", "rp23", status); - - vvd(rp[2][0], 0.5829880828740957684e-3, 1e-14, - "iauPn00", "rp31", status); - vvd(rp[2][1], -0.3984203267708834759e-6, 1e-14, - "iauPn00", "rp32", status); - vvd(rp[2][2], 0.9999998300623538046, 1e-12, - "iauPn00", "rp33", status); - - vvd(rbp[0][0], 0.9999989300052243993, 1e-12, - "iauPn00", "rbp11", status); - vvd(rbp[0][1], -0.1341717990239703727e-2, 1e-14, - "iauPn00", "rbp12", status); - vvd(rbp[0][2], -0.5829075749891684053e-3, 1e-14, - "iauPn00", "rbp13", status); - - vvd(rbp[1][0], 0.1341718013831739992e-2, 1e-14, - "iauPn00", "rbp21", status); - vvd(rbp[1][1], 0.9999990998959191343, 1e-12, - "iauPn00", "rbp22", status); - vvd(rbp[1][2], -0.3505759733565421170e-6, 1e-14, - "iauPn00", "rbp23", status); - - vvd(rbp[2][0], 0.5829075206857717883e-3, 1e-14, - "iauPn00", "rbp31", status); - vvd(rbp[2][1], -0.4315219955198608970e-6, 1e-14, - "iauPn00", "rbp32", status); - vvd(rbp[2][2], 0.9999998301093036269, 1e-12, - "iauPn00", "rbp33", status); - - vvd(rn[0][0], 0.9999999999536069682, 1e-12, - "iauPn00", "rn11", status); - vvd(rn[0][1], 0.8837746144872140812e-5, 1e-16, - "iauPn00", "rn12", status); - vvd(rn[0][2], 0.3831488838252590008e-5, 1e-16, - "iauPn00", "rn13", status); - - vvd(rn[1][0], -0.8837590456633197506e-5, 1e-16, - "iauPn00", "rn21", status); - vvd(rn[1][1], 0.9999999991354692733, 1e-12, - "iauPn00", "rn22", status); - vvd(rn[1][2], -0.4063198798559573702e-4, 1e-16, - "iauPn00", "rn23", status); - - vvd(rn[2][0], -0.3831847930135328368e-5, 1e-16, - "iauPn00", "rn31", status); - vvd(rn[2][1], 0.4063195412258150427e-4, 1e-16, - "iauPn00", "rn32", status); - vvd(rn[2][2], 0.9999999991671806225, 1e-12, - "iauPn00", "rn33", status); - - vvd(rbpn[0][0], 0.9999989440499982806, 1e-12, - "iauPn00", "rbpn11", status); - vvd(rbpn[0][1], -0.1332880253640848301e-2, 1e-14, - "iauPn00", "rbpn12", status); - vvd(rbpn[0][2], -0.5790760898731087295e-3, 1e-14, - "iauPn00", "rbpn13", status); - - vvd(rbpn[1][0], 0.1332856746979948745e-2, 1e-14, - "iauPn00", "rbpn21", status); - vvd(rbpn[1][1], 0.9999991109064768883, 1e-12, - "iauPn00", "rbpn22", status); - vvd(rbpn[1][2], -0.4097740555723063806e-4, 1e-14, - "iauPn00", "rbpn23", status); - - vvd(rbpn[2][0], 0.5791301929950205000e-3, 1e-14, - "iauPn00", "rbpn31", status); - vvd(rbpn[2][1], 0.4020553681373702931e-4, 1e-14, - "iauPn00", "rbpn32", status); - vvd(rbpn[2][2], 0.9999998314958529887, 1e-12, - "iauPn00", "rbpn33", status); - -} - -static void t_pn00a(int *status) -/* -** - - - - - - - - -** t _ p n 0 0 a -** - - - - - - - - -** -** Test iauPn00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPn00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps, epsa, - rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; - - - iauPn00a(2400000.5, 53736.0, - &dpsi, &deps, &epsa, rb, rp, rbp, rn, rbpn); - - vvd(dpsi, -0.9630909107115518431e-5, 1e-12, - "iauPn00a", "dpsi", status); - vvd(deps, 0.4063239174001678710e-4, 1e-12, - "iauPn00a", "deps", status); - vvd(epsa, 0.4090791789404229916, 1e-12, "iauPn00a", "epsa", status); - - vvd(rb[0][0], 0.9999999999999942498, 1e-12, - "iauPn00a", "rb11", status); - vvd(rb[0][1], -0.7078279744199196626e-7, 1e-16, - "iauPn00a", "rb12", status); - vvd(rb[0][2], 0.8056217146976134152e-7, 1e-16, - "iauPn00a", "rb13", status); - - vvd(rb[1][0], 0.7078279477857337206e-7, 1e-16, - "iauPn00a", "rb21", status); - vvd(rb[1][1], 0.9999999999999969484, 1e-12, - "iauPn00a", "rb22", status); - vvd(rb[1][2], 0.3306041454222136517e-7, 1e-16, - "iauPn00a", "rb23", status); - - vvd(rb[2][0], -0.8056217380986972157e-7, 1e-16, - "iauPn00a", "rb31", status); - vvd(rb[2][1], -0.3306040883980552500e-7, 1e-16, - "iauPn00a", "rb32", status); - vvd(rb[2][2], 0.9999999999999962084, 1e-12, - "iauPn00a", "rb33", status); - - vvd(rp[0][0], 0.9999989300532289018, 1e-12, - "iauPn00a", "rp11", status); - vvd(rp[0][1], -0.1341647226791824349e-2, 1e-14, - "iauPn00a", "rp12", status); - vvd(rp[0][2], -0.5829880927190296547e-3, 1e-14, - "iauPn00a", "rp13", status); - - vvd(rp[1][0], 0.1341647231069759008e-2, 1e-14, - "iauPn00a", "rp21", status); - vvd(rp[1][1], 0.9999990999908750433, 1e-12, - "iauPn00a", "rp22", status); - vvd(rp[1][2], -0.3837444441583715468e-6, 1e-14, - "iauPn00a", "rp23", status); - - vvd(rp[2][0], 0.5829880828740957684e-3, 1e-14, - "iauPn00a", "rp31", status); - vvd(rp[2][1], -0.3984203267708834759e-6, 1e-14, - "iauPn00a", "rp32", status); - vvd(rp[2][2], 0.9999998300623538046, 1e-12, - "iauPn00a", "rp33", status); - - vvd(rbp[0][0], 0.9999989300052243993, 1e-12, - "iauPn00a", "rbp11", status); - vvd(rbp[0][1], -0.1341717990239703727e-2, 1e-14, - "iauPn00a", "rbp12", status); - vvd(rbp[0][2], -0.5829075749891684053e-3, 1e-14, - "iauPn00a", "rbp13", status); - - vvd(rbp[1][0], 0.1341718013831739992e-2, 1e-14, - "iauPn00a", "rbp21", status); - vvd(rbp[1][1], 0.9999990998959191343, 1e-12, - "iauPn00a", "rbp22", status); - vvd(rbp[1][2], -0.3505759733565421170e-6, 1e-14, - "iauPn00a", "rbp23", status); - - vvd(rbp[2][0], 0.5829075206857717883e-3, 1e-14, - "iauPn00a", "rbp31", status); - vvd(rbp[2][1], -0.4315219955198608970e-6, 1e-14, - "iauPn00a", "rbp32", status); - vvd(rbp[2][2], 0.9999998301093036269, 1e-12, - "iauPn00a", "rbp33", status); - - vvd(rn[0][0], 0.9999999999536227949, 1e-12, - "iauPn00a", "rn11", status); - vvd(rn[0][1], 0.8836238544090873336e-5, 1e-14, - "iauPn00a", "rn12", status); - vvd(rn[0][2], 0.3830835237722400669e-5, 1e-14, - "iauPn00a", "rn13", status); - - vvd(rn[1][0], -0.8836082880798569274e-5, 1e-14, - "iauPn00a", "rn21", status); - vvd(rn[1][1], 0.9999999991354655028, 1e-12, - "iauPn00a", "rn22", status); - vvd(rn[1][2], -0.4063240865362499850e-4, 1e-14, - "iauPn00a", "rn23", status); - - vvd(rn[2][0], -0.3831194272065995866e-5, 1e-14, - "iauPn00a", "rn31", status); - vvd(rn[2][1], 0.4063237480216291775e-4, 1e-14, - "iauPn00a", "rn32", status); - vvd(rn[2][2], 0.9999999991671660338, 1e-12, - "iauPn00a", "rn33", status); - - vvd(rbpn[0][0], 0.9999989440476103435, 1e-12, - "iauPn00a", "rbpn11", status); - vvd(rbpn[0][1], -0.1332881761240011763e-2, 1e-14, - "iauPn00a", "rbpn12", status); - vvd(rbpn[0][2], -0.5790767434730085751e-3, 1e-14, - "iauPn00a", "rbpn13", status); - - vvd(rbpn[1][0], 0.1332858254308954658e-2, 1e-14, - "iauPn00a", "rbpn21", status); - vvd(rbpn[1][1], 0.9999991109044505577, 1e-12, - "iauPn00a", "rbpn22", status); - vvd(rbpn[1][2], -0.4097782710396580452e-4, 1e-14, - "iauPn00a", "rbpn23", status); - - vvd(rbpn[2][0], 0.5791308472168152904e-3, 1e-14, - "iauPn00a", "rbpn31", status); - vvd(rbpn[2][1], 0.4020595661591500259e-4, 1e-14, - "iauPn00a", "rbpn32", status); - vvd(rbpn[2][2], 0.9999998314954572304, 1e-12, - "iauPn00a", "rbpn33", status); - -} - -static void t_pn00b(int *status) -/* -** - - - - - - - - -** t _ p n 0 0 b -** - - - - - - - - -** -** Test iauPn00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPn00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps, epsa, - rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; - - - iauPn00b(2400000.5, 53736.0, &dpsi, &deps, &epsa, - rb, rp, rbp, rn, rbpn); - - vvd(dpsi, -0.9632552291148362783e-5, 1e-12, - "iauPn00b", "dpsi", status); - vvd(deps, 0.4063197106621159367e-4, 1e-12, - "iauPn00b", "deps", status); - vvd(epsa, 0.4090791789404229916, 1e-12, "iauPn00b", "epsa", status); - - vvd(rb[0][0], 0.9999999999999942498, 1e-12, - "iauPn00b", "rb11", status); - vvd(rb[0][1], -0.7078279744199196626e-7, 1e-16, - "iauPn00b", "rb12", status); - vvd(rb[0][2], 0.8056217146976134152e-7, 1e-16, - "iauPn00b", "rb13", status); - - vvd(rb[1][0], 0.7078279477857337206e-7, 1e-16, - "iauPn00b", "rb21", status); - vvd(rb[1][1], 0.9999999999999969484, 1e-12, - "iauPn00b", "rb22", status); - vvd(rb[1][2], 0.3306041454222136517e-7, 1e-16, - "iauPn00b", "rb23", status); - - vvd(rb[2][0], -0.8056217380986972157e-7, 1e-16, - "iauPn00b", "rb31", status); - vvd(rb[2][1], -0.3306040883980552500e-7, 1e-16, - "iauPn00b", "rb32", status); - vvd(rb[2][2], 0.9999999999999962084, 1e-12, - "iauPn00b", "rb33", status); - - vvd(rp[0][0], 0.9999989300532289018, 1e-12, - "iauPn00b", "rp11", status); - vvd(rp[0][1], -0.1341647226791824349e-2, 1e-14, - "iauPn00b", "rp12", status); - vvd(rp[0][2], -0.5829880927190296547e-3, 1e-14, - "iauPn00b", "rp13", status); - - vvd(rp[1][0], 0.1341647231069759008e-2, 1e-14, - "iauPn00b", "rp21", status); - vvd(rp[1][1], 0.9999990999908750433, 1e-12, - "iauPn00b", "rp22", status); - vvd(rp[1][2], -0.3837444441583715468e-6, 1e-14, - "iauPn00b", "rp23", status); - - vvd(rp[2][0], 0.5829880828740957684e-3, 1e-14, - "iauPn00b", "rp31", status); - vvd(rp[2][1], -0.3984203267708834759e-6, 1e-14, - "iauPn00b", "rp32", status); - vvd(rp[2][2], 0.9999998300623538046, 1e-12, - "iauPn00b", "rp33", status); - - vvd(rbp[0][0], 0.9999989300052243993, 1e-12, - "iauPn00b", "rbp11", status); - vvd(rbp[0][1], -0.1341717990239703727e-2, 1e-14, - "iauPn00b", "rbp12", status); - vvd(rbp[0][2], -0.5829075749891684053e-3, 1e-14, - "iauPn00b", "rbp13", status); - - vvd(rbp[1][0], 0.1341718013831739992e-2, 1e-14, - "iauPn00b", "rbp21", status); - vvd(rbp[1][1], 0.9999990998959191343, 1e-12, - "iauPn00b", "rbp22", status); - vvd(rbp[1][2], -0.3505759733565421170e-6, 1e-14, - "iauPn00b", "rbp23", status); - - vvd(rbp[2][0], 0.5829075206857717883e-3, 1e-14, - "iauPn00b", "rbp31", status); - vvd(rbp[2][1], -0.4315219955198608970e-6, 1e-14, - "iauPn00b", "rbp32", status); - vvd(rbp[2][2], 0.9999998301093036269, 1e-12, - "iauPn00b", "rbp33", status); - - vvd(rn[0][0], 0.9999999999536069682, 1e-12, - "iauPn00b", "rn11", status); - vvd(rn[0][1], 0.8837746144871248011e-5, 1e-14, - "iauPn00b", "rn12", status); - vvd(rn[0][2], 0.3831488838252202945e-5, 1e-14, - "iauPn00b", "rn13", status); - - vvd(rn[1][0], -0.8837590456632304720e-5, 1e-14, - "iauPn00b", "rn21", status); - vvd(rn[1][1], 0.9999999991354692733, 1e-12, - "iauPn00b", "rn22", status); - vvd(rn[1][2], -0.4063198798559591654e-4, 1e-14, - "iauPn00b", "rn23", status); - - vvd(rn[2][0], -0.3831847930134941271e-5, 1e-14, - "iauPn00b", "rn31", status); - vvd(rn[2][1], 0.4063195412258168380e-4, 1e-14, - "iauPn00b", "rn32", status); - vvd(rn[2][2], 0.9999999991671806225, 1e-12, - "iauPn00b", "rn33", status); - - vvd(rbpn[0][0], 0.9999989440499982806, 1e-12, - "iauPn00b", "rbpn11", status); - vvd(rbpn[0][1], -0.1332880253640849194e-2, 1e-14, - "iauPn00b", "rbpn12", status); - vvd(rbpn[0][2], -0.5790760898731091166e-3, 1e-14, - "iauPn00b", "rbpn13", status); - - vvd(rbpn[1][0], 0.1332856746979949638e-2, 1e-14, - "iauPn00b", "rbpn21", status); - vvd(rbpn[1][1], 0.9999991109064768883, 1e-12, - "iauPn00b", "rbpn22", status); - vvd(rbpn[1][2], -0.4097740555723081811e-4, 1e-14, - "iauPn00b", "rbpn23", status); - - vvd(rbpn[2][0], 0.5791301929950208873e-3, 1e-14, - "iauPn00b", "rbpn31", status); - vvd(rbpn[2][1], 0.4020553681373720832e-4, 1e-14, - "iauPn00b", "rbpn32", status); - vvd(rbpn[2][2], 0.9999998314958529887, 1e-12, - "iauPn00b", "rbpn33", status); - -} - -static void t_pn06a(int *status) -/* -** - - - - - - - - -** t _ p n 0 6 a -** - - - - - - - - -** -** Test iauPn06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPn06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps, epsa; - double rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; - - - iauPn06a(2400000.5, 53736.0, &dpsi, &deps, &epsa, - rb, rp, rbp, rn, rbpn); - - vvd(dpsi, -0.9630912025820308797e-5, 1e-12, - "iauPn06a", "dpsi", status); - vvd(deps, 0.4063238496887249798e-4, 1e-12, - "iauPn06a", "deps", status); - vvd(epsa, 0.4090789763356509926, 1e-12, "iauPn06a", "epsa", status); - - vvd(rb[0][0], 0.9999999999999942497, 1e-12, - "iauPn06a", "rb11", status); - vvd(rb[0][1], -0.7078368960971557145e-7, 1e-14, - "iauPn06a", "rb12", status); - vvd(rb[0][2], 0.8056213977613185606e-7, 1e-14, - "iauPn06a", "rb13", status); - - vvd(rb[1][0], 0.7078368694637674333e-7, 1e-14, - "iauPn06a", "rb21", status); - vvd(rb[1][1], 0.9999999999999969484, 1e-12, - "iauPn06a", "rb22", status); - vvd(rb[1][2], 0.3305943742989134124e-7, 1e-14, - "iauPn06a", "rb23", status); - - vvd(rb[2][0], -0.8056214211620056792e-7, 1e-14, - "iauPn06a", "rb31", status); - vvd(rb[2][1], -0.3305943172740586950e-7, 1e-14, - "iauPn06a", "rb32", status); - vvd(rb[2][2], 0.9999999999999962084, 1e-12, - "iauPn06a", "rb33", status); - - vvd(rp[0][0], 0.9999989300536854831, 1e-12, - "iauPn06a", "rp11", status); - vvd(rp[0][1], -0.1341646886204443795e-2, 1e-14, - "iauPn06a", "rp12", status); - vvd(rp[0][2], -0.5829880933488627759e-3, 1e-14, - "iauPn06a", "rp13", status); - - vvd(rp[1][0], 0.1341646890569782183e-2, 1e-14, - "iauPn06a", "rp21", status); - vvd(rp[1][1], 0.9999990999913319321, 1e-12, - "iauPn06a", "rp22", status); - vvd(rp[1][2], -0.3835944216374477457e-6, 1e-14, - "iauPn06a", "rp23", status); - - vvd(rp[2][0], 0.5829880833027867368e-3, 1e-14, - "iauPn06a", "rp31", status); - vvd(rp[2][1], -0.3985701514686976112e-6, 1e-14, - "iauPn06a", "rp32", status); - vvd(rp[2][2], 0.9999998300623534950, 1e-12, - "iauPn06a", "rp33", status); - - vvd(rbp[0][0], 0.9999989300056797893, 1e-12, - "iauPn06a", "rbp11", status); - vvd(rbp[0][1], -0.1341717650545059598e-2, 1e-14, - "iauPn06a", "rbp12", status); - vvd(rbp[0][2], -0.5829075756493728856e-3, 1e-14, - "iauPn06a", "rbp13", status); - - vvd(rbp[1][0], 0.1341717674223918101e-2, 1e-14, - "iauPn06a", "rbp21", status); - vvd(rbp[1][1], 0.9999990998963748448, 1e-12, - "iauPn06a", "rbp22", status); - vvd(rbp[1][2], -0.3504269280170069029e-6, 1e-14, - "iauPn06a", "rbp23", status); - - vvd(rbp[2][0], 0.5829075211461454599e-3, 1e-14, - "iauPn06a", "rbp31", status); - vvd(rbp[2][1], -0.4316708436255949093e-6, 1e-14, - "iauPn06a", "rbp32", status); - vvd(rbp[2][2], 0.9999998301093032943, 1e-12, - "iauPn06a", "rbp33", status); - - vvd(rn[0][0], 0.9999999999536227668, 1e-12, - "iauPn06a", "rn11", status); - vvd(rn[0][1], 0.8836241998111535233e-5, 1e-14, - "iauPn06a", "rn12", status); - vvd(rn[0][2], 0.3830834608415287707e-5, 1e-14, - "iauPn06a", "rn13", status); - - vvd(rn[1][0], -0.8836086334870740138e-5, 1e-14, - "iauPn06a", "rn21", status); - vvd(rn[1][1], 0.9999999991354657474, 1e-12, - "iauPn06a", "rn22", status); - vvd(rn[1][2], -0.4063240188248455065e-4, 1e-14, - "iauPn06a", "rn23", status); - - vvd(rn[2][0], -0.3831193642839398128e-5, 1e-14, - "iauPn06a", "rn31", status); - vvd(rn[2][1], 0.4063236803101479770e-4, 1e-14, - "iauPn06a", "rn32", status); - vvd(rn[2][2], 0.9999999991671663114, 1e-12, - "iauPn06a", "rn33", status); - - vvd(rbpn[0][0], 0.9999989440480669738, 1e-12, - "iauPn06a", "rbpn11", status); - vvd(rbpn[0][1], -0.1332881418091915973e-2, 1e-14, - "iauPn06a", "rbpn12", status); - vvd(rbpn[0][2], -0.5790767447612042565e-3, 1e-14, - "iauPn06a", "rbpn13", status); - - vvd(rbpn[1][0], 0.1332857911250989133e-2, 1e-14, - "iauPn06a", "rbpn21", status); - vvd(rbpn[1][1], 0.9999991109049141908, 1e-12, - "iauPn06a", "rbpn22", status); - vvd(rbpn[1][2], -0.4097767128546784878e-4, 1e-14, - "iauPn06a", "rbpn23", status); - - vvd(rbpn[2][0], 0.5791308482835292617e-3, 1e-14, - "iauPn06a", "rbpn31", status); - vvd(rbpn[2][1], 0.4020580099454020310e-4, 1e-14, - "iauPn06a", "rbpn32", status); - vvd(rbpn[2][2], 0.9999998314954628695, 1e-12, - "iauPn06a", "rbpn33", status); - -} - -static void t_pn06(int *status) -/* -** - - - - - - - -** t _ p n 0 6 -** - - - - - - - -** -** Test iauPn06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPn06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsi, deps, epsa, - rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; - - - dpsi = -0.9632552291149335877e-5; - deps = 0.4063197106621141414e-4; - - iauPn06(2400000.5, 53736.0, dpsi, deps, - &epsa, rb, rp, rbp, rn, rbpn); - - vvd(epsa, 0.4090789763356509926, 1e-12, "iauPn06", "epsa", status); - - vvd(rb[0][0], 0.9999999999999942497, 1e-12, - "iauPn06", "rb11", status); - vvd(rb[0][1], -0.7078368960971557145e-7, 1e-14, - "iauPn06", "rb12", status); - vvd(rb[0][2], 0.8056213977613185606e-7, 1e-14, - "iauPn06", "rb13", status); - - vvd(rb[1][0], 0.7078368694637674333e-7, 1e-14, - "iauPn06", "rb21", status); - vvd(rb[1][1], 0.9999999999999969484, 1e-12, - "iauPn06", "rb22", status); - vvd(rb[1][2], 0.3305943742989134124e-7, 1e-14, - "iauPn06", "rb23", status); - - vvd(rb[2][0], -0.8056214211620056792e-7, 1e-14, - "iauPn06", "rb31", status); - vvd(rb[2][1], -0.3305943172740586950e-7, 1e-14, - "iauPn06", "rb32", status); - vvd(rb[2][2], 0.9999999999999962084, 1e-12, - "iauPn06", "rb33", status); - - vvd(rp[0][0], 0.9999989300536854831, 1e-12, - "iauPn06", "rp11", status); - vvd(rp[0][1], -0.1341646886204443795e-2, 1e-14, - "iauPn06", "rp12", status); - vvd(rp[0][2], -0.5829880933488627759e-3, 1e-14, - "iauPn06", "rp13", status); - - vvd(rp[1][0], 0.1341646890569782183e-2, 1e-14, - "iauPn06", "rp21", status); - vvd(rp[1][1], 0.9999990999913319321, 1e-12, - "iauPn06", "rp22", status); - vvd(rp[1][2], -0.3835944216374477457e-6, 1e-14, - "iauPn06", "rp23", status); - - vvd(rp[2][0], 0.5829880833027867368e-3, 1e-14, - "iauPn06", "rp31", status); - vvd(rp[2][1], -0.3985701514686976112e-6, 1e-14, - "iauPn06", "rp32", status); - vvd(rp[2][2], 0.9999998300623534950, 1e-12, - "iauPn06", "rp33", status); - - vvd(rbp[0][0], 0.9999989300056797893, 1e-12, - "iauPn06", "rbp11", status); - vvd(rbp[0][1], -0.1341717650545059598e-2, 1e-14, - "iauPn06", "rbp12", status); - vvd(rbp[0][2], -0.5829075756493728856e-3, 1e-14, - "iauPn06", "rbp13", status); - - vvd(rbp[1][0], 0.1341717674223918101e-2, 1e-14, - "iauPn06", "rbp21", status); - vvd(rbp[1][1], 0.9999990998963748448, 1e-12, - "iauPn06", "rbp22", status); - vvd(rbp[1][2], -0.3504269280170069029e-6, 1e-14, - "iauPn06", "rbp23", status); - - vvd(rbp[2][0], 0.5829075211461454599e-3, 1e-14, - "iauPn06", "rbp31", status); - vvd(rbp[2][1], -0.4316708436255949093e-6, 1e-14, - "iauPn06", "rbp32", status); - vvd(rbp[2][2], 0.9999998301093032943, 1e-12, - "iauPn06", "rbp33", status); - - vvd(rn[0][0], 0.9999999999536069682, 1e-12, - "iauPn06", "rn11", status); - vvd(rn[0][1], 0.8837746921149881914e-5, 1e-14, - "iauPn06", "rn12", status); - vvd(rn[0][2], 0.3831487047682968703e-5, 1e-14, - "iauPn06", "rn13", status); - - vvd(rn[1][0], -0.8837591232983692340e-5, 1e-14, - "iauPn06", "rn21", status); - vvd(rn[1][1], 0.9999999991354692664, 1e-12, - "iauPn06", "rn22", status); - vvd(rn[1][2], -0.4063198798558931215e-4, 1e-14, - "iauPn06", "rn23", status); - - vvd(rn[2][0], -0.3831846139597250235e-5, 1e-14, - "iauPn06", "rn31", status); - vvd(rn[2][1], 0.4063195412258792914e-4, 1e-14, - "iauPn06", "rn32", status); - vvd(rn[2][2], 0.9999999991671806293, 1e-12, - "iauPn06", "rn33", status); - - vvd(rbpn[0][0], 0.9999989440504506688, 1e-12, - "iauPn06", "rbpn11", status); - vvd(rbpn[0][1], -0.1332879913170492655e-2, 1e-14, - "iauPn06", "rbpn12", status); - vvd(rbpn[0][2], -0.5790760923225655753e-3, 1e-14, - "iauPn06", "rbpn13", status); - - vvd(rbpn[1][0], 0.1332856406595754748e-2, 1e-14, - "iauPn06", "rbpn21", status); - vvd(rbpn[1][1], 0.9999991109069366795, 1e-12, - "iauPn06", "rbpn22", status); - vvd(rbpn[1][2], -0.4097725651142641812e-4, 1e-14, - "iauPn06", "rbpn23", status); - - vvd(rbpn[2][0], 0.5791301952321296716e-3, 1e-14, - "iauPn06", "rbpn31", status); - vvd(rbpn[2][1], 0.4020538796195230577e-4, 1e-14, - "iauPn06", "rbpn32", status); - vvd(rbpn[2][2], 0.9999998314958576778, 1e-12, - "iauPn06", "rbpn33", status); - -} - -static void t_pnm00a(int *status) -/* -** - - - - - - - - - -** t _ p n m 0 0 a -** - - - - - - - - - -** -** Test iauPnm00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPnm00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbpn[3][3]; - - - iauPnm00a(2400000.5, 50123.9999, rbpn); - - vvd(rbpn[0][0], 0.9999995832793134257, 1e-12, - "iauPnm00a", "11", status); - vvd(rbpn[0][1], 0.8372384254137809439e-3, 1e-14, - "iauPnm00a", "12", status); - vvd(rbpn[0][2], 0.3639684306407150645e-3, 1e-14, - "iauPnm00a", "13", status); - - vvd(rbpn[1][0], -0.8372535226570394543e-3, 1e-14, - "iauPnm00a", "21", status); - vvd(rbpn[1][1], 0.9999996486491582471, 1e-12, - "iauPnm00a", "22", status); - vvd(rbpn[1][2], 0.4132915262664072381e-4, 1e-14, - "iauPnm00a", "23", status); - - vvd(rbpn[2][0], -0.3639337004054317729e-3, 1e-14, - "iauPnm00a", "31", status); - vvd(rbpn[2][1], -0.4163386925461775873e-4, 1e-14, - "iauPnm00a", "32", status); - vvd(rbpn[2][2], 0.9999999329094390695, 1e-12, - "iauPnm00a", "33", status); - -} - -static void t_pnm00b(int *status) -/* -** - - - - - - - - - -** t _ p n m 0 0 b -** - - - - - - - - - -** -** Test iauPnm00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPnm00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbpn[3][3]; - - - iauPnm00b(2400000.5, 50123.9999, rbpn); - - vvd(rbpn[0][0], 0.9999995832776208280, 1e-12, - "iauPnm00b", "11", status); - vvd(rbpn[0][1], 0.8372401264429654837e-3, 1e-14, - "iauPnm00b", "12", status); - vvd(rbpn[0][2], 0.3639691681450271771e-3, 1e-14, - "iauPnm00b", "13", status); - - vvd(rbpn[1][0], -0.8372552234147137424e-3, 1e-14, - "iauPnm00b", "21", status); - vvd(rbpn[1][1], 0.9999996486477686123, 1e-12, - "iauPnm00b", "22", status); - vvd(rbpn[1][2], 0.4132832190946052890e-4, 1e-14, - "iauPnm00b", "23", status); - - vvd(rbpn[2][0], -0.3639344385341866407e-3, 1e-14, - "iauPnm00b", "31", status); - vvd(rbpn[2][1], -0.4163303977421522785e-4, 1e-14, - "iauPnm00b", "32", status); - vvd(rbpn[2][2], 0.9999999329092049734, 1e-12, - "iauPnm00b", "33", status); - -} - -static void t_pnm06a(int *status) -/* -** - - - - - - - - - -** t _ p n m 0 6 a -** - - - - - - - - - -** -** Test iauPnm06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPnm06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rbpn[3][3]; - - - iauPnm06a(2400000.5, 50123.9999, rbpn); - - vvd(rbpn[0][0], 0.9999995832794205484, 1e-12, - "iauPnm06a", "11", status); - vvd(rbpn[0][1], 0.8372382772630962111e-3, 1e-14, - "iauPnm06a", "12", status); - vvd(rbpn[0][2], 0.3639684771140623099e-3, 1e-14, - "iauPnm06a", "13", status); - - vvd(rbpn[1][0], -0.8372533744743683605e-3, 1e-14, - "iauPnm06a", "21", status); - vvd(rbpn[1][1], 0.9999996486492861646, 1e-12, - "iauPnm06a", "22", status); - vvd(rbpn[1][2], 0.4132905944611019498e-4, 1e-14, - "iauPnm06a", "23", status); - - vvd(rbpn[2][0], -0.3639337469629464969e-3, 1e-14, - "iauPnm06a", "31", status); - vvd(rbpn[2][1], -0.4163377605910663999e-4, 1e-14, - "iauPnm06a", "32", status); - vvd(rbpn[2][2], 0.9999999329094260057, 1e-12, - "iauPnm06a", "33", status); - -} - -static void t_pnm80(int *status) -/* -** - - - - - - - - -** t _ p n m 8 0 -** - - - - - - - - -** -** Test iauPnm80 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPnm80, vvd -** -** This revision: 2013 August 7 -*/ -{ - double rmatpn[3][3]; - - - iauPnm80(2400000.5, 50123.9999, rmatpn); - - vvd(rmatpn[0][0], 0.9999995831934611169, 1e-12, - "iauPnm80", "11", status); - vvd(rmatpn[0][1], 0.8373654045728124011e-3, 1e-14, - "iauPnm80", "12", status); - vvd(rmatpn[0][2], 0.3639121916933106191e-3, 1e-14, - "iauPnm80", "13", status); - - vvd(rmatpn[1][0], -0.8373804896118301316e-3, 1e-14, - "iauPnm80", "21", status); - vvd(rmatpn[1][1], 0.9999996485439674092, 1e-12, - "iauPnm80", "22", status); - vvd(rmatpn[1][2], 0.4130202510421549752e-4, 1e-14, - "iauPnm80", "23", status); - - vvd(rmatpn[2][0], -0.3638774789072144473e-3, 1e-14, - "iauPnm80", "31", status); - vvd(rmatpn[2][1], -0.4160674085851722359e-4, 1e-14, - "iauPnm80", "32", status); - vvd(rmatpn[2][2], 0.9999999329310274805, 1e-12, - "iauPnm80", "33", status); - -} - -static void t_pom00(int *status) -/* -** - - - - - - - - -** t _ p o m 0 0 -** - - - - - - - - -** -** Test iauPom00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPom00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double xp, yp, sp, rpom[3][3]; - - - xp = 2.55060238e-7; - yp = 1.860359247e-6; - sp = -0.1367174580728891460e-10; - - iauPom00(xp, yp, sp, rpom); - - vvd(rpom[0][0], 0.9999999999999674721, 1e-12, - "iauPom00", "11", status); - vvd(rpom[0][1], -0.1367174580728846989e-10, 1e-16, - "iauPom00", "12", status); - vvd(rpom[0][2], 0.2550602379999972345e-6, 1e-16, - "iauPom00", "13", status); - - vvd(rpom[1][0], 0.1414624947957029801e-10, 1e-16, - "iauPom00", "21", status); - vvd(rpom[1][1], 0.9999999999982695317, 1e-12, - "iauPom00", "22", status); - vvd(rpom[1][2], -0.1860359246998866389e-5, 1e-16, - "iauPom00", "23", status); - - vvd(rpom[2][0], -0.2550602379741215021e-6, 1e-16, - "iauPom00", "31", status); - vvd(rpom[2][1], 0.1860359247002414021e-5, 1e-16, - "iauPom00", "32", status); - vvd(rpom[2][2], 0.9999999999982370039, 1e-12, - "iauPom00", "33", status); - -} - -static void t_ppp(int *status) -/* -** - - - - - - -** t _ p p p -** - - - - - - -** -** Test iauPpp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPpp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3], b[3], apb[3]; - - - a[0] = 2.0; - a[1] = 2.0; - a[2] = 3.0; - - b[0] = 1.0; - b[1] = 3.0; - b[2] = 4.0; - - iauPpp(a, b, apb); - - vvd(apb[0], 3.0, 1e-12, "iauPpp", "0", status); - vvd(apb[1], 5.0, 1e-12, "iauPpp", "1", status); - vvd(apb[2], 7.0, 1e-12, "iauPpp", "2", status); - -} - -static void t_ppsp(int *status) -/* -** - - - - - - - -** t _ p p s p -** - - - - - - - -** -** Test iauPpsp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPpsp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3], s, b[3], apsb[3]; - - - a[0] = 2.0; - a[1] = 2.0; - a[2] = 3.0; - - s = 5.0; - - b[0] = 1.0; - b[1] = 3.0; - b[2] = 4.0; - - iauPpsp(a, s, b, apsb); - - vvd(apsb[0], 7.0, 1e-12, "iauPpsp", "0", status); - vvd(apsb[1], 17.0, 1e-12, "iauPpsp", "1", status); - vvd(apsb[2], 23.0, 1e-12, "iauPpsp", "2", status); - -} - -static void t_pr00(int *status) -/* -** - - - - - - - -** t _ p r 0 0 -** - - - - - - - -** -** Test iauPr00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPr00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double dpsipr, depspr; - - iauPr00(2400000.5, 53736, &dpsipr, &depspr); - - vvd(dpsipr, -0.8716465172668347629e-7, 1e-22, - "iauPr00", "dpsipr", status); - vvd(depspr, -0.7342018386722813087e-8, 1e-22, - "iauPr00", "depspr", status); - -} - -static void t_prec76(int *status) -/* -** - - - - - - - - - -** t _ p r e c 7 6 -** - - - - - - - - - -** -** Test iauPrec76 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPrec76, vvd -** -** This revision: 2013 August 7 -*/ -{ - double ep01, ep02, ep11, ep12, zeta, z, theta; - - - ep01 = 2400000.5; - ep02 = 33282.0; - ep11 = 2400000.5; - ep12 = 51544.0; - - iauPrec76(ep01, ep02, ep11, ep12, &zeta, &z, &theta); - - vvd(zeta, 0.5588961642000161243e-2, 1e-12, - "iauPrec76", "zeta", status); - vvd(z, 0.5589922365870680624e-2, 1e-12, - "iauPrec76", "z", status); - vvd(theta, 0.4858945471687296760e-2, 1e-12, - "iauPrec76", "theta", status); - -} - -static void t_pv2p(int *status) -/* -** - - - - - - - -** t _ p v 2 p -** - - - - - - - -** -** Test iauPv2p function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPv2p, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3], p[3]; - - - pv[0][0] = 0.3; - pv[0][1] = 1.2; - pv[0][2] = -2.5; - - pv[1][0] = -0.5; - pv[1][1] = 3.1; - pv[1][2] = 0.9; - - iauPv2p(pv, p); - - vvd(p[0], 0.3, 0.0, "iauPv2p", "1", status); - vvd(p[1], 1.2, 0.0, "iauPv2p", "2", status); - vvd(p[2], -2.5, 0.0, "iauPv2p", "3", status); - -} - -static void t_pv2s(int *status) -/* -** - - - - - - - -** t _ p v 2 s -** - - - - - - - -** -** Test iauPv2s function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPv2s, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3], theta, phi, r, td, pd, rd; - - - pv[0][0] = -0.4514964673880165; - pv[0][1] = 0.03093394277342585; - pv[0][2] = 0.05594668105108779; - - pv[1][0] = 1.292270850663260e-5; - pv[1][1] = 2.652814182060692e-6; - pv[1][2] = 2.568431853930293e-6; - - iauPv2s(pv, &theta, &phi, &r, &td, &pd, &rd); - - vvd(theta, 3.073185307179586515, 1e-12, "iauPv2s", "theta", status); - vvd(phi, 0.1229999999999999992, 1e-12, "iauPv2s", "phi", status); - vvd(r, 0.4559999999999999757, 1e-12, "iauPv2s", "r", status); - vvd(td, -0.7800000000000000364e-5, 1e-16, "iauPv2s", "td", status); - vvd(pd, 0.9010000000000001639e-5, 1e-16, "iauPv2s", "pd", status); - vvd(rd, -0.1229999999999999832e-4, 1e-16, "iauPv2s", "rd", status); - -} - -static void t_pvdpv(int *status) -/* -** - - - - - - - - -** t _ p v d p v -** - - - - - - - - -** -** Test iauPvdpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvdpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[2][3], b[2][3], adb[2]; - - - a[0][0] = 2.0; - a[0][1] = 2.0; - a[0][2] = 3.0; - - a[1][0] = 6.0; - a[1][1] = 0.0; - a[1][2] = 4.0; - - b[0][0] = 1.0; - b[0][1] = 3.0; - b[0][2] = 4.0; - - b[1][0] = 0.0; - b[1][1] = 2.0; - b[1][2] = 8.0; - - iauPvdpv(a, b, adb); - - vvd(adb[0], 20.0, 1e-12, "iauPvdpv", "1", status); - vvd(adb[1], 50.0, 1e-12, "iauPvdpv", "2", status); - -} - -static void t_pvm(int *status) -/* -** - - - - - - -** t _ p v m -** - - - - - - -** -** Test iauPvm function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvm, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3], r, s; - - - pv[0][0] = 0.3; - pv[0][1] = 1.2; - pv[0][2] = -2.5; - - pv[1][0] = 0.45; - pv[1][1] = -0.25; - pv[1][2] = 1.1; - - iauPvm(pv, &r, &s); - - vvd(r, 2.789265136196270604, 1e-12, "iauPvm", "r", status); - vvd(s, 1.214495780149111922, 1e-12, "iauPvm", "s", status); - -} - -static void t_pvmpv(int *status) -/* -** - - - - - - - - -** t _ p v m p v -** - - - - - - - - -** -** Test iauPvmpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvmpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[2][3], b[2][3], amb[2][3]; - - - a[0][0] = 2.0; - a[0][1] = 2.0; - a[0][2] = 3.0; - - a[1][0] = 5.0; - a[1][1] = 6.0; - a[1][2] = 3.0; - - b[0][0] = 1.0; - b[0][1] = 3.0; - b[0][2] = 4.0; - - b[1][0] = 3.0; - b[1][1] = 2.0; - b[1][2] = 1.0; - - iauPvmpv(a, b, amb); - - vvd(amb[0][0], 1.0, 1e-12, "iauPvmpv", "11", status); - vvd(amb[0][1], -1.0, 1e-12, "iauPvmpv", "21", status); - vvd(amb[0][2], -1.0, 1e-12, "iauPvmpv", "31", status); - - vvd(amb[1][0], 2.0, 1e-12, "iauPvmpv", "12", status); - vvd(amb[1][1], 4.0, 1e-12, "iauPvmpv", "22", status); - vvd(amb[1][2], 2.0, 1e-12, "iauPvmpv", "32", status); - -} - -static void t_pvppv(int *status) -/* -** - - - - - - - - -** t _ p v p p v -** - - - - - - - - -** -** Test iauPvppv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvppv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[2][3], b[2][3], apb[2][3]; - - - a[0][0] = 2.0; - a[0][1] = 2.0; - a[0][2] = 3.0; - - a[1][0] = 5.0; - a[1][1] = 6.0; - a[1][2] = 3.0; - - b[0][0] = 1.0; - b[0][1] = 3.0; - b[0][2] = 4.0; - - b[1][0] = 3.0; - b[1][1] = 2.0; - b[1][2] = 1.0; - - iauPvppv(a, b, apb); - - vvd(apb[0][0], 3.0, 1e-12, "iauPvppv", "p1", status); - vvd(apb[0][1], 5.0, 1e-12, "iauPvppv", "p2", status); - vvd(apb[0][2], 7.0, 1e-12, "iauPvppv", "p3", status); - - vvd(apb[1][0], 8.0, 1e-12, "iauPvppv", "v1", status); - vvd(apb[1][1], 8.0, 1e-12, "iauPvppv", "v2", status); - vvd(apb[1][2], 4.0, 1e-12, "iauPvppv", "v3", status); - -} - -static void t_pvstar(int *status) -/* -** - - - - - - - - - -** t _ p v s t a r -** - - - - - - - - - -** -** Test iauPvstar function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvstar, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3], ra, dec, pmr, pmd, px, rv; - int j; - - - pv[0][0] = 126668.5912743160601; - pv[0][1] = 2136.792716839935195; - pv[0][2] = -245251.2339876830091; - - pv[1][0] = -0.4051854035740712739e-2; - pv[1][1] = -0.6253919754866173866e-2; - pv[1][2] = 0.1189353719774107189e-1; - - j = iauPvstar(pv, &ra, &dec, &pmr, &pmd, &px, &rv); - - vvd(ra, 0.1686756e-1, 1e-12, "iauPvstar", "ra", status); - vvd(dec, -1.093989828, 1e-12, "iauPvstar", "dec", status); - vvd(pmr, -0.178323516e-4, 1e-16, "iauPvstar", "pmr", status); - vvd(pmd, 0.2336024047e-5, 1e-16, "iauPvstar", "pmd", status); - vvd(px, 0.74723, 1e-12, "iauPvstar", "px", status); - vvd(rv, -21.6, 1e-11, "iauPvstar", "rv", status); - - viv(j, 0, "iauPvstar", "j", status); - -} - -static void t_pvtob(int *status) -/* -** - - - - - - - - -** t _ p v t o b -** - - - - - - - - -** -** Test iauPvtob function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvtob, vvd -** -** This revision: 2013 October 2 -*/ -{ - double elong, phi, hm, xp, yp, sp, theta, pv[2][3]; - - - elong = 2.0; - phi = 0.5; - hm = 3000.0; - xp = 1e-6; - yp = -0.5e-6; - sp = 1e-8; - theta = 5.0; - - iauPvtob(elong, phi, hm, xp, yp, sp, theta, pv); - - vvd(pv[0][0], 4225081.367071159207, 1e-5, - "iauPvtob", "p(1)", status); - vvd(pv[0][1], 3681943.215856198144, 1e-5, - "iauPvtob", "p(2)", status); - vvd(pv[0][2], 3041149.399241260785, 1e-5, - "iauPvtob", "p(3)", status); - vvd(pv[1][0], -268.4915389365998787, 1e-9, - "iauPvtob", "v(1)", status); - vvd(pv[1][1], 308.0977983288903123, 1e-9, - "iauPvtob", "v(2)", status); - vvd(pv[1][2], 0, 0, - "iauPvtob", "v(3)", status); - -} - -static void t_pvu(int *status) -/* -** - - - - - - -** t _ p v u -** - - - - - - -** -** Test iauPvu function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvu, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3], upv[2][3]; - - - pv[0][0] = 126668.5912743160734; - pv[0][1] = 2136.792716839935565; - pv[0][2] = -245251.2339876830229; - - pv[1][0] = -0.4051854035740713039e-2; - pv[1][1] = -0.6253919754866175788e-2; - pv[1][2] = 0.1189353719774107615e-1; - - iauPvu(2920.0, pv, upv); - - vvd(upv[0][0], 126656.7598605317105, 1e-12, - "iauPvu", "p1", status); - vvd(upv[0][1], 2118.531271155726332, 1e-12, - "iauPvu", "p2", status); - vvd(upv[0][2], -245216.5048590656190, 1e-12, - "iauPvu", "p3", status); - - vvd(upv[1][0], -0.4051854035740713039e-2, 1e-12, - "iauPvu", "v1", status); - vvd(upv[1][1], -0.6253919754866175788e-2, 1e-12, - "iauPvu", "v2", status); - vvd(upv[1][2], 0.1189353719774107615e-1, 1e-12, - "iauPvu", "v3", status); - -} - -static void t_pvup(int *status) -/* -** - - - - - - - -** t _ p v u p -** - - - - - - - -** -** Test iauPvup function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvup, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3], p[3]; - - - pv[0][0] = 126668.5912743160734; - pv[0][1] = 2136.792716839935565; - pv[0][2] = -245251.2339876830229; - - pv[1][0] = -0.4051854035740713039e-2; - pv[1][1] = -0.6253919754866175788e-2; - pv[1][2] = 0.1189353719774107615e-1; - - iauPvup(2920.0, pv, p); - - vvd(p[0], 126656.7598605317105, 1e-12, "iauPvup", "1", status); - vvd(p[1], 2118.531271155726332, 1e-12, "iauPvup", "2", status); - vvd(p[2], -245216.5048590656190, 1e-12, "iauPvup", "3", status); - -} - -static void t_pvxpv(int *status) -/* -** - - - - - - - - -** t _ p v x p v -** - - - - - - - - -** -** Test iauPvxpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPvxpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[2][3], b[2][3], axb[2][3]; - - - a[0][0] = 2.0; - a[0][1] = 2.0; - a[0][2] = 3.0; - - a[1][0] = 6.0; - a[1][1] = 0.0; - a[1][2] = 4.0; - - b[0][0] = 1.0; - b[0][1] = 3.0; - b[0][2] = 4.0; - - b[1][0] = 0.0; - b[1][1] = 2.0; - b[1][2] = 8.0; - - iauPvxpv(a, b, axb); - - vvd(axb[0][0], -1.0, 1e-12, "iauPvxpv", "p1", status); - vvd(axb[0][1], -5.0, 1e-12, "iauPvxpv", "p2", status); - vvd(axb[0][2], 4.0, 1e-12, "iauPvxpv", "p3", status); - - vvd(axb[1][0], -2.0, 1e-12, "iauPvxpv", "v1", status); - vvd(axb[1][1], -36.0, 1e-12, "iauPvxpv", "v2", status); - vvd(axb[1][2], 22.0, 1e-12, "iauPvxpv", "v3", status); - -} - -static void t_pxp(int *status) -/* -** - - - - - - -** t _ p x p -** - - - - - - -** -** Test iauPxp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauPxp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3], b[3], axb[3]; - - - a[0] = 2.0; - a[1] = 2.0; - a[2] = 3.0; - - b[0] = 1.0; - b[1] = 3.0; - b[2] = 4.0; - - iauPxp(a, b, axb); - - vvd(axb[0], -1.0, 1e-12, "iauPxp", "1", status); - vvd(axb[1], -5.0, 1e-12, "iauPxp", "2", status); - vvd(axb[2], 4.0, 1e-12, "iauPxp", "3", status); - -} - -static void t_refco(int *status) -/* -** - - - - - - - - -** t _ r e f c o -** - - - - - - - - -** -** Test iauRefco function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRefco, vvd -** -** This revision: 2013 October 2 -*/ -{ - double phpa, tc, rh, wl, refa, refb; - - - phpa = 800.0; - tc = 10.0; - rh = 0.9; - wl = 0.4; - - iauRefco(phpa, tc, rh, wl, &refa, &refb); - - vvd(refa, 0.2264949956241415009e-3, 1e-15, - "iauRefco", "refa", status); - vvd(refb, -0.2598658261729343970e-6, 1e-18, - "iauRefco", "refb", status); - -} - -static void t_rm2v(int *status) -/* -** - - - - - - - -** t _ r m 2 v -** - - - - - - - -** -** Test iauRm2v function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRm2v, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3], w[3]; - - - r[0][0] = 0.00; - r[0][1] = -0.80; - r[0][2] = -0.60; - - r[1][0] = 0.80; - r[1][1] = -0.36; - r[1][2] = 0.48; - - r[2][0] = 0.60; - r[2][1] = 0.48; - r[2][2] = -0.64; - - iauRm2v(r, w); - - vvd(w[0], 0.0, 1e-12, "iauRm2v", "1", status); - vvd(w[1], 1.413716694115406957, 1e-12, "iauRm2v", "2", status); - vvd(w[2], -1.884955592153875943, 1e-12, "iauRm2v", "3", status); - -} - -static void t_rv2m(int *status) -/* -** - - - - - - - -** t _ r v 2 m -** - - - - - - - -** -** Test iauRv2m function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRv2m, vvd -** -** This revision: 2013 August 7 -*/ -{ - double w[3], r[3][3]; - - - w[0] = 0.0; - w[1] = 1.41371669; - w[2] = -1.88495559; - - iauRv2m(w, r); - - vvd(r[0][0], -0.7071067782221119905, 1e-14, "iauRv2m", "11", status); - vvd(r[0][1], -0.5656854276809129651, 1e-14, "iauRv2m", "12", status); - vvd(r[0][2], -0.4242640700104211225, 1e-14, "iauRv2m", "13", status); - - vvd(r[1][0], 0.5656854276809129651, 1e-14, "iauRv2m", "21", status); - vvd(r[1][1], -0.0925483394532274246, 1e-14, "iauRv2m", "22", status); - vvd(r[1][2], -0.8194112531408833269, 1e-14, "iauRv2m", "23", status); - - vvd(r[2][0], 0.4242640700104211225, 1e-14, "iauRv2m", "31", status); - vvd(r[2][1], -0.8194112531408833269, 1e-14, "iauRv2m", "32", status); - vvd(r[2][2], 0.3854415612311154341, 1e-14, "iauRv2m", "33", status); - -} - -static void t_rx(int *status) -/* -** - - - - - -** t _ r x -** - - - - - -** -** Test iauRx function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRx, vvd -** -** This revision: 2013 August 7 -*/ -{ - double phi, r[3][3]; - - - phi = 0.3456789; - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - iauRx(phi, r); - - vvd(r[0][0], 2.0, 0.0, "iauRx", "11", status); - vvd(r[0][1], 3.0, 0.0, "iauRx", "12", status); - vvd(r[0][2], 2.0, 0.0, "iauRx", "13", status); - - vvd(r[1][0], 3.839043388235612460, 1e-12, "iauRx", "21", status); - vvd(r[1][1], 3.237033249594111899, 1e-12, "iauRx", "22", status); - vvd(r[1][2], 4.516714379005982719, 1e-12, "iauRx", "23", status); - - vvd(r[2][0], 1.806030415924501684, 1e-12, "iauRx", "31", status); - vvd(r[2][1], 3.085711545336372503, 1e-12, "iauRx", "32", status); - vvd(r[2][2], 3.687721683977873065, 1e-12, "iauRx", "33", status); - -} - -static void t_rxp(int *status) -/* -** - - - - - - -** t _ r x p -** - - - - - - -** -** Test iauRxp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRxp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3], p[3], rp[3]; - - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - p[0] = 0.2; - p[1] = 1.5; - p[2] = 0.1; - - iauRxp(r, p, rp); - - vvd(rp[0], 5.1, 1e-12, "iauRxp", "1", status); - vvd(rp[1], 3.9, 1e-12, "iauRxp", "2", status); - vvd(rp[2], 7.1, 1e-12, "iauRxp", "3", status); - -} - -static void t_rxpv(int *status) -/* -** - - - - - - - -** t _ r x p v -** - - - - - - - -** -** Test iauRxpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRxpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3], pv[2][3], rpv[2][3]; - - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - pv[0][0] = 0.2; - pv[0][1] = 1.5; - pv[0][2] = 0.1; - - pv[1][0] = 1.5; - pv[1][1] = 0.2; - pv[1][2] = 0.1; - - iauRxpv(r, pv, rpv); - - vvd(rpv[0][0], 5.1, 1e-12, "iauRxpv", "11", status); - vvd(rpv[1][0], 3.8, 1e-12, "iauRxpv", "12", status); - - vvd(rpv[0][1], 3.9, 1e-12, "iauRxpv", "21", status); - vvd(rpv[1][1], 5.2, 1e-12, "iauRxpv", "22", status); - - vvd(rpv[0][2], 7.1, 1e-12, "iauRxpv", "31", status); - vvd(rpv[1][2], 5.8, 1e-12, "iauRxpv", "32", status); - -} - -static void t_rxr(int *status) -/* -** - - - - - - -** t _ r x r -** - - - - - - -** -** Test iauRxr function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRxr, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3][3], b[3][3], atb[3][3]; - - - a[0][0] = 2.0; - a[0][1] = 3.0; - a[0][2] = 2.0; - - a[1][0] = 3.0; - a[1][1] = 2.0; - a[1][2] = 3.0; - - a[2][0] = 3.0; - a[2][1] = 4.0; - a[2][2] = 5.0; - - b[0][0] = 1.0; - b[0][1] = 2.0; - b[0][2] = 2.0; - - b[1][0] = 4.0; - b[1][1] = 1.0; - b[1][2] = 1.0; - - b[2][0] = 3.0; - b[2][1] = 0.0; - b[2][2] = 1.0; - - iauRxr(a, b, atb); - - vvd(atb[0][0], 20.0, 1e-12, "iauRxr", "11", status); - vvd(atb[0][1], 7.0, 1e-12, "iauRxr", "12", status); - vvd(atb[0][2], 9.0, 1e-12, "iauRxr", "13", status); - - vvd(atb[1][0], 20.0, 1e-12, "iauRxr", "21", status); - vvd(atb[1][1], 8.0, 1e-12, "iauRxr", "22", status); - vvd(atb[1][2], 11.0, 1e-12, "iauRxr", "23", status); - - vvd(atb[2][0], 34.0, 1e-12, "iauRxr", "31", status); - vvd(atb[2][1], 10.0, 1e-12, "iauRxr", "32", status); - vvd(atb[2][2], 15.0, 1e-12, "iauRxr", "33", status); - -} - -static void t_ry(int *status) -/* -** - - - - - -** t _ r y -** - - - - - -** -** Test iauRy function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRy, vvd -** -** This revision: 2013 August 7 -*/ -{ - double theta, r[3][3]; - - - theta = 0.3456789; - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - iauRy(theta, r); - - vvd(r[0][0], 0.8651847818978159930, 1e-12, "iauRy", "11", status); - vvd(r[0][1], 1.467194920539316554, 1e-12, "iauRy", "12", status); - vvd(r[0][2], 0.1875137911274457342, 1e-12, "iauRy", "13", status); - - vvd(r[1][0], 3, 1e-12, "iauRy", "21", status); - vvd(r[1][1], 2, 1e-12, "iauRy", "22", status); - vvd(r[1][2], 3, 1e-12, "iauRy", "23", status); - - vvd(r[2][0], 3.500207892850427330, 1e-12, "iauRy", "31", status); - vvd(r[2][1], 4.779889022262298150, 1e-12, "iauRy", "32", status); - vvd(r[2][2], 5.381899160903798712, 1e-12, "iauRy", "33", status); - -} - -static void t_rz(int *status) -/* -** - - - - - -** t _ r z -** - - - - - -** -** Test iauRz function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauRz, vvd -** -** This revision: 2013 August 7 -*/ -{ - double psi, r[3][3]; - - - psi = 0.3456789; - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - iauRz(psi, r); - - vvd(r[0][0], 2.898197754208926769, 1e-12, "iauRz", "11", status); - vvd(r[0][1], 3.500207892850427330, 1e-12, "iauRz", "12", status); - vvd(r[0][2], 2.898197754208926769, 1e-12, "iauRz", "13", status); - - vvd(r[1][0], 2.144865911309686813, 1e-12, "iauRz", "21", status); - vvd(r[1][1], 0.865184781897815993, 1e-12, "iauRz", "22", status); - vvd(r[1][2], 2.144865911309686813, 1e-12, "iauRz", "23", status); - - vvd(r[2][0], 3.0, 1e-12, "iauRz", "31", status); - vvd(r[2][1], 4.0, 1e-12, "iauRz", "32", status); - vvd(r[2][2], 5.0, 1e-12, "iauRz", "33", status); - -} - -static void t_s00a(int *status) -/* -** - - - - - - - -** t _ s 0 0 a -** - - - - - - - -** -** Test iauS00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double s; - - - s = iauS00a(2400000.5, 52541.0); - - vvd(s, -0.1340684448919163584e-7, 1e-18, "iauS00a", "", status); - -} - -static void t_s00b(int *status) -/* -** - - - - - - - -** t _ s 0 0 b -** - - - - - - - -** -** Test iauS00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double s; - - - s = iauS00b(2400000.5, 52541.0); - - vvd(s, -0.1340695782951026584e-7, 1e-18, "iauS00b", "", status); - -} - -static void t_s00(int *status) -/* -** - - - - - - -** t _ s 0 0 -** - - - - - - -** -** Test iauS00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS00, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y, s; - - - x = 0.5791308486706011000e-3; - y = 0.4020579816732961219e-4; - - s = iauS00(2400000.5, 53736.0, x, y); - - vvd(s, -0.1220036263270905693e-7, 1e-18, "iauS00", "", status); - -} - -static void t_s06a(int *status) -/* -** - - - - - - - -** t _ s 0 6 a -** - - - - - - - -** -** Test iauS06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double s; - - - s = iauS06a(2400000.5, 52541.0); - - vvd(s, -0.1340680437291812383e-7, 1e-18, "iauS06a", "", status); - -} - -static void t_s06(int *status) -/* -** - - - - - - -** t _ s 0 6 -** - - - - - - -** -** Test iauS06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y, s; - - - x = 0.5791308486706011000e-3; - y = 0.4020579816732961219e-4; - - s = iauS06(2400000.5, 53736.0, x, y); - - vvd(s, -0.1220032213076463117e-7, 1e-18, "iauS06", "", status); - -} - -static void t_s2c(int *status) -/* -** - - - - - - -** t _ s 2 c -** - - - - - - -** -** Test iauS2c function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS2c, vvd -** -** This revision: 2013 August 7 -*/ -{ - double c[3]; - - - iauS2c(3.0123, -0.999, c); - - vvd(c[0], -0.5366267667260523906, 1e-12, "iauS2c", "1", status); - vvd(c[1], 0.0697711109765145365, 1e-12, "iauS2c", "2", status); - vvd(c[2], -0.8409302618566214041, 1e-12, "iauS2c", "3", status); - -} - -static void t_s2p(int *status) -/* -** - - - - - - -** t _ s 2 p -** - - - - - - -** -** Test iauS2p function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS2p, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3]; - - - iauS2p(-3.21, 0.123, 0.456, p); - - vvd(p[0], -0.4514964673880165228, 1e-12, "iauS2p", "x", status); - vvd(p[1], 0.0309339427734258688, 1e-12, "iauS2p", "y", status); - vvd(p[2], 0.0559466810510877933, 1e-12, "iauS2p", "z", status); - -} - -static void t_s2pv(int *status) -/* -** - - - - - - - -** t _ s 2 p v -** - - - - - - - -** -** Test iauS2pv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS2pv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3]; - - - iauS2pv(-3.21, 0.123, 0.456, -7.8e-6, 9.01e-6, -1.23e-5, pv); - - vvd(pv[0][0], -0.4514964673880165228, 1e-12, "iauS2pv", "x", status); - vvd(pv[0][1], 0.0309339427734258688, 1e-12, "iauS2pv", "y", status); - vvd(pv[0][2], 0.0559466810510877933, 1e-12, "iauS2pv", "z", status); - - vvd(pv[1][0], 0.1292270850663260170e-4, 1e-16, - "iauS2pv", "vx", status); - vvd(pv[1][1], 0.2652814182060691422e-5, 1e-16, - "iauS2pv", "vy", status); - vvd(pv[1][2], 0.2568431853930292259e-5, 1e-16, - "iauS2pv", "vz", status); - -} - -static void t_s2xpv(int *status) -/* -** - - - - - - - - -** t _ s 2 x p v -** - - - - - - - - -** -** Test iauS2xpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauS2xpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double s1, s2, pv[2][3], spv[2][3]; - - - s1 = 2.0; - s2 = 3.0; - - pv[0][0] = 0.3; - pv[0][1] = 1.2; - pv[0][2] = -2.5; - - pv[1][0] = 0.5; - pv[1][1] = 2.3; - pv[1][2] = -0.4; - - iauS2xpv(s1, s2, pv, spv); - - vvd(spv[0][0], 0.6, 1e-12, "iauS2xpv", "p1", status); - vvd(spv[0][1], 2.4, 1e-12, "iauS2xpv", "p2", status); - vvd(spv[0][2], -5.0, 1e-12, "iauS2xpv", "p3", status); - - vvd(spv[1][0], 1.5, 1e-12, "iauS2xpv", "v1", status); - vvd(spv[1][1], 6.9, 1e-12, "iauS2xpv", "v2", status); - vvd(spv[1][2], -1.2, 1e-12, "iauS2xpv", "v3", status); - -} - -static void t_sepp(int *status) -/* -** - - - - - - - -** t _ s e p p -** - - - - - - - -** -** Test iauSepp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauSepp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double a[3], b[3], s; - - - a[0] = 1.0; - a[1] = 0.1; - a[2] = 0.2; - - b[0] = -3.0; - b[1] = 1e-3; - b[2] = 0.2; - - s = iauSepp(a, b); - - vvd(s, 2.860391919024660768, 1e-12, "iauSepp", "", status); - -} - -static void t_seps(int *status) -/* -** - - - - - - - -** t _ s e p s -** - - - - - - - -** -** Test iauSeps function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauSeps, vvd -** -** This revision: 2013 August 7 -*/ -{ - double al, ap, bl, bp, s; - - - al = 1.0; - ap = 0.1; - - bl = 0.2; - bp = -3.0; - - s = iauSeps(al, ap, bl, bp); - - vvd(s, 2.346722016996998842, 1e-14, "iauSeps", "", status); - -} - -static void t_sp00(int *status) -/* -** - - - - - - - -** t _ s p 0 0 -** - - - - - - - -** -** Test iauSp00 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauSp00, vvd -** -** This revision: 2013 August 7 -*/ -{ - vvd(iauSp00(2400000.5, 52541.0), - -0.6216698469981019309e-11, 1e-12, "iauSp00", "", status); - -} - -static void t_starpm(int *status) -/* -** - - - - - - - - - -** t _ s t a r p m -** - - - - - - - - - -** -** Test iauStarpm function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauStarpm, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double ra1, dec1, pmr1, pmd1, px1, rv1; - double ra2, dec2, pmr2, pmd2, px2, rv2; - int j; - - - ra1 = 0.01686756; - dec1 = -1.093989828; - pmr1 = -1.78323516e-5; - pmd1 = 2.336024047e-6; - px1 = 0.74723; - rv1 = -21.6; - - j = iauStarpm(ra1, dec1, pmr1, pmd1, px1, rv1, - 2400000.5, 50083.0, 2400000.5, 53736.0, - &ra2, &dec2, &pmr2, &pmd2, &px2, &rv2); - - vvd(ra2, 0.01668919069414242368, 1e-13, - "iauStarpm", "ra", status); - vvd(dec2, -1.093966454217127879, 1e-13, - "iauStarpm", "dec", status); - vvd(pmr2, -0.1783662682155932702e-4, 1e-17, - "iauStarpm", "pmr", status); - vvd(pmd2, 0.2338092915987603664e-5, 1e-17, - "iauStarpm", "pmd", status); - vvd(px2, 0.7473533835323493644, 1e-13, - "iauStarpm", "px", status); - vvd(rv2, -21.59905170476860786, 1e-11, - "iauStarpm", "rv", status); - - viv(j, 0, "iauStarpm", "j", status); - -} - -static void t_starpv(int *status) -/* -** - - - - - - - - - -** t _ s t a r p v -** - - - - - - - - - -** -** Test iauStarpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauStarpv, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double ra, dec, pmr, pmd, px, rv, pv[2][3]; - int j; - - - ra = 0.01686756; - dec = -1.093989828; - pmr = -1.78323516e-5; - pmd = 2.336024047e-6; - px = 0.74723; - rv = -21.6; - - j = iauStarpv(ra, dec, pmr, pmd, px, rv, pv); - - vvd(pv[0][0], 126668.5912743160601, 1e-10, - "iauStarpv", "11", status); - vvd(pv[0][1], 2136.792716839935195, 1e-12, - "iauStarpv", "12", status); - vvd(pv[0][2], -245251.2339876830091, 1e-10, - "iauStarpv", "13", status); - - vvd(pv[1][0], -0.4051854035740712739e-2, 1e-13, - "iauStarpv", "21", status); - vvd(pv[1][1], -0.6253919754866173866e-2, 1e-15, - "iauStarpv", "22", status); - vvd(pv[1][2], 0.1189353719774107189e-1, 1e-13, - "iauStarpv", "23", status); - - viv(j, 0, "iauStarpv", "j", status); - -} - -static void t_sxp(int *status) -/* -** - - - - - - -** t _ s x p -** - - - - - - -** -** Test iauSxp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauSxp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double s, p[3], sp[3]; - - - s = 2.0; - - p[0] = 0.3; - p[1] = 1.2; - p[2] = -2.5; - - iauSxp(s, p, sp); - - vvd(sp[0], 0.6, 0.0, "iauSxp", "1", status); - vvd(sp[1], 2.4, 0.0, "iauSxp", "2", status); - vvd(sp[2], -5.0, 0.0, "iauSxp", "3", status); - -} - - -static void t_sxpv(int *status) -/* -** - - - - - - - -** t _ s x p v -** - - - - - - - -** -** Test iauSxpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauSxpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double s, pv[2][3], spv[2][3]; - - - s = 2.0; - - pv[0][0] = 0.3; - pv[0][1] = 1.2; - pv[0][2] = -2.5; - - pv[1][0] = 0.5; - pv[1][1] = 3.2; - pv[1][2] = -0.7; - - iauSxpv(s, pv, spv); - - vvd(spv[0][0], 0.6, 0.0, "iauSxpv", "p1", status); - vvd(spv[0][1], 2.4, 0.0, "iauSxpv", "p2", status); - vvd(spv[0][2], -5.0, 0.0, "iauSxpv", "p3", status); - - vvd(spv[1][0], 1.0, 0.0, "iauSxpv", "v1", status); - vvd(spv[1][1], 6.4, 0.0, "iauSxpv", "v2", status); - vvd(spv[1][2], -1.4, 0.0, "iauSxpv", "v3", status); - -} - -static void t_taitt(int *status) -/* -** - - - - - - - - -** t _ t a i t t -** - - - - - - - - -** -** Test iauTaitt function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTaitt, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double t1, t2; - int j; - - - j = iauTaitt(2453750.5, 0.892482639, &t1, &t2); - - vvd(t1, 2453750.5, 1e-6, "iauTaitt", "t1", status); - vvd(t2, 0.892855139, 1e-12, "iauTaitt", "t2", status); - viv(j, 0, "iauTaitt", "j", status); - -} - -static void t_taiut1(int *status) -/* -** - - - - - - - - - -** t _ t a i u t 1 -** - - - - - - - - - -** -** Test iauTaiut1 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTaiut1, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double u1, u2; - int j; - - - j = iauTaiut1(2453750.5, 0.892482639, -32.6659, &u1, &u2); - - vvd(u1, 2453750.5, 1e-6, "iauTaiut1", "u1", status); - vvd(u2, 0.8921045614537037037, 1e-12, "iauTaiut1", "u2", status); - viv(j, 0, "iauTaiut1", "j", status); - -} - -static void t_taiutc(int *status) -/* -** - - - - - - - - - -** t _ t a i u t c -** - - - - - - - - - -** -** Test iauTaiutc function. -** -** Returned: -** status LOGICAL TRUE = success, FALSE = fail -** -** Called: iauTaiutc, vvd, viv -** -** This revision: 2013 October 3 -*/ -{ - double u1, u2; - int j; - - - j = iauTaiutc(2453750.5, 0.892482639, &u1, &u2); - - vvd(u1, 2453750.5, 1e-6, "iauTaiutc", "u1", status); - vvd(u2, 0.8921006945555555556, 1e-12, "iauTaiutc", "u2", status); - viv(j, 0, "iauTaiutc", "j", status); - -} - -static void t_tcbtdb(int *status) -/* -** - - - - - - - - - -** t _ t c b t d b -** - - - - - - - - - -** -** Test iauTcbtdb function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTcbtdb, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double b1, b2; - int j; - - - j = iauTcbtdb(2453750.5, 0.893019599, &b1, &b2); - - vvd(b1, 2453750.5, 1e-6, "iauTcbtdb", "b1", status); - vvd(b2, 0.8928551362746343397, 1e-12, "iauTcbtdb", "b2", status); - viv(j, 0, "iauTcbtdb", "j", status); - -} - -static void t_tcgtt(int *status) -/* -** - - - - - - - - -** t _ t c g t t -** - - - - - - - - -** -** Test iauTcgtt function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTcgtt, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double t1, t2; - int j; - - - j = iauTcgtt(2453750.5, 0.892862531, &t1, &t2); - - vvd(t1, 2453750.5, 1e-6, "iauTcgtt", "t1", status); - vvd(t2, 0.8928551387488816828, 1e-12, "iauTcgtt", "t2", status); - viv(j, 0, "iauTcgtt", "j", status); - -} - -static void t_tdbtcb(int *status) -/* -** - - - - - - - - - -** t _ t d b t c b -** - - - - - - - - - -** -** Test iauTdbtcb function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTdbtcb, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double b1, b2; - int j; - - - j = iauTdbtcb(2453750.5, 0.892855137, &b1, &b2); - - vvd( b1, 2453750.5, 1e-6, "iauTdbtcb", "b1", status); - vvd( b2, 0.8930195997253656716, 1e-12, "iauTdbtcb", "b2", status); - viv(j, 0, "iauTdbtcb", "j", status); - -} - -static void t_tdbtt(int *status) -/* -** - - - - - - - - -** t _ t d b t t -** - - - - - - - - -** -** Test iauTdbtt function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTdbtt, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double t1, t2; - int j; - - - j = iauTdbtt(2453750.5, 0.892855137, -0.000201, &t1, &t2); - - vvd(t1, 2453750.5, 1e-6, "iauTdbtt", "t1", status); - vvd(t2, 0.8928551393263888889, 1e-12, "iauTdbtt", "t2", status); - viv(j, 0, "iauTdbtt", "j", status); - -} - -static void t_tf2a(int *status) -/* -** - - - - - - - -** t _ t f 2 a -** - - - - - - - -** -** Test iauTf2a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTf2a, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double a; - int j; - - - j = iauTf2a('+', 4, 58, 20.2, &a); - - vvd(a, 1.301739278189537429, 1e-12, "iauTf2a", "a", status); - viv(j, 0, "iauTf2a", "j", status); - -} - -static void t_tf2d(int *status) -/* -** - - - - - - - -** t _ t f 2 d -** - - - - - - - -** -** Test iauTf2d function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTf2d, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double d; - int j; - - - j = iauTf2d(' ', 23, 55, 10.9, &d); - - vvd(d, 0.9966539351851851852, 1e-12, "iauTf2d", "d", status); - viv(j, 0, "iauTf2d", "j", status); - -} - -static void t_tr(int *status) -/* -** - - - - - -** t _ t r -** - - - - - -** -** Test iauTr function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTr, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3], rt[3][3]; - - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - iauTr(r, rt); - - vvd(rt[0][0], 2.0, 0.0, "iauTr", "11", status); - vvd(rt[0][1], 3.0, 0.0, "iauTr", "12", status); - vvd(rt[0][2], 3.0, 0.0, "iauTr", "13", status); - - vvd(rt[1][0], 3.0, 0.0, "iauTr", "21", status); - vvd(rt[1][1], 2.0, 0.0, "iauTr", "22", status); - vvd(rt[1][2], 4.0, 0.0, "iauTr", "23", status); - - vvd(rt[2][0], 2.0, 0.0, "iauTr", "31", status); - vvd(rt[2][1], 3.0, 0.0, "iauTr", "32", status); - vvd(rt[2][2], 5.0, 0.0, "iauTr", "33", status); - -} - -static void t_trxp(int *status) -/* -** - - - - - - - -** t _ t r x p -** - - - - - - - -** -** Test iauTrxp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTrxp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3], p[3], trp[3]; - - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - p[0] = 0.2; - p[1] = 1.5; - p[2] = 0.1; - - iauTrxp(r, p, trp); - - vvd(trp[0], 5.2, 1e-12, "iauTrxp", "1", status); - vvd(trp[1], 4.0, 1e-12, "iauTrxp", "2", status); - vvd(trp[2], 5.4, 1e-12, "iauTrxp", "3", status); - -} - -static void t_trxpv(int *status) -/* -** - - - - - - - - -** t _ t r x p v -** - - - - - - - - -** -** Test iauTrxpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTrxpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3], pv[2][3], trpv[2][3]; - - - r[0][0] = 2.0; - r[0][1] = 3.0; - r[0][2] = 2.0; - - r[1][0] = 3.0; - r[1][1] = 2.0; - r[1][2] = 3.0; - - r[2][0] = 3.0; - r[2][1] = 4.0; - r[2][2] = 5.0; - - pv[0][0] = 0.2; - pv[0][1] = 1.5; - pv[0][2] = 0.1; - - pv[1][0] = 1.5; - pv[1][1] = 0.2; - pv[1][2] = 0.1; - - iauTrxpv(r, pv, trpv); - - vvd(trpv[0][0], 5.2, 1e-12, "iauTrxpv", "p1", status); - vvd(trpv[0][1], 4.0, 1e-12, "iauTrxpv", "p1", status); - vvd(trpv[0][2], 5.4, 1e-12, "iauTrxpv", "p1", status); - - vvd(trpv[1][0], 3.9, 1e-12, "iauTrxpv", "v1", status); - vvd(trpv[1][1], 5.3, 1e-12, "iauTrxpv", "v2", status); - vvd(trpv[1][2], 4.1, 1e-12, "iauTrxpv", "v3", status); - -} - -static void t_tttai(int *status) -/* -** - - - - - - - - -** t _ t t t a i -** - - - - - - - - -** -** Test iauTttai function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTttai, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double a1, a2; - int j; - - - j = iauTttai(2453750.5, 0.892482639, &a1, &a2); - - vvd(a1, 2453750.5, 1e-6, "iauTttai", "a1", status); - vvd(a2, 0.892110139, 1e-12, "iauTttai", "a2", status); - viv(j, 0, "iauTttai", "j", status); - -} - -static void t_tttcg(int *status) -/* -** - - - - - - - - -** t _ t t t c g -** - - - - - - - - -** -** Test iauTttcg function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTttcg, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double g1, g2; - int j; - - - j = iauTttcg(2453750.5, 0.892482639, &g1, &g2); - - vvd( g1, 2453750.5, 1e-6, "iauTttcg", "g1", status); - vvd( g2, 0.8924900312508587113, 1e-12, "iauTttcg", "g2", status); - viv(j, 0, "iauTttcg", "j", status); - -} - -static void t_tttdb(int *status) -/* -** - - - - - - - - -** t _ t t t d b -** - - - - - - - - -** -** Test iauTttdb function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTttdb, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double b1, b2; - int j; - - - j = iauTttdb(2453750.5, 0.892855139, -0.000201, &b1, &b2); - - vvd(b1, 2453750.5, 1e-6, "iauTttdb", "b1", status); - vvd(b2, 0.8928551366736111111, 1e-12, "iauTttdb", "b2", status); - viv(j, 0, "iauTttdb", "j", status); - -} - -static void t_ttut1(int *status) -/* -** - - - - - - - - -** t _ t t u t 1 -** - - - - - - - - -** -** Test iauTtut1 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauTtut1, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double u1, u2; - int j; - - - j = iauTtut1(2453750.5, 0.892855139, 64.8499, &u1, &u2); - - vvd(u1, 2453750.5, 1e-6, "iauTtut1", "u1", status); - vvd(u2, 0.8921045614537037037, 1e-12, "iauTtut1", "u2", status); - viv(j, 0, "iauTtut1", "j", status); - -} - -static void t_ut1tai(int *status) -/* -** - - - - - - - - - -** t _ u t 1 t a i -** - - - - - - - - - -** -** Test iauUt1tai function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauUt1tai, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double a1, a2; - int j; - - - j = iauUt1tai(2453750.5, 0.892104561, -32.6659, &a1, &a2); - - vvd(a1, 2453750.5, 1e-6, "iauUt1tai", "a1", status); - vvd(a2, 0.8924826385462962963, 1e-12, "iauUt1tai", "a2", status); - viv(j, 0, "iauUt1tai", "j", status); - -} - -static void t_ut1tt(int *status) -/* -** - - - - - - - - -** t _ u t 1 t t -** - - - - - - - - -** -** Test iauUt1tt function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauUt1tt, vvd, viv -** -** This revision: 2013 October 3 -*/ -{ - double t1, t2; - int j; - - - j = iauUt1tt(2453750.5, 0.892104561, 64.8499, &t1, &t2); - - vvd(t1, 2453750.5, 1e-6, "iauUt1tt", "t1", status); - vvd(t2, 0.8928551385462962963, 1e-12, "iauUt1tt", "t2", status); - viv(j, 0, "iauUt1tt", "j", status); - -} - -static void t_ut1utc(int *status) -/* -** - - - - - - - - - -** t _ u t 1 u t c -** - - - - - - - - - -** -** Test iauUt1utc function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauUt1utc, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double u1, u2; - int j; - - - j = iauUt1utc(2453750.5, 0.892104561, 0.3341, &u1, &u2); - - vvd(u1, 2453750.5, 1e-6, "iauUt1utc", "u1", status); - vvd(u2, 0.8921006941018518519, 1e-12, "iauUt1utc", "u2", status); - viv(j, 0, "iauUt1utc", "j", status); - -} - -static void t_utctai(int *status) -/* -** - - - - - - - - - -** t _ u t c t a i -** - - - - - - - - - -** -** Test iauUtctai function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauUtctai, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double u1, u2; - int j; - - - j = iauUtctai(2453750.5, 0.892100694, &u1, &u2); - - vvd(u1, 2453750.5, 1e-6, "iauUtctai", "u1", status); - vvd(u2, 0.8924826384444444444, 1e-12, "iauUtctai", "u2", status); - viv(j, 0, "iauUtctai", "j", status); - -} - -static void t_utcut1(int *status) -/* -** - - - - - - - - - -** t _ u t c u t 1 -** - - - - - - - - - -** -** Test iauUtcut1 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauUtcut1, vvd, viv -** -** This revision: 2013 August 7 -*/ -{ - double u1, u2; - int j; - - - j = iauUtcut1(2453750.5, 0.892100694, 0.3341, &u1, &u2); - - vvd(u1, 2453750.5, 1e-6, "iauUtcut1", "u1", status); - vvd(u2, 0.8921045608981481481, 1e-12, "iauUtcut1", "u2", status); - viv(j, 0, "iauUtcut1", "j", status); - -} - -static void t_xy06(int *status) -/* -** - - - - - - - -** t _ x y 0 6 -** - - - - - - - -** -** Test iauXy06 function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauXy06, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y; - - - iauXy06(2400000.5, 53736.0, &x, &y); - - vvd(x, 0.5791308486706010975e-3, 1e-15, "iauXy06", "x", status); - vvd(y, 0.4020579816732958141e-4, 1e-16, "iauXy06", "y", status); - -} - -static void t_xys00a(int *status) -/* -** - - - - - - - - - -** t _ x y s 0 0 a -** - - - - - - - - - -** -** Test iauXys00a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauXys00a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y, s; - - - iauXys00a(2400000.5, 53736.0, &x, &y, &s); - - vvd(x, 0.5791308472168152904e-3, 1e-14, "iauXys00a", "x", status); - vvd(y, 0.4020595661591500259e-4, 1e-15, "iauXys00a", "y", status); - vvd(s, -0.1220040848471549623e-7, 1e-18, "iauXys00a", "s", status); - -} - -static void t_xys00b(int *status) -/* -** - - - - - - - - - -** t _ x y s 0 0 b -** - - - - - - - - - -** -** Test iauXys00b function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauXys00b, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y, s; - - - iauXys00b(2400000.5, 53736.0, &x, &y, &s); - - vvd(x, 0.5791301929950208873e-3, 1e-14, "iauXys00b", "x", status); - vvd(y, 0.4020553681373720832e-4, 1e-15, "iauXys00b", "y", status); - vvd(s, -0.1220027377285083189e-7, 1e-18, "iauXys00b", "s", status); - -} - -static void t_xys06a(int *status) -/* -** - - - - - - - - - -** t _ x y s 0 6 a -** - - - - - - - - - -** -** Test iauXys06a function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauXys06a, vvd -** -** This revision: 2013 August 7 -*/ -{ - double x, y, s; - - - iauXys06a(2400000.5, 53736.0, &x, &y, &s); - - vvd(x, 0.5791308482835292617e-3, 1e-14, "iauXys06a", "x", status); - vvd(y, 0.4020580099454020310e-4, 1e-15, "iauXys06a", "y", status); - vvd(s, -0.1220032294164579896e-7, 1e-18, "iauXys06a", "s", status); - -} - -static void t_zp(int *status) -/* -** - - - - - -** t _ z p -** - - - - - -** -** Test iauZp function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauZp, vvd -** -** This revision: 2013 August 7 -*/ -{ - double p[3]; - - - p[0] = 0.3; - p[1] = 1.2; - p[2] = -2.5; - - iauZp(p); - - vvd(p[0], 0.0, 0.0, "iauZp", "1", status); - vvd(p[1], 0.0, 0.0, "iauZp", "2", status); - vvd(p[2], 0.0, 0.0, "iauZp", "3", status); - -} - -static void t_zpv(int *status) -/* -** - - - - - - -** t _ z p v -** - - - - - - -** -** Test iauZpv function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauZpv, vvd -** -** This revision: 2013 August 7 -*/ -{ - double pv[2][3]; - - - pv[0][0] = 0.3; - pv[0][1] = 1.2; - pv[0][2] = -2.5; - - pv[1][0] = -0.5; - pv[1][1] = 3.1; - pv[1][2] = 0.9; - - iauZpv(pv); - - vvd(pv[0][0], 0.0, 0.0, "iauZpv", "p1", status); - vvd(pv[0][1], 0.0, 0.0, "iauZpv", "p2", status); - vvd(pv[0][2], 0.0, 0.0, "iauZpv", "p3", status); - - vvd(pv[1][0], 0.0, 0.0, "iauZpv", "v1", status); - vvd(pv[1][1], 0.0, 0.0, "iauZpv", "v2", status); - vvd(pv[1][2], 0.0, 0.0, "iauZpv", "v3", status); - -} - -static void t_zr(int *status) -/* -** - - - - - -** t _ z r -** - - - - - -** -** Test iauZr function. -** -** Returned: -** status int FALSE = success, TRUE = fail -** -** Called: iauZr, vvd -** -** This revision: 2013 August 7 -*/ -{ - double r[3][3]; - - - r[0][0] = 2.0; - r[1][0] = 3.0; - r[2][0] = 2.0; - - r[0][1] = 3.0; - r[1][1] = 2.0; - r[2][1] = 3.0; - - r[0][2] = 3.0; - r[1][2] = 4.0; - r[2][2] = 5.0; - - iauZr(r); - - vvd(r[0][0], 0.0, 0.0, "iauZr", "00", status); - vvd(r[1][0], 0.0, 0.0, "iauZr", "01", status); - vvd(r[2][0], 0.0, 0.0, "iauZr", "02", status); - - vvd(r[0][1], 0.0, 0.0, "iauZr", "10", status); - vvd(r[1][1], 0.0, 0.0, "iauZr", "11", status); - vvd(r[2][1], 0.0, 0.0, "iauZr", "12", status); - - vvd(r[0][2], 0.0, 0.0, "iauZr", "20", status); - vvd(r[1][2], 0.0, 0.0, "iauZr", "21", status); - vvd(r[2][2], 0.0, 0.0, "iauZr", "22", status); - -} - -int main(int argc, char *argv[]) -/* -** - - - - - -** m a i n -** - - - - - -** -** This revision: 2016 March 12 -*/ -{ - int status; - - -/* If any command-line argument, switch to verbose reporting. */ - if (argc > 1) { - verbose = 1; - argv[0][0] += 0; /* to avoid compiler warnings */ - } - -/* Preset the &status to FALSE = success. */ - status = 0; - -/* Test all of the SOFA functions. */ - t_a2af(&status); - t_a2tf(&status); - t_ab(&status); - t_af2a(&status); - t_anp(&status); - t_anpm(&status); - t_apcg(&status); - t_apcg13(&status); - t_apci(&status); - t_apci13(&status); - t_apco(&status); - t_apco13(&status); - t_apcs(&status); - t_apcs13(&status); - t_aper(&status); - t_aper13(&status); - t_apio(&status); - t_apio13(&status); - t_atci13(&status); - t_atciq(&status); - t_atciqn(&status); - t_atciqz(&status); - t_atco13(&status); - t_atic13(&status); - t_aticq(&status); - t_aticqn(&status); - t_atio13(&status); - t_atioq(&status); - t_atoc13(&status); - t_atoi13(&status); - t_atoiq(&status); - t_bi00(&status); - t_bp00(&status); - t_bp06(&status); - t_bpn2xy(&status); - t_c2i00a(&status); - t_c2i00b(&status); - t_c2i06a(&status); - t_c2ibpn(&status); - t_c2ixy(&status); - t_c2ixys(&status); - t_c2s(&status); - t_c2t00a(&status); - t_c2t00b(&status); - t_c2t06a(&status); - t_c2tcio(&status); - t_c2teqx(&status); - t_c2tpe(&status); - t_c2txy(&status); - t_cal2jd(&status); - t_cp(&status); - t_cpv(&status); - t_cr(&status); - t_d2dtf(&status); - t_d2tf(&status); - t_dat(&status); - t_dtdb(&status); - t_dtf2d(&status); - t_eceq06(&status); - t_ecm06(&status); - t_ee00(&status); - t_ee00a(&status); - t_ee00b(&status); - t_ee06a(&status); - t_eect00(&status); - t_eform(&status); - t_eo06a(&status); - t_eors(&status); - t_epb(&status); - t_epb2jd(&status); - t_epj(&status); - t_epj2jd(&status); - t_epv00(&status); - t_eqec06(&status); - t_eqeq94(&status); - t_era00(&status); - t_fad03(&status); - t_fae03(&status); - t_faf03(&status); - t_faju03(&status); - t_fal03(&status); - t_falp03(&status); - t_fama03(&status); - t_fame03(&status); - t_fane03(&status); - t_faom03(&status); - t_fapa03(&status); - t_fasa03(&status); - t_faur03(&status); - t_fave03(&status); - t_fk52h(&status); - t_fk5hip(&status); - t_fk5hz(&status); - t_fw2m(&status); - t_fw2xy(&status); - t_g2icrs(&status); - t_gc2gd(&status); - t_gc2gde(&status); - t_gd2gc(&status); - t_gd2gce(&status); - t_gmst00(&status); - t_gmst06(&status); - t_gmst82(&status); - t_gst00a(&status); - t_gst00b(&status); - t_gst06(&status); - t_gst06a(&status); - t_gst94(&status); - t_h2fk5(&status); - t_hfk5z(&status); - t_icrs2g(&status); - t_ir(&status); - t_jd2cal(&status); - t_jdcalf(&status); - t_ld(&status); - t_ldn(&status); - t_ldsun(&status); - t_lteceq(&status); - t_ltecm(&status); - t_lteqec(&status); - t_ltp(&status); - t_ltpb(&status); - t_ltpecl(&status); - t_ltpequ(&status); - t_num00a(&status); - t_num00b(&status); - t_num06a(&status); - t_numat(&status); - t_nut00a(&status); - t_nut00b(&status); - t_nut06a(&status); - t_nut80(&status); - t_nutm80(&status); - t_obl06(&status); - t_obl80(&status); - t_p06e(&status); - t_p2pv(&status); - t_p2s(&status); - t_pap(&status); - t_pas(&status); - t_pb06(&status); - t_pdp(&status); - t_pfw06(&status); - t_plan94(&status); - t_pmat00(&status); - t_pmat06(&status); - t_pmat76(&status); - t_pm(&status); - t_pmp(&status); - t_pmpx(&status); - t_pmsafe(&status); - t_pn(&status); - t_pn00(&status); - t_pn00a(&status); - t_pn00b(&status); - t_pn06a(&status); - t_pn06(&status); - t_pnm00a(&status); - t_pnm00b(&status); - t_pnm06a(&status); - t_pnm80(&status); - t_pom00(&status); - t_ppp(&status); - t_ppsp(&status); - t_pr00(&status); - t_prec76(&status); - t_pv2p(&status); - t_pv2s(&status); - t_pvdpv(&status); - t_pvm(&status); - t_pvmpv(&status); - t_pvppv(&status); - t_pvstar(&status); - t_pvtob(&status); - t_pvu(&status); - t_pvup(&status); - t_pvxpv(&status); - t_pxp(&status); - t_refco(&status); - t_rm2v(&status); - t_rv2m(&status); - t_rx(&status); - t_rxp(&status); - t_rxpv(&status); - t_rxr(&status); - t_ry(&status); - t_rz(&status); - t_s00a(&status); - t_s00b(&status); - t_s00(&status); - t_s06a(&status); - t_s06(&status); - t_s2c(&status); - t_s2p(&status); - t_s2pv(&status); - t_s2xpv(&status); - t_sepp(&status); - t_seps(&status); - t_sp00(&status); - t_starpm(&status); - t_starpv(&status); - t_sxp(&status); - t_sxpv(&status); - t_taitt(&status); - t_taiut1(&status); - t_taiutc(&status); - t_tcbtdb(&status); - t_tcgtt(&status); - t_tdbtcb(&status); - t_tdbtt(&status); - t_tf2a(&status); - t_tf2d(&status); - t_tr(&status); - t_trxp(&status); - t_trxpv(&status); - t_tttai(&status); - t_tttcg(&status); - t_tttdb(&status); - t_ttut1(&status); - t_ut1tai(&status); - t_ut1tt(&status) ; - t_ut1utc(&status); - t_utctai(&status); - t_utcut1(&status); - t_xy06(&status); - t_xys00a(&status); - t_xys00b(&status); - t_xys06a(&status); - t_zp(&status); - t_zpv(&status); - t_zr(&status); - -/* Report, set up an appropriate exit status, and finish. */ - if (status) { - printf("t_sofa_c validation failed!\n"); - } else { - printf("t_sofa_c validation successful\n"); - } - return status; - -/*---------------------------------------------------------------------- -** -** Copyright (C) 2016 -** Standards Of Fundamental Astronomy Board -** of the International Astronomical Union. -** -** ===================== -** SOFA Software License -** ===================== -** -** NOTICE TO USER: -** -** BY USING THIS SOFTWARE YOU ACCEPT THE FOLLOWING SIX TERMS AND -** CONDITIONS WHICH APPLY TO ITS USE. -** -** 1. The Software is owned by the IAU SOFA Board ("SOFA"). -** -** 2. Permission is granted to anyone to use the SOFA software for any -** purpose, including commercial applications, free of charge and -** without payment of royalties, subject to the conditions and -** restrictions listed below. -** -** 3. You (the user) may copy and distribute SOFA source code to others, -** and use and adapt its code and algorithms in your own software, -** on a world-wide, royalty-free basis. That portion of your -** distribution that does not consist of intact and unchanged copies -** of SOFA source code files is a "derived work" that must comply -** with the following requirements: -** -** a) Your work shall be marked or carry a statement that it -** (i) uses routines and computations derived by you from -** software provided by SOFA under license to you; and -** (ii) does not itself constitute software provided by and/or -** endorsed by SOFA. -** -** b) The source code of your derived work must contain descriptions -** of how the derived work is based upon, contains and/or differs -** from the original SOFA software. -** -** c) The names of all routines in your derived work shall not -** include the prefix "iau" or "sofa" or trivial modifications -** thereof such as changes of case. -** -** d) The origin of the SOFA components of your derived work must -** not be misrepresented; you must not claim that you wrote the -** original software, nor file a patent application for SOFA -** software or algorithms embedded in the SOFA software. -** -** e) These requirements must be reproduced intact in any source -** distribution and shall apply to anyone to whom you have -** granted a further right to modify the source code of your -** derived work. -** -** Note that, as originally distributed, the SOFA software is -** intended to be a definitive implementation of the IAU standards, -** and consequently third-party modifications are discouraged. All -** variations, no matter how minor, must be explicitly marked as -** such, as explained above. -** -** 4. You shall not cause the SOFA software to be brought into -** disrepute, either by misuse, or use for inappropriate tasks, or -** by inappropriate modification. -** -** 5. The SOFA software is provided "as is" and SOFA makes no warranty -** as to its use or performance. SOFA does not and cannot warrant -** the performance or results which the user may obtain by using the -** SOFA software. SOFA makes no warranties, express or implied, as -** to non-infringement of third party rights, merchantability, or -** fitness for any particular purpose. In no event will SOFA be -** liable to the user for any consequential, incidental, or special -** damages, including any lost profits or lost savings, even if a -** SOFA representative has been advised of such damages, or for any -** claim by any third party. -** -** 6. The provision of any version of the SOFA software under the terms -** and conditions specified herein does not imply that future -** versions will also be made available under the same terms and -** conditions. -* -** In any published work or commercial product which uses the SOFA -** software directly, acknowledgement (see www.iausofa.org) is -** appreciated. -** -** Correspondence concerning SOFA software should be addressed as -** follows: -** -** By email: sofa@ukho.gov.uk -** By post: IAU SOFA Center -** HM Nautical Almanac Office -** UK Hydrographic Office -** Admiralty Way, Taunton -** Somerset, TA1 2DN -** United Kingdom -** -**--------------------------------------------------------------------*/ -} +#include +#include + +static int verbose = 0; + +/* +** - - - - - - - - - +** t _ s o f a _ c +** - - - - - - - - - +** +** Validate the SOFA C functions. +** +** Each SOFA function is at least called and a usually quite basic test +** is performed. Successful completion is signalled by a confirming +** message. Failure of a given function or group of functions results +** in error messages. +** +** All messages go to stdout. +** +** This revision: 2017 March 15 +** +** SOFA release 2017-04-20 +** +** Copyright (C) 2017 IAU SOFA Board. See notes at end. +*/ + +static void viv(int ival, int ivalok, + const char *func, const char *test, int *status) +/* +** - - - - +** v i v +** - - - - +** +** Validate an integer result. +** +** Internal function used by t_sofa_c program. +** +** Given: +** ival int value computed by function under test +** ivalok int correct value +** func char[] name of function under test +** test char[] name of individual test +** +** Given and returned: +** status int set to TRUE if test fails +** +** This revision: 2013 August 7 +*/ +{ + if (ival != ivalok) { + *status = 1; + printf("%s failed: %s want %d got %d\n", + func, test, ivalok, ival); + } else if (verbose) { + printf("%s passed: %s want %d got %d\n", + func, test, ivalok, ival); + } + +} + +static void vvd(double val, double valok, double dval, + const char *func, const char *test, int *status) +/* +** - - - - +** v v d +** - - - - +** +** Validate a double result. +** +** Internal function used by t_sofa_c program. +** +** Given: +** val double value computed by function under test +** valok double expected value +** dval double maximum allowable error +** func char[] name of function under test +** test char[] name of individual test +** +** Given and returned: +** status int set to TRUE if test fails +** +** This revision: 2016 April 21 +*/ +{ + double a, f; /* absolute and fractional error */ + + + a = val - valok; + if (a != 0.0 && fabs(a) > fabs(dval)) { + f = fabs(valok / a); + *status = 1; + printf("%s failed: %s want %.20g got %.20g (1/%.3g)\n", + func, test, valok, val, f); + } else if (verbose) { + printf("%s passed: %s want %.20g got %.20g\n", + func, test, valok, val); + } + +} + +static void t_a2af(int *status) +/* +** - - - - - - - +** t _ a 2 a f +** - - - - - - - +** +** Test iauA2af function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauA2af, viv +** +** This revision: 2013 August 7 +*/ +{ + int idmsf[4]; + char s; + + + iauA2af(4, 2.345, &s, idmsf); + + viv(s, '+', "iauA2af", "s", status); + + viv(idmsf[0], 134, "iauA2af", "0", status); + viv(idmsf[1], 21, "iauA2af", "1", status); + viv(idmsf[2], 30, "iauA2af", "2", status); + viv(idmsf[3], 9706, "iauA2af", "3", status); + +} + +static void t_a2tf(int *status) +/* +** - - - - - - - +** t _ a 2 t f +** - - - - - - - +** +** Test iauA2tf function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauA2tf, viv +** +** This revision: 2013 August 7 +*/ +{ + int ihmsf[4]; + char s; + + + iauA2tf(4, -3.01234, &s, ihmsf); + + viv((int)s, '-', "iauA2tf", "s", status); + + viv(ihmsf[0], 11, "iauA2tf", "0", status); + viv(ihmsf[1], 30, "iauA2tf", "1", status); + viv(ihmsf[2], 22, "iauA2tf", "2", status); + viv(ihmsf[3], 6484, "iauA2tf", "3", status); + +} + +static void t_ab(int *status) +/* +** - - - - - +** t _ a b +** - - - - - +** +** Test iauAb function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAb, vvd +** +** This revision: 2013 October 1 +*/ +{ + double pnat[3], v[3], s, bm1, ppr[3]; + + + pnat[0] = -0.76321968546737951; + pnat[1] = -0.60869453983060384; + pnat[2] = -0.21676408580639883; + v[0] = 2.1044018893653786e-5; + v[1] = -8.9108923304429319e-5; + v[2] = -3.8633714797716569e-5; + s = 0.99980921395708788; + bm1 = 0.99999999506209258; + + iauAb(pnat, v, s, bm1, ppr); + + vvd(ppr[0], -0.7631631094219556269, 1e-12, "iauAb", "1", status); + vvd(ppr[1], -0.6087553082505590832, 1e-12, "iauAb", "2", status); + vvd(ppr[2], -0.2167926269368471279, 1e-12, "iauAb", "3", status); + +} + +static void t_af2a(int *status) +/* +** - - - - - - - +** t _ a f 2 a +** - - - - - - - +** +** Test iauAf2a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAf2a, viv +** +** This revision: 2013 August 7 +*/ +{ + double a; + int j; + + + j = iauAf2a('-', 45, 13, 27.2, &a); + + vvd(a, -0.7893115794313644842, 1e-12, "iauAf2a", "a", status); + viv(j, 0, "iauAf2a", "j", status); + +} + +static void t_anp(int *status) +/* +** - - - - - - +** t _ a n p +** - - - - - - +** +** Test iauAnp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAnp, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauAnp(-0.1), 6.183185307179586477, 1e-12, "iauAnp", "", status); +} + +static void t_anpm(int *status) +/* +** - - - - - - - +** t _ a n p m +** - - - - - - - +** +** Test iauAnpm function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAnpm, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauAnpm(-4.0), 2.283185307179586477, 1e-12, "iauAnpm", "", status); +} + +static void t_apcg(int *status) +/* +** - - - - - - - +** t _ a p c g +** - - - - - - - +** +** Test iauApcg function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApcg, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, ebpv[2][3], ehp[3]; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + ebpv[0][0] = 0.901310875; + ebpv[0][1] = -0.417402664; + ebpv[0][2] = -0.180982288; + ebpv[1][0] = 0.00742727954; + ebpv[1][1] = 0.0140507459; + ebpv[1][2] = 0.00609045792; + ehp[0] = 0.903358544; + ehp[1] = -0.415395237; + ehp[2] = -0.180084014; + + iauApcg(date1, date2, ebpv, ehp, &astrom); + + vvd(astrom.pmt, 12.65133794027378508, 1e-11, + "iauApcg", "pmt", status); + vvd(astrom.eb[0], 0.901310875, 1e-12, + "iauApcg", "eb(1)", status); + vvd(astrom.eb[1], -0.417402664, 1e-12, + "iauApcg", "eb(2)", status); + vvd(astrom.eb[2], -0.180982288, 1e-12, + "iauApcg", "eb(3)", status); + vvd(astrom.eh[0], 0.8940025429324143045, 1e-12, + "iauApcg", "eh(1)", status); + vvd(astrom.eh[1], -0.4110930268679817955, 1e-12, + "iauApcg", "eh(2)", status); + vvd(astrom.eh[2], -0.1782189004872870264, 1e-12, + "iauApcg", "eh(3)", status); + vvd(astrom.em, 1.010465295811013146, 1e-12, + "iauApcg", "em", status); + vvd(astrom.v[0], 0.4289638913597693554e-4, 1e-16, + "iauApcg", "v(1)", status); + vvd(astrom.v[1], 0.8115034051581320575e-4, 1e-16, + "iauApcg", "v(2)", status); + vvd(astrom.v[2], 0.3517555136380563427e-4, 1e-16, + "iauApcg", "v(3)", status); + vvd(astrom.bm1, 0.9999999951686012981, 1e-12, + "iauApcg", "bm1", status); + vvd(astrom.bpn[0][0], 1.0, 0.0, + "iauApcg", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0.0, 0.0, + "iauApcg", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0.0, 0.0, + "iauApcg", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], 0.0, 0.0, + "iauApcg", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 1.0, 0.0, + "iauApcg", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], 0.0, 0.0, + "iauApcg", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], 0.0, 0.0, + "iauApcg", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0.0, 0.0, + "iauApcg", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 1.0, 0.0, + "iauApcg", "bpn(3,3)", status); + +} + +static void t_apcg13(int *status) +/* +** - - - - - - - - - +** t _ a p c g 1 3 +** - - - - - - - - - +** +** Test iauApcg13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApcg13, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + + iauApcg13(date1, date2, &astrom); + + vvd(astrom.pmt, 12.65133794027378508, 1e-11, + "iauApcg13", "pmt", status); + vvd(astrom.eb[0], 0.9013108747340644755, 1e-12, + "iauApcg13", "eb(1)", status); + vvd(astrom.eb[1], -0.4174026640406119957, 1e-12, + "iauApcg13", "eb(2)", status); + vvd(astrom.eb[2], -0.1809822877867817771, 1e-12, + "iauApcg13", "eb(3)", status); + vvd(astrom.eh[0], 0.8940025429255499549, 1e-12, + "iauApcg13", "eh(1)", status); + vvd(astrom.eh[1], -0.4110930268331896318, 1e-12, + "iauApcg13", "eh(2)", status); + vvd(astrom.eh[2], -0.1782189006019749850, 1e-12, + "iauApcg13", "eh(3)", status); + vvd(astrom.em, 1.010465295964664178, 1e-12, + "iauApcg13", "em", status); + vvd(astrom.v[0], 0.4289638912941341125e-4, 1e-16, + "iauApcg13", "v(1)", status); + vvd(astrom.v[1], 0.8115034032405042132e-4, 1e-16, + "iauApcg13", "v(2)", status); + vvd(astrom.v[2], 0.3517555135536470279e-4, 1e-16, + "iauApcg13", "v(3)", status); + vvd(astrom.bm1, 0.9999999951686013142, 1e-12, + "iauApcg13", "bm1", status); + vvd(astrom.bpn[0][0], 1.0, 0.0, + "iauApcg13", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0.0, 0.0, + "iauApcg13", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0.0, 0.0, + "iauApcg13", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], 0.0, 0.0, + "iauApcg13", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 1.0, 0.0, + "iauApcg13", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], 0.0, 0.0, + "iauApcg13", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], 0.0, 0.0, + "iauApcg13", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0.0, 0.0, + "iauApcg13", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 1.0, 0.0, + "iauApcg13", "bpn(3,3)", status); + +} + +static void t_apci(int *status) +/* +** - - - - - - - +** t _ a p c i +** - - - - - - - +** +** Test iauApci function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApci, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, ebpv[2][3], ehp[3], x, y, s; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + ebpv[0][0] = 0.901310875; + ebpv[0][1] = -0.417402664; + ebpv[0][2] = -0.180982288; + ebpv[1][0] = 0.00742727954; + ebpv[1][1] = 0.0140507459; + ebpv[1][2] = 0.00609045792; + ehp[0] = 0.903358544; + ehp[1] = -0.415395237; + ehp[2] = -0.180084014; + x = 0.0013122272; + y = -2.92808623e-5; + s = 3.05749468e-8; + + iauApci(date1, date2, ebpv, ehp, x, y, s, &astrom); + + vvd(astrom.pmt, 12.65133794027378508, 1e-11, + "iauApci", "pmt", status); + vvd(astrom.eb[0], 0.901310875, 1e-12, + "iauApci", "eb(1)", status); + vvd(astrom.eb[1], -0.417402664, 1e-12, + "iauApci", "eb(2)", status); + vvd(astrom.eb[2], -0.180982288, 1e-12, + "iauApci", "eb(3)", status); + vvd(astrom.eh[0], 0.8940025429324143045, 1e-12, + "iauApci", "eh(1)", status); + vvd(astrom.eh[1], -0.4110930268679817955, 1e-12, + "iauApci", "eh(2)", status); + vvd(astrom.eh[2], -0.1782189004872870264, 1e-12, + "iauApci", "eh(3)", status); + vvd(astrom.em, 1.010465295811013146, 1e-12, + "iauApci", "em", status); + vvd(astrom.v[0], 0.4289638913597693554e-4, 1e-16, + "iauApci", "v(1)", status); + vvd(astrom.v[1], 0.8115034051581320575e-4, 1e-16, + "iauApci", "v(2)", status); + vvd(astrom.v[2], 0.3517555136380563427e-4, 1e-16, + "iauApci", "v(3)", status); + vvd(astrom.bm1, 0.9999999951686012981, 1e-12, + "iauApci", "bm1", status); + vvd(astrom.bpn[0][0], 0.9999991390295159156, 1e-12, + "iauApci", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0.4978650072505016932e-7, 1e-12, + "iauApci", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0.1312227200000000000e-2, 1e-12, + "iauApci", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], -0.1136336653771609630e-7, 1e-12, + "iauApci", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 0.9999999995713154868, 1e-12, + "iauApci", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], -0.2928086230000000000e-4, 1e-12, + "iauApci", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], -0.1312227200895260194e-2, 1e-12, + "iauApci", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0.2928082217872315680e-4, 1e-12, + "iauApci", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 0.9999991386008323373, 1e-12, + "iauApci", "bpn(3,3)", status); + +} + +static void t_apci13(int *status) +/* +** - - - - - - - - - +** t _ a p c i 1 3 +** - - - - - - - - - +** +** Test iauApci13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApci13, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, eo; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + + iauApci13(date1, date2, &astrom, &eo); + + vvd(astrom.pmt, 12.65133794027378508, 1e-11, + "iauApci13", "pmt", status); + vvd(astrom.eb[0], 0.9013108747340644755, 1e-12, + "iauApci13", "eb(1)", status); + vvd(astrom.eb[1], -0.4174026640406119957, 1e-12, + "iauApci13", "eb(2)", status); + vvd(astrom.eb[2], -0.1809822877867817771, 1e-12, + "iauApci13", "eb(3)", status); + vvd(astrom.eh[0], 0.8940025429255499549, 1e-12, + "iauApci13", "eh(1)", status); + vvd(astrom.eh[1], -0.4110930268331896318, 1e-12, + "iauApci13", "eh(2)", status); + vvd(astrom.eh[2], -0.1782189006019749850, 1e-12, + "iauApci13", "eh(3)", status); + vvd(astrom.em, 1.010465295964664178, 1e-12, + "iauApci13", "em", status); + vvd(astrom.v[0], 0.4289638912941341125e-4, 1e-16, + "iauApci13", "v(1)", status); + vvd(astrom.v[1], 0.8115034032405042132e-4, 1e-16, + "iauApci13", "v(2)", status); + vvd(astrom.v[2], 0.3517555135536470279e-4, 1e-16, + "iauApci13", "v(3)", status); + vvd(astrom.bm1, 0.9999999951686013142, 1e-12, + "iauApci13", "bm1", status); + vvd(astrom.bpn[0][0], 0.9999992060376761710, 1e-12, + "iauApci13", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0.4124244860106037157e-7, 1e-12, + "iauApci13", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0.1260128571051709670e-2, 1e-12, + "iauApci13", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], -0.1282291987222130690e-7, 1e-12, + "iauApci13", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 0.9999999997456835325, 1e-12, + "iauApci13", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], -0.2255288829420524935e-4, 1e-12, + "iauApci13", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], -0.1260128571661374559e-2, 1e-12, + "iauApci13", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0.2255285422953395494e-4, 1e-12, + "iauApci13", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 0.9999992057833604343, 1e-12, + "iauApci13", "bpn(3,3)", status); + vvd(eo, -0.2900618712657375647e-2, 1e-12, + "iauApci13", "eo", status); + +} + +static void t_apco(int *status) +/* +** - - - - - - - +** t _ a p c o +** - - - - - - - +** +** Test iauApco function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApco, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, ebpv[2][3], ehp[3], x, y, s, + theta, elong, phi, hm, xp, yp, sp, refa, refb; + iauASTROM astrom; + + + date1 = 2456384.5; + date2 = 0.970031644; + ebpv[0][0] = -0.974170438; + ebpv[0][1] = -0.211520082; + ebpv[0][2] = -0.0917583024; + ebpv[1][0] = 0.00364365824; + ebpv[1][1] = -0.0154287319; + ebpv[1][2] = -0.00668922024; + ehp[0] = -0.973458265; + ehp[1] = -0.209215307; + ehp[2] = -0.0906996477; + x = 0.0013122272; + y = -2.92808623e-5; + s = 3.05749468e-8; + theta = 3.14540971; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + sp = -3.01974337e-11; + refa = 0.000201418779; + refb = -2.36140831e-7; + + iauApco(date1, date2, ebpv, ehp, x, y, s, + theta, elong, phi, hm, xp, yp, sp, + refa, refb, &astrom); + + vvd(astrom.pmt, 13.25248468622587269, 1e-11, + "iauApco", "pmt", status); + vvd(astrom.eb[0], -0.9741827110630322720, 1e-12, + "iauApco", "eb(1)", status); + vvd(astrom.eb[1], -0.2115130190135344832, 1e-12, + "iauApco", "eb(2)", status); + vvd(astrom.eb[2], -0.09179840186949532298, 1e-12, + "iauApco", "eb(3)", status); + vvd(astrom.eh[0], -0.9736425571689739035, 1e-12, + "iauApco", "eh(1)", status); + vvd(astrom.eh[1], -0.2092452125849330936, 1e-12, + "iauApco", "eh(2)", status); + vvd(astrom.eh[2], -0.09075578152243272599, 1e-12, + "iauApco", "eh(3)", status); + vvd(astrom.em, 0.9998233241709957653, 1e-12, + "iauApco", "em", status); + vvd(astrom.v[0], 0.2078704992916728762e-4, 1e-16, + "iauApco", "v(1)", status); + vvd(astrom.v[1], -0.8955360107151952319e-4, 1e-16, + "iauApco", "v(2)", status); + vvd(astrom.v[2], -0.3863338994288951082e-4, 1e-16, + "iauApco", "v(3)", status); + vvd(astrom.bm1, 0.9999999950277561236, 1e-12, + "iauApco", "bm1", status); + vvd(astrom.bpn[0][0], 0.9999991390295159156, 1e-12, + "iauApco", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0.4978650072505016932e-7, 1e-12, + "iauApco", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0.1312227200000000000e-2, 1e-12, + "iauApco", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], -0.1136336653771609630e-7, 1e-12, + "iauApco", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 0.9999999995713154868, 1e-12, + "iauApco", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], -0.2928086230000000000e-4, 1e-12, + "iauApco", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], -0.1312227200895260194e-2, 1e-12, + "iauApco", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0.2928082217872315680e-4, 1e-12, + "iauApco", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 0.9999991386008323373, 1e-12, + "iauApco", "bpn(3,3)", status); + vvd(astrom.along, -0.5278008060301974337, 1e-12, + "iauApco", "along", status); + vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, + "iauApco", "xpl", status); + vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, + "iauApco", "ypl", status); + vvd(astrom.sphi, -0.9440115679003211329, 1e-12, + "iauApco", "sphi", status); + vvd(astrom.cphi, 0.3299123514971474711, 1e-12, + "iauApco", "cphi", status); + vvd(astrom.diurab, 0, 0, + "iauApco", "diurab", status); + vvd(astrom.eral, 2.617608903969802566, 1e-12, + "iauApco", "eral", status); + vvd(astrom.refa, 0.2014187790000000000e-3, 1e-15, + "iauApco", "refa", status); + vvd(astrom.refb, -0.2361408310000000000e-6, 1e-18, + "iauApco", "refb", status); + +} + +static void t_apco13(int *status) +/* +** - - - - - - - - - +** t _ a p c o 1 3 +** - - - - - - - - - +** +** Test iauApco13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApco13, vvd, viv +** +** This revision: 2017 March 15 +*/ +{ + double utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, eo; + iauASTROM astrom; + int j; + + + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + + j = iauApco13(utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, &astrom, &eo); + + vvd(astrom.pmt, 13.25248468622475727, 1e-11, + "iauApco13", "pmt", status); + vvd(astrom.eb[0], -0.9741827107320875162, 1e-12, + "iauApco13", "eb(1)", status); + vvd(astrom.eb[1], -0.2115130190489716682, 1e-12, + "iauApco13", "eb(2)", status); + vvd(astrom.eb[2], -0.09179840189496755339, 1e-12, + "iauApco13", "eb(3)", status); + vvd(astrom.eh[0], -0.9736425572586935247, 1e-12, + "iauApco13", "eh(1)", status); + vvd(astrom.eh[1], -0.2092452121603336166, 1e-12, + "iauApco13", "eh(2)", status); + vvd(astrom.eh[2], -0.09075578153885665295, 1e-12, + "iauApco13", "eh(3)", status); + vvd(astrom.em, 0.9998233240913898141, 1e-12, + "iauApco13", "em", status); + vvd(astrom.v[0], 0.2078704994520489246e-4, 1e-16, + "iauApco13", "v(1)", status); + vvd(astrom.v[1], -0.8955360133238868938e-4, 1e-16, + "iauApco13", "v(2)", status); + vvd(astrom.v[2], -0.3863338993055887398e-4, 1e-16, + "iauApco13", "v(3)", status); + vvd(astrom.bm1, 0.9999999950277561004, 1e-12, + "iauApco13", "bm1", status); + vvd(astrom.bpn[0][0], 0.9999991390295147999, 1e-12, + "iauApco13", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0.4978650075315529277e-7, 1e-12, + "iauApco13", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0.001312227200850293372, 1e-12, + "iauApco13", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], -0.1136336652812486604e-7, 1e-12, + "iauApco13", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 0.9999999995713154865, 1e-12, + "iauApco13", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], -0.2928086230975367296e-4, 1e-12, + "iauApco13", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], -0.001312227201745553566, 1e-12, + "iauApco13", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0.2928082218847679162e-4, 1e-12, + "iauApco13", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 0.9999991386008312212, 1e-12, + "iauApco13", "bpn(3,3)", status); + vvd(astrom.along, -0.5278008060301974337, 1e-12, + "iauApco13", "along", status); + vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, + "iauApco13", "xpl", status); + vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, + "iauApco13", "ypl", status); + vvd(astrom.sphi, -0.9440115679003211329, 1e-12, + "iauApco13", "sphi", status); + vvd(astrom.cphi, 0.3299123514971474711, 1e-12, + "iauApco13", "cphi", status); + vvd(astrom.diurab, 0, 0, + "iauApco13", "diurab", status); + vvd(astrom.eral, 2.617608909189066140, 1e-12, + "iauApco13", "eral", status); + vvd(astrom.refa, 0.2014187785940396921e-3, 1e-15, + "iauApco13", "refa", status); + vvd(astrom.refb, -0.2361408314943696227e-6, 1e-18, + "iauApco13", "refb", status); + vvd(eo, -0.003020548354802412839, 1e-14, + "iauApco13", "eo", status); + viv(j, 0, "iauApco13", "j", status); + +} + +static void t_apcs(int *status) +/* +** - - - - - - - +** t _ a p c s +** - - - - - - - +** +** Test iauApcs function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApcs, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, pv[2][3], ebpv[2][3], ehp[3]; + iauASTROM astrom; + + + date1 = 2456384.5; + date2 = 0.970031644; + pv[0][0] = -1836024.09; + pv[0][1] = 1056607.72; + pv[0][2] = -5998795.26; + pv[1][0] = -77.0361767; + pv[1][1] = -133.310856; + pv[1][2] = 0.0971855934; + ebpv[0][0] = -0.974170438; + ebpv[0][1] = -0.211520082; + ebpv[0][2] = -0.0917583024; + ebpv[1][0] = 0.00364365824; + ebpv[1][1] = -0.0154287319; + ebpv[1][2] = -0.00668922024; + ehp[0] = -0.973458265; + ehp[1] = -0.209215307; + ehp[2] = -0.0906996477; + + iauApcs(date1, date2, pv, ebpv, ehp, &astrom); + + vvd(astrom.pmt, 13.25248468622587269, 1e-11, + "iauApcs", "pmt", status); + vvd(astrom.eb[0], -0.9741827110629881886, 1e-12, + "iauApcs", "eb(1)", status); + vvd(astrom.eb[1], -0.2115130190136415986, 1e-12, + "iauApcs", "eb(2)", status); + vvd(astrom.eb[2], -0.09179840186954412099, 1e-12, + "iauApcs", "eb(3)", status); + vvd(astrom.eh[0], -0.9736425571689454706, 1e-12, + "iauApcs", "eh(1)", status); + vvd(astrom.eh[1], -0.2092452125850435930, 1e-12, + "iauApcs", "eh(2)", status); + vvd(astrom.eh[2], -0.09075578152248299218, 1e-12, + "iauApcs", "eh(3)", status); + vvd(astrom.em, 0.9998233241709796859, 1e-12, + "iauApcs", "em", status); + vvd(astrom.v[0], 0.2078704993282685510e-4, 1e-16, + "iauApcs", "v(1)", status); + vvd(astrom.v[1], -0.8955360106989405683e-4, 1e-16, + "iauApcs", "v(2)", status); + vvd(astrom.v[2], -0.3863338994289409097e-4, 1e-16, + "iauApcs", "v(3)", status); + vvd(astrom.bm1, 0.9999999950277561237, 1e-12, + "iauApcs", "bm1", status); + vvd(astrom.bpn[0][0], 1, 0, + "iauApcs", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0, 0, + "iauApcs", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0, 0, + "iauApcs", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], 0, 0, + "iauApcs", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 1, 0, + "iauApcs", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], 0, 0, + "iauApcs", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], 0, 0, + "iauApcs", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0, 0, + "iauApcs", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 1, 0, + "iauApcs", "bpn(3,3)", status); + +} + +static void t_apcs13(int *status) +/* +** - - - - - - - - - +** t _ a p c s 1 3 +** - - - - - - - - - +** +** Test iauApcs13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApcs13, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, pv[2][3]; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + pv[0][0] = -6241497.16; + pv[0][1] = 401346.896; + pv[0][2] = -1251136.04; + pv[1][0] = -29.264597; + pv[1][1] = -455.021831; + pv[1][2] = 0.0266151194; + + iauApcs13(date1, date2, pv, &astrom); + + vvd(astrom.pmt, 12.65133794027378508, 1e-11, + "iauApcs13", "pmt", status); + vvd(astrom.eb[0], 0.9012691529025250644, 1e-12, + "iauApcs13", "eb(1)", status); + vvd(astrom.eb[1], -0.4173999812023194317, 1e-12, + "iauApcs13", "eb(2)", status); + vvd(astrom.eb[2], -0.1809906511146429670, 1e-12, + "iauApcs13", "eb(3)", status); + vvd(astrom.eh[0], 0.8939939101760130792, 1e-12, + "iauApcs13", "eh(1)", status); + vvd(astrom.eh[1], -0.4111053891734021478, 1e-12, + "iauApcs13", "eh(2)", status); + vvd(astrom.eh[2], -0.1782336880636997374, 1e-12, + "iauApcs13", "eh(3)", status); + vvd(astrom.em, 1.010428384373491095, 1e-12, + "iauApcs13", "em", status); + vvd(astrom.v[0], 0.4279877294121697570e-4, 1e-16, + "iauApcs13", "v(1)", status); + vvd(astrom.v[1], 0.7963255087052120678e-4, 1e-16, + "iauApcs13", "v(2)", status); + vvd(astrom.v[2], 0.3517564013384691531e-4, 1e-16, + "iauApcs13", "v(3)", status); + vvd(astrom.bm1, 0.9999999952947980978, 1e-12, + "iauApcs13", "bm1", status); + vvd(astrom.bpn[0][0], 1, 0, + "iauApcs13", "bpn(1,1)", status); + vvd(astrom.bpn[1][0], 0, 0, + "iauApcs13", "bpn(2,1)", status); + vvd(astrom.bpn[2][0], 0, 0, + "iauApcs13", "bpn(3,1)", status); + vvd(astrom.bpn[0][1], 0, 0, + "iauApcs13", "bpn(1,2)", status); + vvd(astrom.bpn[1][1], 1, 0, + "iauApcs13", "bpn(2,2)", status); + vvd(astrom.bpn[2][1], 0, 0, + "iauApcs13", "bpn(3,2)", status); + vvd(astrom.bpn[0][2], 0, 0, + "iauApcs13", "bpn(1,3)", status); + vvd(astrom.bpn[1][2], 0, 0, + "iauApcs13", "bpn(2,3)", status); + vvd(astrom.bpn[2][2], 1, 0, + "iauApcs13", "bpn(3,3)", status); + +} + +static void t_aper(int *status) +/* +** - - - - - - - +** t _ a p e r +** - - - - - - - +* +** Test iauAper function. +* +** Returned: +** status int FALSE = success, TRUE = fail +* +** Called: iauAper, vvd +* +** This revision: 2013 October 3 +*/ +{ + double theta; + iauASTROM astrom; + + + astrom.along = 1.234; + theta = 5.678; + + iauAper(theta, &astrom); + + vvd(astrom.eral, 6.912000000000000000, 1e-12, + "iauAper", "pmt", status); + +} + +static void t_aper13(int *status) +/* +** - - - - - - - - - +** t _ a p e r 1 3 +** - - - - - - - - - +** +** Test iauAper13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAper13, vvd +** +** This revision: 2013 October 3 +*/ +{ + double ut11, ut12; + iauASTROM astrom; + + + astrom.along = 1.234; + ut11 = 2456165.5; + ut12 = 0.401182685; + + iauAper13(ut11, ut12, &astrom); + + vvd(astrom.eral, 3.316236661789694933, 1e-12, + "iauAper13", "pmt", status); + +} + +static void t_apio(int *status) +/* +** - - - - - - - +** t _ a p i o +** - - - - - - - +** +** Test iauApio function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApio, vvd +** +** This revision: 2013 October 3 +*/ +{ + double sp, theta, elong, phi, hm, xp, yp, refa, refb; + iauASTROM astrom; + + + sp = -3.01974337e-11; + theta = 3.14540971; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + refa = 0.000201418779; + refb = -2.36140831e-7; + + iauApio(sp, theta, elong, phi, hm, xp, yp, refa, refb, &astrom); + + vvd(astrom.along, -0.5278008060301974337, 1e-12, + "iauApio", "along", status); + vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, + "iauApio", "xpl", status); + vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, + "iauApio", "ypl", status); + vvd(astrom.sphi, -0.9440115679003211329, 1e-12, + "iauApio", "sphi", status); + vvd(astrom.cphi, 0.3299123514971474711, 1e-12, + "iauApio", "cphi", status); + vvd(astrom.diurab, 0.5135843661699913529e-6, 1e-12, + "iauApio", "diurab", status); + vvd(astrom.eral, 2.617608903969802566, 1e-12, + "iauApio", "eral", status); + vvd(astrom.refa, 0.2014187790000000000e-3, 1e-15, + "iauApio", "refa", status); + vvd(astrom.refb, -0.2361408310000000000e-6, 1e-18, + "iauApio", "refb", status); + +} + +static void t_apio13(int *status) +/* +** - - - - - - - - - +** t _ a p i o 1 3 +** - - - - - - - - - +** +** Test iauApio13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApio13, vvd, viv +** +** This revision: 2013 October 4 +*/ +{ + double utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl; + int j; + iauASTROM astrom; + + + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + + j = iauApio13(utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, &astrom); + + vvd(astrom.along, -0.5278008060301974337, 1e-12, + "iauApio13", "along", status); + vvd(astrom.xpl, 0.1133427418174939329e-5, 1e-17, + "iauApio13", "xpl", status); + vvd(astrom.ypl, 0.1453347595745898629e-5, 1e-17, + "iauApio13", "ypl", status); + vvd(astrom.sphi, -0.9440115679003211329, 1e-12, + "iauApio13", "sphi", status); + vvd(astrom.cphi, 0.3299123514971474711, 1e-12, + "iauApio13", "cphi", status); + vvd(astrom.diurab, 0.5135843661699913529e-6, 1e-12, + "iauApio13", "diurab", status); + vvd(astrom.eral, 2.617608909189066140, 1e-12, + "iauApio13", "eral", status); + vvd(astrom.refa, 0.2014187785940396921e-3, 1e-15, + "iauApio13", "refa", status); + vvd(astrom.refb, -0.2361408314943696227e-6, 1e-18, + "iauApio13", "refb", status); + viv(j, 0, "iauApio13", "j", status); + +} + +static void t_atci13(int *status) +/* +** - - - - - - - - - +** t _ a t c i 1 3 +** - - - - - - - - - +** +** Test iauAtci13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAtci13, vvd +** +** This revision: 2017 March 15 +*/ +{ + double rc, dc, pr, pd, px, rv, date1, date2, ri, di, eo; + + + rc = 2.71; + dc = 0.174; + pr = 1e-5; + pd = 5e-6; + px = 0.1; + rv = 55.0; + date1 = 2456165.5; + date2 = 0.401182685; + + iauAtci13(rc, dc, pr, pd, px, rv, date1, date2, &ri, &di, &eo); + + vvd(ri, 2.710121572968696744, 1e-12, + "iauAtci13", "ri", status); + vvd(di, 0.1729371367219539137, 1e-12, + "iauAtci13", "di", status); + vvd(eo, -0.002900618712657375647, 1e-14, + "iauAtci13", "eo", status); + +} + +static void t_atciq(int *status) +/* +** - - - - - - - - +** t _ a t c i q +** - - - - - - - - +** +** Test iauAtciq function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApci13, iauAtciq, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, eo, rc, dc, pr, pd, px, rv, ri, di; + iauASTROM astrom; + + date1 = 2456165.5; + date2 = 0.401182685; + iauApci13(date1, date2, &astrom, &eo); + rc = 2.71; + dc = 0.174; + pr = 1e-5; + pd = 5e-6; + px = 0.1; + rv = 55.0; + + iauAtciq(rc, dc, pr, pd, px, rv, &astrom, &ri, &di); + + vvd(ri, 2.710121572968696744, 1e-12, "iauAtciq", "ri", status); + vvd(di, 0.1729371367219539137, 1e-12, "iauAtciq", "di", status); + +} + +static void t_atciqn(int *status) +/* +** - - - - - - - - - +** t _ a t c i q n +** - - - - - - - - - +** +** Test iauAtciqn function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApci13, iauAtciqn, vvd +** +** This revision: 2017 March 15 +*/ +{ + iauLDBODY b[3]; + double date1, date2, eo, rc, dc, pr, pd, px, rv, ri, di; + iauASTROM astrom; + + date1 = 2456165.5; + date2 = 0.401182685; + iauApci13(date1, date2, &astrom, &eo); + rc = 2.71; + dc = 0.174; + pr = 1e-5; + pd = 5e-6; + px = 0.1; + rv = 55.0; + b[0].bm = 0.00028574; + b[0].dl = 3e-10; + b[0].pv[0][0] = -7.81014427; + b[0].pv[0][1] = -5.60956681; + b[0].pv[0][2] = -1.98079819; + b[0].pv[1][0] = 0.0030723249; + b[0].pv[1][1] = -0.00406995477; + b[0].pv[1][2] = -0.00181335842; + b[1].bm = 0.00095435; + b[1].dl = 3e-9; + b[1].pv[0][0] = 0.738098796; + b[1].pv[0][1] = 4.63658692; + b[1].pv[0][2] = 1.9693136; + b[1].pv[1][0] = -0.00755816922; + b[1].pv[1][1] = 0.00126913722; + b[1].pv[1][2] = 0.000727999001; + b[2].bm = 1.0; + b[2].dl = 6e-6; + b[2].pv[0][0] = -0.000712174377; + b[2].pv[0][1] = -0.00230478303; + b[2].pv[0][2] = -0.00105865966; + b[2].pv[1][0] = 6.29235213e-6; + b[2].pv[1][1] = -3.30888387e-7; + b[2].pv[1][2] = -2.96486623e-7; + + iauAtciqn ( rc, dc, pr, pd, px, rv, &astrom, 3, b, &ri, &di); + + vvd(ri, 2.710122008104983335, 1e-12, "iauAtciqn", "ri", status); + vvd(di, 0.1729371916492767821, 1e-12, "iauAtciqn", "di", status); + +} + +static void t_atciqz(int *status) +/* +** - - - - - - - - - +** t _ a t c i q z +** - - - - - - - - - +** +** Test iauAtciqz function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApci13, iauAtciqz, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, eo, rc, dc, ri, di; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + iauApci13(date1, date2, &astrom, &eo); + rc = 2.71; + dc = 0.174; + + iauAtciqz(rc, dc, &astrom, &ri, &di); + + vvd(ri, 2.709994899247256984, 1e-12, "iauAtciqz", "ri", status); + vvd(di, 0.1728740720984931891, 1e-12, "iauAtciqz", "di", status); + +} + +static void t_atco13(int *status) +/* +** - - - - - - - - - +** t _ a t c o 1 3 +** - - - - - - - - - +** +** Test iauAtco13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAtco13, vvd, viv +** +** This revision: 2017 March 15 +*/ +{ + double rc, dc, pr, pd, px, rv, utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + aob, zob, hob, dob, rob, eo; + int j; + + + rc = 2.71; + dc = 0.174; + pr = 1e-5; + pd = 5e-6; + px = 0.1; + rv = 55.0; + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + + j = iauAtco13(rc, dc, pr, pd, px, rv, + utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, + &aob, &zob, &hob, &dob, &rob, &eo); + + vvd(aob, 0.09251774485385390973, 1e-12, "iauAtco13", "aob", status); + vvd(zob, 1.407661405256671703, 1e-12, "iauAtco13", "zob", status); + vvd(hob, -0.09265154431430045141, 1e-12, "iauAtco13", "hob", status); + vvd(dob, 0.1716626560074556029, 1e-12, "iauAtco13", "dob", status); + vvd(rob, 2.710260453503366591, 1e-12, "iauAtco13", "rob", status); + vvd(eo, -0.003020548354802412839, 1e-14, "iauAtco13", "eo", status); + viv(j, 0, "iauAtco13", "j", status); + +} + +static void t_atic13(int *status) +/* +** - - - - - - - - - +** t _ a t i c 1 3 +** - - - - - - - - - +** +** Test iauAtic13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAtic13, vvd +** +** This revision: 2017 March 15 +*/ +{ + double ri, di, date1, date2, rc, dc, eo; + + + ri = 2.710121572969038991; + di = 0.1729371367218230438; + date1 = 2456165.5; + date2 = 0.401182685; + + iauAtic13(ri, di, date1, date2, &rc, &dc, &eo); + + vvd(rc, 2.710126504531716819, 1e-12, "iauAtic13", "rc", status); + vvd(dc, 0.1740632537627034482, 1e-12, "iauAtic13", "dc", status); + vvd(eo, -0.002900618712657375647, 1e-14, "iauAtic13", "eo", status); + +} + +static void t_aticq(int *status) +/* +** - - - - - - - - +** t _ a t i c q +** - - - - - - - - +** +** Test iauAticq function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApci13, iauAticq, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, eo, ri, di, rc, dc; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + iauApci13(date1, date2, &astrom, &eo); + ri = 2.710121572969038991; + di = 0.1729371367218230438; + + iauAticq(ri, di, &astrom, &rc, &dc); + + vvd(rc, 2.710126504531716819, 1e-12, "iauAticq", "rc", status); + vvd(dc, 0.1740632537627034482, 1e-12, "iauAticq", "dc", status); + +} + +static void t_aticqn(int *status) +/* +** - - - - - - - - - +** t _ a t i c q n +** - - - - - - - - - +** +** Test iauAticqn function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApci13, iauAticqn, vvd +** +** This revision: 2017 March 15 +*/ +{ + double date1, date2, eo, ri, di, rc, dc; + iauLDBODY b[3]; + iauASTROM astrom; + + + date1 = 2456165.5; + date2 = 0.401182685; + iauApci13(date1, date2, &astrom, &eo); + ri = 2.709994899247599271; + di = 0.1728740720983623469; + b[0].bm = 0.00028574; + b[0].dl = 3e-10; + b[0].pv[0][0] = -7.81014427; + b[0].pv[0][1] = -5.60956681; + b[0].pv[0][2] = -1.98079819; + b[0].pv[1][0] = 0.0030723249; + b[0].pv[1][1] = -0.00406995477; + b[0].pv[1][2] = -0.00181335842; + b[1].bm = 0.00095435; + b[1].dl = 3e-9; + b[1].pv[0][0] = 0.738098796; + b[1].pv[0][1] = 4.63658692; + b[1].pv[0][2] = 1.9693136; + b[1].pv[1][0] = -0.00755816922; + b[1].pv[1][1] = 0.00126913722; + b[1].pv[1][2] = 0.000727999001; + b[2].bm = 1.0; + b[2].dl = 6e-6; + b[2].pv[0][0] = -0.000712174377; + b[2].pv[0][1] = -0.00230478303; + b[2].pv[0][2] = -0.00105865966; + b[2].pv[1][0] = 6.29235213e-6; + b[2].pv[1][1] = -3.30888387e-7; + b[2].pv[1][2] = -2.96486623e-7; + + iauAticqn(ri, di, &astrom, 3, b, &rc, &dc); + + vvd(rc, 2.709999575033027333, 1e-12, "iauAtciqn", "rc", status); + vvd(dc, 0.1739999656316469990, 1e-12, "iauAtciqn", "dc", status); + +} + +static void t_atio13(int *status) +/* +** - - - - - - - - - +** t _ a t i o 1 3 +** - - - - - - - - - +** +** Test iauAtio13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAtio13, vvd, viv +** +** This revision: 2013 October 3 +*/ +{ + double ri, di, utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, aob, zob, hob, dob, rob; + int j; + + + ri = 2.710121572969038991; + di = 0.1729371367218230438; + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + + j = iauAtio13(ri, di, utc1, utc2, dut1, elong, phi, hm, + xp, yp, phpa, tc, rh, wl, + &aob, &zob, &hob, &dob, &rob); + + vvd(aob, 0.09233952224794989993, 1e-12, "iauAtio13", "aob", status); + vvd(zob, 1.407758704513722461, 1e-12, "iauAtio13", "zob", status); + vvd(hob, -0.09247619879782006106, 1e-12, "iauAtio13", "hob", status); + vvd(dob, 0.1717653435758265198, 1e-12, "iauAtio13", "dob", status); + vvd(rob, 2.710085107986886201, 1e-12, "iauAtio13", "rob", status); + viv(j, 0, "iauAtio13", "j", status); + +} + +static void t_atioq(int *status) +/* +** - - - - - - - - +** t _ a t i o q +** - - - - - - - - +** +** Test iauAtioq function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauApio13, iauAtioq, vvd, viv +** +** This revision: 2013 October 4 +*/ +{ + double utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, ri, di, aob, zob, hob, dob, rob; + iauASTROM astrom; + + + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + (void) iauApio13(utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, &astrom); + ri = 2.710121572969038991; + di = 0.1729371367218230438; + + iauAtioq(ri, di, &astrom, &aob, &zob, &hob, &dob, &rob); + + vvd(aob, 0.09233952224794989993, 1e-12, "iauAtioq", "aob", status); + vvd(zob, 1.407758704513722461, 1e-12, "iauAtioq", "zob", status); + vvd(hob, -0.09247619879782006106, 1e-12, "iauAtioq", "hob", status); + vvd(dob, 0.1717653435758265198, 1e-12, "iauAtioq", "dob", status); + vvd(rob, 2.710085107986886201, 1e-12, "iauAtioq", "rob", status); + +} + +static void t_atoc13(int *status) +/* +** - - - - - - - - - +** t _ a t o c 1 3 +** - - - - - - - - - +** +** Test iauAtoc13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAtoc13, vvd, viv +** +** This revision: 2017 March 15 +*/ +{ + double utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + ob1, ob2, rc, dc; + int j; + + + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + + ob1 = 2.710085107986886201; + ob2 = 0.1717653435758265198; + j = iauAtoc13 ( "R", ob1, ob2, utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + &rc, &dc); + vvd(rc, 2.709956744660731630, 1e-12, "iauAtoc13", "R/rc", status); + vvd(dc, 0.1741696500896438967, 1e-12, "iauAtoc13", "R/dc", status); + viv(j, 0, "iauAtoc13", "R/j", status); + + ob1 = -0.09247619879782006106; + ob2 = 0.1717653435758265198; + j = iauAtoc13 ( "H", ob1, ob2, utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + &rc, &dc); + vvd(rc, 2.709956744660731630, 1e-12, "iauAtoc13", "H/rc", status); + vvd(dc, 0.1741696500896438967, 1e-12, "iauAtoc13", "H/dc", status); + viv(j, 0, "iauAtoc13", "H/j", status); + + ob1 = 0.09233952224794989993; + ob2 = 1.407758704513722461; + j = iauAtoc13 ( "A", ob1, ob2, utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + &rc, &dc); + vvd(rc, 2.709956744660731630, 1e-12, "iauAtoc13", "A/rc", status); + vvd(dc, 0.1741696500896438970, 1e-12, "iauAtoc13", "A/dc", status); + viv(j, 0, "iauAtoc13", "A/j", status); + +} + +static void t_atoi13(int *status) +/* +** - - - - - - - - - +** t _ a t o i 1 3 +** - - - - - - - - - +** +** Test iauAtoi13 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauAtoi13, vvd, viv +** +** This revision: 2013 October 3 +*/ +{ + double utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl, + ob1, ob2, ri, di; + int j; + + + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + + ob1 = 2.710085107986886201; + ob2 = 0.1717653435758265198; + j = iauAtoi13 ( "R", ob1, ob2, utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + &ri, &di); + vvd(ri, 2.710121574449135955, 1e-12, "iauAtoi13", "R/ri", status); + vvd(di, 0.1729371839114567725, 1e-12, "iauAtoi13", "R/di", status); + viv(j, 0, "iauAtoi13", "R/J", status); + + ob1 = -0.09247619879782006106; + ob2 = 0.1717653435758265198; + j = iauAtoi13 ( "H", ob1, ob2, utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + &ri, &di); + vvd(ri, 2.710121574449135955, 1e-12, "iauAtoi13", "H/ri", status); + vvd(di, 0.1729371839114567725, 1e-12, "iauAtoi13", "H/di", status); + viv(j, 0, "iauAtoi13", "H/J", status); + + ob1 = 0.09233952224794989993; + ob2 = 1.407758704513722461; + j = iauAtoi13 ( "A", ob1, ob2, utc1, utc2, dut1, + elong, phi, hm, xp, yp, phpa, tc, rh, wl, + &ri, &di); + vvd(ri, 2.710121574449135955, 1e-12, "iauAtoi13", "A/ri", status); + vvd(di, 0.1729371839114567728, 1e-12, "iauAtoi13", "A/di", status); + viv(j, 0, "iauAtoi13", "A/J", status); + +} + +static void t_atoiq(int *status) +/* +** - - - - - - - - +** t _ a t o i q +** - - - - - - - - +* +** Test iauAtoiq function. +* +** Returned: +** status int FALSE = success, TRUE = fail +* +** Called: iauApio13, iauAtoiq, vvd +* +** This revision: 2013 October 4 +*/ +{ + double utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl, + ob1, ob2, ri, di; + iauASTROM astrom; + + + utc1 = 2456384.5; + utc2 = 0.969254051; + dut1 = 0.1550675; + elong = -0.527800806; + phi = -1.2345856; + hm = 2738.0; + xp = 2.47230737e-7; + yp = 1.82640464e-6; + phpa = 731.0; + tc = 12.8; + rh = 0.59; + wl = 0.55; + (void) iauApio13(utc1, utc2, dut1, elong, phi, hm, xp, yp, + phpa, tc, rh, wl, &astrom); + + ob1 = 2.710085107986886201; + ob2 = 0.1717653435758265198; + iauAtoiq("R", ob1, ob2, &astrom, &ri, &di); + vvd(ri, 2.710121574449135955, 1e-12, + "iauAtoiq", "R/ri", status); + vvd(di, 0.1729371839114567725, 1e-12, + "iauAtoiq", "R/di", status); + + ob1 = -0.09247619879782006106; + ob2 = 0.1717653435758265198; + iauAtoiq("H", ob1, ob2, &astrom, &ri, &di); + vvd(ri, 2.710121574449135955, 1e-12, + "iauAtoiq", "H/ri", status); + vvd(di, 0.1729371839114567725, 1e-12, + "iauAtoiq", "H/di", status); + + ob1 = 0.09233952224794989993; + ob2 = 1.407758704513722461; + iauAtoiq("A", ob1, ob2, &astrom, &ri, &di); + vvd(ri, 2.710121574449135955, 1e-12, + "iauAtoiq", "A/ri", status); + vvd(di, 0.1729371839114567728, 1e-12, + "iauAtoiq", "A/di", status); + +} + +static void t_bi00(int *status) +/* +** - - - - - - - +** t _ b i 0 0 +** - - - - - - - +** +** Test iauBi00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauBi00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsibi, depsbi, dra; + + iauBi00(&dpsibi, &depsbi, &dra); + + vvd(dpsibi, -0.2025309152835086613e-6, 1e-12, + "iauBi00", "dpsibi", status); + vvd(depsbi, -0.3306041454222147847e-7, 1e-12, + "iauBi00", "depsbi", status); + vvd(dra, -0.7078279744199225506e-7, 1e-12, + "iauBi00", "dra", status); +} + +static void t_bp00(int *status) +/* +** - - - - - - - +** t _ b p 0 0 +** - - - - - - - +** +** Test iauBp00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauBp00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rb[3][3], rp[3][3], rbp[3][3]; + + + iauBp00(2400000.5, 50123.9999, rb, rp, rbp); + + vvd(rb[0][0], 0.9999999999999942498, 1e-12, + "iauBp00", "rb11", status); + vvd(rb[0][1], -0.7078279744199196626e-7, 1e-16, + "iauBp00", "rb12", status); + vvd(rb[0][2], 0.8056217146976134152e-7, 1e-16, + "iauBp00", "rb13", status); + vvd(rb[1][0], 0.7078279477857337206e-7, 1e-16, + "iauBp00", "rb21", status); + vvd(rb[1][1], 0.9999999999999969484, 1e-12, + "iauBp00", "rb22", status); + vvd(rb[1][2], 0.3306041454222136517e-7, 1e-16, + "iauBp00", "rb23", status); + vvd(rb[2][0], -0.8056217380986972157e-7, 1e-16, + "iauBp00", "rb31", status); + vvd(rb[2][1], -0.3306040883980552500e-7, 1e-16, + "iauBp00", "rb32", status); + vvd(rb[2][2], 0.9999999999999962084, 1e-12, + "iauBp00", "rb33", status); + + vvd(rp[0][0], 0.9999995504864048241, 1e-12, + "iauBp00", "rp11", status); + vvd(rp[0][1], 0.8696113836207084411e-3, 1e-14, + "iauBp00", "rp12", status); + vvd(rp[0][2], 0.3778928813389333402e-3, 1e-14, + "iauBp00", "rp13", status); + vvd(rp[1][0], -0.8696113818227265968e-3, 1e-14, + "iauBp00", "rp21", status); + vvd(rp[1][1], 0.9999996218879365258, 1e-12, + "iauBp00", "rp22", status); + vvd(rp[1][2], -0.1690679263009242066e-6, 1e-14, + "iauBp00", "rp23", status); + vvd(rp[2][0], -0.3778928854764695214e-3, 1e-14, + "iauBp00", "rp31", status); + vvd(rp[2][1], -0.1595521004195286491e-6, 1e-14, + "iauBp00", "rp32", status); + vvd(rp[2][2], 0.9999999285984682756, 1e-12, + "iauBp00", "rp33", status); + + vvd(rbp[0][0], 0.9999995505175087260, 1e-12, + "iauBp00", "rbp11", status); + vvd(rbp[0][1], 0.8695405883617884705e-3, 1e-14, + "iauBp00", "rbp12", status); + vvd(rbp[0][2], 0.3779734722239007105e-3, 1e-14, + "iauBp00", "rbp13", status); + vvd(rbp[1][0], -0.8695405990410863719e-3, 1e-14, + "iauBp00", "rbp21", status); + vvd(rbp[1][1], 0.9999996219494925900, 1e-12, + "iauBp00", "rbp22", status); + vvd(rbp[1][2], -0.1360775820404982209e-6, 1e-14, + "iauBp00", "rbp23", status); + vvd(rbp[2][0], -0.3779734476558184991e-3, 1e-14, + "iauBp00", "rbp31", status); + vvd(rbp[2][1], -0.1925857585832024058e-6, 1e-14, + "iauBp00", "rbp32", status); + vvd(rbp[2][2], 0.9999999285680153377, 1e-12, + "iauBp00", "rbp33", status); +} + +static void t_bp06(int *status) +/* +** - - - - - - - +** t _ b p 0 6 +** - - - - - - - +** +** Test iauBp06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauBp06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rb[3][3], rp[3][3], rbp[3][3]; + + + iauBp06(2400000.5, 50123.9999, rb, rp, rbp); + + vvd(rb[0][0], 0.9999999999999942497, 1e-12, + "iauBp06", "rb11", status); + vvd(rb[0][1], -0.7078368960971557145e-7, 1e-14, + "iauBp06", "rb12", status); + vvd(rb[0][2], 0.8056213977613185606e-7, 1e-14, + "iauBp06", "rb13", status); + vvd(rb[1][0], 0.7078368694637674333e-7, 1e-14, + "iauBp06", "rb21", status); + vvd(rb[1][1], 0.9999999999999969484, 1e-12, + "iauBp06", "rb22", status); + vvd(rb[1][2], 0.3305943742989134124e-7, 1e-14, + "iauBp06", "rb23", status); + vvd(rb[2][0], -0.8056214211620056792e-7, 1e-14, + "iauBp06", "rb31", status); + vvd(rb[2][1], -0.3305943172740586950e-7, 1e-14, + "iauBp06", "rb32", status); + vvd(rb[2][2], 0.9999999999999962084, 1e-12, + "iauBp06", "rb33", status); + + vvd(rp[0][0], 0.9999995504864960278, 1e-12, + "iauBp06", "rp11", status); + vvd(rp[0][1], 0.8696112578855404832e-3, 1e-14, + "iauBp06", "rp12", status); + vvd(rp[0][2], 0.3778929293341390127e-3, 1e-14, + "iauBp06", "rp13", status); + vvd(rp[1][0], -0.8696112560510186244e-3, 1e-14, + "iauBp06", "rp21", status); + vvd(rp[1][1], 0.9999996218880458820, 1e-12, + "iauBp06", "rp22", status); + vvd(rp[1][2], -0.1691646168941896285e-6, 1e-14, + "iauBp06", "rp23", status); + vvd(rp[2][0], -0.3778929335557603418e-3, 1e-14, + "iauBp06", "rp31", status); + vvd(rp[2][1], -0.1594554040786495076e-6, 1e-14, + "iauBp06", "rp32", status); + vvd(rp[2][2], 0.9999999285984501222, 1e-12, + "iauBp06", "rp33", status); + + vvd(rbp[0][0], 0.9999995505176007047, 1e-12, + "iauBp06", "rbp11", status); + vvd(rbp[0][1], 0.8695404617348208406e-3, 1e-14, + "iauBp06", "rbp12", status); + vvd(rbp[0][2], 0.3779735201865589104e-3, 1e-14, + "iauBp06", "rbp13", status); + vvd(rbp[1][0], -0.8695404723772031414e-3, 1e-14, + "iauBp06", "rbp21", status); + vvd(rbp[1][1], 0.9999996219496027161, 1e-12, + "iauBp06", "rbp22", status); + vvd(rbp[1][2], -0.1361752497080270143e-6, 1e-14, + "iauBp06", "rbp23", status); + vvd(rbp[2][0], -0.3779734957034089490e-3, 1e-14, + "iauBp06", "rbp31", status); + vvd(rbp[2][1], -0.1924880847894457113e-6, 1e-14, + "iauBp06", "rbp32", status); + vvd(rbp[2][2], 0.9999999285679971958, 1e-12, + "iauBp06", "rbp33", status); +} + +static void t_bpn2xy(int *status) +/* +** - - - - - - - - - +** t _ b p n 2 x y +** - - - - - - - - - +** +** Test iauBpn2xy function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauBpn2xy, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbpn[3][3], x, y; + + + rbpn[0][0] = 9.999962358680738e-1; + rbpn[0][1] = -2.516417057665452e-3; + rbpn[0][2] = -1.093569785342370e-3; + + rbpn[1][0] = 2.516462370370876e-3; + rbpn[1][1] = 9.999968329010883e-1; + rbpn[1][2] = 4.006159587358310e-5; + + rbpn[2][0] = 1.093465510215479e-3; + rbpn[2][1] = -4.281337229063151e-5; + rbpn[2][2] = 9.999994012499173e-1; + + iauBpn2xy(rbpn, &x, &y); + + vvd(x, 1.093465510215479e-3, 1e-12, "iauBpn2xy", "x", status); + vvd(y, -4.281337229063151e-5, 1e-12, "iauBpn2xy", "y", status); + +} + +static void t_c2i00a(int *status) +/* +** - - - - - - - - - +** t _ c 2 i 0 0 a +** - - - - - - - - - +** +** Test iauC2i00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2i00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rc2i[3][3]; + + + iauC2i00a(2400000.5, 53736.0, rc2i); + + vvd(rc2i[0][0], 0.9999998323037165557, 1e-12, + "iauC2i00a", "11", status); + vvd(rc2i[0][1], 0.5581526348992140183e-9, 1e-12, + "iauC2i00a", "12", status); + vvd(rc2i[0][2], -0.5791308477073443415e-3, 1e-12, + "iauC2i00a", "13", status); + + vvd(rc2i[1][0], -0.2384266227870752452e-7, 1e-12, + "iauC2i00a", "21", status); + vvd(rc2i[1][1], 0.9999999991917405258, 1e-12, + "iauC2i00a", "22", status); + vvd(rc2i[1][2], -0.4020594955028209745e-4, 1e-12, + "iauC2i00a", "23", status); + + vvd(rc2i[2][0], 0.5791308472168152904e-3, 1e-12, + "iauC2i00a", "31", status); + vvd(rc2i[2][1], 0.4020595661591500259e-4, 1e-12, + "iauC2i00a", "32", status); + vvd(rc2i[2][2], 0.9999998314954572304, 1e-12, + "iauC2i00a", "33", status); + +} + +static void t_c2i00b(int *status) +/* +** - - - - - - - - - +** t _ c 2 i 0 0 b +** - - - - - - - - - +** +** Test iauC2i00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2i00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rc2i[3][3]; + + + iauC2i00b(2400000.5, 53736.0, rc2i); + + vvd(rc2i[0][0], 0.9999998323040954356, 1e-12, + "iauC2i00b", "11", status); + vvd(rc2i[0][1], 0.5581526349131823372e-9, 1e-12, + "iauC2i00b", "12", status); + vvd(rc2i[0][2], -0.5791301934855394005e-3, 1e-12, + "iauC2i00b", "13", status); + + vvd(rc2i[1][0], -0.2384239285499175543e-7, 1e-12, + "iauC2i00b", "21", status); + vvd(rc2i[1][1], 0.9999999991917574043, 1e-12, + "iauC2i00b", "22", status); + vvd(rc2i[1][2], -0.4020552974819030066e-4, 1e-12, + "iauC2i00b", "23", status); + + vvd(rc2i[2][0], 0.5791301929950208873e-3, 1e-12, + "iauC2i00b", "31", status); + vvd(rc2i[2][1], 0.4020553681373720832e-4, 1e-12, + "iauC2i00b", "32", status); + vvd(rc2i[2][2], 0.9999998314958529887, 1e-12, + "iauC2i00b", "33", status); + +} + +static void t_c2i06a(int *status) +/* +** - - - - - - - - - +** t _ c 2 i 0 6 a +** - - - - - - - - - +** +** Test iauC2i06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2i06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rc2i[3][3]; + + + iauC2i06a(2400000.5, 53736.0, rc2i); + + vvd(rc2i[0][0], 0.9999998323037159379, 1e-12, + "iauC2i06a", "11", status); + vvd(rc2i[0][1], 0.5581121329587613787e-9, 1e-12, + "iauC2i06a", "12", status); + vvd(rc2i[0][2], -0.5791308487740529749e-3, 1e-12, + "iauC2i06a", "13", status); + + vvd(rc2i[1][0], -0.2384253169452306581e-7, 1e-12, + "iauC2i06a", "21", status); + vvd(rc2i[1][1], 0.9999999991917467827, 1e-12, + "iauC2i06a", "22", status); + vvd(rc2i[1][2], -0.4020579392895682558e-4, 1e-12, + "iauC2i06a", "23", status); + + vvd(rc2i[2][0], 0.5791308482835292617e-3, 1e-12, + "iauC2i06a", "31", status); + vvd(rc2i[2][1], 0.4020580099454020310e-4, 1e-12, + "iauC2i06a", "32", status); + vvd(rc2i[2][2], 0.9999998314954628695, 1e-12, + "iauC2i06a", "33", status); + +} + +static void t_c2ibpn(int *status) +/* +** - - - - - - - - - +** t _ c 2 i b p n +** - - - - - - - - - +** +** Test iauC2ibpn function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2ibpn, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbpn[3][3], rc2i[3][3]; + + + rbpn[0][0] = 9.999962358680738e-1; + rbpn[0][1] = -2.516417057665452e-3; + rbpn[0][2] = -1.093569785342370e-3; + + rbpn[1][0] = 2.516462370370876e-3; + rbpn[1][1] = 9.999968329010883e-1; + rbpn[1][2] = 4.006159587358310e-5; + + rbpn[2][0] = 1.093465510215479e-3; + rbpn[2][1] = -4.281337229063151e-5; + rbpn[2][2] = 9.999994012499173e-1; + + iauC2ibpn(2400000.5, 50123.9999, rbpn, rc2i); + + vvd(rc2i[0][0], 0.9999994021664089977, 1e-12, + "iauC2ibpn", "11", status); + vvd(rc2i[0][1], -0.3869195948017503664e-8, 1e-12, + "iauC2ibpn", "12", status); + vvd(rc2i[0][2], -0.1093465511383285076e-2, 1e-12, + "iauC2ibpn", "13", status); + + vvd(rc2i[1][0], 0.5068413965715446111e-7, 1e-12, + "iauC2ibpn", "21", status); + vvd(rc2i[1][1], 0.9999999990835075686, 1e-12, + "iauC2ibpn", "22", status); + vvd(rc2i[1][2], 0.4281334246452708915e-4, 1e-12, + "iauC2ibpn", "23", status); + + vvd(rc2i[2][0], 0.1093465510215479000e-2, 1e-12, + "iauC2ibpn", "31", status); + vvd(rc2i[2][1], -0.4281337229063151000e-4, 1e-12, + "iauC2ibpn", "32", status); + vvd(rc2i[2][2], 0.9999994012499173103, 1e-12, + "iauC2ibpn", "33", status); + +} + +static void t_c2ixy(int *status) +/* +** - - - - - - - - +** t _ c 2 i x y +** - - - - - - - - +** +** Test iauC2ixy function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2ixy, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y, rc2i[3][3]; + + + x = 0.5791308486706011000e-3; + y = 0.4020579816732961219e-4; + + iauC2ixy(2400000.5, 53736, x, y, rc2i); + + vvd(rc2i[0][0], 0.9999998323037157138, 1e-12, + "iauC2ixy", "11", status); + vvd(rc2i[0][1], 0.5581526349032241205e-9, 1e-12, + "iauC2ixy", "12", status); + vvd(rc2i[0][2], -0.5791308491611263745e-3, 1e-12, + "iauC2ixy", "13", status); + + vvd(rc2i[1][0], -0.2384257057469842953e-7, 1e-12, + "iauC2ixy", "21", status); + vvd(rc2i[1][1], 0.9999999991917468964, 1e-12, + "iauC2ixy", "22", status); + vvd(rc2i[1][2], -0.4020579110172324363e-4, 1e-12, + "iauC2ixy", "23", status); + + vvd(rc2i[2][0], 0.5791308486706011000e-3, 1e-12, + "iauC2ixy", "31", status); + vvd(rc2i[2][1], 0.4020579816732961219e-4, 1e-12, + "iauC2ixy", "32", status); + vvd(rc2i[2][2], 0.9999998314954627590, 1e-12, + "iauC2ixy", "33", status); + +} + +static void t_c2ixys(int *status) +/* +** - - - - - - - - - +** t _ c 2 i x y s +** - - - - - - - - - +** +** Test iauC2ixys function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2ixys, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y, s, rc2i[3][3]; + + + x = 0.5791308486706011000e-3; + y = 0.4020579816732961219e-4; + s = -0.1220040848472271978e-7; + + iauC2ixys(x, y, s, rc2i); + + vvd(rc2i[0][0], 0.9999998323037157138, 1e-12, + "iauC2ixys", "11", status); + vvd(rc2i[0][1], 0.5581984869168499149e-9, 1e-12, + "iauC2ixys", "12", status); + vvd(rc2i[0][2], -0.5791308491611282180e-3, 1e-12, + "iauC2ixys", "13", status); + + vvd(rc2i[1][0], -0.2384261642670440317e-7, 1e-12, + "iauC2ixys", "21", status); + vvd(rc2i[1][1], 0.9999999991917468964, 1e-12, + "iauC2ixys", "22", status); + vvd(rc2i[1][2], -0.4020579110169668931e-4, 1e-12, + "iauC2ixys", "23", status); + + vvd(rc2i[2][0], 0.5791308486706011000e-3, 1e-12, + "iauC2ixys", "31", status); + vvd(rc2i[2][1], 0.4020579816732961219e-4, 1e-12, + "iauC2ixys", "32", status); + vvd(rc2i[2][2], 0.9999998314954627590, 1e-12, + "iauC2ixys", "33", status); + +} + +static void t_c2s(int *status) +/* +** - - - - - - +** t _ c 2 s +** - - - - - - +** +** Test iauC2s function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2s, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3], theta, phi; + + + p[0] = 100.0; + p[1] = -50.0; + p[2] = 25.0; + + iauC2s(p, &theta, &phi); + + vvd(theta, -0.4636476090008061162, 1e-14, "iauC2s", "theta", status); + vvd(phi, 0.2199879773954594463, 1e-14, "iauC2s", "phi", status); + +} + +static void t_c2t00a(int *status) +/* +** - - - - - - - - - +** t _ c 2 t 0 0 a +** - - - - - - - - - +** +** Test iauC2t00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2t00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double tta, ttb, uta, utb, xp, yp, rc2t[3][3]; + + + tta = 2400000.5; + uta = 2400000.5; + ttb = 53736.0; + utb = 53736.0; + xp = 2.55060238e-7; + yp = 1.860359247e-6; + + iauC2t00a(tta, ttb, uta, utb, xp, yp, rc2t); + + vvd(rc2t[0][0], -0.1810332128307182668, 1e-12, + "iauC2t00a", "11", status); + vvd(rc2t[0][1], 0.9834769806938457836, 1e-12, + "iauC2t00a", "12", status); + vvd(rc2t[0][2], 0.6555535638688341725e-4, 1e-12, + "iauC2t00a", "13", status); + + vvd(rc2t[1][0], -0.9834768134135984552, 1e-12, + "iauC2t00a", "21", status); + vvd(rc2t[1][1], -0.1810332203649520727, 1e-12, + "iauC2t00a", "22", status); + vvd(rc2t[1][2], 0.5749801116141056317e-3, 1e-12, + "iauC2t00a", "23", status); + + vvd(rc2t[2][0], 0.5773474014081406921e-3, 1e-12, + "iauC2t00a", "31", status); + vvd(rc2t[2][1], 0.3961832391770163647e-4, 1e-12, + "iauC2t00a", "32", status); + vvd(rc2t[2][2], 0.9999998325501692289, 1e-12, + "iauC2t00a", "33", status); + +} + +static void t_c2t00b(int *status) +/* +** - - - - - - - - - +** t _ c 2 t 0 0 b +** - - - - - - - - - +** +** Test iauC2t00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2t00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double tta, ttb, uta, utb, xp, yp, rc2t[3][3]; + + + tta = 2400000.5; + uta = 2400000.5; + ttb = 53736.0; + utb = 53736.0; + xp = 2.55060238e-7; + yp = 1.860359247e-6; + + iauC2t00b(tta, ttb, uta, utb, xp, yp, rc2t); + + vvd(rc2t[0][0], -0.1810332128439678965, 1e-12, + "iauC2t00b", "11", status); + vvd(rc2t[0][1], 0.9834769806913872359, 1e-12, + "iauC2t00b", "12", status); + vvd(rc2t[0][2], 0.6555565082458415611e-4, 1e-12, + "iauC2t00b", "13", status); + + vvd(rc2t[1][0], -0.9834768134115435923, 1e-12, + "iauC2t00b", "21", status); + vvd(rc2t[1][1], -0.1810332203784001946, 1e-12, + "iauC2t00b", "22", status); + vvd(rc2t[1][2], 0.5749793922030017230e-3, 1e-12, + "iauC2t00b", "23", status); + + vvd(rc2t[2][0], 0.5773467471863534901e-3, 1e-12, + "iauC2t00b", "31", status); + vvd(rc2t[2][1], 0.3961790411549945020e-4, 1e-12, + "iauC2t00b", "32", status); + vvd(rc2t[2][2], 0.9999998325505635738, 1e-12, + "iauC2t00b", "33", status); + +} + +static void t_c2t06a(int *status) +/* +** - - - - - - - - - +** t _ c 2 t 0 6 a +** - - - - - - - - - +** +** Test iauC2t06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2t06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double tta, ttb, uta, utb, xp, yp, rc2t[3][3]; + + + tta = 2400000.5; + uta = 2400000.5; + ttb = 53736.0; + utb = 53736.0; + xp = 2.55060238e-7; + yp = 1.860359247e-6; + + iauC2t06a(tta, ttb, uta, utb, xp, yp, rc2t); + + vvd(rc2t[0][0], -0.1810332128305897282, 1e-12, + "iauC2t06a", "11", status); + vvd(rc2t[0][1], 0.9834769806938592296, 1e-12, + "iauC2t06a", "12", status); + vvd(rc2t[0][2], 0.6555550962998436505e-4, 1e-12, + "iauC2t06a", "13", status); + + vvd(rc2t[1][0], -0.9834768134136214897, 1e-12, + "iauC2t06a", "21", status); + vvd(rc2t[1][1], -0.1810332203649130832, 1e-12, + "iauC2t06a", "22", status); + vvd(rc2t[1][2], 0.5749800844905594110e-3, 1e-12, + "iauC2t06a", "23", status); + + vvd(rc2t[2][0], 0.5773474024748545878e-3, 1e-12, + "iauC2t06a", "31", status); + vvd(rc2t[2][1], 0.3961816829632690581e-4, 1e-12, + "iauC2t06a", "32", status); + vvd(rc2t[2][2], 0.9999998325501747785, 1e-12, + "iauC2t06a", "33", status); + +} + +static void t_c2tcio(int *status) +/* +** - - - - - - - - - +** t _ c 2 t c i o +** - - - - - - - - - +** +** Test iauC2tcio function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2tcio, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rc2i[3][3], era, rpom[3][3], rc2t[3][3]; + + + rc2i[0][0] = 0.9999998323037164738; + rc2i[0][1] = 0.5581526271714303683e-9; + rc2i[0][2] = -0.5791308477073443903e-3; + + rc2i[1][0] = -0.2384266227524722273e-7; + rc2i[1][1] = 0.9999999991917404296; + rc2i[1][2] = -0.4020594955030704125e-4; + + rc2i[2][0] = 0.5791308472168153320e-3; + rc2i[2][1] = 0.4020595661593994396e-4; + rc2i[2][2] = 0.9999998314954572365; + + era = 1.75283325530307; + + rpom[0][0] = 0.9999999999999674705; + rpom[0][1] = -0.1367174580728847031e-10; + rpom[0][2] = 0.2550602379999972723e-6; + + rpom[1][0] = 0.1414624947957029721e-10; + rpom[1][1] = 0.9999999999982694954; + rpom[1][2] = -0.1860359246998866338e-5; + + rpom[2][0] = -0.2550602379741215275e-6; + rpom[2][1] = 0.1860359247002413923e-5; + rpom[2][2] = 0.9999999999982369658; + + + iauC2tcio(rc2i, era, rpom, rc2t); + + vvd(rc2t[0][0], -0.1810332128307110439, 1e-12, + "iauC2tcio", "11", status); + vvd(rc2t[0][1], 0.9834769806938470149, 1e-12, + "iauC2tcio", "12", status); + vvd(rc2t[0][2], 0.6555535638685466874e-4, 1e-12, + "iauC2tcio", "13", status); + + vvd(rc2t[1][0], -0.9834768134135996657, 1e-12, + "iauC2tcio", "21", status); + vvd(rc2t[1][1], -0.1810332203649448367, 1e-12, + "iauC2tcio", "22", status); + vvd(rc2t[1][2], 0.5749801116141106528e-3, 1e-12, + "iauC2tcio", "23", status); + + vvd(rc2t[2][0], 0.5773474014081407076e-3, 1e-12, + "iauC2tcio", "31", status); + vvd(rc2t[2][1], 0.3961832391772658944e-4, 1e-12, + "iauC2tcio", "32", status); + vvd(rc2t[2][2], 0.9999998325501691969, 1e-12, + "iauC2tcio", "33", status); + +} + +static void t_c2teqx(int *status) +/* +** - - - - - - - - - +** t _ c 2 t e q x +** - - - - - - - - - +** +** Test iauC2teqx function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2teqx, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbpn[3][3], gst, rpom[3][3], rc2t[3][3]; + + + rbpn[0][0] = 0.9999989440476103608; + rbpn[0][1] = -0.1332881761240011518e-2; + rbpn[0][2] = -0.5790767434730085097e-3; + + rbpn[1][0] = 0.1332858254308954453e-2; + rbpn[1][1] = 0.9999991109044505944; + rbpn[1][2] = -0.4097782710401555759e-4; + + rbpn[2][0] = 0.5791308472168153320e-3; + rbpn[2][1] = 0.4020595661593994396e-4; + rbpn[2][2] = 0.9999998314954572365; + + gst = 1.754166138040730516; + + rpom[0][0] = 0.9999999999999674705; + rpom[0][1] = -0.1367174580728847031e-10; + rpom[0][2] = 0.2550602379999972723e-6; + + rpom[1][0] = 0.1414624947957029721e-10; + rpom[1][1] = 0.9999999999982694954; + rpom[1][2] = -0.1860359246998866338e-5; + + rpom[2][0] = -0.2550602379741215275e-6; + rpom[2][1] = 0.1860359247002413923e-5; + rpom[2][2] = 0.9999999999982369658; + + iauC2teqx(rbpn, gst, rpom, rc2t); + + vvd(rc2t[0][0], -0.1810332128528685730, 1e-12, + "iauC2teqx", "11", status); + vvd(rc2t[0][1], 0.9834769806897685071, 1e-12, + "iauC2teqx", "12", status); + vvd(rc2t[0][2], 0.6555535639982634449e-4, 1e-12, + "iauC2teqx", "13", status); + + vvd(rc2t[1][0], -0.9834768134095211257, 1e-12, + "iauC2teqx", "21", status); + vvd(rc2t[1][1], -0.1810332203871023800, 1e-12, + "iauC2teqx", "22", status); + vvd(rc2t[1][2], 0.5749801116126438962e-3, 1e-12, + "iauC2teqx", "23", status); + + vvd(rc2t[2][0], 0.5773474014081539467e-3, 1e-12, + "iauC2teqx", "31", status); + vvd(rc2t[2][1], 0.3961832391768640871e-4, 1e-12, + "iauC2teqx", "32", status); + vvd(rc2t[2][2], 0.9999998325501691969, 1e-12, + "iauC2teqx", "33", status); + +} + +static void t_c2tpe(int *status) +/* +** - - - - - - - - +** t _ c 2 t p e +** - - - - - - - - +** +** Test iauC2tpe function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2tpe, vvd +** +** This revision: 2013 August 7 +*/ +{ + double tta, ttb, uta, utb, dpsi, deps, xp, yp, rc2t[3][3]; + + + tta = 2400000.5; + uta = 2400000.5; + ttb = 53736.0; + utb = 53736.0; + deps = 0.4090789763356509900; + dpsi = -0.9630909107115582393e-5; + xp = 2.55060238e-7; + yp = 1.860359247e-6; + + iauC2tpe(tta, ttb, uta, utb, dpsi, deps, xp, yp, rc2t); + + vvd(rc2t[0][0], -0.1813677995763029394, 1e-12, + "iauC2tpe", "11", status); + vvd(rc2t[0][1], 0.9023482206891683275, 1e-12, + "iauC2tpe", "12", status); + vvd(rc2t[0][2], -0.3909902938641085751, 1e-12, + "iauC2tpe", "13", status); + + vvd(rc2t[1][0], -0.9834147641476804807, 1e-12, + "iauC2tpe", "21", status); + vvd(rc2t[1][1], -0.1659883635434995121, 1e-12, + "iauC2tpe", "22", status); + vvd(rc2t[1][2], 0.7309763898042819705e-1, 1e-12, + "iauC2tpe", "23", status); + + vvd(rc2t[2][0], 0.1059685430673215247e-2, 1e-12, + "iauC2tpe", "31", status); + vvd(rc2t[2][1], 0.3977631855605078674, 1e-12, + "iauC2tpe", "32", status); + vvd(rc2t[2][2], 0.9174875068792735362, 1e-12, + "iauC2tpe", "33", status); + +} + +static void t_c2txy(int *status) +/* +** - - - - - - - - +** t _ c 2 t x y +** - - - - - - - - +** +** Test iauC2txy function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauC2txy, vvd +** +** This revision: 2013 August 7 +*/ +{ + double tta, ttb, uta, utb, x, y, xp, yp, rc2t[3][3]; + + + tta = 2400000.5; + uta = 2400000.5; + ttb = 53736.0; + utb = 53736.0; + x = 0.5791308486706011000e-3; + y = 0.4020579816732961219e-4; + xp = 2.55060238e-7; + yp = 1.860359247e-6; + + iauC2txy(tta, ttb, uta, utb, x, y, xp, yp, rc2t); + + vvd(rc2t[0][0], -0.1810332128306279253, 1e-12, + "iauC2txy", "11", status); + vvd(rc2t[0][1], 0.9834769806938520084, 1e-12, + "iauC2txy", "12", status); + vvd(rc2t[0][2], 0.6555551248057665829e-4, 1e-12, + "iauC2txy", "13", status); + + vvd(rc2t[1][0], -0.9834768134136142314, 1e-12, + "iauC2txy", "21", status); + vvd(rc2t[1][1], -0.1810332203649529312, 1e-12, + "iauC2txy", "22", status); + vvd(rc2t[1][2], 0.5749800843594139912e-3, 1e-12, + "iauC2txy", "23", status); + + vvd(rc2t[2][0], 0.5773474028619264494e-3, 1e-12, + "iauC2txy", "31", status); + vvd(rc2t[2][1], 0.3961816546911624260e-4, 1e-12, + "iauC2txy", "32", status); + vvd(rc2t[2][2], 0.9999998325501746670, 1e-12, + "iauC2txy", "33", status); + +} + +static void t_cal2jd(int *status) +/* +** - - - - - - - - - +** t _ c a l 2 j d +** - - - - - - - - - +** +** Test iauCal2jd function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauCal2jd, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + int j; + double djm0, djm; + + + j = iauCal2jd(2003, 06, 01, &djm0, &djm); + + vvd(djm0, 2400000.5, 0.0, "iauCal2jd", "djm0", status); + vvd(djm, 52791.0, 0.0, "iauCal2jd", "djm", status); + + viv(j, 0, "iauCal2jd", "j", status); + +} + +static void t_cp(int *status) +/* +** - - - - - +** t _ c p +** - - - - - +** +** Test iauCp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauCp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3], c[3]; + + + p[0] = 0.3; + p[1] = 1.2; + p[2] = -2.5; + + iauCp(p, c); + + vvd(c[0], 0.3, 0.0, "iauCp", "1", status); + vvd(c[1], 1.2, 0.0, "iauCp", "2", status); + vvd(c[2], -2.5, 0.0, "iauCp", "3", status); +} + +static void t_cpv(int *status) +/* +** - - - - - - +** t _ c p v +** - - - - - - +** +** Test iauCpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauCpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3], c[2][3]; + + + pv[0][0] = 0.3; + pv[0][1] = 1.2; + pv[0][2] = -2.5; + + pv[1][0] = -0.5; + pv[1][1] = 3.1; + pv[1][2] = 0.9; + + iauCpv(pv, c); + + vvd(c[0][0], 0.3, 0.0, "iauCpv", "p1", status); + vvd(c[0][1], 1.2, 0.0, "iauCpv", "p2", status); + vvd(c[0][2], -2.5, 0.0, "iauCpv", "p3", status); + + vvd(c[1][0], -0.5, 0.0, "iauCpv", "v1", status); + vvd(c[1][1], 3.1, 0.0, "iauCpv", "v2", status); + vvd(c[1][2], 0.9, 0.0, "iauCpv", "v3", status); + +} + +static void t_cr(int *status) +/* +** - - - - - +** t _ c r +** - - - - - +** +** Test iauCr function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauCr, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3], c[3][3]; + + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + iauCr(r, c); + + vvd(c[0][0], 2.0, 0.0, "iauCr", "11", status); + vvd(c[0][1], 3.0, 0.0, "iauCr", "12", status); + vvd(c[0][2], 2.0, 0.0, "iauCr", "13", status); + + vvd(c[1][0], 3.0, 0.0, "iauCr", "21", status); + vvd(c[1][1], 2.0, 0.0, "iauCr", "22", status); + vvd(c[1][2], 3.0, 0.0, "iauCr", "23", status); + + vvd(c[2][0], 3.0, 0.0, "iauCr", "31", status); + vvd(c[2][1], 4.0, 0.0, "iauCr", "32", status); + vvd(c[2][2], 5.0, 0.0, "iauCr", "33", status); +} + +static void t_d2dtf(int *status ) +/* +** - - - - - - - - +** t _ d 2 d t f +** - - - - - - - - +** +** Test iauD2dtf function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauD2dtf, viv +** +** This revision: 2013 August 7 +*/ +{ + int j, iy, im, id, ihmsf[4]; + + + j = iauD2dtf("UTC", 5, 2400000.5, 49533.99999, &iy, &im, &id, ihmsf); + + viv(iy, 1994, "iauD2dtf", "y", status); + viv(im, 6, "iauD2dtf", "mo", status); + viv(id, 30, "iauD2dtf", "d", status); + viv(ihmsf[0], 23, "iauD2dtf", "h", status); + viv(ihmsf[1], 59, "iauD2dtf", "m", status); + viv(ihmsf[2], 60, "iauD2dtf", "s", status); + viv(ihmsf[3], 13599, "iauD2dtf", "f", status); + viv(j, 0, "iauD2dtf", "j", status); + +} + +static void t_d2tf(int *status) +/* +** - - - - - - - +** t _ d 2 t f +** - - - - - - - +** +** Test iauD2tf function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauD2tf, viv, vvd +** +** This revision: 2013 August 7 +*/ +{ + int ihmsf[4]; + char s; + + + iauD2tf(4, -0.987654321, &s, ihmsf); + + viv((int)s, '-', "iauD2tf", "s", status); + + viv(ihmsf[0], 23, "iauD2tf", "0", status); + viv(ihmsf[1], 42, "iauD2tf", "1", status); + viv(ihmsf[2], 13, "iauD2tf", "2", status); + viv(ihmsf[3], 3333, "iauD2tf", "3", status); + +} + +static void t_dat(int *status) +/* +** - - - - - - +** t _ d a t +** - - - - - - +** +** Test iauDat function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauDat, vvd, viv +** +** This revision: 2016 July 11 +*/ +{ + int j; + double deltat; + + + j = iauDat(2003, 6, 1, 0.0, &deltat); + + vvd(deltat, 32.0, 0.0, "iauDat", "d1", status); + viv(j, 0, "iauDat", "j1", status); + + j = iauDat(2008, 1, 17, 0.0, &deltat); + + vvd(deltat, 33.0, 0.0, "iauDat", "d2", status); + viv(j, 0, "iauDat", "j2", status); + + j = iauDat(2017, 9, 1, 0.0, &deltat); + + vvd(deltat, 37.0, 0.0, "iauDat", "d3", status); + viv(j, 0, "iauDat", "j3", status); + +} + +static void t_dtdb(int *status) +/* +** - - - - - - - +** t _ d t d b +** - - - - - - - +** +** Test iauDtdb function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauDtdb, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dtdb; + + + dtdb = iauDtdb(2448939.5, 0.123, 0.76543, 5.0123, 5525.242, 3190.0); + + vvd(dtdb, -0.1280368005936998991e-2, 1e-15, "iauDtdb", "", status); + +} + +static void t_dtf2d(int *status) +/* +** - - - - - - - - +** t _ d t f 2 d +** - - - - - - - - +** +** Test iauDtf2d function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauDtf2d, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double u1, u2; + int j; + + + j = iauDtf2d("UTC", 1994, 6, 30, 23, 59, 60.13599, &u1, &u2); + + vvd(u1+u2, 2449534.49999, 1e-6, "iauDtf2d", "u", status); + viv(j, 0, "iauDtf2d", "j", status); + +} + +static void t_eceq06(int *status) +/* +** - - - - - +** t _ e c e q 0 6 +** - - - - - +** +** Test iauEceq06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEceq06, vvd +** +** This revision: 2016 March 12 +*/ +{ + double date1, date2, dl, db, dr, dd; + + + date1 = 2456165.5; + date2 = 0.401182685; + dl = 5.1; + db = -0.9; + + iauEceq06(date1, date2, dl, db, &dr, &dd); + + vvd(dr, 5.533459733613627767, 1e-14, "iauEceq06", "dr", status); + vvd(dd, -1.246542932554480576, 1e-14, "iauEceq06", "dd", status); + +} + +static void t_ecm06(int *status) +/* +** - - - - - - - - +** t _ e c m 0 6 +** - - - - - - - - +** +** Test iauEcm06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEcm06, vvd +** +** This revision: 2016 March 12 +*/ +{ + double date1, date2, rm[3][3]; + + + date1 = 2456165.5; + date2 = 0.401182685; + + iauEcm06(date1, date2, rm); + + vvd(rm[0][0], 0.9999952427708701137, 1e-14, + "iauEcm06", "rm11", status); + vvd(rm[0][1], -0.2829062057663042347e-2, 1e-14, + "iauEcm06", "rm12", status); + vvd(rm[0][2], -0.1229163741100017629e-2, 1e-14, + "iauEcm06", "rm13", status); + vvd(rm[1][0], 0.3084546876908653562e-2, 1e-14, + "iauEcm06", "rm21", status); + vvd(rm[1][1], 0.9174891871550392514, 1e-14, + "iauEcm06", "rm22", status); + vvd(rm[1][2], 0.3977487611849338124, 1e-14, + "iauEcm06", "rm23", status); + vvd(rm[2][0], 0.2488512951527405928e-5, 1e-14, + "iauEcm06", "rm31", status); + vvd(rm[2][1], -0.3977506604161195467, 1e-14, + "iauEcm06", "rm32", status); + vvd(rm[2][2], 0.9174935488232863071, 1e-14, + "iauEcm06", "rm33", status); + +} + +static void t_ee00(int *status) +/* +** - - - - - - - +** t _ e e 0 0 +** - - - - - - - +** +** Test iauEe00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEe00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double epsa, dpsi, ee; + + + epsa = 0.4090789763356509900; + dpsi = -0.9630909107115582393e-5; + + ee = iauEe00(2400000.5, 53736.0, epsa, dpsi); + + vvd(ee, -0.8834193235367965479e-5, 1e-18, "iauEe00", "", status); + +} + +static void t_ee00a(int *status) +/* +** - - - - - - - - +** t _ e e 0 0 a +** - - - - - - - - +** +** Test iauEe00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEe00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double ee; + + + ee = iauEe00a(2400000.5, 53736.0); + + vvd(ee, -0.8834192459222588227e-5, 1e-18, "iauEe00a", "", status); + +} + +static void t_ee00b(int *status) +/* +** - - - - - - - - +** t _ e e 0 0 b +** - - - - - - - - +** +** Test iauEe00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEe00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double ee; + + + ee = iauEe00b(2400000.5, 53736.0); + + vvd(ee, -0.8835700060003032831e-5, 1e-18, "iauEe00b", "", status); + +} + +static void t_ee06a(int *status) +/* +** - - - - - - - - +** t _ e e 0 6 a +** - - - - - - - - +** +** Test iauEe06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEe06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double ee; + + + ee = iauEe06a(2400000.5, 53736.0); + + vvd(ee, -0.8834195072043790156e-5, 1e-15, "iauEe06a", "", status); +} + +static void t_eect00(int *status) +/* +** - - - - - - - - - +** t _ e e c t 0 0 +** - - - - - - - - - +** +** Test iauEect00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEect00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double eect; + + + eect = iauEect00(2400000.5, 53736.0); + + vvd(eect, 0.2046085004885125264e-8, 1e-20, "iauEect00", "", status); + +} + +static void t_eform(int *status) +/* +** - - - - - - - - +** t _ e f o r m +** - - - - - - - - +** +** Test iauEform function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEform, viv, vvd +** +** This revision: 2016 March 12 +*/ +{ + int j; + double a, f; + + j = iauEform(0, &a, &f); + + viv(j, -1, "iauEform", "j0", status); + + j = iauEform(WGS84, &a, &f); + + viv(j, 0, "iauEform", "j1", status); + vvd(a, 6378137.0, 1e-10, "iauEform", "a1", status); + vvd(f, 0.3352810664747480720e-2, 1e-18, "iauEform", "f1", status); + + j = iauEform(GRS80, &a, &f); + + viv(j, 0, "iauEform", "j2", status); + vvd(a, 6378137.0, 1e-10, "iauEform", "a2", status); + vvd(f, 0.3352810681182318935e-2, 1e-18, "iauEform", "f2", status); + + j = iauEform(WGS72, &a, &f); + + viv(j, 0, "iauEform", "j2", status); + vvd(a, 6378135.0, 1e-10, "iauEform", "a3", status); + vvd(f, 0.3352779454167504862e-2, 1e-18, "iauEform", "f3", status); + + j = iauEform(4, &a, &f); + viv(j, -1, "iauEform", "j3", status); +} + +static void t_eo06a(int *status) +/* +** - - - - - - - - +** t _ e o 0 6 a +** - - - - - - - - +** +** Test iauEo06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEo06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double eo; + + + eo = iauEo06a(2400000.5, 53736.0); + + vvd(eo, -0.1332882371941833644e-2, 1e-15, "iauEo06a", "", status); + +} + +static void t_eors(int *status) +/* +** - - - - - - - +** t _ e o r s +** - - - - - - - +** +** Test iauEors function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEors, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rnpb[3][3], s, eo; + + + rnpb[0][0] = 0.9999989440476103608; + rnpb[0][1] = -0.1332881761240011518e-2; + rnpb[0][2] = -0.5790767434730085097e-3; + + rnpb[1][0] = 0.1332858254308954453e-2; + rnpb[1][1] = 0.9999991109044505944; + rnpb[1][2] = -0.4097782710401555759e-4; + + rnpb[2][0] = 0.5791308472168153320e-3; + rnpb[2][1] = 0.4020595661593994396e-4; + rnpb[2][2] = 0.9999998314954572365; + + s = -0.1220040848472271978e-7; + + eo = iauEors(rnpb, s); + + vvd(eo, -0.1332882715130744606e-2, 1e-14, "iauEors", "", status); + +} + +static void t_epb(int *status) +/* +** - - - - - - +** t _ e p b +** - - - - - - +** +** Test iauEpb function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEpb, vvd +** +** This revision: 2013 August 7 +*/ +{ + double epb; + + + epb = iauEpb(2415019.8135, 30103.18648); + + vvd(epb, 1982.418424159278580, 1e-12, "iauEpb", "", status); + +} + +static void t_epb2jd(int *status) +/* +** - - - - - - - - - +** t _ e p b 2 j d +** - - - - - - - - - +** +** Test iauEpb2jd function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEpb2jd, vvd +** +** This revision: 2013 August 7 +*/ +{ + double epb, djm0, djm; + + + epb = 1957.3; + + iauEpb2jd(epb, &djm0, &djm); + + vvd(djm0, 2400000.5, 1e-9, "iauEpb2jd", "djm0", status); + vvd(djm, 35948.1915101513, 1e-9, "iauEpb2jd", "mjd", status); + +} + +static void t_epj(int *status) +/* +** - - - - - - +** t _ e p j +** - - - - - - +** +** Test iauEpj function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEpj, vvd +** +** This revision: 2013 August 7 +*/ +{ + double epj; + + + epj = iauEpj(2451545, -7392.5); + + vvd(epj, 1979.760438056125941, 1e-12, "iauEpj", "", status); + +} + +static void t_epj2jd(int *status) +/* +** - - - - - - - - - +** t _ e p j 2 j d +** - - - - - - - - - +** +** Test iauEpj2jd function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEpj2jd, vvd +** +** This revision: 2013 August 7 +*/ +{ + double epj, djm0, djm; + + + epj = 1996.8; + + iauEpj2jd(epj, &djm0, &djm); + + vvd(djm0, 2400000.5, 1e-9, "iauEpj2jd", "djm0", status); + vvd(djm, 50375.7, 1e-9, "iauEpj2jd", "mjd", status); + +} + +static void t_epv00(int *status) +/* +** - - - - - - - - +** t _ e p v 0 0 +** - - - - - - - - +** +** Test iauEpv00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEpv00, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double pvh[2][3], pvb[2][3]; + int j; + + + j = iauEpv00(2400000.5, 53411.52501161, pvh, pvb); + + vvd(pvh[0][0], -0.7757238809297706813, 1e-14, + "iauEpv00", "ph(x)", status); + vvd(pvh[0][1], 0.5598052241363340596, 1e-14, + "iauEpv00", "ph(y)", status); + vvd(pvh[0][2], 0.2426998466481686993, 1e-14, + "iauEpv00", "ph(z)", status); + + vvd(pvh[1][0], -0.1091891824147313846e-1, 1e-15, + "iauEpv00", "vh(x)", status); + vvd(pvh[1][1], -0.1247187268440845008e-1, 1e-15, + "iauEpv00", "vh(y)", status); + vvd(pvh[1][2], -0.5407569418065039061e-2, 1e-15, + "iauEpv00", "vh(z)", status); + + vvd(pvb[0][0], -0.7714104440491111971, 1e-14, + "iauEpv00", "pb(x)", status); + vvd(pvb[0][1], 0.5598412061824171323, 1e-14, + "iauEpv00", "pb(y)", status); + vvd(pvb[0][2], 0.2425996277722452400, 1e-14, + "iauEpv00", "pb(z)", status); + + vvd(pvb[1][0], -0.1091874268116823295e-1, 1e-15, + "iauEpv00", "vb(x)", status); + vvd(pvb[1][1], -0.1246525461732861538e-1, 1e-15, + "iauEpv00", "vb(y)", status); + vvd(pvb[1][2], -0.5404773180966231279e-2, 1e-15, + "iauEpv00", "vb(z)", status); + + viv(j, 0, "iauEpv00", "j", status); + +} + +static void t_eqec06(int *status) +/* +** - - - - - - - - - +** t _ e q e c 0 6 +** - - - - - - - - - +** +** Test iauEqec06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEqec06, vvd +** +** This revision: 2016 March 12 +*/ +{ + double date1, date2, dr, dd, dl, db; + + + date1 = 1234.5; + date2 = 2440000.5; + dr = 1.234; + dd = 0.987; + + iauEqec06(date1, date2, dr, dd, &dl, &db); + + vvd(dl, 1.342509918994654619, 1e-14, "iauEqec06", "dl", status); + vvd(db, 0.5926215259704608132, 1e-14, "iauEqec06", "db", status); + +} + +static void t_eqeq94(int *status) +/* +** - - - - - - - - - +** t _ e q e q 9 4 +** - - - - - - - - - +** +** Test iauEqeq94 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEqeq94, vvd +** +** This revision: 2013 August 7 +*/ +{ + double eqeq; + + + eqeq = iauEqeq94(2400000.5, 41234.0); + + vvd(eqeq, 0.5357758254609256894e-4, 1e-17, "iauEqeq94", "", status); + +} + +static void t_era00(int *status) +/* +** - - - - - - - - +** t _ e r a 0 0 +** - - - - - - - - +** +** Test iauEra00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauEra00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double era00; + + + era00 = iauEra00(2400000.5, 54388.0); + + vvd(era00, 0.4022837240028158102, 1e-12, "iauEra00", "", status); + +} + +static void t_fad03(int *status) +/* +** - - - - - - - - +** t _ f a d 0 3 +** - - - - - - - - +** +** Test iauFad03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFad03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFad03(0.80), 1.946709205396925672, 1e-12, + "iauFad03", "", status); +} + +static void t_fae03(int *status) +/* +** - - - - - - - - +** t _ f a e 0 3 +** - - - - - - - - +** +** Test iauFae03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFae03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFae03(0.80), 1.744713738913081846, 1e-12, + "iauFae03", "", status); +} + +static void t_faf03(int *status) +/* +** - - - - - - - - +** t _ f a f 0 3 +** - - - - - - - - +** +** Test iauFaf03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFaf03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFaf03(0.80), 0.2597711366745499518, 1e-12, + "iauFaf03", "", status); +} + +static void t_faju03(int *status) +/* +** - - - - - - - - - +** t _ f a j u 0 3 +** - - - - - - - - - +** +** Test iauFaju03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFaju03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFaju03(0.80), 5.275711665202481138, 1e-12, + "iauFaju03", "", status); +} + +static void t_fal03(int *status) +/* +** - - - - - - - - +** t _ f a l 0 3 +** - - - - - - - - +** +** Test iauFal03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFal03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFal03(0.80), 5.132369751108684150, 1e-12, + "iauFal03", "", status); +} + +static void t_falp03(int *status) +/* +** - - - - - - - - - +** t _ f a l p 0 3 +** - - - - - - - - - +** +** Test iauFalp03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFalp03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFalp03(0.80), 6.226797973505507345, 1e-12, + "iauFalp03", "", status); +} + +static void t_fama03(int *status) +/* +** - - - - - - - - - +** t _ f a m a 0 3 +** - - - - - - - - - +** +** Test iauFama03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFama03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFama03(0.80), 3.275506840277781492, 1e-12, + "iauFama03", "", status); +} + +static void t_fame03(int *status) +/* +** - - - - - - - - - +** t _ f a m e 0 3 +** - - - - - - - - - +** +** Test iauFame03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFame03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFame03(0.80), 5.417338184297289661, 1e-12, + "iauFame03", "", status); +} + +static void t_fane03(int *status) +/* +** - - - - - - - - - +** t _ f a n e 0 3 +** - - - - - - - - - +** +** Test iauFane03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFane03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFane03(0.80), 2.079343830860413523, 1e-12, + "iauFane03", "", status); +} + +static void t_faom03(int *status) +/* +** - - - - - - - - - +** t _ f a o m 0 3 +** - - - - - - - - - +** +** Test iauFaom03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFaom03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFaom03(0.80), -5.973618440951302183, 1e-12, + "iauFaom03", "", status); +} + +static void t_fapa03(int *status) +/* +** - - - - - - - - - +** t _ f a p a 0 3 +** - - - - - - - - - +** +** Test iauFapa03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFapa03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFapa03(0.80), 0.1950884762240000000e-1, 1e-12, + "iauFapa03", "", status); +} + +static void t_fasa03(int *status) +/* +** - - - - - - - - - +** t _ f a s a 0 3 +** - - - - - - - - - +** +** Test iauFasa03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFasa03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFasa03(0.80), 5.371574539440827046, 1e-12, + "iauFasa03", "", status); +} + +static void t_faur03(int *status) +/* +** - - - - - - - - - +** t _ f a u r 0 3 +** - - - - - - - - - +** +** Test iauFaur03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFaur03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFaur03(0.80), 5.180636450180413523, 1e-12, + "iauFaur03", "", status); +} + +static void t_fave03(int *status) +/* +** - - - - - - - - - +** t _ f a v e 0 3 +** - - - - - - - - - +** +** Test iauFave03 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFave03, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauFave03(0.80), 3.424900460533758000, 1e-12, + "iauFave03", "", status); +} + +static void t_fk52h(int *status) +/* +** - - - - - - - - +** t _ f k 5 2 h +** - - - - - - - - +** +** Test iauFk52h function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFk52h, vvd +** +** This revision: 2017 January 3 +*/ +{ + double r5, d5, dr5, dd5, px5, rv5, rh, dh, drh, ddh, pxh, rvh; + + + r5 = 1.76779433; + d5 = -0.2917517103; + dr5 = -1.91851572e-7; + dd5 = -5.8468475e-6; + px5 = 0.379210; + rv5 = -7.6; + + iauFk52h(r5, d5, dr5, dd5, px5, rv5, + &rh, &dh, &drh, &ddh, &pxh, &rvh); + + vvd(rh, 1.767794226299947632, 1e-14, + "iauFk52h", "ra", status); + vvd(dh, -0.2917516070530391757, 1e-14, + "iauFk52h", "dec", status); + vvd(drh, -0.19618741256057224e-6,1e-19, + "iauFk52h", "dr5", status); + vvd(ddh, -0.58459905176693911e-5, 1e-19, + "iauFk52h", "dd5", status); + vvd(pxh, 0.37921, 1e-14, + "iauFk52h", "px", status); + vvd(rvh, -7.6000000940000254, 1e-11, + "iauFk52h", "rv", status); + +} + +static void t_fk5hip(int *status) +/* +** - - - - - - - - - +** t _ f k 5 h i p +** - - - - - - - - - +** +** Test iauFk5hip function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFk5hip, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r5h[3][3], s5h[3]; + + + iauFk5hip(r5h, s5h); + + vvd(r5h[0][0], 0.9999999999999928638, 1e-14, + "iauFk5hip", "11", status); + vvd(r5h[0][1], 0.1110223351022919694e-6, 1e-17, + "iauFk5hip", "12", status); + vvd(r5h[0][2], 0.4411803962536558154e-7, 1e-17, + "iauFk5hip", "13", status); + vvd(r5h[1][0], -0.1110223308458746430e-6, 1e-17, + "iauFk5hip", "21", status); + vvd(r5h[1][1], 0.9999999999999891830, 1e-14, + "iauFk5hip", "22", status); + vvd(r5h[1][2], -0.9647792498984142358e-7, 1e-17, + "iauFk5hip", "23", status); + vvd(r5h[2][0], -0.4411805033656962252e-7, 1e-17, + "iauFk5hip", "31", status); + vvd(r5h[2][1], 0.9647792009175314354e-7, 1e-17, + "iauFk5hip", "32", status); + vvd(r5h[2][2], 0.9999999999999943728, 1e-14, + "iauFk5hip", "33", status); + vvd(s5h[0], -0.1454441043328607981e-8, 1e-17, + "iauFk5hip", "s1", status); + vvd(s5h[1], 0.2908882086657215962e-8, 1e-17, + "iauFk5hip", "s2", status); + vvd(s5h[2], 0.3393695767766751955e-8, 1e-17, + "iauFk5hip", "s3", status); + +} + +static void t_fk5hz(int *status) +/* +** - - - - - - - - +** t _ f k 5 h z +** - - - - - - - - +** +** Test iauFk5hz function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFk5hz, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r5, d5, rh, dh; + + + r5 = 1.76779433; + d5 = -0.2917517103; + + iauFk5hz(r5, d5, 2400000.5, 54479.0, &rh, &dh); + + vvd(rh, 1.767794191464423978, 1e-12, "iauFk5hz", "ra", status); + vvd(dh, -0.2917516001679884419, 1e-12, "iauFk5hz", "dec", status); + +} + +static void t_fw2m(int *status) +/* +** - - - - - - - +** t _ f w 2 m +** - - - - - - - +** +** Test iauFw2m function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFw2m, vvd +** +** This revision: 2013 August 7 +*/ +{ + double gamb, phib, psi, eps, r[3][3]; + + + gamb = -0.2243387670997992368e-5; + phib = 0.4091014602391312982; + psi = -0.9501954178013015092e-3; + eps = 0.4091014316587367472; + + iauFw2m(gamb, phib, psi, eps, r); + + vvd(r[0][0], 0.9999995505176007047, 1e-12, + "iauFw2m", "11", status); + vvd(r[0][1], 0.8695404617348192957e-3, 1e-12, + "iauFw2m", "12", status); + vvd(r[0][2], 0.3779735201865582571e-3, 1e-12, + "iauFw2m", "13", status); + + vvd(r[1][0], -0.8695404723772016038e-3, 1e-12, + "iauFw2m", "21", status); + vvd(r[1][1], 0.9999996219496027161, 1e-12, + "iauFw2m", "22", status); + vvd(r[1][2], -0.1361752496887100026e-6, 1e-12, + "iauFw2m", "23", status); + + vvd(r[2][0], -0.3779734957034082790e-3, 1e-12, + "iauFw2m", "31", status); + vvd(r[2][1], -0.1924880848087615651e-6, 1e-12, + "iauFw2m", "32", status); + vvd(r[2][2], 0.9999999285679971958, 1e-12, + "iauFw2m", "33", status); + +} + +static void t_fw2xy(int *status) +/* +** - - - - - - - - +** t _ f w 2 x y +** - - - - - - - - +** +** Test iauFw2xy function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauFw2xy, vvd +** +** This revision: 2013 August 7 +*/ +{ + double gamb, phib, psi, eps, x, y; + + + gamb = -0.2243387670997992368e-5; + phib = 0.4091014602391312982; + psi = -0.9501954178013015092e-3; + eps = 0.4091014316587367472; + + iauFw2xy(gamb, phib, psi, eps, &x, &y); + + vvd(x, -0.3779734957034082790e-3, 1e-14, "iauFw2xy", "x", status); + vvd(y, -0.1924880848087615651e-6, 1e-14, "iauFw2xy", "y", status); + +} + +static void t_g2icrs(int *status) +/* +** - - - - - - - - - +** t _ g 2 i c r s +** - - - - - - - - - +** +** Test iauG2icrs function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauG2icrs, vvd +** +** This revision: 2015 January 30 +*/ +{ + double dl, db, dr, dd; + + + dl = 5.5850536063818546461558105; + db = -0.7853981633974483096156608; + iauG2icrs (dl, db, &dr, &dd); + vvd(dr, 5.9338074302227188048671, 1e-14, "iauG2icrs", "R", status); + vvd(dd, -1.1784870613579944551541, 1e-14, "iauG2icrs", "D", status); + } + +static void t_gc2gd(int *status) +/* +** - - - - - - - - +** t _ g c 2 g d +** - - - - - - - - +** +** Test iauGc2gd function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGc2gd, viv, vvd +** +** This revision: 2016 March 12 +*/ +{ + int j; + double xyz[] = {2e6, 3e6, 5.244e6}; + double e, p, h; + + j = iauGc2gd(0, xyz, &e, &p, &h); + + viv(j, -1, "iauGc2gd", "j0", status); + + j = iauGc2gd(WGS84, xyz, &e, &p, &h); + + viv(j, 0, "iauGc2gd", "j1", status); + vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gd", "e1", status); + vvd(p, 0.97160184819075459, 1e-14, "iauGc2gd", "p1", status); + vvd(h, 331.4172461426059892, 1e-8, "iauGc2gd", "h1", status); + + j = iauGc2gd(GRS80, xyz, &e, &p, &h); + + viv(j, 0, "iauGc2gd", "j2", status); + vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gd", "e2", status); + vvd(p, 0.97160184820607853, 1e-14, "iauGc2gd", "p2", status); + vvd(h, 331.41731754844348, 1e-8, "iauGc2gd", "h2", status); + + j = iauGc2gd(WGS72, xyz, &e, &p, &h); + + viv(j, 0, "iauGc2gd", "j3", status); + vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gd", "e3", status); + vvd(p, 0.9716018181101511937, 1e-14, "iauGc2gd", "p3", status); + vvd(h, 333.2770726130318123, 1e-8, "iauGc2gd", "h3", status); + + j = iauGc2gd(4, xyz, &e, &p, &h); + + viv(j, -1, "iauGc2gd", "j4", status); +} + +static void t_gc2gde(int *status) +/* +** - - - - - - - - - +** t _ g c 2 g d e +** - - - - - - - - - +** +** Test iauGc2gde function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGc2gde, viv, vvd +** +** This revision: 2016 March 12 +*/ +{ + int j; + double a = 6378136.0, f = 0.0033528; + double xyz[] = {2e6, 3e6, 5.244e6}; + double e, p, h; + + j = iauGc2gde(a, f, xyz, &e, &p, &h); + + viv(j, 0, "iauGc2gde", "j", status); + vvd(e, 0.9827937232473290680, 1e-14, "iauGc2gde", "e", status); + vvd(p, 0.9716018377570411532, 1e-14, "iauGc2gde", "p", status); + vvd(h, 332.36862495764397, 1e-8, "iauGc2gde", "h", status); +} + +static void t_gd2gc(int *status) +/* +** - - - - - - - - +** t _ g d 2 g c +** - - - - - - - - +** +** Test iauGd2gc function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGd2gc, viv, vvd +** +** This revision: 2016 March 12 +*/ +{ + int j; + double e = 3.1, p = -0.5, h = 2500.0; + double xyz[3]; + + j = iauGd2gc(0, e, p, h, xyz); + + viv(j, -1, "iauGd2gc", "j0", status); + + j = iauGd2gc(WGS84, e, p, h, xyz); + + viv(j, 0, "iauGd2gc", "j1", status); + vvd(xyz[0], -5599000.5577049947, 1e-7, "iauGd2gc", "1/1", status); + vvd(xyz[1], 233011.67223479203, 1e-7, "iauGd2gc", "2/1", status); + vvd(xyz[2], -3040909.4706983363, 1e-7, "iauGd2gc", "3/1", status); + + j = iauGd2gc(GRS80, e, p, h, xyz); + + viv(j, 0, "iauGd2gc", "j2", status); + vvd(xyz[0], -5599000.5577260984, 1e-7, "iauGd2gc", "1/2", status); + vvd(xyz[1], 233011.6722356702949, 1e-7, "iauGd2gc", "2/2", status); + vvd(xyz[2], -3040909.4706095476, 1e-7, "iauGd2gc", "3/2", status); + + j = iauGd2gc(WGS72, e, p, h, xyz); + + viv(j, 0, "iauGd2gc", "j3", status); + vvd(xyz[0], -5598998.7626301490, 1e-7, "iauGd2gc", "1/3", status); + vvd(xyz[1], 233011.5975297822211, 1e-7, "iauGd2gc", "2/3", status); + vvd(xyz[2], -3040908.6861467111, 1e-7, "iauGd2gc", "3/3", status); + + j = iauGd2gc(4, e, p, h, xyz); + + viv(j, -1, "iauGd2gc", "j4", status); +} + +static void t_gd2gce(int *status) +/* +** - - - - - - - - - +** t _ g d 2 g c e +** - - - - - - - - - +** +** Test iauGd2gce function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGd2gce, viv, vvd +** +** This revision: 2016 March 12 +*/ +{ + int j; + double a = 6378136.0, f = 0.0033528; + double e = 3.1, p = -0.5, h = 2500.0; + double xyz[3]; + + j = iauGd2gce(a, f, e, p, h, xyz); + + viv(j, 0, "iauGd2gce", "j", status); + vvd(xyz[0], -5598999.6665116328, 1e-7, "iauGd2gce", "1", status); + vvd(xyz[1], 233011.6351463057189, 1e-7, "iauGd2gce", "2", status); + vvd(xyz[2], -3040909.0517314132, 1e-7, "iauGd2gce", "3", status); +} + +static void t_gmst00(int *status) +/* +** - - - - - - - - - +** t _ g m s t 0 0 +** - - - - - - - - - +** +** Test iauGmst00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGmst00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta; + + + theta = iauGmst00(2400000.5, 53736.0, 2400000.5, 53736.0); + + vvd(theta, 1.754174972210740592, 1e-12, "iauGmst00", "", status); + +} + +static void t_gmst06(int *status) +/* +** - - - - - - - - - +** t _ g m s t 0 6 +** - - - - - - - - - +** +** Test iauGmst06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGmst06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta; + + + theta = iauGmst06(2400000.5, 53736.0, 2400000.5, 53736.0); + + vvd(theta, 1.754174971870091203, 1e-12, "iauGmst06", "", status); + +} + +static void t_gmst82(int *status) +/* +** - - - - - - - - - +** t _ g m s t 8 2 +** - - - - - - - - - +** +** Test iauGmst82 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGmst82, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta; + + + theta = iauGmst82(2400000.5, 53736.0); + + vvd(theta, 1.754174981860675096, 1e-12, "iauGmst82", "", status); + +} + +static void t_gst00a(int *status) +/* +** - - - - - - - - - +** t _ g s t 0 0 a +** - - - - - - - - - +** +** Test iauGst00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGst00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta; + + + theta = iauGst00a(2400000.5, 53736.0, 2400000.5, 53736.0); + + vvd(theta, 1.754166138018281369, 1e-12, "iauGst00a", "", status); + +} + +static void t_gst00b(int *status) +/* +** - - - - - - - - - +** t _ g s t 0 0 b +** - - - - - - - - - +** +** Test iauGst00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGst00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta; + + + theta = iauGst00b(2400000.5, 53736.0); + + vvd(theta, 1.754166136510680589, 1e-12, "iauGst00b", "", status); + +} + +static void t_gst06(int *status) +/* +** - - - - - - - - +** t _ g s t 0 6 +** - - - - - - - - +** +** Test iauGst06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGst06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rnpb[3][3], theta; + + + rnpb[0][0] = 0.9999989440476103608; + rnpb[0][1] = -0.1332881761240011518e-2; + rnpb[0][2] = -0.5790767434730085097e-3; + + rnpb[1][0] = 0.1332858254308954453e-2; + rnpb[1][1] = 0.9999991109044505944; + rnpb[1][2] = -0.4097782710401555759e-4; + + rnpb[2][0] = 0.5791308472168153320e-3; + rnpb[2][1] = 0.4020595661593994396e-4; + rnpb[2][2] = 0.9999998314954572365; + + theta = iauGst06(2400000.5, 53736.0, 2400000.5, 53736.0, rnpb); + + vvd(theta, 1.754166138018167568, 1e-12, "iauGst06", "", status); + +} + +static void t_gst06a(int *status) +/* +** - - - - - - - - - +** t _ g s t 0 6 a +** - - - - - - - - - +** +** Test iauGst06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGst06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta; + + + theta = iauGst06a(2400000.5, 53736.0, 2400000.5, 53736.0); + + vvd(theta, 1.754166137675019159, 1e-12, "iauGst06a", "", status); + +} + +static void t_gst94(int *status) +/* +** - - - - - - - - +** t _ g s t 9 4 +** - - - - - - - - +** +** Test iauGst94 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauGst94, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta; + + + theta = iauGst94(2400000.5, 53736.0); + + vvd(theta, 1.754166136020645203, 1e-12, "iauGst94", "", status); + +} + +static void t_icrs2g(int *status) +/* +** - - - - - - - - - +** t _ i c r s 2 g +** - - - - - - - - - +** +** Test iauIcrs2g function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauIcrs2g, vvd +** +** This revision: 2015 January 30 +*/ +{ + double dr, dd, dl, db; + + dr = 5.9338074302227188048671087; + dd = -1.1784870613579944551540570; + iauIcrs2g (dr, dd, &dl, &db); + vvd(dl, 5.5850536063818546461558, 1e-14, "iauIcrs2g", "L", status); + vvd(db, -0.7853981633974483096157, 1e-14, "iauIcrs2g", "B", status); + } + +static void t_h2fk5(int *status) +/* +** - - - - - - - - +** t _ h 2 f k 5 +** - - - - - - - - +** +** Test iauH2fk5 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauH2fk5, vvd +** +** This revision: 2017 January 3 +*/ +{ + double rh, dh, drh, ddh, pxh, rvh, r5, d5, dr5, dd5, px5, rv5; + + + rh = 1.767794352; + dh = -0.2917512594; + drh = -2.76413026e-6; + ddh = -5.92994449e-6; + pxh = 0.379210; + rvh = -7.6; + + iauH2fk5(rh, dh, drh, ddh, pxh, rvh, + &r5, &d5, &dr5, &dd5, &px5, &rv5); + + vvd(r5, 1.767794455700065506, 1e-13, + "iauH2fk5", "ra", status); + vvd(d5, -0.2917513626469638890, 1e-13, + "iauH2fk5", "dec", status); + vvd(dr5, -0.27597945024511204e-5, 1e-18, + "iauH2fk5", "dr5", status); + vvd(dd5, -0.59308014093262838e-5, 1e-18, + "iauH2fk5", "dd5", status); + vvd(px5, 0.37921, 1e-13, + "iauH2fk5", "px", status); + vvd(rv5, -7.6000001309071126, 1e-11, + "iauH2fk5", "rv", status); + +} + +static void t_hfk5z(int *status) +/* +** - - - - - - - - +** t _ h f k 5 z +** - - - - - - - - +** +** Test iauHfk5z function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauHfk5z, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rh, dh, r5, d5, dr5, dd5; + + + + rh = 1.767794352; + dh = -0.2917512594; + + iauHfk5z(rh, dh, 2400000.5, 54479.0, &r5, &d5, &dr5, &dd5); + + vvd(r5, 1.767794490535581026, 1e-13, + "iauHfk5z", "ra", status); + vvd(d5, -0.2917513695320114258, 1e-14, + "iauHfk5z", "dec", status); + vvd(dr5, 0.4335890983539243029e-8, 1e-22, + "iauHfk5z", "dr5", status); + vvd(dd5, -0.8569648841237745902e-9, 1e-23, + "iauHfk5z", "dd5", status); + +} + +static void t_ir(int *status) +/* +** - - - - - +** t _ i r +** - - - - - +** +** Test iauIr function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauIr, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3]; + + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + iauIr(r); + + vvd(r[0][0], 1.0, 0.0, "iauIr", "11", status); + vvd(r[0][1], 0.0, 0.0, "iauIr", "12", status); + vvd(r[0][2], 0.0, 0.0, "iauIr", "13", status); + + vvd(r[1][0], 0.0, 0.0, "iauIr", "21", status); + vvd(r[1][1], 1.0, 0.0, "iauIr", "22", status); + vvd(r[1][2], 0.0, 0.0, "iauIr", "23", status); + + vvd(r[2][0], 0.0, 0.0, "iauIr", "31", status); + vvd(r[2][1], 0.0, 0.0, "iauIr", "32", status); + vvd(r[2][2], 1.0, 0.0, "iauIr", "33", status); + +} + +static void t_jd2cal(int *status) +/* +** - - - - - - - - - +** t _ j d 2 c a l +** - - - - - - - - - +** +** Test iauJd2cal function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauJd2cal, viv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dj1, dj2, fd; + int iy, im, id, j; + + + dj1 = 2400000.5; + dj2 = 50123.9999; + + j = iauJd2cal(dj1, dj2, &iy, &im, &id, &fd); + + viv(iy, 1996, "iauJd2cal", "y", status); + viv(im, 2, "iauJd2cal", "m", status); + viv(id, 10, "iauJd2cal", "d", status); + vvd(fd, 0.9999, 1e-7, "iauJd2cal", "fd", status); + viv(j, 0, "iauJd2cal", "j", status); + +} + +static void t_jdcalf(int *status) +/* +** - - - - - - - - - +** t _ j d c a l f +** - - - - - - - - - +** +** Test iauJdcalf function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauJdcalf, viv +** +** This revision: 2013 August 7 +*/ +{ + double dj1, dj2; + int iydmf[4], j; + + + dj1 = 2400000.5; + dj2 = 50123.9999; + + j = iauJdcalf(4, dj1, dj2, iydmf); + + viv(iydmf[0], 1996, "iauJdcalf", "y", status); + viv(iydmf[1], 2, "iauJdcalf", "m", status); + viv(iydmf[2], 10, "iauJdcalf", "d", status); + viv(iydmf[3], 9999, "iauJdcalf", "f", status); + + viv(j, 0, "iauJdcalf", "j", status); + +} + +static void t_ld(int *status) +/* +** - - - - - +** t _ l d +** - - - - - +** +** Test iauLd function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLd, vvd +* +** This revision: 2013 October 2 +*/ +{ + double bm, p[3], q[3], e[3], em, dlim, p1[3]; + + + bm = 0.00028574; + p[0] = -0.763276255; + p[1] = -0.608633767; + p[2] = -0.216735543; + q[0] = -0.763276255; + q[1] = -0.608633767; + q[2] = -0.216735543; + e[0] = 0.76700421; + e[1] = 0.605629598; + e[2] = 0.211937094; + em = 8.91276983; + dlim = 3e-10; + + iauLd(bm, p, q, e, em, dlim, p1); + + vvd(p1[0], -0.7632762548968159627, 1e-12, + "iauLd", "1", status); + vvd(p1[1], -0.6086337670823762701, 1e-12, + "iauLd", "2", status); + vvd(p1[2], -0.2167355431320546947, 1e-12, + "iauLd", "3", status); + +} + +static void t_ldn(int *status) +/* +** - - - - - - +** t _ l d n +** - - - - - - +** +** Test iauLdn function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLdn, vvd +** +** This revision: 2013 October 2 +*/ +{ + int n; + iauLDBODY b[3]; + double ob[3], sc[3], sn[3]; + + + n = 3; + b[0].bm = 0.00028574; + b[0].dl = 3e-10; + b[0].pv[0][0] = -7.81014427; + b[0].pv[0][1] = -5.60956681; + b[0].pv[0][2] = -1.98079819; + b[0].pv[1][0] = 0.0030723249; + b[0].pv[1][1] = -0.00406995477; + b[0].pv[1][2] = -0.00181335842; + b[1].bm = 0.00095435; + b[1].dl = 3e-9; + b[1].pv[0][0] = 0.738098796; + b[1].pv[0][1] = 4.63658692; + b[1].pv[0][2] = 1.9693136; + b[1].pv[1][0] = -0.00755816922; + b[1].pv[1][1] = 0.00126913722; + b[1].pv[1][2] = 0.000727999001; + b[2].bm = 1.0; + b[2].dl = 6e-6; + b[2].pv[0][0] = -0.000712174377; + b[2].pv[0][1] = -0.00230478303; + b[2].pv[0][2] = -0.00105865966; + b[2].pv[1][0] = 6.29235213e-6; + b[2].pv[1][1] = -3.30888387e-7; + b[2].pv[1][2] = -2.96486623e-7; + ob[0] = -0.974170437; + ob[1] = -0.2115201; + ob[2] = -0.0917583114; + sc[0] = -0.763276255; + sc[1] = -0.608633767; + sc[2] = -0.216735543; + + iauLdn(n, b, ob, sc, sn); + + vvd(sn[0], -0.7632762579693333866, 1e-12, + "iauLdn", "1", status); + vvd(sn[1], -0.6086337636093002660, 1e-12, + "iauLdn", "2", status); + vvd(sn[2], -0.2167355420646328159, 1e-12, + "iauLdn", "3", status); + +} + +static void t_ldsun(int *status) +/* +** - - - - - - - - +** t _ l d s u n +** - - - - - - - - +** +** Test iauLdsun function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLdsun, vvd +** +** This revision: 2013 October 2 +*/ +{ + double p[3], e[3], em, p1[3]; + + + p[0] = -0.763276255; + p[1] = -0.608633767; + p[2] = -0.216735543; + e[0] = -0.973644023; + e[1] = -0.20925523; + e[2] = -0.0907169552; + em = 0.999809214; + + iauLdsun(p, e, em, p1); + + vvd(p1[0], -0.7632762580731413169, 1e-12, + "iauLdsun", "1", status); + vvd(p1[1], -0.6086337635262647900, 1e-12, + "iauLdsun", "2", status); + vvd(p1[2], -0.2167355419322321302, 1e-12, + "iauLdsun", "3", status); + +} + +static void t_lteceq(int *status) +/* +** - - - - - - - - - +** t _ l t e c e q +** - - - - - - - - - +** +** Test iauLteceq function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLteceq, vvd +** +** This revision: 2016 March 12 +*/ +{ + double epj, dl, db, dr, dd; + + + epj = 2500.0; + dl = 1.5; + db = 0.6; + + iauLteceq(epj, dl, db, &dr, &dd); + + vvd(dr, 1.275156021861921167, 1e-14, "iauLteceq", "dr", status); + vvd(dd, 0.9966573543519204791, 1e-14, "iauLteceq", "dd", status); + +} + +static void t_ltecm(int *status) +/* +** - - - - - - - - +** t _ l t e c m +** - - - - - - - - +** +** Test iauLtecm function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLtecm, vvd +** +** This revision: 2016 March 12 +*/ +{ + double epj, rm[3][3]; + + + epj = -3000.0; + + iauLtecm(epj, rm); + + vvd(rm[0][0], 0.3564105644859788825, 1e-14, + "iauLtecm", "rm11", status); + vvd(rm[0][1], 0.8530575738617682284, 1e-14, + "iauLtecm", "rm12", status); + vvd(rm[0][2], 0.3811355207795060435, 1e-14, + "iauLtecm", "rm13", status); + vvd(rm[1][0], -0.9343283469640709942, 1e-14, + "iauLtecm", "rm21", status); + vvd(rm[1][1], 0.3247830597681745976, 1e-14, + "iauLtecm", "rm22", status); + vvd(rm[1][2], 0.1467872751535940865, 1e-14, + "iauLtecm", "rm23", status); + vvd(rm[2][0], 0.1431636191201167793e-2, 1e-14, + "iauLtecm", "rm31", status); + vvd(rm[2][1], -0.4084222566960599342, 1e-14, + "iauLtecm", "rm32", status); + vvd(rm[2][2], 0.9127919865189030899, 1e-14, + "iauLtecm", "rm33", status); + +} + +static void t_lteqec(int *status) +/* +** - - - - - - - - - +** t _ l t e q e c +** - - - - - - - - - +** +** Test iauLteqec function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLteqec, vvd +** +** This revision: 2016 March 12 +*/ +{ + double epj, dr, dd, dl, db; + + + epj = -1500.0; + dr = 1.234; + dd = 0.987; + + iauLteqec(epj, dr, dd, &dl, &db); + + vvd(dl, 0.5039483649047114859, 1e-14, "iauLteqec", "dl", status); + vvd(db, 0.5848534459726224882, 1e-14, "iauLteqec", "db", status); + +} + +static void t_ltp(int *status) +/* +** - - - - - - +** t _ l t p +** - - - - - - +** +** Test iauLtp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLtp, vvd +** +** This revision: 2016 March 12 +*/ +{ + double epj, rp[3][3]; + + + epj = 1666.666; + + iauLtp(epj, rp); + + vvd(rp[0][0], 0.9967044141159213819, 1e-14, + "iauLtp", "rp11", status); + vvd(rp[0][1], 0.7437801893193210840e-1, 1e-14, + "iauLtp", "rp12", status); + vvd(rp[0][2], 0.3237624409345603401e-1, 1e-14, + "iauLtp", "rp13", status); + vvd(rp[1][0], -0.7437802731819618167e-1, 1e-14, + "iauLtp", "rp21", status); + vvd(rp[1][1], 0.9972293894454533070, 1e-14, + "iauLtp", "rp22", status); + vvd(rp[1][2], -0.1205768842723593346e-2, 1e-14, + "iauLtp", "rp23", status); + vvd(rp[2][0], -0.3237622482766575399e-1, 1e-14, + "iauLtp", "rp31", status); + vvd(rp[2][1], -0.1206286039697609008e-2, 1e-14, + "iauLtp", "rp32", status); + vvd(rp[2][2], 0.9994750246704010914, 1e-14, + "iauLtp", "rp33", status); + +} + +static void t_ltpb(int *status) +/* +** - - - - - - - +** t _ l t p b +** - - - - - - - +** +** Test iauLtpb function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLtpb, vvd +** +** This revision: 2016 March 12 +*/ +{ + double epj, rpb[3][3]; + + + epj = 1666.666; + + iauLtpb(epj, rpb); + + vvd(rpb[0][0], 0.9967044167723271851, 1e-14, + "iauLtpb", "rpb11", status); + vvd(rpb[0][1], 0.7437794731203340345e-1, 1e-14, + "iauLtpb", "rpb12", status); + vvd(rpb[0][2], 0.3237632684841625547e-1, 1e-14, + "iauLtpb", "rpb13", status); + vvd(rpb[1][0], -0.7437795663437177152e-1, 1e-14, + "iauLtpb", "rpb21", status); + vvd(rpb[1][1], 0.9972293947500013666, 1e-14, + "iauLtpb", "rpb22", status); + vvd(rpb[1][2], -0.1205741865911243235e-2, 1e-14, + "iauLtpb", "rpb23", status); + vvd(rpb[2][0], -0.3237630543224664992e-1, 1e-14, + "iauLtpb", "rpb31", status); + vvd(rpb[2][1], -0.1206316791076485295e-2, 1e-14, + "iauLtpb", "rpb32", status); + vvd(rpb[2][2], 0.9994750220222438819, 1e-14, + "iauLtpb", "rpb33", status); + +} + +static void t_ltpecl(int *status) +/* +** - - - - - - - - - +** t _ l t p e c l +** - - - - - - - - - +** +** Test iauLtpecl function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLtpecl, vvd +** +** This revision: 2016 March 12 +*/ +{ + double epj, vec[3]; + + + epj = -1500.0; + + iauLtpecl(epj, vec); + + vvd(vec[0], 0.4768625676477096525e-3, 1e-14, + "iauLtpecl", "vec1", status); + vvd(vec[1], -0.4052259533091875112, 1e-14, + "iauLtpecl", "vec2", status); + vvd(vec[2], 0.9142164401096448012, 1e-14, + "iauLtpecl", "vec3", status); + +} + +static void t_ltpequ(int *status) +/* +** - - - - - - - - - +** t _ l t p e q u +** - - - - - - - - - +** +** Test iauLtpequ function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauLtpequ, vvd +** +** This revision: 2016 March 12 +*/ +{ + double epj, veq[3]; + + + epj = -2500.0; + + iauLtpequ(epj, veq); + + vvd(veq[0], -0.3586652560237326659, 1e-14, + "iauLtpequ", "veq1", status); + vvd(veq[1], -0.1996978910771128475, 1e-14, + "iauLtpequ", "veq2", status); + vvd(veq[2], 0.9118552442250819624, 1e-14, + "iauLtpequ", "veq3", status); + +} + +static void t_num00a(int *status) +/* +** - - - - - - - - - +** t _ n u m 0 0 a +** - - - - - - - - - +** +** Test iauNum00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNum00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rmatn[3][3]; + + + iauNum00a(2400000.5, 53736.0, rmatn); + + vvd(rmatn[0][0], 0.9999999999536227949, 1e-12, + "iauNum00a", "11", status); + vvd(rmatn[0][1], 0.8836238544090873336e-5, 1e-12, + "iauNum00a", "12", status); + vvd(rmatn[0][2], 0.3830835237722400669e-5, 1e-12, + "iauNum00a", "13", status); + + vvd(rmatn[1][0], -0.8836082880798569274e-5, 1e-12, + "iauNum00a", "21", status); + vvd(rmatn[1][1], 0.9999999991354655028, 1e-12, + "iauNum00a", "22", status); + vvd(rmatn[1][2], -0.4063240865362499850e-4, 1e-12, + "iauNum00a", "23", status); + + vvd(rmatn[2][0], -0.3831194272065995866e-5, 1e-12, + "iauNum00a", "31", status); + vvd(rmatn[2][1], 0.4063237480216291775e-4, 1e-12, + "iauNum00a", "32", status); + vvd(rmatn[2][2], 0.9999999991671660338, 1e-12, + "iauNum00a", "33", status); + +} + +static void t_num00b(int *status) +/* +** - - - - - - - - - +** t _ n u m 0 0 b +** - - - - - - - - - +** +** Test iauNum00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNum00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rmatn[3][3]; + + iauNum00b(2400000.5, 53736, rmatn); + + vvd(rmatn[0][0], 0.9999999999536069682, 1e-12, + "iauNum00b", "11", status); + vvd(rmatn[0][1], 0.8837746144871248011e-5, 1e-12, + "iauNum00b", "12", status); + vvd(rmatn[0][2], 0.3831488838252202945e-5, 1e-12, + "iauNum00b", "13", status); + + vvd(rmatn[1][0], -0.8837590456632304720e-5, 1e-12, + "iauNum00b", "21", status); + vvd(rmatn[1][1], 0.9999999991354692733, 1e-12, + "iauNum00b", "22", status); + vvd(rmatn[1][2], -0.4063198798559591654e-4, 1e-12, + "iauNum00b", "23", status); + + vvd(rmatn[2][0], -0.3831847930134941271e-5, 1e-12, + "iauNum00b", "31", status); + vvd(rmatn[2][1], 0.4063195412258168380e-4, 1e-12, + "iauNum00b", "32", status); + vvd(rmatn[2][2], 0.9999999991671806225, 1e-12, + "iauNum00b", "33", status); + +} + +static void t_num06a(int *status) +/* +** - - - - - - - - - +** t _ n u m 0 6 a +** - - - - - - - - - +** +** Test iauNum06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNum06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rmatn[3][3]; + + iauNum06a(2400000.5, 53736, rmatn); + + vvd(rmatn[0][0], 0.9999999999536227668, 1e-12, + "iauNum06a", "11", status); + vvd(rmatn[0][1], 0.8836241998111535233e-5, 1e-12, + "iauNum06a", "12", status); + vvd(rmatn[0][2], 0.3830834608415287707e-5, 1e-12, + "iauNum06a", "13", status); + + vvd(rmatn[1][0], -0.8836086334870740138e-5, 1e-12, + "iauNum06a", "21", status); + vvd(rmatn[1][1], 0.9999999991354657474, 1e-12, + "iauNum06a", "22", status); + vvd(rmatn[1][2], -0.4063240188248455065e-4, 1e-12, + "iauNum06a", "23", status); + + vvd(rmatn[2][0], -0.3831193642839398128e-5, 1e-12, + "iauNum06a", "31", status); + vvd(rmatn[2][1], 0.4063236803101479770e-4, 1e-12, + "iauNum06a", "32", status); + vvd(rmatn[2][2], 0.9999999991671663114, 1e-12, + "iauNum06a", "33", status); + +} + +static void t_numat(int *status) +/* +** - - - - - - - - +** t _ n u m a t +** - - - - - - - - +** +** Test iauNumat function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNumat, vvd +** +** This revision: 2013 August 7 +*/ +{ + double epsa, dpsi, deps, rmatn[3][3]; + + + epsa = 0.4090789763356509900; + dpsi = -0.9630909107115582393e-5; + deps = 0.4063239174001678826e-4; + + iauNumat(epsa, dpsi, deps, rmatn); + + vvd(rmatn[0][0], 0.9999999999536227949, 1e-12, + "iauNumat", "11", status); + vvd(rmatn[0][1], 0.8836239320236250577e-5, 1e-12, + "iauNumat", "12", status); + vvd(rmatn[0][2], 0.3830833447458251908e-5, 1e-12, + "iauNumat", "13", status); + + vvd(rmatn[1][0], -0.8836083657016688588e-5, 1e-12, + "iauNumat", "21", status); + vvd(rmatn[1][1], 0.9999999991354654959, 1e-12, + "iauNumat", "22", status); + vvd(rmatn[1][2], -0.4063240865361857698e-4, 1e-12, + "iauNumat", "23", status); + + vvd(rmatn[2][0], -0.3831192481833385226e-5, 1e-12, + "iauNumat", "31", status); + vvd(rmatn[2][1], 0.4063237480216934159e-4, 1e-12, + "iauNumat", "32", status); + vvd(rmatn[2][2], 0.9999999991671660407, 1e-12, + "iauNumat", "33", status); + +} + +static void t_nut00a(int *status) +/* +** - - - - - - - - - +** t _ n u t 0 0 a +** - - - - - - - - - +** +** Test iauNut00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNut00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps; + + + iauNut00a(2400000.5, 53736.0, &dpsi, &deps); + + vvd(dpsi, -0.9630909107115518431e-5, 1e-13, + "iauNut00a", "dpsi", status); + vvd(deps, 0.4063239174001678710e-4, 1e-13, + "iauNut00a", "deps", status); + +} + +static void t_nut00b(int *status) +/* +** - - - - - - - - - +** t _ n u t 0 0 b +** - - - - - - - - - +** +** Test iauNut00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNut00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps; + + + iauNut00b(2400000.5, 53736.0, &dpsi, &deps); + + vvd(dpsi, -0.9632552291148362783e-5, 1e-13, + "iauNut00b", "dpsi", status); + vvd(deps, 0.4063197106621159367e-4, 1e-13, + "iauNut00b", "deps", status); + +} + +static void t_nut06a(int *status) +/* +** - - - - - - - - - +** t _ n u t 0 6 a +** - - - - - - - - - +** +** Test iauNut06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNut06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps; + + + iauNut06a(2400000.5, 53736.0, &dpsi, &deps); + + vvd(dpsi, -0.9630912025820308797e-5, 1e-13, + "iauNut06a", "dpsi", status); + vvd(deps, 0.4063238496887249798e-4, 1e-13, + "iauNut06a", "deps", status); + +} + +static void t_nut80(int *status) +/* +** - - - - - - - - +** t _ n u t 8 0 +** - - - - - - - - +** +** Test iauNut80 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNut80, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps; + + + iauNut80(2400000.5, 53736.0, &dpsi, &deps); + + vvd(dpsi, -0.9643658353226563966e-5, 1e-13, + "iauNut80", "dpsi", status); + vvd(deps, 0.4060051006879713322e-4, 1e-13, + "iauNut80", "deps", status); + +} + +static void t_nutm80(int *status) +/* +** - - - - - - - - - +** t _ n u t m 8 0 +** - - - - - - - - - +** +** Test iauNutm80 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauNutm80, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rmatn[3][3]; + + + iauNutm80(2400000.5, 53736.0, rmatn); + + vvd(rmatn[0][0], 0.9999999999534999268, 1e-12, + "iauNutm80", "11", status); + vvd(rmatn[0][1], 0.8847935789636432161e-5, 1e-12, + "iauNutm80", "12", status); + vvd(rmatn[0][2], 0.3835906502164019142e-5, 1e-12, + "iauNutm80", "13", status); + + vvd(rmatn[1][0], -0.8847780042583435924e-5, 1e-12, + "iauNutm80", "21", status); + vvd(rmatn[1][1], 0.9999999991366569963, 1e-12, + "iauNutm80", "22", status); + vvd(rmatn[1][2], -0.4060052702727130809e-4, 1e-12, + "iauNutm80", "23", status); + + vvd(rmatn[2][0], -0.3836265729708478796e-5, 1e-12, + "iauNutm80", "31", status); + vvd(rmatn[2][1], 0.4060049308612638555e-4, 1e-12, + "iauNutm80", "32", status); + vvd(rmatn[2][2], 0.9999999991684415129, 1e-12, + "iauNutm80", "33", status); + +} + +static void t_obl06(int *status) +/* +** - - - - - - - - +** t _ o b l 0 6 +** - - - - - - - - +** +** Test iauObl06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauObl06, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauObl06(2400000.5, 54388.0), 0.4090749229387258204, 1e-14, + "iauObl06", "", status); +} + +static void t_obl80(int *status) +/* +** - - - - - - - - +** t _ o b l 8 0 +** - - - - - - - - +** +** Test iauObl80 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauObl80, vvd +** +** This revision: 2013 August 7 +*/ +{ + double eps0; + + + eps0 = iauObl80(2400000.5, 54388.0); + + vvd(eps0, 0.4090751347643816218, 1e-14, "iauObl80", "", status); + +} + +static void t_p06e(int *status) +/* +** - - - - - - - +** t _ p 0 6 e +** - - - - - - - +** +** Test iauP06e function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauP06e, vvd +** +** This revision: 2013 August 7 +*/ +{ + double eps0, psia, oma, bpa, bqa, pia, bpia, + epsa, chia, za, zetaa, thetaa, pa, gam, phi, psi; + + + iauP06e(2400000.5, 52541.0, &eps0, &psia, &oma, &bpa, + &bqa, &pia, &bpia, &epsa, &chia, &za, + &zetaa, &thetaa, &pa, &gam, &phi, &psi); + + vvd(eps0, 0.4090926006005828715, 1e-14, + "iauP06e", "eps0", status); + vvd(psia, 0.6664369630191613431e-3, 1e-14, + "iauP06e", "psia", status); + vvd(oma , 0.4090925973783255982, 1e-14, + "iauP06e", "oma", status); + vvd(bpa, 0.5561149371265209445e-6, 1e-14, + "iauP06e", "bpa", status); + vvd(bqa, -0.6191517193290621270e-5, 1e-14, + "iauP06e", "bqa", status); + vvd(pia, 0.6216441751884382923e-5, 1e-14, + "iauP06e", "pia", status); + vvd(bpia, 3.052014180023779882, 1e-14, + "iauP06e", "bpia", status); + vvd(epsa, 0.4090864054922431688, 1e-14, + "iauP06e", "epsa", status); + vvd(chia, 0.1387703379530915364e-5, 1e-14, + "iauP06e", "chia", status); + vvd(za, 0.2921789846651790546e-3, 1e-14, + "iauP06e", "za", status); + vvd(zetaa, 0.3178773290332009310e-3, 1e-14, + "iauP06e", "zetaa", status); + vvd(thetaa, 0.2650932701657497181e-3, 1e-14, + "iauP06e", "thetaa", status); + vvd(pa, 0.6651637681381016344e-3, 1e-14, + "iauP06e", "pa", status); + vvd(gam, 0.1398077115963754987e-5, 1e-14, + "iauP06e", "gam", status); + vvd(phi, 0.4090864090837462602, 1e-14, + "iauP06e", "phi", status); + vvd(psi, 0.6664464807480920325e-3, 1e-14, + "iauP06e", "psi", status); + +} + +static void t_p2pv(int *status) +/* +** - - - - - - - +** t _ p 2 p v +** - - - - - - - +** +** Test iauP2pv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauP2pv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3], pv[2][3]; + + + p[0] = 0.25; + p[1] = 1.2; + p[2] = 3.0; + + pv[0][0] = 0.3; + pv[0][1] = 1.2; + pv[0][2] = -2.5; + + pv[1][0] = -0.5; + pv[1][1] = 3.1; + pv[1][2] = 0.9; + + iauP2pv(p, pv); + + vvd(pv[0][0], 0.25, 0.0, "iauP2pv", "p1", status); + vvd(pv[0][1], 1.2, 0.0, "iauP2pv", "p2", status); + vvd(pv[0][2], 3.0, 0.0, "iauP2pv", "p3", status); + + vvd(pv[1][0], 0.0, 0.0, "iauP2pv", "v1", status); + vvd(pv[1][1], 0.0, 0.0, "iauP2pv", "v2", status); + vvd(pv[1][2], 0.0, 0.0, "iauP2pv", "v3", status); + +} + +static void t_p2s(int *status) +/* +** - - - - - - +** t _ p 2 s +** - - - - - - +** +** Test iauP2s function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauP2s, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3], theta, phi, r; + + + p[0] = 100.0; + p[1] = -50.0; + p[2] = 25.0; + + iauP2s(p, &theta, &phi, &r); + + vvd(theta, -0.4636476090008061162, 1e-12, "iauP2s", "theta", status); + vvd(phi, 0.2199879773954594463, 1e-12, "iauP2s", "phi", status); + vvd(r, 114.5643923738960002, 1e-9, "iauP2s", "r", status); + +} + +static void t_pap(int *status) +/* +** - - - - - - +** t _ p a p +** - - - - - - +** +** Test iauPap function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPap, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3], b[3], theta; + + + a[0] = 1.0; + a[1] = 0.1; + a[2] = 0.2; + + b[0] = -3.0; + b[1] = 1e-3; + b[2] = 0.2; + + theta = iauPap(a, b); + + vvd(theta, 0.3671514267841113674, 1e-12, "iauPap", "", status); + +} + +static void t_pas(int *status) +/* +** - - - - - - +** t _ p a s +** - - - - - - +** +** Test iauPas function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPas, vvd +** +** This revision: 2013 August 7 +*/ +{ + double al, ap, bl, bp, theta; + + + al = 1.0; + ap = 0.1; + bl = 0.2; + bp = -1.0; + + theta = iauPas(al, ap, bl, bp); + + vvd(theta, -2.724544922932270424, 1e-12, "iauPas", "", status); + +} + +static void t_pb06(int *status) +/* +** - - - - - - - +** t _ p b 0 6 +** - - - - - - - +** +** Test iauPb06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPb06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double bzeta, bz, btheta; + + + iauPb06(2400000.5, 50123.9999, &bzeta, &bz, &btheta); + + vvd(bzeta, -0.5092634016326478238e-3, 1e-12, + "iauPb06", "bzeta", status); + vvd(bz, -0.3602772060566044413e-3, 1e-12, + "iauPb06", "bz", status); + vvd(btheta, -0.3779735537167811177e-3, 1e-12, + "iauPb06", "btheta", status); + +} + +static void t_pdp(int *status) +/* +** - - - - - - +** t _ p d p +** - - - - - - +** +** Test iauPdp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPdp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3], b[3], adb; + + + a[0] = 2.0; + a[1] = 2.0; + a[2] = 3.0; + + b[0] = 1.0; + b[1] = 3.0; + b[2] = 4.0; + + adb = iauPdp(a, b); + + vvd(adb, 20, 1e-12, "iauPdp", "", status); + +} + +static void t_pfw06(int *status) +/* +** - - - - - - - - +** t _ p f w 0 6 +** - - - - - - - - +** +** Test iauPfw06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPfw06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double gamb, phib, psib, epsa; + + + iauPfw06(2400000.5, 50123.9999, &gamb, &phib, &psib, &epsa); + + vvd(gamb, -0.2243387670997995690e-5, 1e-16, + "iauPfw06", "gamb", status); + vvd(phib, 0.4091014602391312808, 1e-12, + "iauPfw06", "phib", status); + vvd(psib, -0.9501954178013031895e-3, 1e-14, + "iauPfw06", "psib", status); + vvd(epsa, 0.4091014316587367491, 1e-12, + "iauPfw06", "epsa", status); + +} + +static void t_plan94(int *status) +/* +** - - - - - - - - - +** t _ p l a n 9 4 +** - - - - - - - - - +** +** Test iauPlan94 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPlan94, vvd, viv +** +** This revision: 2013 October 2 +*/ +{ + double pv[2][3]; + int j; + + + j = iauPlan94(2400000.5, 1e6, 0, pv); + + vvd(pv[0][0], 0.0, 0.0, "iauPlan94", "x 1", status); + vvd(pv[0][1], 0.0, 0.0, "iauPlan94", "y 1", status); + vvd(pv[0][2], 0.0, 0.0, "iauPlan94", "z 1", status); + + vvd(pv[1][0], 0.0, 0.0, "iauPlan94", "xd 1", status); + vvd(pv[1][1], 0.0, 0.0, "iauPlan94", "yd 1", status); + vvd(pv[1][2], 0.0, 0.0, "iauPlan94", "zd 1", status); + + viv(j, -1, "iauPlan94", "j 1", status); + + j = iauPlan94(2400000.5, 1e6, 10, pv); + + viv(j, -1, "iauPlan94", "j 2", status); + + j = iauPlan94(2400000.5, -320000, 3, pv); + + vvd(pv[0][0], 0.9308038666832975759, 1e-11, + "iauPlan94", "x 3", status); + vvd(pv[0][1], 0.3258319040261346000, 1e-11, + "iauPlan94", "y 3", status); + vvd(pv[0][2], 0.1422794544481140560, 1e-11, + "iauPlan94", "z 3", status); + + vvd(pv[1][0], -0.6429458958255170006e-2, 1e-11, + "iauPlan94", "xd 3", status); + vvd(pv[1][1], 0.1468570657704237764e-1, 1e-11, + "iauPlan94", "yd 3", status); + vvd(pv[1][2], 0.6406996426270981189e-2, 1e-11, + "iauPlan94", "zd 3", status); + + viv(j, 1, "iauPlan94", "j 3", status); + + j = iauPlan94(2400000.5, 43999.9, 1, pv); + + vvd(pv[0][0], 0.2945293959257430832, 1e-11, + "iauPlan94", "x 4", status); + vvd(pv[0][1], -0.2452204176601049596, 1e-11, + "iauPlan94", "y 4", status); + vvd(pv[0][2], -0.1615427700571978153, 1e-11, + "iauPlan94", "z 4", status); + + vvd(pv[1][0], 0.1413867871404614441e-1, 1e-11, + "iauPlan94", "xd 4", status); + vvd(pv[1][1], 0.1946548301104706582e-1, 1e-11, + "iauPlan94", "yd 4", status); + vvd(pv[1][2], 0.8929809783898904786e-2, 1e-11, + "iauPlan94", "zd 4", status); + + viv(j, 0, "iauPlan94", "j 4", status); + +} + +static void t_pmat00(int *status) +/* +** - - - - - - - - - +** t _ p m a t 0 0 +** - - - - - - - - - +** +** Test iauPmat00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPmat00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbp[3][3]; + + + iauPmat00(2400000.5, 50123.9999, rbp); + + vvd(rbp[0][0], 0.9999995505175087260, 1e-12, + "iauPmat00", "11", status); + vvd(rbp[0][1], 0.8695405883617884705e-3, 1e-14, + "iauPmat00", "12", status); + vvd(rbp[0][2], 0.3779734722239007105e-3, 1e-14, + "iauPmat00", "13", status); + + vvd(rbp[1][0], -0.8695405990410863719e-3, 1e-14, + "iauPmat00", "21", status); + vvd(rbp[1][1], 0.9999996219494925900, 1e-12, + "iauPmat00", "22", status); + vvd(rbp[1][2], -0.1360775820404982209e-6, 1e-14, + "iauPmat00", "23", status); + + vvd(rbp[2][0], -0.3779734476558184991e-3, 1e-14, + "iauPmat00", "31", status); + vvd(rbp[2][1], -0.1925857585832024058e-6, 1e-14, + "iauPmat00", "32", status); + vvd(rbp[2][2], 0.9999999285680153377, 1e-12, + "iauPmat00", "33", status); + +} + +static void t_pmat06(int *status) +/* +** - - - - - - - - - +** t _ p m a t 0 6 +** - - - - - - - - - +** +** Test iauPmat06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPmat06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbp[3][3]; + + + iauPmat06(2400000.5, 50123.9999, rbp); + + vvd(rbp[0][0], 0.9999995505176007047, 1e-12, + "iauPmat06", "11", status); + vvd(rbp[0][1], 0.8695404617348208406e-3, 1e-14, + "iauPmat06", "12", status); + vvd(rbp[0][2], 0.3779735201865589104e-3, 1e-14, + "iauPmat06", "13", status); + + vvd(rbp[1][0], -0.8695404723772031414e-3, 1e-14, + "iauPmat06", "21", status); + vvd(rbp[1][1], 0.9999996219496027161, 1e-12, + "iauPmat06", "22", status); + vvd(rbp[1][2], -0.1361752497080270143e-6, 1e-14, + "iauPmat06", "23", status); + + vvd(rbp[2][0], -0.3779734957034089490e-3, 1e-14, + "iauPmat06", "31", status); + vvd(rbp[2][1], -0.1924880847894457113e-6, 1e-14, + "iauPmat06", "32", status); + vvd(rbp[2][2], 0.9999999285679971958, 1e-12, + "iauPmat06", "33", status); + +} + +static void t_pmat76(int *status) +/* +** - - - - - - - - - +** t _ p m a t 7 6 +** - - - - - - - - - +** +** Test iauPmat76 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPmat76, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rmatp[3][3]; + + + iauPmat76(2400000.5, 50123.9999, rmatp); + + vvd(rmatp[0][0], 0.9999995504328350733, 1e-12, + "iauPmat76", "11", status); + vvd(rmatp[0][1], 0.8696632209480960785e-3, 1e-14, + "iauPmat76", "12", status); + vvd(rmatp[0][2], 0.3779153474959888345e-3, 1e-14, + "iauPmat76", "13", status); + + vvd(rmatp[1][0], -0.8696632209485112192e-3, 1e-14, + "iauPmat76", "21", status); + vvd(rmatp[1][1], 0.9999996218428560614, 1e-12, + "iauPmat76", "22", status); + vvd(rmatp[1][2], -0.1643284776111886407e-6, 1e-14, + "iauPmat76", "23", status); + + vvd(rmatp[2][0], -0.3779153474950335077e-3, 1e-14, + "iauPmat76", "31", status); + vvd(rmatp[2][1], -0.1643306746147366896e-6, 1e-14, + "iauPmat76", "32", status); + vvd(rmatp[2][2], 0.9999999285899790119, 1e-12, + "iauPmat76", "33", status); + +} + +static void t_pm(int *status) +/* +** - - - - - +** t _ p m +** - - - - - +** +** Test iauPm function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPm, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3], r; + + + p[0] = 0.3; + p[1] = 1.2; + p[2] = -2.5; + + r = iauPm(p); + + vvd(r, 2.789265136196270604, 1e-12, "iauPm", "", status); + +} + +static void t_pmp(int *status) +/* +** - - - - - - +** t _ p m p +** - - - - - - +** +** Test iauPmp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPmp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3], b[3], amb[3]; + + + a[0] = 2.0; + a[1] = 2.0; + a[2] = 3.0; + + b[0] = 1.0; + b[1] = 3.0; + b[2] = 4.0; + + iauPmp(a, b, amb); + + vvd(amb[0], 1.0, 1e-12, "iauPmp", "0", status); + vvd(amb[1], -1.0, 1e-12, "iauPmp", "1", status); + vvd(amb[2], -1.0, 1e-12, "iauPmp", "2", status); + +} + +static void t_pmpx(int *status) +/* +** - - - - - - - +** t _ p m p x +** - - - - - - - +** +** Test iauPmpx function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPmpx, vvd +** +** This revision: 2017 March 15 +*/ +{ + double rc, dc, pr, pd, px, rv, pmt, pob[3], pco[3]; + + + rc = 1.234; + dc = 0.789; + pr = 1e-5; + pd = -2e-5; + px = 1e-2; + rv = 10.0; + pmt = 8.75; + pob[0] = 0.9; + pob[1] = 0.4; + pob[2] = 0.1; + + iauPmpx(rc, dc, pr, pd, px, rv, pmt, pob, pco); + + vvd(pco[0], 0.2328137623960308438, 1e-12, + "iauPmpx", "1", status); + vvd(pco[1], 0.6651097085397855328, 1e-12, + "iauPmpx", "2", status); + vvd(pco[2], 0.7095257765896359837, 1e-12, + "iauPmpx", "3", status); + +} + +static void t_pmsafe(int *status) +/* +** - - - - - - - - - +** t _ p m s a f e +** - - - - - - - - - +** +** Test iauPmsafe function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPmsafe, vvd, viv +** +** This revision: 2017 March 15 +*/ +{ + int j; + double ra1, dec1, pmr1, pmd1, px1, rv1, ep1a, ep1b, ep2a, ep2b, + ra2, dec2, pmr2, pmd2, px2, rv2; + + + ra1 = 1.234; + dec1 = 0.789; + pmr1 = 1e-5; + pmd1 = -2e-5; + px1 = 1e-2; + rv1 = 10.0; + ep1a = 2400000.5; + ep1b = 48348.5625; + ep2a = 2400000.5; + ep2b = 51544.5; + + j = iauPmsafe(ra1, dec1, pmr1, pmd1, px1, rv1, + ep1a, ep1b, ep2a, ep2b, + &ra2, &dec2, &pmr2, &pmd2, &px2, &rv2); + + vvd(ra2, 1.234087484501017061, 1e-12, + "iauPmsafe", "ra2", status); + vvd(dec2, 0.7888249982450468567, 1e-12, + "iauPmsafe", "dec2", status); + vvd(pmr2, 0.9996457663586073988e-5, 1e-12, + "iauPmsafe", "pmr2", status); + vvd(pmd2, -0.2000040085106754565e-4, 1e-16, + "iauPmsafe", "pmd2", status); + vvd(px2, 0.9999997295356830666e-2, 1e-12, + "iauPmsafe", "px2", status); + vvd(rv2, 10.38468380293920069, 1e-10, + "iauPmsafe", "rv2", status); + viv ( j, 0, "iauPmsafe", "j", status); + +} + +static void t_pn(int *status) +/* +** - - - - - +** t _ p n +** - - - - - +** +** Test iauPn function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPn, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3], r, u[3]; + + + p[0] = 0.3; + p[1] = 1.2; + p[2] = -2.5; + + iauPn(p, &r, u); + + vvd(r, 2.789265136196270604, 1e-12, "iauPn", "r", status); + + vvd(u[0], 0.1075552109073112058, 1e-12, "iauPn", "u1", status); + vvd(u[1], 0.4302208436292448232, 1e-12, "iauPn", "u2", status); + vvd(u[2], -0.8962934242275933816, 1e-12, "iauPn", "u3", status); + +} + +static void t_pn00(int *status) +/* +** - - - - - - - +** t _ p n 0 0 +** - - - - - - - +** +** Test iauPn00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPn00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps, epsa, + rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; + + + dpsi = -0.9632552291149335877e-5; + deps = 0.4063197106621141414e-4; + + iauPn00(2400000.5, 53736.0, dpsi, deps, + &epsa, rb, rp, rbp, rn, rbpn); + + vvd(epsa, 0.4090791789404229916, 1e-12, "iauPn00", "epsa", status); + + vvd(rb[0][0], 0.9999999999999942498, 1e-12, + "iauPn00", "rb11", status); + vvd(rb[0][1], -0.7078279744199196626e-7, 1e-18, + "iauPn00", "rb12", status); + vvd(rb[0][2], 0.8056217146976134152e-7, 1e-18, + "iauPn00", "rb13", status); + + vvd(rb[1][0], 0.7078279477857337206e-7, 1e-18, + "iauPn00", "rb21", status); + vvd(rb[1][1], 0.9999999999999969484, 1e-12, + "iauPn00", "rb22", status); + vvd(rb[1][2], 0.3306041454222136517e-7, 1e-18, + "iauPn00", "rb23", status); + + vvd(rb[2][0], -0.8056217380986972157e-7, 1e-18, + "iauPn00", "rb31", status); + vvd(rb[2][1], -0.3306040883980552500e-7, 1e-18, + "iauPn00", "rb32", status); + vvd(rb[2][2], 0.9999999999999962084, 1e-12, + "iauPn00", "rb33", status); + + vvd(rp[0][0], 0.9999989300532289018, 1e-12, + "iauPn00", "rp11", status); + vvd(rp[0][1], -0.1341647226791824349e-2, 1e-14, + "iauPn00", "rp12", status); + vvd(rp[0][2], -0.5829880927190296547e-3, 1e-14, + "iauPn00", "rp13", status); + + vvd(rp[1][0], 0.1341647231069759008e-2, 1e-14, + "iauPn00", "rp21", status); + vvd(rp[1][1], 0.9999990999908750433, 1e-12, + "iauPn00", "rp22", status); + vvd(rp[1][2], -0.3837444441583715468e-6, 1e-14, + "iauPn00", "rp23", status); + + vvd(rp[2][0], 0.5829880828740957684e-3, 1e-14, + "iauPn00", "rp31", status); + vvd(rp[2][1], -0.3984203267708834759e-6, 1e-14, + "iauPn00", "rp32", status); + vvd(rp[2][2], 0.9999998300623538046, 1e-12, + "iauPn00", "rp33", status); + + vvd(rbp[0][0], 0.9999989300052243993, 1e-12, + "iauPn00", "rbp11", status); + vvd(rbp[0][1], -0.1341717990239703727e-2, 1e-14, + "iauPn00", "rbp12", status); + vvd(rbp[0][2], -0.5829075749891684053e-3, 1e-14, + "iauPn00", "rbp13", status); + + vvd(rbp[1][0], 0.1341718013831739992e-2, 1e-14, + "iauPn00", "rbp21", status); + vvd(rbp[1][1], 0.9999990998959191343, 1e-12, + "iauPn00", "rbp22", status); + vvd(rbp[1][2], -0.3505759733565421170e-6, 1e-14, + "iauPn00", "rbp23", status); + + vvd(rbp[2][0], 0.5829075206857717883e-3, 1e-14, + "iauPn00", "rbp31", status); + vvd(rbp[2][1], -0.4315219955198608970e-6, 1e-14, + "iauPn00", "rbp32", status); + vvd(rbp[2][2], 0.9999998301093036269, 1e-12, + "iauPn00", "rbp33", status); + + vvd(rn[0][0], 0.9999999999536069682, 1e-12, + "iauPn00", "rn11", status); + vvd(rn[0][1], 0.8837746144872140812e-5, 1e-16, + "iauPn00", "rn12", status); + vvd(rn[0][2], 0.3831488838252590008e-5, 1e-16, + "iauPn00", "rn13", status); + + vvd(rn[1][0], -0.8837590456633197506e-5, 1e-16, + "iauPn00", "rn21", status); + vvd(rn[1][1], 0.9999999991354692733, 1e-12, + "iauPn00", "rn22", status); + vvd(rn[1][2], -0.4063198798559573702e-4, 1e-16, + "iauPn00", "rn23", status); + + vvd(rn[2][0], -0.3831847930135328368e-5, 1e-16, + "iauPn00", "rn31", status); + vvd(rn[2][1], 0.4063195412258150427e-4, 1e-16, + "iauPn00", "rn32", status); + vvd(rn[2][2], 0.9999999991671806225, 1e-12, + "iauPn00", "rn33", status); + + vvd(rbpn[0][0], 0.9999989440499982806, 1e-12, + "iauPn00", "rbpn11", status); + vvd(rbpn[0][1], -0.1332880253640848301e-2, 1e-14, + "iauPn00", "rbpn12", status); + vvd(rbpn[0][2], -0.5790760898731087295e-3, 1e-14, + "iauPn00", "rbpn13", status); + + vvd(rbpn[1][0], 0.1332856746979948745e-2, 1e-14, + "iauPn00", "rbpn21", status); + vvd(rbpn[1][1], 0.9999991109064768883, 1e-12, + "iauPn00", "rbpn22", status); + vvd(rbpn[1][2], -0.4097740555723063806e-4, 1e-14, + "iauPn00", "rbpn23", status); + + vvd(rbpn[2][0], 0.5791301929950205000e-3, 1e-14, + "iauPn00", "rbpn31", status); + vvd(rbpn[2][1], 0.4020553681373702931e-4, 1e-14, + "iauPn00", "rbpn32", status); + vvd(rbpn[2][2], 0.9999998314958529887, 1e-12, + "iauPn00", "rbpn33", status); + +} + +static void t_pn00a(int *status) +/* +** - - - - - - - - +** t _ p n 0 0 a +** - - - - - - - - +** +** Test iauPn00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPn00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps, epsa, + rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; + + + iauPn00a(2400000.5, 53736.0, + &dpsi, &deps, &epsa, rb, rp, rbp, rn, rbpn); + + vvd(dpsi, -0.9630909107115518431e-5, 1e-12, + "iauPn00a", "dpsi", status); + vvd(deps, 0.4063239174001678710e-4, 1e-12, + "iauPn00a", "deps", status); + vvd(epsa, 0.4090791789404229916, 1e-12, "iauPn00a", "epsa", status); + + vvd(rb[0][0], 0.9999999999999942498, 1e-12, + "iauPn00a", "rb11", status); + vvd(rb[0][1], -0.7078279744199196626e-7, 1e-16, + "iauPn00a", "rb12", status); + vvd(rb[0][2], 0.8056217146976134152e-7, 1e-16, + "iauPn00a", "rb13", status); + + vvd(rb[1][0], 0.7078279477857337206e-7, 1e-16, + "iauPn00a", "rb21", status); + vvd(rb[1][1], 0.9999999999999969484, 1e-12, + "iauPn00a", "rb22", status); + vvd(rb[1][2], 0.3306041454222136517e-7, 1e-16, + "iauPn00a", "rb23", status); + + vvd(rb[2][0], -0.8056217380986972157e-7, 1e-16, + "iauPn00a", "rb31", status); + vvd(rb[2][1], -0.3306040883980552500e-7, 1e-16, + "iauPn00a", "rb32", status); + vvd(rb[2][2], 0.9999999999999962084, 1e-12, + "iauPn00a", "rb33", status); + + vvd(rp[0][0], 0.9999989300532289018, 1e-12, + "iauPn00a", "rp11", status); + vvd(rp[0][1], -0.1341647226791824349e-2, 1e-14, + "iauPn00a", "rp12", status); + vvd(rp[0][2], -0.5829880927190296547e-3, 1e-14, + "iauPn00a", "rp13", status); + + vvd(rp[1][0], 0.1341647231069759008e-2, 1e-14, + "iauPn00a", "rp21", status); + vvd(rp[1][1], 0.9999990999908750433, 1e-12, + "iauPn00a", "rp22", status); + vvd(rp[1][2], -0.3837444441583715468e-6, 1e-14, + "iauPn00a", "rp23", status); + + vvd(rp[2][0], 0.5829880828740957684e-3, 1e-14, + "iauPn00a", "rp31", status); + vvd(rp[2][1], -0.3984203267708834759e-6, 1e-14, + "iauPn00a", "rp32", status); + vvd(rp[2][2], 0.9999998300623538046, 1e-12, + "iauPn00a", "rp33", status); + + vvd(rbp[0][0], 0.9999989300052243993, 1e-12, + "iauPn00a", "rbp11", status); + vvd(rbp[0][1], -0.1341717990239703727e-2, 1e-14, + "iauPn00a", "rbp12", status); + vvd(rbp[0][2], -0.5829075749891684053e-3, 1e-14, + "iauPn00a", "rbp13", status); + + vvd(rbp[1][0], 0.1341718013831739992e-2, 1e-14, + "iauPn00a", "rbp21", status); + vvd(rbp[1][1], 0.9999990998959191343, 1e-12, + "iauPn00a", "rbp22", status); + vvd(rbp[1][2], -0.3505759733565421170e-6, 1e-14, + "iauPn00a", "rbp23", status); + + vvd(rbp[2][0], 0.5829075206857717883e-3, 1e-14, + "iauPn00a", "rbp31", status); + vvd(rbp[2][1], -0.4315219955198608970e-6, 1e-14, + "iauPn00a", "rbp32", status); + vvd(rbp[2][2], 0.9999998301093036269, 1e-12, + "iauPn00a", "rbp33", status); + + vvd(rn[0][0], 0.9999999999536227949, 1e-12, + "iauPn00a", "rn11", status); + vvd(rn[0][1], 0.8836238544090873336e-5, 1e-14, + "iauPn00a", "rn12", status); + vvd(rn[0][2], 0.3830835237722400669e-5, 1e-14, + "iauPn00a", "rn13", status); + + vvd(rn[1][0], -0.8836082880798569274e-5, 1e-14, + "iauPn00a", "rn21", status); + vvd(rn[1][1], 0.9999999991354655028, 1e-12, + "iauPn00a", "rn22", status); + vvd(rn[1][2], -0.4063240865362499850e-4, 1e-14, + "iauPn00a", "rn23", status); + + vvd(rn[2][0], -0.3831194272065995866e-5, 1e-14, + "iauPn00a", "rn31", status); + vvd(rn[2][1], 0.4063237480216291775e-4, 1e-14, + "iauPn00a", "rn32", status); + vvd(rn[2][2], 0.9999999991671660338, 1e-12, + "iauPn00a", "rn33", status); + + vvd(rbpn[0][0], 0.9999989440476103435, 1e-12, + "iauPn00a", "rbpn11", status); + vvd(rbpn[0][1], -0.1332881761240011763e-2, 1e-14, + "iauPn00a", "rbpn12", status); + vvd(rbpn[0][2], -0.5790767434730085751e-3, 1e-14, + "iauPn00a", "rbpn13", status); + + vvd(rbpn[1][0], 0.1332858254308954658e-2, 1e-14, + "iauPn00a", "rbpn21", status); + vvd(rbpn[1][1], 0.9999991109044505577, 1e-12, + "iauPn00a", "rbpn22", status); + vvd(rbpn[1][2], -0.4097782710396580452e-4, 1e-14, + "iauPn00a", "rbpn23", status); + + vvd(rbpn[2][0], 0.5791308472168152904e-3, 1e-14, + "iauPn00a", "rbpn31", status); + vvd(rbpn[2][1], 0.4020595661591500259e-4, 1e-14, + "iauPn00a", "rbpn32", status); + vvd(rbpn[2][2], 0.9999998314954572304, 1e-12, + "iauPn00a", "rbpn33", status); + +} + +static void t_pn00b(int *status) +/* +** - - - - - - - - +** t _ p n 0 0 b +** - - - - - - - - +** +** Test iauPn00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPn00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps, epsa, + rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; + + + iauPn00b(2400000.5, 53736.0, &dpsi, &deps, &epsa, + rb, rp, rbp, rn, rbpn); + + vvd(dpsi, -0.9632552291148362783e-5, 1e-12, + "iauPn00b", "dpsi", status); + vvd(deps, 0.4063197106621159367e-4, 1e-12, + "iauPn00b", "deps", status); + vvd(epsa, 0.4090791789404229916, 1e-12, "iauPn00b", "epsa", status); + + vvd(rb[0][0], 0.9999999999999942498, 1e-12, + "iauPn00b", "rb11", status); + vvd(rb[0][1], -0.7078279744199196626e-7, 1e-16, + "iauPn00b", "rb12", status); + vvd(rb[0][2], 0.8056217146976134152e-7, 1e-16, + "iauPn00b", "rb13", status); + + vvd(rb[1][0], 0.7078279477857337206e-7, 1e-16, + "iauPn00b", "rb21", status); + vvd(rb[1][1], 0.9999999999999969484, 1e-12, + "iauPn00b", "rb22", status); + vvd(rb[1][2], 0.3306041454222136517e-7, 1e-16, + "iauPn00b", "rb23", status); + + vvd(rb[2][0], -0.8056217380986972157e-7, 1e-16, + "iauPn00b", "rb31", status); + vvd(rb[2][1], -0.3306040883980552500e-7, 1e-16, + "iauPn00b", "rb32", status); + vvd(rb[2][2], 0.9999999999999962084, 1e-12, + "iauPn00b", "rb33", status); + + vvd(rp[0][0], 0.9999989300532289018, 1e-12, + "iauPn00b", "rp11", status); + vvd(rp[0][1], -0.1341647226791824349e-2, 1e-14, + "iauPn00b", "rp12", status); + vvd(rp[0][2], -0.5829880927190296547e-3, 1e-14, + "iauPn00b", "rp13", status); + + vvd(rp[1][0], 0.1341647231069759008e-2, 1e-14, + "iauPn00b", "rp21", status); + vvd(rp[1][1], 0.9999990999908750433, 1e-12, + "iauPn00b", "rp22", status); + vvd(rp[1][2], -0.3837444441583715468e-6, 1e-14, + "iauPn00b", "rp23", status); + + vvd(rp[2][0], 0.5829880828740957684e-3, 1e-14, + "iauPn00b", "rp31", status); + vvd(rp[2][1], -0.3984203267708834759e-6, 1e-14, + "iauPn00b", "rp32", status); + vvd(rp[2][2], 0.9999998300623538046, 1e-12, + "iauPn00b", "rp33", status); + + vvd(rbp[0][0], 0.9999989300052243993, 1e-12, + "iauPn00b", "rbp11", status); + vvd(rbp[0][1], -0.1341717990239703727e-2, 1e-14, + "iauPn00b", "rbp12", status); + vvd(rbp[0][2], -0.5829075749891684053e-3, 1e-14, + "iauPn00b", "rbp13", status); + + vvd(rbp[1][0], 0.1341718013831739992e-2, 1e-14, + "iauPn00b", "rbp21", status); + vvd(rbp[1][1], 0.9999990998959191343, 1e-12, + "iauPn00b", "rbp22", status); + vvd(rbp[1][2], -0.3505759733565421170e-6, 1e-14, + "iauPn00b", "rbp23", status); + + vvd(rbp[2][0], 0.5829075206857717883e-3, 1e-14, + "iauPn00b", "rbp31", status); + vvd(rbp[2][1], -0.4315219955198608970e-6, 1e-14, + "iauPn00b", "rbp32", status); + vvd(rbp[2][2], 0.9999998301093036269, 1e-12, + "iauPn00b", "rbp33", status); + + vvd(rn[0][0], 0.9999999999536069682, 1e-12, + "iauPn00b", "rn11", status); + vvd(rn[0][1], 0.8837746144871248011e-5, 1e-14, + "iauPn00b", "rn12", status); + vvd(rn[0][2], 0.3831488838252202945e-5, 1e-14, + "iauPn00b", "rn13", status); + + vvd(rn[1][0], -0.8837590456632304720e-5, 1e-14, + "iauPn00b", "rn21", status); + vvd(rn[1][1], 0.9999999991354692733, 1e-12, + "iauPn00b", "rn22", status); + vvd(rn[1][2], -0.4063198798559591654e-4, 1e-14, + "iauPn00b", "rn23", status); + + vvd(rn[2][0], -0.3831847930134941271e-5, 1e-14, + "iauPn00b", "rn31", status); + vvd(rn[2][1], 0.4063195412258168380e-4, 1e-14, + "iauPn00b", "rn32", status); + vvd(rn[2][2], 0.9999999991671806225, 1e-12, + "iauPn00b", "rn33", status); + + vvd(rbpn[0][0], 0.9999989440499982806, 1e-12, + "iauPn00b", "rbpn11", status); + vvd(rbpn[0][1], -0.1332880253640849194e-2, 1e-14, + "iauPn00b", "rbpn12", status); + vvd(rbpn[0][2], -0.5790760898731091166e-3, 1e-14, + "iauPn00b", "rbpn13", status); + + vvd(rbpn[1][0], 0.1332856746979949638e-2, 1e-14, + "iauPn00b", "rbpn21", status); + vvd(rbpn[1][1], 0.9999991109064768883, 1e-12, + "iauPn00b", "rbpn22", status); + vvd(rbpn[1][2], -0.4097740555723081811e-4, 1e-14, + "iauPn00b", "rbpn23", status); + + vvd(rbpn[2][0], 0.5791301929950208873e-3, 1e-14, + "iauPn00b", "rbpn31", status); + vvd(rbpn[2][1], 0.4020553681373720832e-4, 1e-14, + "iauPn00b", "rbpn32", status); + vvd(rbpn[2][2], 0.9999998314958529887, 1e-12, + "iauPn00b", "rbpn33", status); + +} + +static void t_pn06a(int *status) +/* +** - - - - - - - - +** t _ p n 0 6 a +** - - - - - - - - +** +** Test iauPn06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPn06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps, epsa; + double rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; + + + iauPn06a(2400000.5, 53736.0, &dpsi, &deps, &epsa, + rb, rp, rbp, rn, rbpn); + + vvd(dpsi, -0.9630912025820308797e-5, 1e-12, + "iauPn06a", "dpsi", status); + vvd(deps, 0.4063238496887249798e-4, 1e-12, + "iauPn06a", "deps", status); + vvd(epsa, 0.4090789763356509926, 1e-12, "iauPn06a", "epsa", status); + + vvd(rb[0][0], 0.9999999999999942497, 1e-12, + "iauPn06a", "rb11", status); + vvd(rb[0][1], -0.7078368960971557145e-7, 1e-14, + "iauPn06a", "rb12", status); + vvd(rb[0][2], 0.8056213977613185606e-7, 1e-14, + "iauPn06a", "rb13", status); + + vvd(rb[1][0], 0.7078368694637674333e-7, 1e-14, + "iauPn06a", "rb21", status); + vvd(rb[1][1], 0.9999999999999969484, 1e-12, + "iauPn06a", "rb22", status); + vvd(rb[1][2], 0.3305943742989134124e-7, 1e-14, + "iauPn06a", "rb23", status); + + vvd(rb[2][0], -0.8056214211620056792e-7, 1e-14, + "iauPn06a", "rb31", status); + vvd(rb[2][1], -0.3305943172740586950e-7, 1e-14, + "iauPn06a", "rb32", status); + vvd(rb[2][2], 0.9999999999999962084, 1e-12, + "iauPn06a", "rb33", status); + + vvd(rp[0][0], 0.9999989300536854831, 1e-12, + "iauPn06a", "rp11", status); + vvd(rp[0][1], -0.1341646886204443795e-2, 1e-14, + "iauPn06a", "rp12", status); + vvd(rp[0][2], -0.5829880933488627759e-3, 1e-14, + "iauPn06a", "rp13", status); + + vvd(rp[1][0], 0.1341646890569782183e-2, 1e-14, + "iauPn06a", "rp21", status); + vvd(rp[1][1], 0.9999990999913319321, 1e-12, + "iauPn06a", "rp22", status); + vvd(rp[1][2], -0.3835944216374477457e-6, 1e-14, + "iauPn06a", "rp23", status); + + vvd(rp[2][0], 0.5829880833027867368e-3, 1e-14, + "iauPn06a", "rp31", status); + vvd(rp[2][1], -0.3985701514686976112e-6, 1e-14, + "iauPn06a", "rp32", status); + vvd(rp[2][2], 0.9999998300623534950, 1e-12, + "iauPn06a", "rp33", status); + + vvd(rbp[0][0], 0.9999989300056797893, 1e-12, + "iauPn06a", "rbp11", status); + vvd(rbp[0][1], -0.1341717650545059598e-2, 1e-14, + "iauPn06a", "rbp12", status); + vvd(rbp[0][2], -0.5829075756493728856e-3, 1e-14, + "iauPn06a", "rbp13", status); + + vvd(rbp[1][0], 0.1341717674223918101e-2, 1e-14, + "iauPn06a", "rbp21", status); + vvd(rbp[1][1], 0.9999990998963748448, 1e-12, + "iauPn06a", "rbp22", status); + vvd(rbp[1][2], -0.3504269280170069029e-6, 1e-14, + "iauPn06a", "rbp23", status); + + vvd(rbp[2][0], 0.5829075211461454599e-3, 1e-14, + "iauPn06a", "rbp31", status); + vvd(rbp[2][1], -0.4316708436255949093e-6, 1e-14, + "iauPn06a", "rbp32", status); + vvd(rbp[2][2], 0.9999998301093032943, 1e-12, + "iauPn06a", "rbp33", status); + + vvd(rn[0][0], 0.9999999999536227668, 1e-12, + "iauPn06a", "rn11", status); + vvd(rn[0][1], 0.8836241998111535233e-5, 1e-14, + "iauPn06a", "rn12", status); + vvd(rn[0][2], 0.3830834608415287707e-5, 1e-14, + "iauPn06a", "rn13", status); + + vvd(rn[1][0], -0.8836086334870740138e-5, 1e-14, + "iauPn06a", "rn21", status); + vvd(rn[1][1], 0.9999999991354657474, 1e-12, + "iauPn06a", "rn22", status); + vvd(rn[1][2], -0.4063240188248455065e-4, 1e-14, + "iauPn06a", "rn23", status); + + vvd(rn[2][0], -0.3831193642839398128e-5, 1e-14, + "iauPn06a", "rn31", status); + vvd(rn[2][1], 0.4063236803101479770e-4, 1e-14, + "iauPn06a", "rn32", status); + vvd(rn[2][2], 0.9999999991671663114, 1e-12, + "iauPn06a", "rn33", status); + + vvd(rbpn[0][0], 0.9999989440480669738, 1e-12, + "iauPn06a", "rbpn11", status); + vvd(rbpn[0][1], -0.1332881418091915973e-2, 1e-14, + "iauPn06a", "rbpn12", status); + vvd(rbpn[0][2], -0.5790767447612042565e-3, 1e-14, + "iauPn06a", "rbpn13", status); + + vvd(rbpn[1][0], 0.1332857911250989133e-2, 1e-14, + "iauPn06a", "rbpn21", status); + vvd(rbpn[1][1], 0.9999991109049141908, 1e-12, + "iauPn06a", "rbpn22", status); + vvd(rbpn[1][2], -0.4097767128546784878e-4, 1e-14, + "iauPn06a", "rbpn23", status); + + vvd(rbpn[2][0], 0.5791308482835292617e-3, 1e-14, + "iauPn06a", "rbpn31", status); + vvd(rbpn[2][1], 0.4020580099454020310e-4, 1e-14, + "iauPn06a", "rbpn32", status); + vvd(rbpn[2][2], 0.9999998314954628695, 1e-12, + "iauPn06a", "rbpn33", status); + +} + +static void t_pn06(int *status) +/* +** - - - - - - - +** t _ p n 0 6 +** - - - - - - - +** +** Test iauPn06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPn06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsi, deps, epsa, + rb[3][3], rp[3][3], rbp[3][3], rn[3][3], rbpn[3][3]; + + + dpsi = -0.9632552291149335877e-5; + deps = 0.4063197106621141414e-4; + + iauPn06(2400000.5, 53736.0, dpsi, deps, + &epsa, rb, rp, rbp, rn, rbpn); + + vvd(epsa, 0.4090789763356509926, 1e-12, "iauPn06", "epsa", status); + + vvd(rb[0][0], 0.9999999999999942497, 1e-12, + "iauPn06", "rb11", status); + vvd(rb[0][1], -0.7078368960971557145e-7, 1e-14, + "iauPn06", "rb12", status); + vvd(rb[0][2], 0.8056213977613185606e-7, 1e-14, + "iauPn06", "rb13", status); + + vvd(rb[1][0], 0.7078368694637674333e-7, 1e-14, + "iauPn06", "rb21", status); + vvd(rb[1][1], 0.9999999999999969484, 1e-12, + "iauPn06", "rb22", status); + vvd(rb[1][2], 0.3305943742989134124e-7, 1e-14, + "iauPn06", "rb23", status); + + vvd(rb[2][0], -0.8056214211620056792e-7, 1e-14, + "iauPn06", "rb31", status); + vvd(rb[2][1], -0.3305943172740586950e-7, 1e-14, + "iauPn06", "rb32", status); + vvd(rb[2][2], 0.9999999999999962084, 1e-12, + "iauPn06", "rb33", status); + + vvd(rp[0][0], 0.9999989300536854831, 1e-12, + "iauPn06", "rp11", status); + vvd(rp[0][1], -0.1341646886204443795e-2, 1e-14, + "iauPn06", "rp12", status); + vvd(rp[0][2], -0.5829880933488627759e-3, 1e-14, + "iauPn06", "rp13", status); + + vvd(rp[1][0], 0.1341646890569782183e-2, 1e-14, + "iauPn06", "rp21", status); + vvd(rp[1][1], 0.9999990999913319321, 1e-12, + "iauPn06", "rp22", status); + vvd(rp[1][2], -0.3835944216374477457e-6, 1e-14, + "iauPn06", "rp23", status); + + vvd(rp[2][0], 0.5829880833027867368e-3, 1e-14, + "iauPn06", "rp31", status); + vvd(rp[2][1], -0.3985701514686976112e-6, 1e-14, + "iauPn06", "rp32", status); + vvd(rp[2][2], 0.9999998300623534950, 1e-12, + "iauPn06", "rp33", status); + + vvd(rbp[0][0], 0.9999989300056797893, 1e-12, + "iauPn06", "rbp11", status); + vvd(rbp[0][1], -0.1341717650545059598e-2, 1e-14, + "iauPn06", "rbp12", status); + vvd(rbp[0][2], -0.5829075756493728856e-3, 1e-14, + "iauPn06", "rbp13", status); + + vvd(rbp[1][0], 0.1341717674223918101e-2, 1e-14, + "iauPn06", "rbp21", status); + vvd(rbp[1][1], 0.9999990998963748448, 1e-12, + "iauPn06", "rbp22", status); + vvd(rbp[1][2], -0.3504269280170069029e-6, 1e-14, + "iauPn06", "rbp23", status); + + vvd(rbp[2][0], 0.5829075211461454599e-3, 1e-14, + "iauPn06", "rbp31", status); + vvd(rbp[2][1], -0.4316708436255949093e-6, 1e-14, + "iauPn06", "rbp32", status); + vvd(rbp[2][2], 0.9999998301093032943, 1e-12, + "iauPn06", "rbp33", status); + + vvd(rn[0][0], 0.9999999999536069682, 1e-12, + "iauPn06", "rn11", status); + vvd(rn[0][1], 0.8837746921149881914e-5, 1e-14, + "iauPn06", "rn12", status); + vvd(rn[0][2], 0.3831487047682968703e-5, 1e-14, + "iauPn06", "rn13", status); + + vvd(rn[1][0], -0.8837591232983692340e-5, 1e-14, + "iauPn06", "rn21", status); + vvd(rn[1][1], 0.9999999991354692664, 1e-12, + "iauPn06", "rn22", status); + vvd(rn[1][2], -0.4063198798558931215e-4, 1e-14, + "iauPn06", "rn23", status); + + vvd(rn[2][0], -0.3831846139597250235e-5, 1e-14, + "iauPn06", "rn31", status); + vvd(rn[2][1], 0.4063195412258792914e-4, 1e-14, + "iauPn06", "rn32", status); + vvd(rn[2][2], 0.9999999991671806293, 1e-12, + "iauPn06", "rn33", status); + + vvd(rbpn[0][0], 0.9999989440504506688, 1e-12, + "iauPn06", "rbpn11", status); + vvd(rbpn[0][1], -0.1332879913170492655e-2, 1e-14, + "iauPn06", "rbpn12", status); + vvd(rbpn[0][2], -0.5790760923225655753e-3, 1e-14, + "iauPn06", "rbpn13", status); + + vvd(rbpn[1][0], 0.1332856406595754748e-2, 1e-14, + "iauPn06", "rbpn21", status); + vvd(rbpn[1][1], 0.9999991109069366795, 1e-12, + "iauPn06", "rbpn22", status); + vvd(rbpn[1][2], -0.4097725651142641812e-4, 1e-14, + "iauPn06", "rbpn23", status); + + vvd(rbpn[2][0], 0.5791301952321296716e-3, 1e-14, + "iauPn06", "rbpn31", status); + vvd(rbpn[2][1], 0.4020538796195230577e-4, 1e-14, + "iauPn06", "rbpn32", status); + vvd(rbpn[2][2], 0.9999998314958576778, 1e-12, + "iauPn06", "rbpn33", status); + +} + +static void t_pnm00a(int *status) +/* +** - - - - - - - - - +** t _ p n m 0 0 a +** - - - - - - - - - +** +** Test iauPnm00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPnm00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbpn[3][3]; + + + iauPnm00a(2400000.5, 50123.9999, rbpn); + + vvd(rbpn[0][0], 0.9999995832793134257, 1e-12, + "iauPnm00a", "11", status); + vvd(rbpn[0][1], 0.8372384254137809439e-3, 1e-14, + "iauPnm00a", "12", status); + vvd(rbpn[0][2], 0.3639684306407150645e-3, 1e-14, + "iauPnm00a", "13", status); + + vvd(rbpn[1][0], -0.8372535226570394543e-3, 1e-14, + "iauPnm00a", "21", status); + vvd(rbpn[1][1], 0.9999996486491582471, 1e-12, + "iauPnm00a", "22", status); + vvd(rbpn[1][2], 0.4132915262664072381e-4, 1e-14, + "iauPnm00a", "23", status); + + vvd(rbpn[2][0], -0.3639337004054317729e-3, 1e-14, + "iauPnm00a", "31", status); + vvd(rbpn[2][1], -0.4163386925461775873e-4, 1e-14, + "iauPnm00a", "32", status); + vvd(rbpn[2][2], 0.9999999329094390695, 1e-12, + "iauPnm00a", "33", status); + +} + +static void t_pnm00b(int *status) +/* +** - - - - - - - - - +** t _ p n m 0 0 b +** - - - - - - - - - +** +** Test iauPnm00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPnm00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbpn[3][3]; + + + iauPnm00b(2400000.5, 50123.9999, rbpn); + + vvd(rbpn[0][0], 0.9999995832776208280, 1e-12, + "iauPnm00b", "11", status); + vvd(rbpn[0][1], 0.8372401264429654837e-3, 1e-14, + "iauPnm00b", "12", status); + vvd(rbpn[0][2], 0.3639691681450271771e-3, 1e-14, + "iauPnm00b", "13", status); + + vvd(rbpn[1][0], -0.8372552234147137424e-3, 1e-14, + "iauPnm00b", "21", status); + vvd(rbpn[1][1], 0.9999996486477686123, 1e-12, + "iauPnm00b", "22", status); + vvd(rbpn[1][2], 0.4132832190946052890e-4, 1e-14, + "iauPnm00b", "23", status); + + vvd(rbpn[2][0], -0.3639344385341866407e-3, 1e-14, + "iauPnm00b", "31", status); + vvd(rbpn[2][1], -0.4163303977421522785e-4, 1e-14, + "iauPnm00b", "32", status); + vvd(rbpn[2][2], 0.9999999329092049734, 1e-12, + "iauPnm00b", "33", status); + +} + +static void t_pnm06a(int *status) +/* +** - - - - - - - - - +** t _ p n m 0 6 a +** - - - - - - - - - +** +** Test iauPnm06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPnm06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rbpn[3][3]; + + + iauPnm06a(2400000.5, 50123.9999, rbpn); + + vvd(rbpn[0][0], 0.9999995832794205484, 1e-12, + "iauPnm06a", "11", status); + vvd(rbpn[0][1], 0.8372382772630962111e-3, 1e-14, + "iauPnm06a", "12", status); + vvd(rbpn[0][2], 0.3639684771140623099e-3, 1e-14, + "iauPnm06a", "13", status); + + vvd(rbpn[1][0], -0.8372533744743683605e-3, 1e-14, + "iauPnm06a", "21", status); + vvd(rbpn[1][1], 0.9999996486492861646, 1e-12, + "iauPnm06a", "22", status); + vvd(rbpn[1][2], 0.4132905944611019498e-4, 1e-14, + "iauPnm06a", "23", status); + + vvd(rbpn[2][0], -0.3639337469629464969e-3, 1e-14, + "iauPnm06a", "31", status); + vvd(rbpn[2][1], -0.4163377605910663999e-4, 1e-14, + "iauPnm06a", "32", status); + vvd(rbpn[2][2], 0.9999999329094260057, 1e-12, + "iauPnm06a", "33", status); + +} + +static void t_pnm80(int *status) +/* +** - - - - - - - - +** t _ p n m 8 0 +** - - - - - - - - +** +** Test iauPnm80 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPnm80, vvd +** +** This revision: 2013 August 7 +*/ +{ + double rmatpn[3][3]; + + + iauPnm80(2400000.5, 50123.9999, rmatpn); + + vvd(rmatpn[0][0], 0.9999995831934611169, 1e-12, + "iauPnm80", "11", status); + vvd(rmatpn[0][1], 0.8373654045728124011e-3, 1e-14, + "iauPnm80", "12", status); + vvd(rmatpn[0][2], 0.3639121916933106191e-3, 1e-14, + "iauPnm80", "13", status); + + vvd(rmatpn[1][0], -0.8373804896118301316e-3, 1e-14, + "iauPnm80", "21", status); + vvd(rmatpn[1][1], 0.9999996485439674092, 1e-12, + "iauPnm80", "22", status); + vvd(rmatpn[1][2], 0.4130202510421549752e-4, 1e-14, + "iauPnm80", "23", status); + + vvd(rmatpn[2][0], -0.3638774789072144473e-3, 1e-14, + "iauPnm80", "31", status); + vvd(rmatpn[2][1], -0.4160674085851722359e-4, 1e-14, + "iauPnm80", "32", status); + vvd(rmatpn[2][2], 0.9999999329310274805, 1e-12, + "iauPnm80", "33", status); + +} + +static void t_pom00(int *status) +/* +** - - - - - - - - +** t _ p o m 0 0 +** - - - - - - - - +** +** Test iauPom00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPom00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double xp, yp, sp, rpom[3][3]; + + + xp = 2.55060238e-7; + yp = 1.860359247e-6; + sp = -0.1367174580728891460e-10; + + iauPom00(xp, yp, sp, rpom); + + vvd(rpom[0][0], 0.9999999999999674721, 1e-12, + "iauPom00", "11", status); + vvd(rpom[0][1], -0.1367174580728846989e-10, 1e-16, + "iauPom00", "12", status); + vvd(rpom[0][2], 0.2550602379999972345e-6, 1e-16, + "iauPom00", "13", status); + + vvd(rpom[1][0], 0.1414624947957029801e-10, 1e-16, + "iauPom00", "21", status); + vvd(rpom[1][1], 0.9999999999982695317, 1e-12, + "iauPom00", "22", status); + vvd(rpom[1][2], -0.1860359246998866389e-5, 1e-16, + "iauPom00", "23", status); + + vvd(rpom[2][0], -0.2550602379741215021e-6, 1e-16, + "iauPom00", "31", status); + vvd(rpom[2][1], 0.1860359247002414021e-5, 1e-16, + "iauPom00", "32", status); + vvd(rpom[2][2], 0.9999999999982370039, 1e-12, + "iauPom00", "33", status); + +} + +static void t_ppp(int *status) +/* +** - - - - - - +** t _ p p p +** - - - - - - +** +** Test iauPpp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPpp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3], b[3], apb[3]; + + + a[0] = 2.0; + a[1] = 2.0; + a[2] = 3.0; + + b[0] = 1.0; + b[1] = 3.0; + b[2] = 4.0; + + iauPpp(a, b, apb); + + vvd(apb[0], 3.0, 1e-12, "iauPpp", "0", status); + vvd(apb[1], 5.0, 1e-12, "iauPpp", "1", status); + vvd(apb[2], 7.0, 1e-12, "iauPpp", "2", status); + +} + +static void t_ppsp(int *status) +/* +** - - - - - - - +** t _ p p s p +** - - - - - - - +** +** Test iauPpsp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPpsp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3], s, b[3], apsb[3]; + + + a[0] = 2.0; + a[1] = 2.0; + a[2] = 3.0; + + s = 5.0; + + b[0] = 1.0; + b[1] = 3.0; + b[2] = 4.0; + + iauPpsp(a, s, b, apsb); + + vvd(apsb[0], 7.0, 1e-12, "iauPpsp", "0", status); + vvd(apsb[1], 17.0, 1e-12, "iauPpsp", "1", status); + vvd(apsb[2], 23.0, 1e-12, "iauPpsp", "2", status); + +} + +static void t_pr00(int *status) +/* +** - - - - - - - +** t _ p r 0 0 +** - - - - - - - +** +** Test iauPr00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPr00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double dpsipr, depspr; + + iauPr00(2400000.5, 53736, &dpsipr, &depspr); + + vvd(dpsipr, -0.8716465172668347629e-7, 1e-22, + "iauPr00", "dpsipr", status); + vvd(depspr, -0.7342018386722813087e-8, 1e-22, + "iauPr00", "depspr", status); + +} + +static void t_prec76(int *status) +/* +** - - - - - - - - - +** t _ p r e c 7 6 +** - - - - - - - - - +** +** Test iauPrec76 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPrec76, vvd +** +** This revision: 2013 August 7 +*/ +{ + double ep01, ep02, ep11, ep12, zeta, z, theta; + + + ep01 = 2400000.5; + ep02 = 33282.0; + ep11 = 2400000.5; + ep12 = 51544.0; + + iauPrec76(ep01, ep02, ep11, ep12, &zeta, &z, &theta); + + vvd(zeta, 0.5588961642000161243e-2, 1e-12, + "iauPrec76", "zeta", status); + vvd(z, 0.5589922365870680624e-2, 1e-12, + "iauPrec76", "z", status); + vvd(theta, 0.4858945471687296760e-2, 1e-12, + "iauPrec76", "theta", status); + +} + +static void t_pv2p(int *status) +/* +** - - - - - - - +** t _ p v 2 p +** - - - - - - - +** +** Test iauPv2p function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPv2p, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3], p[3]; + + + pv[0][0] = 0.3; + pv[0][1] = 1.2; + pv[0][2] = -2.5; + + pv[1][0] = -0.5; + pv[1][1] = 3.1; + pv[1][2] = 0.9; + + iauPv2p(pv, p); + + vvd(p[0], 0.3, 0.0, "iauPv2p", "1", status); + vvd(p[1], 1.2, 0.0, "iauPv2p", "2", status); + vvd(p[2], -2.5, 0.0, "iauPv2p", "3", status); + +} + +static void t_pv2s(int *status) +/* +** - - - - - - - +** t _ p v 2 s +** - - - - - - - +** +** Test iauPv2s function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPv2s, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3], theta, phi, r, td, pd, rd; + + + pv[0][0] = -0.4514964673880165; + pv[0][1] = 0.03093394277342585; + pv[0][2] = 0.05594668105108779; + + pv[1][0] = 1.292270850663260e-5; + pv[1][1] = 2.652814182060692e-6; + pv[1][2] = 2.568431853930293e-6; + + iauPv2s(pv, &theta, &phi, &r, &td, &pd, &rd); + + vvd(theta, 3.073185307179586515, 1e-12, "iauPv2s", "theta", status); + vvd(phi, 0.1229999999999999992, 1e-12, "iauPv2s", "phi", status); + vvd(r, 0.4559999999999999757, 1e-12, "iauPv2s", "r", status); + vvd(td, -0.7800000000000000364e-5, 1e-16, "iauPv2s", "td", status); + vvd(pd, 0.9010000000000001639e-5, 1e-16, "iauPv2s", "pd", status); + vvd(rd, -0.1229999999999999832e-4, 1e-16, "iauPv2s", "rd", status); + +} + +static void t_pvdpv(int *status) +/* +** - - - - - - - - +** t _ p v d p v +** - - - - - - - - +** +** Test iauPvdpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvdpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[2][3], b[2][3], adb[2]; + + + a[0][0] = 2.0; + a[0][1] = 2.0; + a[0][2] = 3.0; + + a[1][0] = 6.0; + a[1][1] = 0.0; + a[1][2] = 4.0; + + b[0][0] = 1.0; + b[0][1] = 3.0; + b[0][2] = 4.0; + + b[1][0] = 0.0; + b[1][1] = 2.0; + b[1][2] = 8.0; + + iauPvdpv(a, b, adb); + + vvd(adb[0], 20.0, 1e-12, "iauPvdpv", "1", status); + vvd(adb[1], 50.0, 1e-12, "iauPvdpv", "2", status); + +} + +static void t_pvm(int *status) +/* +** - - - - - - +** t _ p v m +** - - - - - - +** +** Test iauPvm function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvm, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3], r, s; + + + pv[0][0] = 0.3; + pv[0][1] = 1.2; + pv[0][2] = -2.5; + + pv[1][0] = 0.45; + pv[1][1] = -0.25; + pv[1][2] = 1.1; + + iauPvm(pv, &r, &s); + + vvd(r, 2.789265136196270604, 1e-12, "iauPvm", "r", status); + vvd(s, 1.214495780149111922, 1e-12, "iauPvm", "s", status); + +} + +static void t_pvmpv(int *status) +/* +** - - - - - - - - +** t _ p v m p v +** - - - - - - - - +** +** Test iauPvmpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvmpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[2][3], b[2][3], amb[2][3]; + + + a[0][0] = 2.0; + a[0][1] = 2.0; + a[0][2] = 3.0; + + a[1][0] = 5.0; + a[1][1] = 6.0; + a[1][2] = 3.0; + + b[0][0] = 1.0; + b[0][1] = 3.0; + b[0][2] = 4.0; + + b[1][0] = 3.0; + b[1][1] = 2.0; + b[1][2] = 1.0; + + iauPvmpv(a, b, amb); + + vvd(amb[0][0], 1.0, 1e-12, "iauPvmpv", "11", status); + vvd(amb[0][1], -1.0, 1e-12, "iauPvmpv", "21", status); + vvd(amb[0][2], -1.0, 1e-12, "iauPvmpv", "31", status); + + vvd(amb[1][0], 2.0, 1e-12, "iauPvmpv", "12", status); + vvd(amb[1][1], 4.0, 1e-12, "iauPvmpv", "22", status); + vvd(amb[1][2], 2.0, 1e-12, "iauPvmpv", "32", status); + +} + +static void t_pvppv(int *status) +/* +** - - - - - - - - +** t _ p v p p v +** - - - - - - - - +** +** Test iauPvppv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvppv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[2][3], b[2][3], apb[2][3]; + + + a[0][0] = 2.0; + a[0][1] = 2.0; + a[0][2] = 3.0; + + a[1][0] = 5.0; + a[1][1] = 6.0; + a[1][2] = 3.0; + + b[0][0] = 1.0; + b[0][1] = 3.0; + b[0][2] = 4.0; + + b[1][0] = 3.0; + b[1][1] = 2.0; + b[1][2] = 1.0; + + iauPvppv(a, b, apb); + + vvd(apb[0][0], 3.0, 1e-12, "iauPvppv", "p1", status); + vvd(apb[0][1], 5.0, 1e-12, "iauPvppv", "p2", status); + vvd(apb[0][2], 7.0, 1e-12, "iauPvppv", "p3", status); + + vvd(apb[1][0], 8.0, 1e-12, "iauPvppv", "v1", status); + vvd(apb[1][1], 8.0, 1e-12, "iauPvppv", "v2", status); + vvd(apb[1][2], 4.0, 1e-12, "iauPvppv", "v3", status); + +} + +static void t_pvstar(int *status) +/* +** - - - - - - - - - +** t _ p v s t a r +** - - - - - - - - - +** +** Test iauPvstar function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvstar, vvd, viv +** +** This revision: 2017 March 15 +*/ +{ + double pv[2][3], ra, dec, pmr, pmd, px, rv; + int j; + + + pv[0][0] = 126668.5912743160601; + pv[0][1] = 2136.792716839935195; + pv[0][2] = -245251.2339876830091; + + pv[1][0] = -0.4051854035740712739e-2; + pv[1][1] = -0.6253919754866173866e-2; + pv[1][2] = 0.1189353719774107189e-1; + + j = iauPvstar(pv, &ra, &dec, &pmr, &pmd, &px, &rv); + + vvd(ra, 0.1686756e-1, 1e-12, "iauPvstar", "ra", status); + vvd(dec, -1.093989828, 1e-12, "iauPvstar", "dec", status); + vvd(pmr, -0.1783235160000472788e-4, 1e-16, "iauPvstar", "pmr", status); + vvd(pmd, 0.2336024047000619347e-5, 1e-16, "iauPvstar", "pmd", status); + vvd(px, 0.74723, 1e-12, "iauPvstar", "px", status); + vvd(rv, -21.60000010107306010, 1e-11, "iauPvstar", "rv", status); + + viv(j, 0, "iauPvstar", "j", status); + +} + +static void t_pvtob(int *status) +/* +** - - - - - - - - +** t _ p v t o b +** - - - - - - - - +** +** Test iauPvtob function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvtob, vvd +** +** This revision: 2013 October 2 +*/ +{ + double elong, phi, hm, xp, yp, sp, theta, pv[2][3]; + + + elong = 2.0; + phi = 0.5; + hm = 3000.0; + xp = 1e-6; + yp = -0.5e-6; + sp = 1e-8; + theta = 5.0; + + iauPvtob(elong, phi, hm, xp, yp, sp, theta, pv); + + vvd(pv[0][0], 4225081.367071159207, 1e-5, + "iauPvtob", "p(1)", status); + vvd(pv[0][1], 3681943.215856198144, 1e-5, + "iauPvtob", "p(2)", status); + vvd(pv[0][2], 3041149.399241260785, 1e-5, + "iauPvtob", "p(3)", status); + vvd(pv[1][0], -268.4915389365998787, 1e-9, + "iauPvtob", "v(1)", status); + vvd(pv[1][1], 308.0977983288903123, 1e-9, + "iauPvtob", "v(2)", status); + vvd(pv[1][2], 0, 0, + "iauPvtob", "v(3)", status); + +} + +static void t_pvu(int *status) +/* +** - - - - - - +** t _ p v u +** - - - - - - +** +** Test iauPvu function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvu, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3], upv[2][3]; + + + pv[0][0] = 126668.5912743160734; + pv[0][1] = 2136.792716839935565; + pv[0][2] = -245251.2339876830229; + + pv[1][0] = -0.4051854035740713039e-2; + pv[1][1] = -0.6253919754866175788e-2; + pv[1][2] = 0.1189353719774107615e-1; + + iauPvu(2920.0, pv, upv); + + vvd(upv[0][0], 126656.7598605317105, 1e-12, + "iauPvu", "p1", status); + vvd(upv[0][1], 2118.531271155726332, 1e-12, + "iauPvu", "p2", status); + vvd(upv[0][2], -245216.5048590656190, 1e-12, + "iauPvu", "p3", status); + + vvd(upv[1][0], -0.4051854035740713039e-2, 1e-12, + "iauPvu", "v1", status); + vvd(upv[1][1], -0.6253919754866175788e-2, 1e-12, + "iauPvu", "v2", status); + vvd(upv[1][2], 0.1189353719774107615e-1, 1e-12, + "iauPvu", "v3", status); + +} + +static void t_pvup(int *status) +/* +** - - - - - - - +** t _ p v u p +** - - - - - - - +** +** Test iauPvup function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvup, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3], p[3]; + + + pv[0][0] = 126668.5912743160734; + pv[0][1] = 2136.792716839935565; + pv[0][2] = -245251.2339876830229; + + pv[1][0] = -0.4051854035740713039e-2; + pv[1][1] = -0.6253919754866175788e-2; + pv[1][2] = 0.1189353719774107615e-1; + + iauPvup(2920.0, pv, p); + + vvd(p[0], 126656.7598605317105, 1e-12, "iauPvup", "1", status); + vvd(p[1], 2118.531271155726332, 1e-12, "iauPvup", "2", status); + vvd(p[2], -245216.5048590656190, 1e-12, "iauPvup", "3", status); + +} + +static void t_pvxpv(int *status) +/* +** - - - - - - - - +** t _ p v x p v +** - - - - - - - - +** +** Test iauPvxpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPvxpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[2][3], b[2][3], axb[2][3]; + + + a[0][0] = 2.0; + a[0][1] = 2.0; + a[0][2] = 3.0; + + a[1][0] = 6.0; + a[1][1] = 0.0; + a[1][2] = 4.0; + + b[0][0] = 1.0; + b[0][1] = 3.0; + b[0][2] = 4.0; + + b[1][0] = 0.0; + b[1][1] = 2.0; + b[1][2] = 8.0; + + iauPvxpv(a, b, axb); + + vvd(axb[0][0], -1.0, 1e-12, "iauPvxpv", "p1", status); + vvd(axb[0][1], -5.0, 1e-12, "iauPvxpv", "p2", status); + vvd(axb[0][2], 4.0, 1e-12, "iauPvxpv", "p3", status); + + vvd(axb[1][0], -2.0, 1e-12, "iauPvxpv", "v1", status); + vvd(axb[1][1], -36.0, 1e-12, "iauPvxpv", "v2", status); + vvd(axb[1][2], 22.0, 1e-12, "iauPvxpv", "v3", status); + +} + +static void t_pxp(int *status) +/* +** - - - - - - +** t _ p x p +** - - - - - - +** +** Test iauPxp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauPxp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3], b[3], axb[3]; + + + a[0] = 2.0; + a[1] = 2.0; + a[2] = 3.0; + + b[0] = 1.0; + b[1] = 3.0; + b[2] = 4.0; + + iauPxp(a, b, axb); + + vvd(axb[0], -1.0, 1e-12, "iauPxp", "1", status); + vvd(axb[1], -5.0, 1e-12, "iauPxp", "2", status); + vvd(axb[2], 4.0, 1e-12, "iauPxp", "3", status); + +} + +static void t_refco(int *status) +/* +** - - - - - - - - +** t _ r e f c o +** - - - - - - - - +** +** Test iauRefco function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRefco, vvd +** +** This revision: 2013 October 2 +*/ +{ + double phpa, tc, rh, wl, refa, refb; + + + phpa = 800.0; + tc = 10.0; + rh = 0.9; + wl = 0.4; + + iauRefco(phpa, tc, rh, wl, &refa, &refb); + + vvd(refa, 0.2264949956241415009e-3, 1e-15, + "iauRefco", "refa", status); + vvd(refb, -0.2598658261729343970e-6, 1e-18, + "iauRefco", "refb", status); + +} + +static void t_rm2v(int *status) +/* +** - - - - - - - +** t _ r m 2 v +** - - - - - - - +** +** Test iauRm2v function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRm2v, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3], w[3]; + + + r[0][0] = 0.00; + r[0][1] = -0.80; + r[0][2] = -0.60; + + r[1][0] = 0.80; + r[1][1] = -0.36; + r[1][2] = 0.48; + + r[2][0] = 0.60; + r[2][1] = 0.48; + r[2][2] = -0.64; + + iauRm2v(r, w); + + vvd(w[0], 0.0, 1e-12, "iauRm2v", "1", status); + vvd(w[1], 1.413716694115406957, 1e-12, "iauRm2v", "2", status); + vvd(w[2], -1.884955592153875943, 1e-12, "iauRm2v", "3", status); + +} + +static void t_rv2m(int *status) +/* +** - - - - - - - +** t _ r v 2 m +** - - - - - - - +** +** Test iauRv2m function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRv2m, vvd +** +** This revision: 2013 August 7 +*/ +{ + double w[3], r[3][3]; + + + w[0] = 0.0; + w[1] = 1.41371669; + w[2] = -1.88495559; + + iauRv2m(w, r); + + vvd(r[0][0], -0.7071067782221119905, 1e-14, "iauRv2m", "11", status); + vvd(r[0][1], -0.5656854276809129651, 1e-14, "iauRv2m", "12", status); + vvd(r[0][2], -0.4242640700104211225, 1e-14, "iauRv2m", "13", status); + + vvd(r[1][0], 0.5656854276809129651, 1e-14, "iauRv2m", "21", status); + vvd(r[1][1], -0.0925483394532274246, 1e-14, "iauRv2m", "22", status); + vvd(r[1][2], -0.8194112531408833269, 1e-14, "iauRv2m", "23", status); + + vvd(r[2][0], 0.4242640700104211225, 1e-14, "iauRv2m", "31", status); + vvd(r[2][1], -0.8194112531408833269, 1e-14, "iauRv2m", "32", status); + vvd(r[2][2], 0.3854415612311154341, 1e-14, "iauRv2m", "33", status); + +} + +static void t_rx(int *status) +/* +** - - - - - +** t _ r x +** - - - - - +** +** Test iauRx function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRx, vvd +** +** This revision: 2013 August 7 +*/ +{ + double phi, r[3][3]; + + + phi = 0.3456789; + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + iauRx(phi, r); + + vvd(r[0][0], 2.0, 0.0, "iauRx", "11", status); + vvd(r[0][1], 3.0, 0.0, "iauRx", "12", status); + vvd(r[0][2], 2.0, 0.0, "iauRx", "13", status); + + vvd(r[1][0], 3.839043388235612460, 1e-12, "iauRx", "21", status); + vvd(r[1][1], 3.237033249594111899, 1e-12, "iauRx", "22", status); + vvd(r[1][2], 4.516714379005982719, 1e-12, "iauRx", "23", status); + + vvd(r[2][0], 1.806030415924501684, 1e-12, "iauRx", "31", status); + vvd(r[2][1], 3.085711545336372503, 1e-12, "iauRx", "32", status); + vvd(r[2][2], 3.687721683977873065, 1e-12, "iauRx", "33", status); + +} + +static void t_rxp(int *status) +/* +** - - - - - - +** t _ r x p +** - - - - - - +** +** Test iauRxp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRxp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3], p[3], rp[3]; + + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + p[0] = 0.2; + p[1] = 1.5; + p[2] = 0.1; + + iauRxp(r, p, rp); + + vvd(rp[0], 5.1, 1e-12, "iauRxp", "1", status); + vvd(rp[1], 3.9, 1e-12, "iauRxp", "2", status); + vvd(rp[2], 7.1, 1e-12, "iauRxp", "3", status); + +} + +static void t_rxpv(int *status) +/* +** - - - - - - - +** t _ r x p v +** - - - - - - - +** +** Test iauRxpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRxpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3], pv[2][3], rpv[2][3]; + + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + pv[0][0] = 0.2; + pv[0][1] = 1.5; + pv[0][2] = 0.1; + + pv[1][0] = 1.5; + pv[1][1] = 0.2; + pv[1][2] = 0.1; + + iauRxpv(r, pv, rpv); + + vvd(rpv[0][0], 5.1, 1e-12, "iauRxpv", "11", status); + vvd(rpv[1][0], 3.8, 1e-12, "iauRxpv", "12", status); + + vvd(rpv[0][1], 3.9, 1e-12, "iauRxpv", "21", status); + vvd(rpv[1][1], 5.2, 1e-12, "iauRxpv", "22", status); + + vvd(rpv[0][2], 7.1, 1e-12, "iauRxpv", "31", status); + vvd(rpv[1][2], 5.8, 1e-12, "iauRxpv", "32", status); + +} + +static void t_rxr(int *status) +/* +** - - - - - - +** t _ r x r +** - - - - - - +** +** Test iauRxr function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRxr, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3][3], b[3][3], atb[3][3]; + + + a[0][0] = 2.0; + a[0][1] = 3.0; + a[0][2] = 2.0; + + a[1][0] = 3.0; + a[1][1] = 2.0; + a[1][2] = 3.0; + + a[2][0] = 3.0; + a[2][1] = 4.0; + a[2][2] = 5.0; + + b[0][0] = 1.0; + b[0][1] = 2.0; + b[0][2] = 2.0; + + b[1][0] = 4.0; + b[1][1] = 1.0; + b[1][2] = 1.0; + + b[2][0] = 3.0; + b[2][1] = 0.0; + b[2][2] = 1.0; + + iauRxr(a, b, atb); + + vvd(atb[0][0], 20.0, 1e-12, "iauRxr", "11", status); + vvd(atb[0][1], 7.0, 1e-12, "iauRxr", "12", status); + vvd(atb[0][2], 9.0, 1e-12, "iauRxr", "13", status); + + vvd(atb[1][0], 20.0, 1e-12, "iauRxr", "21", status); + vvd(atb[1][1], 8.0, 1e-12, "iauRxr", "22", status); + vvd(atb[1][2], 11.0, 1e-12, "iauRxr", "23", status); + + vvd(atb[2][0], 34.0, 1e-12, "iauRxr", "31", status); + vvd(atb[2][1], 10.0, 1e-12, "iauRxr", "32", status); + vvd(atb[2][2], 15.0, 1e-12, "iauRxr", "33", status); + +} + +static void t_ry(int *status) +/* +** - - - - - +** t _ r y +** - - - - - +** +** Test iauRy function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRy, vvd +** +** This revision: 2013 August 7 +*/ +{ + double theta, r[3][3]; + + + theta = 0.3456789; + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + iauRy(theta, r); + + vvd(r[0][0], 0.8651847818978159930, 1e-12, "iauRy", "11", status); + vvd(r[0][1], 1.467194920539316554, 1e-12, "iauRy", "12", status); + vvd(r[0][2], 0.1875137911274457342, 1e-12, "iauRy", "13", status); + + vvd(r[1][0], 3, 1e-12, "iauRy", "21", status); + vvd(r[1][1], 2, 1e-12, "iauRy", "22", status); + vvd(r[1][2], 3, 1e-12, "iauRy", "23", status); + + vvd(r[2][0], 3.500207892850427330, 1e-12, "iauRy", "31", status); + vvd(r[2][1], 4.779889022262298150, 1e-12, "iauRy", "32", status); + vvd(r[2][2], 5.381899160903798712, 1e-12, "iauRy", "33", status); + +} + +static void t_rz(int *status) +/* +** - - - - - +** t _ r z +** - - - - - +** +** Test iauRz function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauRz, vvd +** +** This revision: 2013 August 7 +*/ +{ + double psi, r[3][3]; + + + psi = 0.3456789; + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + iauRz(psi, r); + + vvd(r[0][0], 2.898197754208926769, 1e-12, "iauRz", "11", status); + vvd(r[0][1], 3.500207892850427330, 1e-12, "iauRz", "12", status); + vvd(r[0][2], 2.898197754208926769, 1e-12, "iauRz", "13", status); + + vvd(r[1][0], 2.144865911309686813, 1e-12, "iauRz", "21", status); + vvd(r[1][1], 0.865184781897815993, 1e-12, "iauRz", "22", status); + vvd(r[1][2], 2.144865911309686813, 1e-12, "iauRz", "23", status); + + vvd(r[2][0], 3.0, 1e-12, "iauRz", "31", status); + vvd(r[2][1], 4.0, 1e-12, "iauRz", "32", status); + vvd(r[2][2], 5.0, 1e-12, "iauRz", "33", status); + +} + +static void t_s00a(int *status) +/* +** - - - - - - - +** t _ s 0 0 a +** - - - - - - - +** +** Test iauS00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double s; + + + s = iauS00a(2400000.5, 52541.0); + + vvd(s, -0.1340684448919163584e-7, 1e-18, "iauS00a", "", status); + +} + +static void t_s00b(int *status) +/* +** - - - - - - - +** t _ s 0 0 b +** - - - - - - - +** +** Test iauS00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double s; + + + s = iauS00b(2400000.5, 52541.0); + + vvd(s, -0.1340695782951026584e-7, 1e-18, "iauS00b", "", status); + +} + +static void t_s00(int *status) +/* +** - - - - - - +** t _ s 0 0 +** - - - - - - +** +** Test iauS00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS00, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y, s; + + + x = 0.5791308486706011000e-3; + y = 0.4020579816732961219e-4; + + s = iauS00(2400000.5, 53736.0, x, y); + + vvd(s, -0.1220036263270905693e-7, 1e-18, "iauS00", "", status); + +} + +static void t_s06a(int *status) +/* +** - - - - - - - +** t _ s 0 6 a +** - - - - - - - +** +** Test iauS06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double s; + + + s = iauS06a(2400000.5, 52541.0); + + vvd(s, -0.1340680437291812383e-7, 1e-18, "iauS06a", "", status); + +} + +static void t_s06(int *status) +/* +** - - - - - - +** t _ s 0 6 +** - - - - - - +** +** Test iauS06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y, s; + + + x = 0.5791308486706011000e-3; + y = 0.4020579816732961219e-4; + + s = iauS06(2400000.5, 53736.0, x, y); + + vvd(s, -0.1220032213076463117e-7, 1e-18, "iauS06", "", status); + +} + +static void t_s2c(int *status) +/* +** - - - - - - +** t _ s 2 c +** - - - - - - +** +** Test iauS2c function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS2c, vvd +** +** This revision: 2013 August 7 +*/ +{ + double c[3]; + + + iauS2c(3.0123, -0.999, c); + + vvd(c[0], -0.5366267667260523906, 1e-12, "iauS2c", "1", status); + vvd(c[1], 0.0697711109765145365, 1e-12, "iauS2c", "2", status); + vvd(c[2], -0.8409302618566214041, 1e-12, "iauS2c", "3", status); + +} + +static void t_s2p(int *status) +/* +** - - - - - - +** t _ s 2 p +** - - - - - - +** +** Test iauS2p function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS2p, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3]; + + + iauS2p(-3.21, 0.123, 0.456, p); + + vvd(p[0], -0.4514964673880165228, 1e-12, "iauS2p", "x", status); + vvd(p[1], 0.0309339427734258688, 1e-12, "iauS2p", "y", status); + vvd(p[2], 0.0559466810510877933, 1e-12, "iauS2p", "z", status); + +} + +static void t_s2pv(int *status) +/* +** - - - - - - - +** t _ s 2 p v +** - - - - - - - +** +** Test iauS2pv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS2pv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3]; + + + iauS2pv(-3.21, 0.123, 0.456, -7.8e-6, 9.01e-6, -1.23e-5, pv); + + vvd(pv[0][0], -0.4514964673880165228, 1e-12, "iauS2pv", "x", status); + vvd(pv[0][1], 0.0309339427734258688, 1e-12, "iauS2pv", "y", status); + vvd(pv[0][2], 0.0559466810510877933, 1e-12, "iauS2pv", "z", status); + + vvd(pv[1][0], 0.1292270850663260170e-4, 1e-16, + "iauS2pv", "vx", status); + vvd(pv[1][1], 0.2652814182060691422e-5, 1e-16, + "iauS2pv", "vy", status); + vvd(pv[1][2], 0.2568431853930292259e-5, 1e-16, + "iauS2pv", "vz", status); + +} + +static void t_s2xpv(int *status) +/* +** - - - - - - - - +** t _ s 2 x p v +** - - - - - - - - +** +** Test iauS2xpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauS2xpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double s1, s2, pv[2][3], spv[2][3]; + + + s1 = 2.0; + s2 = 3.0; + + pv[0][0] = 0.3; + pv[0][1] = 1.2; + pv[0][2] = -2.5; + + pv[1][0] = 0.5; + pv[1][1] = 2.3; + pv[1][2] = -0.4; + + iauS2xpv(s1, s2, pv, spv); + + vvd(spv[0][0], 0.6, 1e-12, "iauS2xpv", "p1", status); + vvd(spv[0][1], 2.4, 1e-12, "iauS2xpv", "p2", status); + vvd(spv[0][2], -5.0, 1e-12, "iauS2xpv", "p3", status); + + vvd(spv[1][0], 1.5, 1e-12, "iauS2xpv", "v1", status); + vvd(spv[1][1], 6.9, 1e-12, "iauS2xpv", "v2", status); + vvd(spv[1][2], -1.2, 1e-12, "iauS2xpv", "v3", status); + +} + +static void t_sepp(int *status) +/* +** - - - - - - - +** t _ s e p p +** - - - - - - - +** +** Test iauSepp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauSepp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double a[3], b[3], s; + + + a[0] = 1.0; + a[1] = 0.1; + a[2] = 0.2; + + b[0] = -3.0; + b[1] = 1e-3; + b[2] = 0.2; + + s = iauSepp(a, b); + + vvd(s, 2.860391919024660768, 1e-12, "iauSepp", "", status); + +} + +static void t_seps(int *status) +/* +** - - - - - - - +** t _ s e p s +** - - - - - - - +** +** Test iauSeps function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauSeps, vvd +** +** This revision: 2013 August 7 +*/ +{ + double al, ap, bl, bp, s; + + + al = 1.0; + ap = 0.1; + + bl = 0.2; + bp = -3.0; + + s = iauSeps(al, ap, bl, bp); + + vvd(s, 2.346722016996998842, 1e-14, "iauSeps", "", status); + +} + +static void t_sp00(int *status) +/* +** - - - - - - - +** t _ s p 0 0 +** - - - - - - - +** +** Test iauSp00 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauSp00, vvd +** +** This revision: 2013 August 7 +*/ +{ + vvd(iauSp00(2400000.5, 52541.0), + -0.6216698469981019309e-11, 1e-12, "iauSp00", "", status); + +} + +static void t_starpm(int *status) +/* +** - - - - - - - - - +** t _ s t a r p m +** - - - - - - - - - +** +** Test iauStarpm function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauStarpm, vvd, viv +** +** This revision: 2017 March 15 +*/ +{ + double ra1, dec1, pmr1, pmd1, px1, rv1; + double ra2, dec2, pmr2, pmd2, px2, rv2; + int j; + + + ra1 = 0.01686756; + dec1 = -1.093989828; + pmr1 = -1.78323516e-5; + pmd1 = 2.336024047e-6; + px1 = 0.74723; + rv1 = -21.6; + + j = iauStarpm(ra1, dec1, pmr1, pmd1, px1, rv1, + 2400000.5, 50083.0, 2400000.5, 53736.0, + &ra2, &dec2, &pmr2, &pmd2, &px2, &rv2); + + vvd(ra2, 0.01668919069414256149, 1e-13, + "iauStarpm", "ra", status); + vvd(dec2, -1.093966454217127897, 1e-13, + "iauStarpm", "dec", status); + vvd(pmr2, -0.1783662682153176524e-4, 1e-17, + "iauStarpm", "pmr", status); + vvd(pmd2, 0.2338092915983989595e-5, 1e-17, + "iauStarpm", "pmd", status); + vvd(px2, 0.7473533835317719243, 1e-13, + "iauStarpm", "px", status); + vvd(rv2, -21.59905170476417175, 1e-11, + "iauStarpm", "rv", status); + + viv(j, 0, "iauStarpm", "j", status); + +} + +static void t_starpv(int *status) +/* +** - - - - - - - - - +** t _ s t a r p v +** - - - - - - - - - +** +** Test iauStarpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauStarpv, vvd, viv +** +** This revision: 2017 March 15 +*/ +{ + double ra, dec, pmr, pmd, px, rv, pv[2][3]; + int j; + + + ra = 0.01686756; + dec = -1.093989828; + pmr = -1.78323516e-5; + pmd = 2.336024047e-6; + px = 0.74723; + rv = -21.6; + + j = iauStarpv(ra, dec, pmr, pmd, px, rv, pv); + + vvd(pv[0][0], 126668.5912743160601, 1e-10, + "iauStarpv", "11", status); + vvd(pv[0][1], 2136.792716839935195, 1e-12, + "iauStarpv", "12", status); + vvd(pv[0][2], -245251.2339876830091, 1e-10, + "iauStarpv", "13", status); + + vvd(pv[1][0], -0.4051854008955659551e-2, 1e-13, + "iauStarpv", "21", status); + vvd(pv[1][1], -0.6253919754414777970e-2, 1e-15, + "iauStarpv", "22", status); + vvd(pv[1][2], 0.1189353714588109341e-1, 1e-13, + "iauStarpv", "23", status); + + viv(j, 0, "iauStarpv", "j", status); + +} + +static void t_sxp(int *status) +/* +** - - - - - - +** t _ s x p +** - - - - - - +** +** Test iauSxp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauSxp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double s, p[3], sp[3]; + + + s = 2.0; + + p[0] = 0.3; + p[1] = 1.2; + p[2] = -2.5; + + iauSxp(s, p, sp); + + vvd(sp[0], 0.6, 0.0, "iauSxp", "1", status); + vvd(sp[1], 2.4, 0.0, "iauSxp", "2", status); + vvd(sp[2], -5.0, 0.0, "iauSxp", "3", status); + +} + + +static void t_sxpv(int *status) +/* +** - - - - - - - +** t _ s x p v +** - - - - - - - +** +** Test iauSxpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauSxpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double s, pv[2][3], spv[2][3]; + + + s = 2.0; + + pv[0][0] = 0.3; + pv[0][1] = 1.2; + pv[0][2] = -2.5; + + pv[1][0] = 0.5; + pv[1][1] = 3.2; + pv[1][2] = -0.7; + + iauSxpv(s, pv, spv); + + vvd(spv[0][0], 0.6, 0.0, "iauSxpv", "p1", status); + vvd(spv[0][1], 2.4, 0.0, "iauSxpv", "p2", status); + vvd(spv[0][2], -5.0, 0.0, "iauSxpv", "p3", status); + + vvd(spv[1][0], 1.0, 0.0, "iauSxpv", "v1", status); + vvd(spv[1][1], 6.4, 0.0, "iauSxpv", "v2", status); + vvd(spv[1][2], -1.4, 0.0, "iauSxpv", "v3", status); + +} + +static void t_taitt(int *status) +/* +** - - - - - - - - +** t _ t a i t t +** - - - - - - - - +** +** Test iauTaitt function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTaitt, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double t1, t2; + int j; + + + j = iauTaitt(2453750.5, 0.892482639, &t1, &t2); + + vvd(t1, 2453750.5, 1e-6, "iauTaitt", "t1", status); + vvd(t2, 0.892855139, 1e-12, "iauTaitt", "t2", status); + viv(j, 0, "iauTaitt", "j", status); + +} + +static void t_taiut1(int *status) +/* +** - - - - - - - - - +** t _ t a i u t 1 +** - - - - - - - - - +** +** Test iauTaiut1 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTaiut1, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double u1, u2; + int j; + + + j = iauTaiut1(2453750.5, 0.892482639, -32.6659, &u1, &u2); + + vvd(u1, 2453750.5, 1e-6, "iauTaiut1", "u1", status); + vvd(u2, 0.8921045614537037037, 1e-12, "iauTaiut1", "u2", status); + viv(j, 0, "iauTaiut1", "j", status); + +} + +static void t_taiutc(int *status) +/* +** - - - - - - - - - +** t _ t a i u t c +** - - - - - - - - - +** +** Test iauTaiutc function. +** +** Returned: +** status LOGICAL TRUE = success, FALSE = fail +** +** Called: iauTaiutc, vvd, viv +** +** This revision: 2013 October 3 +*/ +{ + double u1, u2; + int j; + + + j = iauTaiutc(2453750.5, 0.892482639, &u1, &u2); + + vvd(u1, 2453750.5, 1e-6, "iauTaiutc", "u1", status); + vvd(u2, 0.8921006945555555556, 1e-12, "iauTaiutc", "u2", status); + viv(j, 0, "iauTaiutc", "j", status); + +} + +static void t_tcbtdb(int *status) +/* +** - - - - - - - - - +** t _ t c b t d b +** - - - - - - - - - +** +** Test iauTcbtdb function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTcbtdb, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double b1, b2; + int j; + + + j = iauTcbtdb(2453750.5, 0.893019599, &b1, &b2); + + vvd(b1, 2453750.5, 1e-6, "iauTcbtdb", "b1", status); + vvd(b2, 0.8928551362746343397, 1e-12, "iauTcbtdb", "b2", status); + viv(j, 0, "iauTcbtdb", "j", status); + +} + +static void t_tcgtt(int *status) +/* +** - - - - - - - - +** t _ t c g t t +** - - - - - - - - +** +** Test iauTcgtt function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTcgtt, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double t1, t2; + int j; + + + j = iauTcgtt(2453750.5, 0.892862531, &t1, &t2); + + vvd(t1, 2453750.5, 1e-6, "iauTcgtt", "t1", status); + vvd(t2, 0.8928551387488816828, 1e-12, "iauTcgtt", "t2", status); + viv(j, 0, "iauTcgtt", "j", status); + +} + +static void t_tdbtcb(int *status) +/* +** - - - - - - - - - +** t _ t d b t c b +** - - - - - - - - - +** +** Test iauTdbtcb function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTdbtcb, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double b1, b2; + int j; + + + j = iauTdbtcb(2453750.5, 0.892855137, &b1, &b2); + + vvd( b1, 2453750.5, 1e-6, "iauTdbtcb", "b1", status); + vvd( b2, 0.8930195997253656716, 1e-12, "iauTdbtcb", "b2", status); + viv(j, 0, "iauTdbtcb", "j", status); + +} + +static void t_tdbtt(int *status) +/* +** - - - - - - - - +** t _ t d b t t +** - - - - - - - - +** +** Test iauTdbtt function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTdbtt, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double t1, t2; + int j; + + + j = iauTdbtt(2453750.5, 0.892855137, -0.000201, &t1, &t2); + + vvd(t1, 2453750.5, 1e-6, "iauTdbtt", "t1", status); + vvd(t2, 0.8928551393263888889, 1e-12, "iauTdbtt", "t2", status); + viv(j, 0, "iauTdbtt", "j", status); + +} + +static void t_tf2a(int *status) +/* +** - - - - - - - +** t _ t f 2 a +** - - - - - - - +** +** Test iauTf2a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTf2a, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double a; + int j; + + + j = iauTf2a('+', 4, 58, 20.2, &a); + + vvd(a, 1.301739278189537429, 1e-12, "iauTf2a", "a", status); + viv(j, 0, "iauTf2a", "j", status); + +} + +static void t_tf2d(int *status) +/* +** - - - - - - - +** t _ t f 2 d +** - - - - - - - +** +** Test iauTf2d function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTf2d, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double d; + int j; + + + j = iauTf2d(' ', 23, 55, 10.9, &d); + + vvd(d, 0.9966539351851851852, 1e-12, "iauTf2d", "d", status); + viv(j, 0, "iauTf2d", "j", status); + +} + +static void t_tr(int *status) +/* +** - - - - - +** t _ t r +** - - - - - +** +** Test iauTr function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTr, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3], rt[3][3]; + + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + iauTr(r, rt); + + vvd(rt[0][0], 2.0, 0.0, "iauTr", "11", status); + vvd(rt[0][1], 3.0, 0.0, "iauTr", "12", status); + vvd(rt[0][2], 3.0, 0.0, "iauTr", "13", status); + + vvd(rt[1][0], 3.0, 0.0, "iauTr", "21", status); + vvd(rt[1][1], 2.0, 0.0, "iauTr", "22", status); + vvd(rt[1][2], 4.0, 0.0, "iauTr", "23", status); + + vvd(rt[2][0], 2.0, 0.0, "iauTr", "31", status); + vvd(rt[2][1], 3.0, 0.0, "iauTr", "32", status); + vvd(rt[2][2], 5.0, 0.0, "iauTr", "33", status); + +} + +static void t_trxp(int *status) +/* +** - - - - - - - +** t _ t r x p +** - - - - - - - +** +** Test iauTrxp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTrxp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3], p[3], trp[3]; + + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + p[0] = 0.2; + p[1] = 1.5; + p[2] = 0.1; + + iauTrxp(r, p, trp); + + vvd(trp[0], 5.2, 1e-12, "iauTrxp", "1", status); + vvd(trp[1], 4.0, 1e-12, "iauTrxp", "2", status); + vvd(trp[2], 5.4, 1e-12, "iauTrxp", "3", status); + +} + +static void t_trxpv(int *status) +/* +** - - - - - - - - +** t _ t r x p v +** - - - - - - - - +** +** Test iauTrxpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTrxpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3], pv[2][3], trpv[2][3]; + + + r[0][0] = 2.0; + r[0][1] = 3.0; + r[0][2] = 2.0; + + r[1][0] = 3.0; + r[1][1] = 2.0; + r[1][2] = 3.0; + + r[2][0] = 3.0; + r[2][1] = 4.0; + r[2][2] = 5.0; + + pv[0][0] = 0.2; + pv[0][1] = 1.5; + pv[0][2] = 0.1; + + pv[1][0] = 1.5; + pv[1][1] = 0.2; + pv[1][2] = 0.1; + + iauTrxpv(r, pv, trpv); + + vvd(trpv[0][0], 5.2, 1e-12, "iauTrxpv", "p1", status); + vvd(trpv[0][1], 4.0, 1e-12, "iauTrxpv", "p1", status); + vvd(trpv[0][2], 5.4, 1e-12, "iauTrxpv", "p1", status); + + vvd(trpv[1][0], 3.9, 1e-12, "iauTrxpv", "v1", status); + vvd(trpv[1][1], 5.3, 1e-12, "iauTrxpv", "v2", status); + vvd(trpv[1][2], 4.1, 1e-12, "iauTrxpv", "v3", status); + +} + +static void t_tttai(int *status) +/* +** - - - - - - - - +** t _ t t t a i +** - - - - - - - - +** +** Test iauTttai function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTttai, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double a1, a2; + int j; + + + j = iauTttai(2453750.5, 0.892482639, &a1, &a2); + + vvd(a1, 2453750.5, 1e-6, "iauTttai", "a1", status); + vvd(a2, 0.892110139, 1e-12, "iauTttai", "a2", status); + viv(j, 0, "iauTttai", "j", status); + +} + +static void t_tttcg(int *status) +/* +** - - - - - - - - +** t _ t t t c g +** - - - - - - - - +** +** Test iauTttcg function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTttcg, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double g1, g2; + int j; + + + j = iauTttcg(2453750.5, 0.892482639, &g1, &g2); + + vvd( g1, 2453750.5, 1e-6, "iauTttcg", "g1", status); + vvd( g2, 0.8924900312508587113, 1e-12, "iauTttcg", "g2", status); + viv(j, 0, "iauTttcg", "j", status); + +} + +static void t_tttdb(int *status) +/* +** - - - - - - - - +** t _ t t t d b +** - - - - - - - - +** +** Test iauTttdb function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTttdb, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double b1, b2; + int j; + + + j = iauTttdb(2453750.5, 0.892855139, -0.000201, &b1, &b2); + + vvd(b1, 2453750.5, 1e-6, "iauTttdb", "b1", status); + vvd(b2, 0.8928551366736111111, 1e-12, "iauTttdb", "b2", status); + viv(j, 0, "iauTttdb", "j", status); + +} + +static void t_ttut1(int *status) +/* +** - - - - - - - - +** t _ t t u t 1 +** - - - - - - - - +** +** Test iauTtut1 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauTtut1, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double u1, u2; + int j; + + + j = iauTtut1(2453750.5, 0.892855139, 64.8499, &u1, &u2); + + vvd(u1, 2453750.5, 1e-6, "iauTtut1", "u1", status); + vvd(u2, 0.8921045614537037037, 1e-12, "iauTtut1", "u2", status); + viv(j, 0, "iauTtut1", "j", status); + +} + +static void t_ut1tai(int *status) +/* +** - - - - - - - - - +** t _ u t 1 t a i +** - - - - - - - - - +** +** Test iauUt1tai function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauUt1tai, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double a1, a2; + int j; + + + j = iauUt1tai(2453750.5, 0.892104561, -32.6659, &a1, &a2); + + vvd(a1, 2453750.5, 1e-6, "iauUt1tai", "a1", status); + vvd(a2, 0.8924826385462962963, 1e-12, "iauUt1tai", "a2", status); + viv(j, 0, "iauUt1tai", "j", status); + +} + +static void t_ut1tt(int *status) +/* +** - - - - - - - - +** t _ u t 1 t t +** - - - - - - - - +** +** Test iauUt1tt function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauUt1tt, vvd, viv +** +** This revision: 2013 October 3 +*/ +{ + double t1, t2; + int j; + + + j = iauUt1tt(2453750.5, 0.892104561, 64.8499, &t1, &t2); + + vvd(t1, 2453750.5, 1e-6, "iauUt1tt", "t1", status); + vvd(t2, 0.8928551385462962963, 1e-12, "iauUt1tt", "t2", status); + viv(j, 0, "iauUt1tt", "j", status); + +} + +static void t_ut1utc(int *status) +/* +** - - - - - - - - - +** t _ u t 1 u t c +** - - - - - - - - - +** +** Test iauUt1utc function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauUt1utc, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double u1, u2; + int j; + + + j = iauUt1utc(2453750.5, 0.892104561, 0.3341, &u1, &u2); + + vvd(u1, 2453750.5, 1e-6, "iauUt1utc", "u1", status); + vvd(u2, 0.8921006941018518519, 1e-12, "iauUt1utc", "u2", status); + viv(j, 0, "iauUt1utc", "j", status); + +} + +static void t_utctai(int *status) +/* +** - - - - - - - - - +** t _ u t c t a i +** - - - - - - - - - +** +** Test iauUtctai function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauUtctai, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double u1, u2; + int j; + + + j = iauUtctai(2453750.5, 0.892100694, &u1, &u2); + + vvd(u1, 2453750.5, 1e-6, "iauUtctai", "u1", status); + vvd(u2, 0.8924826384444444444, 1e-12, "iauUtctai", "u2", status); + viv(j, 0, "iauUtctai", "j", status); + +} + +static void t_utcut1(int *status) +/* +** - - - - - - - - - +** t _ u t c u t 1 +** - - - - - - - - - +** +** Test iauUtcut1 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauUtcut1, vvd, viv +** +** This revision: 2013 August 7 +*/ +{ + double u1, u2; + int j; + + + j = iauUtcut1(2453750.5, 0.892100694, 0.3341, &u1, &u2); + + vvd(u1, 2453750.5, 1e-6, "iauUtcut1", "u1", status); + vvd(u2, 0.8921045608981481481, 1e-12, "iauUtcut1", "u2", status); + viv(j, 0, "iauUtcut1", "j", status); + +} + +static void t_xy06(int *status) +/* +** - - - - - - - +** t _ x y 0 6 +** - - - - - - - +** +** Test iauXy06 function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauXy06, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y; + + + iauXy06(2400000.5, 53736.0, &x, &y); + + vvd(x, 0.5791308486706010975e-3, 1e-15, "iauXy06", "x", status); + vvd(y, 0.4020579816732958141e-4, 1e-16, "iauXy06", "y", status); + +} + +static void t_xys00a(int *status) +/* +** - - - - - - - - - +** t _ x y s 0 0 a +** - - - - - - - - - +** +** Test iauXys00a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauXys00a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y, s; + + + iauXys00a(2400000.5, 53736.0, &x, &y, &s); + + vvd(x, 0.5791308472168152904e-3, 1e-14, "iauXys00a", "x", status); + vvd(y, 0.4020595661591500259e-4, 1e-15, "iauXys00a", "y", status); + vvd(s, -0.1220040848471549623e-7, 1e-18, "iauXys00a", "s", status); + +} + +static void t_xys00b(int *status) +/* +** - - - - - - - - - +** t _ x y s 0 0 b +** - - - - - - - - - +** +** Test iauXys00b function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauXys00b, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y, s; + + + iauXys00b(2400000.5, 53736.0, &x, &y, &s); + + vvd(x, 0.5791301929950208873e-3, 1e-14, "iauXys00b", "x", status); + vvd(y, 0.4020553681373720832e-4, 1e-15, "iauXys00b", "y", status); + vvd(s, -0.1220027377285083189e-7, 1e-18, "iauXys00b", "s", status); + +} + +static void t_xys06a(int *status) +/* +** - - - - - - - - - +** t _ x y s 0 6 a +** - - - - - - - - - +** +** Test iauXys06a function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauXys06a, vvd +** +** This revision: 2013 August 7 +*/ +{ + double x, y, s; + + + iauXys06a(2400000.5, 53736.0, &x, &y, &s); + + vvd(x, 0.5791308482835292617e-3, 1e-14, "iauXys06a", "x", status); + vvd(y, 0.4020580099454020310e-4, 1e-15, "iauXys06a", "y", status); + vvd(s, -0.1220032294164579896e-7, 1e-18, "iauXys06a", "s", status); + +} + +static void t_zp(int *status) +/* +** - - - - - +** t _ z p +** - - - - - +** +** Test iauZp function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauZp, vvd +** +** This revision: 2013 August 7 +*/ +{ + double p[3]; + + + p[0] = 0.3; + p[1] = 1.2; + p[2] = -2.5; + + iauZp(p); + + vvd(p[0], 0.0, 0.0, "iauZp", "1", status); + vvd(p[1], 0.0, 0.0, "iauZp", "2", status); + vvd(p[2], 0.0, 0.0, "iauZp", "3", status); + +} + +static void t_zpv(int *status) +/* +** - - - - - - +** t _ z p v +** - - - - - - +** +** Test iauZpv function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauZpv, vvd +** +** This revision: 2013 August 7 +*/ +{ + double pv[2][3]; + + + pv[0][0] = 0.3; + pv[0][1] = 1.2; + pv[0][2] = -2.5; + + pv[1][0] = -0.5; + pv[1][1] = 3.1; + pv[1][2] = 0.9; + + iauZpv(pv); + + vvd(pv[0][0], 0.0, 0.0, "iauZpv", "p1", status); + vvd(pv[0][1], 0.0, 0.0, "iauZpv", "p2", status); + vvd(pv[0][2], 0.0, 0.0, "iauZpv", "p3", status); + + vvd(pv[1][0], 0.0, 0.0, "iauZpv", "v1", status); + vvd(pv[1][1], 0.0, 0.0, "iauZpv", "v2", status); + vvd(pv[1][2], 0.0, 0.0, "iauZpv", "v3", status); + +} + +static void t_zr(int *status) +/* +** - - - - - +** t _ z r +** - - - - - +** +** Test iauZr function. +** +** Returned: +** status int FALSE = success, TRUE = fail +** +** Called: iauZr, vvd +** +** This revision: 2013 August 7 +*/ +{ + double r[3][3]; + + + r[0][0] = 2.0; + r[1][0] = 3.0; + r[2][0] = 2.0; + + r[0][1] = 3.0; + r[1][1] = 2.0; + r[2][1] = 3.0; + + r[0][2] = 3.0; + r[1][2] = 4.0; + r[2][2] = 5.0; + + iauZr(r); + + vvd(r[0][0], 0.0, 0.0, "iauZr", "00", status); + vvd(r[1][0], 0.0, 0.0, "iauZr", "01", status); + vvd(r[2][0], 0.0, 0.0, "iauZr", "02", status); + + vvd(r[0][1], 0.0, 0.0, "iauZr", "10", status); + vvd(r[1][1], 0.0, 0.0, "iauZr", "11", status); + vvd(r[2][1], 0.0, 0.0, "iauZr", "12", status); + + vvd(r[0][2], 0.0, 0.0, "iauZr", "20", status); + vvd(r[1][2], 0.0, 0.0, "iauZr", "21", status); + vvd(r[2][2], 0.0, 0.0, "iauZr", "22", status); + +} + +int main(int argc, char *argv[]) +/* +** - - - - - +** m a i n +** - - - - - +** +** This revision: 2016 March 12 +*/ +{ + int status; + + +/* If any command-line argument, switch to verbose reporting. */ + if (argc > 1) { + verbose = 1; + argv[0][0] += 0; /* to avoid compiler warnings */ + } + +/* Preset the &status to FALSE = success. */ + status = 0; + +/* Test all of the SOFA functions. */ + t_a2af(&status); + t_a2tf(&status); + t_ab(&status); + t_af2a(&status); + t_anp(&status); + t_anpm(&status); + t_apcg(&status); + t_apcg13(&status); + t_apci(&status); + t_apci13(&status); + t_apco(&status); + t_apco13(&status); + t_apcs(&status); + t_apcs13(&status); + t_aper(&status); + t_aper13(&status); + t_apio(&status); + t_apio13(&status); + t_atci13(&status); + t_atciq(&status); + t_atciqn(&status); + t_atciqz(&status); + t_atco13(&status); + t_atic13(&status); + t_aticq(&status); + t_aticqn(&status); + t_atio13(&status); + t_atioq(&status); + t_atoc13(&status); + t_atoi13(&status); + t_atoiq(&status); + t_bi00(&status); + t_bp00(&status); + t_bp06(&status); + t_bpn2xy(&status); + t_c2i00a(&status); + t_c2i00b(&status); + t_c2i06a(&status); + t_c2ibpn(&status); + t_c2ixy(&status); + t_c2ixys(&status); + t_c2s(&status); + t_c2t00a(&status); + t_c2t00b(&status); + t_c2t06a(&status); + t_c2tcio(&status); + t_c2teqx(&status); + t_c2tpe(&status); + t_c2txy(&status); + t_cal2jd(&status); + t_cp(&status); + t_cpv(&status); + t_cr(&status); + t_d2dtf(&status); + t_d2tf(&status); + t_dat(&status); + t_dtdb(&status); + t_dtf2d(&status); + t_eceq06(&status); + t_ecm06(&status); + t_ee00(&status); + t_ee00a(&status); + t_ee00b(&status); + t_ee06a(&status); + t_eect00(&status); + t_eform(&status); + t_eo06a(&status); + t_eors(&status); + t_epb(&status); + t_epb2jd(&status); + t_epj(&status); + t_epj2jd(&status); + t_epv00(&status); + t_eqec06(&status); + t_eqeq94(&status); + t_era00(&status); + t_fad03(&status); + t_fae03(&status); + t_faf03(&status); + t_faju03(&status); + t_fal03(&status); + t_falp03(&status); + t_fama03(&status); + t_fame03(&status); + t_fane03(&status); + t_faom03(&status); + t_fapa03(&status); + t_fasa03(&status); + t_faur03(&status); + t_fave03(&status); + t_fk52h(&status); + t_fk5hip(&status); + t_fk5hz(&status); + t_fw2m(&status); + t_fw2xy(&status); + t_g2icrs(&status); + t_gc2gd(&status); + t_gc2gde(&status); + t_gd2gc(&status); + t_gd2gce(&status); + t_gmst00(&status); + t_gmst06(&status); + t_gmst82(&status); + t_gst00a(&status); + t_gst00b(&status); + t_gst06(&status); + t_gst06a(&status); + t_gst94(&status); + t_h2fk5(&status); + t_hfk5z(&status); + t_icrs2g(&status); + t_ir(&status); + t_jd2cal(&status); + t_jdcalf(&status); + t_ld(&status); + t_ldn(&status); + t_ldsun(&status); + t_lteceq(&status); + t_ltecm(&status); + t_lteqec(&status); + t_ltp(&status); + t_ltpb(&status); + t_ltpecl(&status); + t_ltpequ(&status); + t_num00a(&status); + t_num00b(&status); + t_num06a(&status); + t_numat(&status); + t_nut00a(&status); + t_nut00b(&status); + t_nut06a(&status); + t_nut80(&status); + t_nutm80(&status); + t_obl06(&status); + t_obl80(&status); + t_p06e(&status); + t_p2pv(&status); + t_p2s(&status); + t_pap(&status); + t_pas(&status); + t_pb06(&status); + t_pdp(&status); + t_pfw06(&status); + t_plan94(&status); + t_pmat00(&status); + t_pmat06(&status); + t_pmat76(&status); + t_pm(&status); + t_pmp(&status); + t_pmpx(&status); + t_pmsafe(&status); + t_pn(&status); + t_pn00(&status); + t_pn00a(&status); + t_pn00b(&status); + t_pn06a(&status); + t_pn06(&status); + t_pnm00a(&status); + t_pnm00b(&status); + t_pnm06a(&status); + t_pnm80(&status); + t_pom00(&status); + t_ppp(&status); + t_ppsp(&status); + t_pr00(&status); + t_prec76(&status); + t_pv2p(&status); + t_pv2s(&status); + t_pvdpv(&status); + t_pvm(&status); + t_pvmpv(&status); + t_pvppv(&status); + t_pvstar(&status); + t_pvtob(&status); + t_pvu(&status); + t_pvup(&status); + t_pvxpv(&status); + t_pxp(&status); + t_refco(&status); + t_rm2v(&status); + t_rv2m(&status); + t_rx(&status); + t_rxp(&status); + t_rxpv(&status); + t_rxr(&status); + t_ry(&status); + t_rz(&status); + t_s00a(&status); + t_s00b(&status); + t_s00(&status); + t_s06a(&status); + t_s06(&status); + t_s2c(&status); + t_s2p(&status); + t_s2pv(&status); + t_s2xpv(&status); + t_sepp(&status); + t_seps(&status); + t_sp00(&status); + t_starpm(&status); + t_starpv(&status); + t_sxp(&status); + t_sxpv(&status); + t_taitt(&status); + t_taiut1(&status); + t_taiutc(&status); + t_tcbtdb(&status); + t_tcgtt(&status); + t_tdbtcb(&status); + t_tdbtt(&status); + t_tf2a(&status); + t_tf2d(&status); + t_tr(&status); + t_trxp(&status); + t_trxpv(&status); + t_tttai(&status); + t_tttcg(&status); + t_tttdb(&status); + t_ttut1(&status); + t_ut1tai(&status); + t_ut1tt(&status) ; + t_ut1utc(&status); + t_utctai(&status); + t_utcut1(&status); + t_xy06(&status); + t_xys00a(&status); + t_xys00b(&status); + t_xys06a(&status); + t_zp(&status); + t_zpv(&status); + t_zr(&status); + +/* Report, set up an appropriate exit status, and finish. */ + if (status) { + printf("t_sofa_c validation failed!\n"); + } else { + printf("t_sofa_c validation successful\n"); + } + return status; +} +/*---------------------------------------------------------------------- +** +** Copyright (C) 2017 +** Standards Of Fundamental Astronomy Board +** of the International Astronomical Union. +** +** ===================== +** SOFA Software License +** ===================== +** +** NOTICE TO USER: +** +** BY USING THIS SOFTWARE YOU ACCEPT THE FOLLOWING SIX TERMS AND +** CONDITIONS WHICH APPLY TO ITS USE. +** +** 1. The Software is owned by the IAU SOFA Board ("SOFA"). +** +** 2. Permission is granted to anyone to use the SOFA software for any +** purpose, including commercial applications, free of charge and +** without payment of royalties, subject to the conditions and +** restrictions listed below. +** +** 3. You (the user) may copy and distribute SOFA source code to others, +** and use and adapt its code and algorithms in your own software, +** on a world-wide, royalty-free basis. That portion of your +** distribution that does not consist of intact and unchanged copies +** of SOFA source code files is a "derived work" that must comply +** with the following requirements: +** +** a) Your work shall be marked or carry a statement that it +** (i) uses routines and computations derived by you from +** software provided by SOFA under license to you; and +** (ii) does not itself constitute software provided by and/or +** endorsed by SOFA. +** +** b) The source code of your derived work must contain descriptions +** of how the derived work is based upon, contains and/or differs +** from the original SOFA software. +** +** c) The names of all routines in your derived work shall not +** include the prefix "iau" or "sofa" or trivial modifications +** thereof such as changes of case. +** +** d) The origin of the SOFA components of your derived work must +** not be misrepresented; you must not claim that you wrote the +** original software, nor file a patent application for SOFA +** software or algorithms embedded in the SOFA software. +** +** e) These requirements must be reproduced intact in any source +** distribution and shall apply to anyone to whom you have +** granted a further right to modify the source code of your +** derived work. +** +** Note that, as originally distributed, the SOFA software is +** intended to be a definitive implementation of the IAU standards, +** and consequently third-party modifications are discouraged. All +** variations, no matter how minor, must be explicitly marked as +** such, as explained above. +** +** 4. You shall not cause the SOFA software to be brought into +** disrepute, either by misuse, or use for inappropriate tasks, or +** by inappropriate modification. +** +** 5. The SOFA software is provided "as is" and SOFA makes no warranty +** as to its use or performance. SOFA does not and cannot warrant +** the performance or results which the user may obtain by using the +** SOFA software. SOFA makes no warranties, express or implied, as +** to non-infringement of third party rights, merchantability, or +** fitness for any particular purpose. In no event will SOFA be +** liable to the user for any consequential, incidental, or special +** damages, including any lost profits or lost savings, even if a +** SOFA representative has been advised of such damages, or for any +** claim by any third party. +** +** 6. The provision of any version of the SOFA software under the terms +** and conditions specified herein does not imply that future +** versions will also be made available under the same terms and +** conditions. +* +** In any published work or commercial product which uses the SOFA +** software directly, acknowledgement (see www.iausofa.org) is +** appreciated. +** +** Correspondence concerning SOFA software should be addressed as +** follows: +** +** By email: sofa@ukho.gov.uk +** By post: IAU SOFA Center +** HM Nautical Almanac Office +** UK Hydrographic Office +** Admiralty Way, Taunton +** Somerset, TA1 2DN +** United Kingdom +** +**--------------------------------------------------------------------*/ diff --git a/WorldWideAstronomy/SOFA/taitt.c b/WorldWideAstronomy/SOFA/taitt.c index e019b94..eb2b86e 100644 --- a/WorldWideAstronomy/SOFA/taitt.c +++ b/WorldWideAstronomy/SOFA/taitt.c @@ -40,9 +40,9 @@ int iauTaitt(double tai1, double tai2, double *tt1, double *tt2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -64,7 +64,7 @@ int iauTaitt(double tai1, double tai2, double *tt1, double *tt2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/taiut1.c b/WorldWideAstronomy/SOFA/taiut1.c index 876eab7..0d5aa0f 100644 --- a/WorldWideAstronomy/SOFA/taiut1.c +++ b/WorldWideAstronomy/SOFA/taiut1.c @@ -42,9 +42,9 @@ int iauTaiut1(double tai1, double tai2, double dta, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. ** */ { @@ -66,7 +66,7 @@ int iauTaiut1(double tai1, double tai2, double dta, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/taiutc.c b/WorldWideAstronomy/SOFA/taiutc.c index d2297dd..24278bf 100644 --- a/WorldWideAstronomy/SOFA/taiutc.c +++ b/WorldWideAstronomy/SOFA/taiutc.c @@ -63,9 +63,9 @@ int iauTaiutc(double tai1, double tai2, double *utc1, double *utc2) ** ** This revision: 2013 September 12 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int big1; @@ -113,7 +113,7 @@ int iauTaiutc(double tai1, double tai2, double *utc1, double *utc2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tcbtdb.c b/WorldWideAstronomy/SOFA/tcbtdb.c index 7e2dad5..7c10fb9 100644 --- a/WorldWideAstronomy/SOFA/tcbtdb.c +++ b/WorldWideAstronomy/SOFA/tcbtdb.c @@ -54,9 +54,9 @@ int iauTcbtdb(double tcb1, double tcb2, double *tdb1, double *tdb2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -86,7 +86,7 @@ int iauTcbtdb(double tcb1, double tcb2, double *tdb1, double *tdb2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tcgtt.c b/WorldWideAstronomy/SOFA/tcgtt.c index 383087f..f7b86fd 100644 --- a/WorldWideAstronomy/SOFA/tcgtt.c +++ b/WorldWideAstronomy/SOFA/tcgtt.c @@ -39,9 +39,9 @@ int iauTcgtt(double tcg1, double tcg2, double *tt1, double *tt2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -63,7 +63,7 @@ int iauTcgtt(double tcg1, double tcg2, double *tt1, double *tt2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tdbtcb.c b/WorldWideAstronomy/SOFA/tdbtcb.c index e9d3354..401e3d6 100644 --- a/WorldWideAstronomy/SOFA/tdbtcb.c +++ b/WorldWideAstronomy/SOFA/tdbtcb.c @@ -54,9 +54,9 @@ int iauTdbtcb(double tdb1, double tdb2, double *tcb1, double *tcb2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -91,7 +91,7 @@ int iauTdbtcb(double tdb1, double tdb2, double *tcb1, double *tcb2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tdbtt.c b/WorldWideAstronomy/SOFA/tdbtt.c index 88cdfea..8ef65f3 100644 --- a/WorldWideAstronomy/SOFA/tdbtt.c +++ b/WorldWideAstronomy/SOFA/tdbtt.c @@ -52,9 +52,9 @@ int iauTdbtt(double tdb1, double tdb2, double dtr, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. ** */ { @@ -76,7 +76,7 @@ int iauTdbtt(double tdb1, double tdb2, double dtr, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tf2a.c b/WorldWideAstronomy/SOFA/tf2a.c index d2e388e..c66c1eb 100644 --- a/WorldWideAstronomy/SOFA/tf2a.c +++ b/WorldWideAstronomy/SOFA/tf2a.c @@ -41,9 +41,9 @@ int iauTf2a(char s, int ihour, int imin, double sec, double *rad) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -61,7 +61,7 @@ int iauTf2a(char s, int ihour, int imin, double sec, double *rad) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tf2d.c b/WorldWideAstronomy/SOFA/tf2d.c index cd5dc02..b78e3ee 100644 --- a/WorldWideAstronomy/SOFA/tf2d.c +++ b/WorldWideAstronomy/SOFA/tf2d.c @@ -41,9 +41,9 @@ int iauTf2d(char s, int ihour, int imin, double sec, double *days) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -61,7 +61,7 @@ int iauTf2d(char s, int ihour, int imin, double sec, double *days) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tr.c b/WorldWideAstronomy/SOFA/tr.c index 7518e8f..031ae2a 100644 --- a/WorldWideAstronomy/SOFA/tr.c +++ b/WorldWideAstronomy/SOFA/tr.c @@ -27,9 +27,9 @@ void iauTr(double r[3][3], double rt[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double wm[3][3]; @@ -47,7 +47,7 @@ void iauTr(double r[3][3], double rt[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/trxp.c b/WorldWideAstronomy/SOFA/trxp.c index 01fc562..54c2fe4 100644 --- a/WorldWideAstronomy/SOFA/trxp.c +++ b/WorldWideAstronomy/SOFA/trxp.c @@ -29,9 +29,9 @@ void iauTrxp(double r[3][3], double p[3], double trp[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double tr[3][3]; @@ -47,7 +47,7 @@ void iauTrxp(double r[3][3], double p[3], double trp[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/trxpv.c b/WorldWideAstronomy/SOFA/trxpv.c index b6ecef6..2547949 100644 --- a/WorldWideAstronomy/SOFA/trxpv.c +++ b/WorldWideAstronomy/SOFA/trxpv.c @@ -29,9 +29,9 @@ void iauTrxpv(double r[3][3], double pv[2][3], double trpv[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double tr[3][3]; @@ -47,7 +47,7 @@ void iauTrxpv(double r[3][3], double pv[2][3], double trpv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tttai.c b/WorldWideAstronomy/SOFA/tttai.c index 7efd7bc..aafa5e7 100644 --- a/WorldWideAstronomy/SOFA/tttai.c +++ b/WorldWideAstronomy/SOFA/tttai.c @@ -40,9 +40,9 @@ int iauTttai(double tt1, double tt2, double *tai1, double *tai2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -64,7 +64,7 @@ int iauTttai(double tt1, double tt2, double *tai1, double *tai2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tttcg.c b/WorldWideAstronomy/SOFA/tttcg.c index 23edfc7..28372dd 100644 --- a/WorldWideAstronomy/SOFA/tttcg.c +++ b/WorldWideAstronomy/SOFA/tttcg.c @@ -39,9 +39,9 @@ int iauTttcg(double tt1, double tt2, double *tcg1, double *tcg2) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -66,7 +66,7 @@ int iauTttcg(double tt1, double tt2, double *tcg1, double *tcg2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/tttdb.c b/WorldWideAstronomy/SOFA/tttdb.c index 7d23e10..32efa03 100644 --- a/WorldWideAstronomy/SOFA/tttdb.c +++ b/WorldWideAstronomy/SOFA/tttdb.c @@ -52,9 +52,9 @@ int iauTttdb(double tt1, double tt2, double dtr, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dtrd; @@ -75,7 +75,7 @@ int iauTttdb(double tt1, double tt2, double dtr, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ttut1.c b/WorldWideAstronomy/SOFA/ttut1.c index 1a81d25..18a411f 100644 --- a/WorldWideAstronomy/SOFA/ttut1.c +++ b/WorldWideAstronomy/SOFA/ttut1.c @@ -41,9 +41,9 @@ int iauTtut1(double tt1, double tt2, double dt, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dtd; @@ -64,7 +64,7 @@ int iauTtut1(double tt1, double tt2, double dt, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ut1tai.c b/WorldWideAstronomy/SOFA/ut1tai.c index 0a7c7d4..70a50e4 100644 --- a/WorldWideAstronomy/SOFA/ut1tai.c +++ b/WorldWideAstronomy/SOFA/ut1tai.c @@ -42,9 +42,9 @@ int iauUt1tai(double ut11, double ut12, double dta, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dtad; @@ -65,7 +65,7 @@ int iauUt1tai(double ut11, double ut12, double dta, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ut1tt.c b/WorldWideAstronomy/SOFA/ut1tt.c index 8c03daa..6b92032 100644 --- a/WorldWideAstronomy/SOFA/ut1tt.c +++ b/WorldWideAstronomy/SOFA/ut1tt.c @@ -41,9 +41,9 @@ int iauUt1tt(double ut11, double ut12, double dt, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double dtd; @@ -64,7 +64,7 @@ int iauUt1tt(double ut11, double ut12, double dt, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/ut1utc.c b/WorldWideAstronomy/SOFA/ut1utc.c index f093a1f..1dfa8ed 100644 --- a/WorldWideAstronomy/SOFA/ut1utc.c +++ b/WorldWideAstronomy/SOFA/ut1utc.c @@ -69,9 +69,9 @@ int iauUt1utc(double ut11, double ut12, double dut1, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int big1; @@ -147,7 +147,7 @@ int iauUt1utc(double ut11, double ut12, double dut1, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/utctai.c b/WorldWideAstronomy/SOFA/utctai.c index df4bf65..46312c4 100644 --- a/WorldWideAstronomy/SOFA/utctai.c +++ b/WorldWideAstronomy/SOFA/utctai.c @@ -65,9 +65,9 @@ int iauUtctai(double utc1, double utc2, double *tai1, double *tai2) ** ** This revision: 2013 July 26 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. ** */ { @@ -132,7 +132,7 @@ int iauUtctai(double utc1, double utc2, double *tai1, double *tai2) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/utcut1.c b/WorldWideAstronomy/SOFA/utcut1.c index 4056671..17ee045 100644 --- a/WorldWideAstronomy/SOFA/utcut1.c +++ b/WorldWideAstronomy/SOFA/utcut1.c @@ -70,9 +70,9 @@ int iauUtcut1(double utc1, double utc2, double dut1, ** ** This revision: 2013 August 12 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { int iy, im, id, js, jw; @@ -101,7 +101,7 @@ int iauUtcut1(double utc1, double utc2, double dut1, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/xy06.c b/WorldWideAstronomy/SOFA/xy06.c index 84f5d3e..202f2cc 100644 --- a/WorldWideAstronomy/SOFA/xy06.c +++ b/WorldWideAstronomy/SOFA/xy06.c @@ -92,9 +92,9 @@ void iauXy06(double date1, double date2, double *x, double *y) ** ** This revision: 2013 August 21 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { @@ -2712,7 +2712,7 @@ void iauXy06(double date1, double date2, double *x, double *y) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/xys00a.c b/WorldWideAstronomy/SOFA/xys00a.c index 36291d3..8ec3f85 100644 --- a/WorldWideAstronomy/SOFA/xys00a.c +++ b/WorldWideAstronomy/SOFA/xys00a.c @@ -66,9 +66,9 @@ void iauXys00a(double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3]; @@ -87,7 +87,7 @@ void iauXys00a(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/xys00b.c b/WorldWideAstronomy/SOFA/xys00b.c index ea85539..fc0c887 100644 --- a/WorldWideAstronomy/SOFA/xys00b.c +++ b/WorldWideAstronomy/SOFA/xys00b.c @@ -66,9 +66,9 @@ void iauXys00b(double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3]; @@ -87,7 +87,7 @@ void iauXys00b(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/xys06a.c b/WorldWideAstronomy/SOFA/xys06a.c index c36a8d5..d080600 100644 --- a/WorldWideAstronomy/SOFA/xys06a.c +++ b/WorldWideAstronomy/SOFA/xys06a.c @@ -66,9 +66,9 @@ void iauXys06a(double date1, double date2, ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { double rbpn[3][3]; @@ -87,7 +87,7 @@ void iauXys06a(double date1, double date2, /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/zp.c b/WorldWideAstronomy/SOFA/zp.c index 294c4d3..e7ccaa1 100644 --- a/WorldWideAstronomy/SOFA/zp.c +++ b/WorldWideAstronomy/SOFA/zp.c @@ -18,9 +18,9 @@ void iauZp(double p[3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { p[0] = 0.0; @@ -31,7 +31,7 @@ void iauZp(double p[3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/zpv.c b/WorldWideAstronomy/SOFA/zpv.c index c5563b1..7be2576 100644 --- a/WorldWideAstronomy/SOFA/zpv.c +++ b/WorldWideAstronomy/SOFA/zpv.c @@ -21,9 +21,9 @@ void iauZpv(double pv[2][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { iauZp(pv[0]); @@ -33,7 +33,7 @@ void iauZpv(double pv[2][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/SOFA/zr.c b/WorldWideAstronomy/SOFA/zr.c index 08eeee1..1086e85 100644 --- a/WorldWideAstronomy/SOFA/zr.c +++ b/WorldWideAstronomy/SOFA/zr.c @@ -18,9 +18,9 @@ void iauZr(double r[3][3]) ** ** This revision: 2013 June 18 ** -** SOFA release 2016-05-03 +** SOFA release 2017-04-20 ** -** Copyright (C) 2016 IAU SOFA Board. See notes at end. +** Copyright (C) 2017 IAU SOFA Board. See notes at end. */ { r[0][0] = 0.0; @@ -37,7 +37,7 @@ void iauZr(double r[3][3]) /*---------------------------------------------------------------------- ** -** Copyright (C) 2016 +** Copyright (C) 2017 ** Standards Of Fundamental Astronomy Board ** of the International Astronomical Union. ** diff --git a/WorldWideAstronomy/WWA/Astronomy/SpaceMotion/pvstar.cs b/WorldWideAstronomy/WWA/Astronomy/SpaceMotion/pvstar.cs index 1c83b96..8547795 100644 --- a/WorldWideAstronomy/WWA/Astronomy/SpaceMotion/pvstar.cs +++ b/WorldWideAstronomy/WWA/Astronomy/SpaceMotion/pvstar.cs @@ -30,7 +30,7 @@ public static partial class WWA /// /// Please read the ReadMe.1st text file for more information. /// - /// pv-vector (AU, AU/day) + /// pv-vector (au, au/day) /// right ascension (radians) /// declination (radians) /// RA proper motion (radians/year) @@ -57,12 +57,12 @@ public static int wwaPvstar(double[,] pv, ref double ra, ref double dec, ref dou double[] pv1 = new double[3]; - /* Isolate the radial component of the velocity (AU/day, inertial). */ + /* Isolate the radial component of the velocity (au/day, inertial). */ wwaPn(CopyArray(pv, 0), ref r, x); vr = wwaPdp(x, CopyArray(pv, 1)); wwaSxp(vr, x, ur); - /* Isolate the transverse component of the velocity (AU/day, inertial). */ + /* Isolate the transverse component of the velocity (au/day, inertial). */ wwaPmp(CopyArray(pv, 1), ur, ut); vt = wwaPm(ut); @@ -72,9 +72,9 @@ public static int wwaPvstar(double[,] pv, ref double ra, ref double dec, ref dou /* The inertial-to-observed correction terms. */ d = 1.0 + betr; - w = 1.0 - betr * betr - bett * bett; - if (d == 0.0 || w < 0) return -1; - del = Math.Sqrt(w) - 1.0; + w = betr * betr - bett * bett; + if (d == 0.0 || w > 1.0) return -1; + del = w / (Math.Sqrt(1.0 - w) + 1.0); /* Apply relativistic correction factor to radial velocity component. */ w = (betr != 0) ? (betr - del) / (betr * d) : 1.0; @@ -84,7 +84,7 @@ public static int wwaPvstar(double[,] pv, ref double ra, ref double dec, ref dou /* component. */ wwaSxp(1.0 / d, ut, ust); - /* Combine the two to obtain the observed velocity vector (AU/day). */ + /* Combine the two to obtain the observed velocity vector (au/day). */ //wwaPpp(usr, ust, CopyArray(pv, 1)); pv1 = CopyArray(pv, 1); wwaPpp(usr, ust, pv1); diff --git a/WorldWideAstronomy/WWA/wwa.cs b/WorldWideAstronomy/WWA/wwa.cs index 0185961..6bd5f68 100644 --- a/WorldWideAstronomy/WWA/wwa.cs +++ b/WorldWideAstronomy/WWA/wwa.cs @@ -159,9 +159,10 @@ public struct wwaLDBODY public const double TTMTAI = 32.184; /// - /// Astronomical unit (m) + /// Astronomical unit (m, IAU 2012) /// - public const double DAU = 149597870e3; + //public const double DAU = 149597870e3; + public const double DAU = 149597870.7e3; /// /// Speed of light (m/s) @@ -171,7 +172,8 @@ public struct wwaLDBODY /// /// Light time for 1 au (s) /// - public const double AULT = 499.004782; + //public const double AULT = 499.004782; + public const double AULT = (DAU / CMPS); /// /// Speed of light (AU per day) diff --git a/WorldWideAstronomy/WWATest/Program.cs b/WorldWideAstronomy/WWATest/Program.cs index d7fe58c..b84b845 100644 --- a/WorldWideAstronomy/WWATest/Program.cs +++ b/WorldWideAstronomy/WWATest/Program.cs @@ -299,14 +299,22 @@ static void t_apcg(ref int status) "wwaApcg", "eh(3)", ref status); vvd(astrom.em, 1.010465295811013146, 1e-12, "wwaApcg", "em", ref status); - vvd(astrom.v[0], 0.4289638897813379954e-4, 1e-16, - "wwaApcg", "v(1_", ref status); - vvd(astrom.v[1], 0.8115034021720941898e-4, 1e-16, - "wwaApcg", "v(2)", ref status); - vvd(astrom.v[2], 0.3517555123437237778e-4, 1e-16, - "wwaApcg", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999951686013336, 1e-12, - "wwaApcg", "bm1", ref status); + //vvd(astrom.v[0], 0.4289638897813379954e-4, 1e-16, + // "wwaApcg", "v(1_", ref status); + vvd(astrom.v[0], 0.4289638913597693554e-4, 1e-16, + "wwaApcg", "v(1)", ref status); + //vvd(astrom.v[1], 0.8115034021720941898e-4, 1e-16, + // "wwaApcg", "v(2)", ref status); + vvd(astrom.v[1], 0.8115034051581320575e-4, 1e-16, + "wwaApcg", "v(2)", ref status); + //vvd(astrom.v[2], 0.3517555123437237778e-4, 1e-16, + // "wwaApcg", "v(3)", ref status); + vvd(astrom.v[2], 0.3517555136380563427e-4, 1e-16, + "wwaApcg", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999951686013336, 1e-12, + // "wwaApcg", "bm1", ref status); + vvd(astrom.bm1, 0.9999999951686012981, 1e-12, + "wwaApcg", "bm1", ref status); vvd(astrom.bpn[0, 0], 1.0, 0.0, "wwaApcg", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0.0, 0.0, @@ -372,14 +380,22 @@ static void t_apcg13(ref int status) "wwaApcg13", "eh(3)", ref status); vvd(astrom.em, 1.010465295964664178, 1e-12, "wwaApcg13", "em", ref status); - vvd(astrom.v[0], 0.4289638897157027528e-4, 1e-16, - "wwaApcg13", "v(1)", ref status); - vvd(astrom.v[1], 0.8115034002544663526e-4, 1e-16, - "wwaApcg13", "v(2)", ref status); - vvd(astrom.v[2], 0.3517555122593144633e-4, 1e-16, - "wwaApcg13", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999951686013498, 1e-12, - "wwaApcg13", "bm1", ref status); + //vvd(astrom.v[0], 0.4289638897157027528e-4, 1e-16, + // "wwaApcg13", "v(1)", ref status); + vvd(astrom.v[0], 0.4289638912941341125e-4, 1e-16, + "wwaApcg13", "v(1)", ref status); + //vvd(astrom.v[1], 0.8115034002544663526e-4, 1e-16, + // "wwaApcg13", "v(2)", ref status); + vvd(astrom.v[1], 0.8115034032405042132e-4, 1e-16, + "wwaApcg13", "v(2)", ref status); + //vvd(astrom.v[2], 0.3517555122593144633e-4, 1e-16, + // "wwaApcg13", "v(3)", ref status); + vvd(astrom.v[2], 0.3517555135536470279e-4, 1e-16, + "wwaApcg13", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999951686013498, 1e-12, + // "wwaApcg13", "bm1", ref status); + vvd(astrom.bm1, 0.9999999951686013142, 1e-12, + "wwaApcg13", "bm1", ref status); vvd(astrom.bpn[0, 0], 1.0, 0.0, "wwaApcg13", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0.0, 0.0, @@ -459,14 +475,22 @@ static void t_apci(ref int status) "wwaApci", "eh(3)", ref status); vvd(astrom.em, 1.010465295811013146, 1e-12, "wwaApci", "em", ref status); - vvd(astrom.v[0], 0.4289638897813379954e-4, 1e-16, - "wwaApci", "v(1)", ref status); - vvd(astrom.v[1], 0.8115034021720941898e-4, 1e-16, - "wwaApci", "v(2)", ref status); - vvd(astrom.v[2], 0.3517555123437237778e-4, 1e-16, - "wwaApci", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999951686013336, 1e-12, - "wwaApci", "bm1", ref status); + //vvd(astrom.v[0], 0.4289638897813379954e-4, 1e-16, + // "wwaApci", "v(1)", ref status); + vvd(astrom.v[0], 0.4289638913597693554e-4, 1e-16, + "wwaApci", "v(1)", ref status); + //vvd(astrom.v[1], 0.8115034021720941898e-4, 1e-16, + // "wwaApci", "v(2)", ref status); + vvd(astrom.v[1], 0.8115034051581320575e-4, 1e-16, + "wwaApci", "v(2)", ref status); + //vvd(astrom.v[2], 0.3517555123437237778e-4, 1e-16, + // "wwaApci", "v(3)", ref status); + vvd(astrom.v[2], 0.3517555136380563427e-4, 1e-16, + "wwaApci", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999951686013336, 1e-12, + // "wwaApci", "bm1", ref status); + vvd(astrom.bm1, 0.9999999951686012981, 1e-12, + "wwaApci", "bm1", ref status); vvd(astrom.bpn[0, 0], 0.9999991390295159156, 1e-12, "wwaApci", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0.4978650072505016932e-7, 1e-12, @@ -532,14 +556,23 @@ static void t_apci13(ref int status) "wwaApci13", "eh(3)", ref status); vvd(astrom.em, 1.010465295964664178, 1e-12, "wwaApci13", "em", ref status); - vvd(astrom.v[0], 0.4289638897157027528e-4, 1e-16, - "wwaApci13", "v(1)", ref status); - vvd(astrom.v[1], 0.8115034002544663526e-4, 1e-16, - "wwaApci13", "v(2)", ref status); - vvd(astrom.v[2], 0.3517555122593144633e-4, 1e-16, - "wwaApci13", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999951686013498, 1e-12, + //vvd(astrom.v[0], 0.4289638897157027528e-4, 1e-16, + // "wwaApci13", "v(1)", ref status); + //vvd(astrom.v[1], 0.8115034002544663526e-4, 1e-16, + // "wwaApci13", "v(2)", ref status); + //vvd(astrom.v[2], 0.3517555122593144633e-4, 1e-16, + // "wwaApci13", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999951686013498, 1e-12, + // "wwaApci13", "bm1", ref status); + vvd(astrom.v[0], 0.4289638912941341125e-4, 1e-16, + "wwaApci13", "v(1)", ref status); + vvd(astrom.v[1], 0.8115034032405042132e-4, 1e-16, + "wwaApci13", "v(2)", ref status); + vvd(astrom.v[2], 0.3517555135536470279e-4, 1e-16, + "wwaApci13", "v(3)", ref status); + vvd(astrom.bm1, 0.9999999951686013142, 1e-12, "wwaApci13", "bm1", ref status); + vvd(astrom.bpn[0, 0], 0.9999992060376761710, 1e-12, "wwaApci13", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0.4124244860106037157e-7, 1e-12, @@ -619,28 +652,51 @@ static void t_apco(ref int status) vvd(astrom.pmt, 13.25248468622587269, 1e-11, "wwaApco", "pmt", ref status); - vvd(astrom.eb[0], -0.9741827110630897003, 1e-12, - "wwaApco", "eb(1)", ref status); - vvd(astrom.eb[1], -0.2115130190135014340, 1e-12, + //vvd(astrom.eb[0], -0.9741827110630897003, 1e-12, + // "wwaApco", "eb(1)", ref status); + //vvd(astrom.eb[1], -0.2115130190135014340, 1e-12, + // "wwaApco", "eb(2)", ref status); + //vvd(astrom.eb[2], -0.09179840186968295686, 1e-12, + // "wwaApco", "eb(3)", ref status); + //vvd(astrom.eh[0], -0.9736425571689670428, 1e-12, + // "wwaApco", "eh(1)", ref status); + //vvd(astrom.eh[1], -0.2092452125848862201, 1e-12, + // "wwaApco", "eh(2)", ref status); + //vvd(astrom.eh[2], -0.09075578152261439954, 1e-12, + // "wwaApco", "eh(3)", ref status); + //vvd(astrom.em, 0.9998233241710617934, 1e-12, + // "wwaApco", "em", ref status); + //vvd(astrom.v[0], 0.2078704985147609823e-4, 1e-16, + // "wwaApco", "v(1)", ref status); + //vvd(astrom.v[1], -0.8955360074407552709e-4, 1e-16, + // "wwaApco", "v(2)", ref status); + //vvd(astrom.v[2], -0.3863338980073114703e-4, 1e-16, + // "wwaApco", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999950277561600, 1e-12, + // "wwaApco", "bm1", ref status); + vvd(astrom.eb[0], -0.9741827110630322720, 1e-12, + "wwaApco", "eb(1)", ref status); + vvd(astrom.eb[1], -0.2115130190135344832, 1e-12, "wwaApco", "eb(2)", ref status); - vvd(astrom.eb[2], -0.09179840186968295686, 1e-12, + vvd(astrom.eb[2], -0.09179840186949532298, 1e-12, "wwaApco", "eb(3)", ref status); - vvd(astrom.eh[0], -0.9736425571689670428, 1e-12, + vvd(astrom.eh[0], -0.9736425571689739035, 1e-12, "wwaApco", "eh(1)", ref status); - vvd(astrom.eh[1], -0.2092452125848862201, 1e-12, + vvd(astrom.eh[1], -0.2092452125849330936, 1e-12, "wwaApco", "eh(2)", ref status); - vvd(astrom.eh[2], -0.09075578152261439954, 1e-12, + vvd(astrom.eh[2], -0.09075578152243272599, 1e-12, "wwaApco", "eh(3)", ref status); - vvd(astrom.em, 0.9998233241710617934, 1e-12, + vvd(astrom.em, 0.9998233241709957653, 1e-12, "wwaApco", "em", ref status); - vvd(astrom.v[0], 0.2078704985147609823e-4, 1e-16, + vvd(astrom.v[0], 0.2078704992916728762e-4, 1e-16, "wwaApco", "v(1)", ref status); - vvd(astrom.v[1], -0.8955360074407552709e-4, 1e-16, + vvd(astrom.v[1], -0.8955360107151952319e-4, 1e-16, "wwaApco", "v(2)", ref status); - vvd(astrom.v[2], -0.3863338980073114703e-4, 1e-16, + vvd(astrom.v[2], -0.3863338994288951082e-4, 1e-16, "wwaApco", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999950277561600, 1e-12, + vvd(astrom.bm1, 0.9999999950277561236, 1e-12, "wwaApco", "bm1", ref status); + vvd(astrom.bpn[0, 0], 0.9999991390295159156, 1e-12, "wwaApco", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0.4978650072505016932e-7, 1e-12, @@ -724,28 +780,51 @@ static void t_apco13(ref int status) vvd(astrom.pmt, 13.25248468622475727, 1e-11, "wwaApco13", "pmt", ref status); - vvd(astrom.eb[0], -0.9741827107321449445, 1e-12, - "wwaApco13", "eb(1)", ref status); - vvd(astrom.eb[1], -0.2115130190489386190, 1e-12, + //vvd(astrom.eb[0], -0.9741827107321449445, 1e-12, + // "wwaApco13", "eb(1)", ref status); + //vvd(astrom.eb[1], -0.2115130190489386190, 1e-12, + // "wwaApco13", "eb(2)", ref status); + //vvd(astrom.eb[2], -0.09179840189515518726, 1e-12, + // "wwaApco13", "eb(3)", ref status); + //vvd(astrom.eh[0], -0.9736425572586866640, 1e-12, + // "wwaApco13", "eh(1)", ref status); + //vvd(astrom.eh[1], -0.2092452121602867431, 1e-12, + // "wwaApco13", "eh(2)", ref status); + //vvd(astrom.eh[2], -0.09075578153903832650, 1e-12, + // "wwaApco13", "eh(3)", ref status); + //vvd(astrom.em, 0.9998233240914558422, 1e-12, + // "wwaApco13", "em", ref status); + //vvd(astrom.v[0], 0.2078704986751370303e-4, 1e-16, + // "wwaApco13", "v(1)", ref status); + //vvd(astrom.v[1], -0.8955360100494469232e-4, 1e-16, + // "wwaApco13", "v(2)", ref status); + //vvd(astrom.v[2], -0.3863338978840051024e-4, 1e-16, + // "wwaApco13", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999950277561368, 1e-12, + // "wwaApco13", "bm1", ref status); + vvd(astrom.eb[0], -0.9741827107320875162, 1e-12, + "wwaApco13", "eb(1)", ref status); + vvd(astrom.eb[1], -0.2115130190489716682, 1e-12, "wwaApco13", "eb(2)", ref status); - vvd(astrom.eb[2], -0.09179840189515518726, 1e-12, + vvd(astrom.eb[2], -0.09179840189496755339, 1e-12, "wwaApco13", "eb(3)", ref status); - vvd(astrom.eh[0], -0.9736425572586866640, 1e-12, + vvd(astrom.eh[0], -0.9736425572586935247, 1e-12, "wwaApco13", "eh(1)", ref status); - vvd(astrom.eh[1], -0.2092452121602867431, 1e-12, + vvd(astrom.eh[1], -0.2092452121603336166, 1e-12, "wwaApco13", "eh(2)", ref status); - vvd(astrom.eh[2], -0.09075578153903832650, 1e-12, + vvd(astrom.eh[2], -0.09075578153885665295, 1e-12, "wwaApco13", "eh(3)", ref status); - vvd(astrom.em, 0.9998233240914558422, 1e-12, + vvd(astrom.em, 0.9998233240913898141, 1e-12, "wwaApco13", "em", ref status); - vvd(astrom.v[0], 0.2078704986751370303e-4, 1e-16, + vvd(astrom.v[0], 0.2078704994520489246e-4, 1e-16, "wwaApco13", "v(1)", ref status); - vvd(astrom.v[1], -0.8955360100494469232e-4, 1e-16, + vvd(astrom.v[1], -0.8955360133238868938e-4, 1e-16, "wwaApco13", "v(2)", ref status); - vvd(astrom.v[2], -0.3863338978840051024e-4, 1e-16, + vvd(astrom.v[2], -0.3863338993055887398e-4, 1e-16, "wwaApco13", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999950277561368, 1e-12, + vvd(astrom.bm1, 0.9999999950277561004, 1e-12, "wwaApco13", "bm1", ref status); + vvd(astrom.bpn[0, 0], 0.9999991390295147999, 1e-12, "wwaApco13", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0.4978650075315529277e-7, 1e-12, @@ -836,28 +915,51 @@ static void t_apcs(ref int status) vvd(astrom.pmt, 13.25248468622587269, 1e-11, "wwaApcs", "pmt", ref status); - vvd(astrom.eb[0], -0.9741827110630456169, 1e-12, - "wwaApcs", "eb(1)", ref status); - vvd(astrom.eb[1], -0.2115130190136085494, 1e-12, + //vvd(astrom.eb[0], -0.9741827110630456169, 1e-12, + // "wwaApcs", "eb(1)", ref status); + //vvd(astrom.eb[1], -0.2115130190136085494, 1e-12, + // "wwaApcs", "eb(2)", ref status); + //vvd(astrom.eb[2], -0.09179840186973175487, 1e-12, + // "wwaApcs", "eb(3)", ref status); + //vvd(astrom.eh[0], -0.9736425571689386099, 1e-12, + // "wwaApcs", "eh(1)", ref status); + //vvd(astrom.eh[1], -0.2092452125849967195, 1e-12, + // "wwaApcs", "eh(2)", ref status); + //vvd(astrom.eh[2], -0.09075578152266466572, 1e-12, + // "wwaApcs", "eh(3)", ref status); + //vvd(astrom.em, 0.9998233241710457140, 1e-12, + // "wwaApcs", "em", ref status); + //vvd(astrom.v[0], 0.2078704985513566571e-4, 1e-16, + // "wwaApcs", "v(1)", ref status); + //vvd(astrom.v[1], -0.8955360074245006073e-4, 1e-16, + // "wwaApcs", "v(2)", ref status); + //vvd(astrom.v[2], -0.3863338980073572719e-4, 1e-16, + // "wwaApcs", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999950277561601, 1e-12, + // "wwaApcs", "bm1", ref status); + vvd(astrom.eb[0], -0.9741827110629881886, 1e-12, + "wwaApcs", "eb(1)", ref status); + vvd(astrom.eb[1], -0.2115130190136415986, 1e-12, "wwaApcs", "eb(2)", ref status); - vvd(astrom.eb[2], -0.09179840186973175487, 1e-12, + vvd(astrom.eb[2], -0.09179840186954412099, 1e-12, "wwaApcs", "eb(3)", ref status); - vvd(astrom.eh[0], -0.9736425571689386099, 1e-12, + vvd(astrom.eh[0], -0.9736425571689454706, 1e-12, "wwaApcs", "eh(1)", ref status); - vvd(astrom.eh[1], -0.2092452125849967195, 1e-12, + vvd(astrom.eh[1], -0.2092452125850435930, 1e-12, "wwaApcs", "eh(2)", ref status); - vvd(astrom.eh[2], -0.09075578152266466572, 1e-12, + vvd(astrom.eh[2], -0.09075578152248299218, 1e-12, "wwaApcs", "eh(3)", ref status); - vvd(astrom.em, 0.9998233241710457140, 1e-12, + vvd(astrom.em, 0.9998233241709796859, 1e-12, "wwaApcs", "em", ref status); - vvd(astrom.v[0], 0.2078704985513566571e-4, 1e-16, + vvd(astrom.v[0], 0.2078704993282685510e-4, 1e-16, "wwaApcs", "v(1)", ref status); - vvd(astrom.v[1], -0.8955360074245006073e-4, 1e-16, + vvd(astrom.v[1], -0.8955360106989405683e-4, 1e-16, "wwaApcs", "v(2)", ref status); - vvd(astrom.v[2], -0.3863338980073572719e-4, 1e-16, + vvd(astrom.v[2], -0.3863338994289409097e-4, 1e-16, "wwaApcs", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999950277561601, 1e-12, + vvd(astrom.bm1, 0.9999999950277561237, 1e-12, "wwaApcs", "bm1", ref status); + vvd(astrom.bpn[0, 0], 1, 0, "wwaApcs", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0, 0, @@ -916,28 +1018,51 @@ static void t_apcs13(ref int status) vvd(astrom.pmt, 12.65133794027378508, 1e-11, "wwaApcs13", "pmt", ref status); - vvd(astrom.eb[0], 0.9012691529023298391, 1e-12, - "wwaApcs13", "eb(1)", ref status); - vvd(astrom.eb[1], -0.4173999812023068781, 1e-12, + //vvd(astrom.eb[0], 0.9012691529023298391, 1e-12, + // "wwaApcs13", "eb(1)", ref status); + //vvd(astrom.eb[1], -0.4173999812023068781, 1e-12, + // "wwaApcs13", "eb(2)", ref status); + //vvd(astrom.eb[2], -0.1809906511146821008, 1e-12, + // "wwaApcs13", "eb(3)", ref status); + //vvd(astrom.eh[0], 0.8939939101759726824, 1e-12, + // "wwaApcs13", "eh(1)", ref status); + //vvd(astrom.eh[1], -0.4111053891734599955, 1e-12, + // "wwaApcs13", "eh(2)", ref status); + //vvd(astrom.eh[2], -0.1782336880637689334, 1e-12, + // "wwaApcs13", "eh(3)", ref status); + //vvd(astrom.em, 1.010428384373318379, 1e-12, + // "wwaApcs13", "em", ref status); + //vvd(astrom.v[0], 0.4279877278327626511e-4, 1e-16, + // "wwaApcs13", "v(1)", ref status); + //vvd(astrom.v[1], 0.7963255057040027770e-4, 1e-16, + // "wwaApcs13", "v(2)", ref status); + //vvd(astrom.v[2], 0.3517564000441374759e-4, 1e-16, + // "wwaApcs13", "v(3)", ref status); + //vvd(astrom.bm1, 0.9999999952947981330, 1e-12, + // "wwaApcs13", "bm1", ref status); + vvd(astrom.eb[0], 0.9012691529025250644, 1e-12, + "wwaApcs13", "eb(1)", ref status); + vvd(astrom.eb[1], -0.4173999812023194317, 1e-12, "wwaApcs13", "eb(2)", ref status); - vvd(astrom.eb[2], -0.1809906511146821008, 1e-12, + vvd(astrom.eb[2], -0.1809906511146429670, 1e-12, "wwaApcs13", "eb(3)", ref status); - vvd(astrom.eh[0], 0.8939939101759726824, 1e-12, + vvd(astrom.eh[0], 0.8939939101760130792, 1e-12, "wwaApcs13", "eh(1)", ref status); - vvd(astrom.eh[1], -0.4111053891734599955, 1e-12, + vvd(astrom.eh[1], -0.4111053891734021478, 1e-12, "wwaApcs13", "eh(2)", ref status); - vvd(astrom.eh[2], -0.1782336880637689334, 1e-12, + vvd(astrom.eh[2], -0.1782336880636997374, 1e-12, "wwaApcs13", "eh(3)", ref status); - vvd(astrom.em, 1.010428384373318379, 1e-12, + vvd(astrom.em, 1.010428384373491095, 1e-12, "wwaApcs13", "em", ref status); - vvd(astrom.v[0], 0.4279877278327626511e-4, 1e-16, + vvd(astrom.v[0], 0.4279877294121697570e-4, 1e-16, "wwaApcs13", "v(1)", ref status); - vvd(astrom.v[1], 0.7963255057040027770e-4, 1e-16, + vvd(astrom.v[1], 0.7963255087052120678e-4, 1e-16, "wwaApcs13", "v(2)", ref status); - vvd(astrom.v[2], 0.3517564000441374759e-4, 1e-16, + vvd(astrom.v[2], 0.3517564013384691531e-4, 1e-16, "wwaApcs13", "v(3)", ref status); - vvd(astrom.bm1, 0.9999999952947981330, 1e-12, + vvd(astrom.bm1, 0.9999999952947980978, 1e-12, "wwaApcs13", "bm1", ref status); + vvd(astrom.bpn[0, 0], 1, 0, "wwaApcs13", "bpn(1,1)", ref status); vvd(astrom.bpn[1, 0], 0, 0, @@ -1161,9 +1286,13 @@ static void t_atci13(ref int status) WWA.wwaAtci13(rc, dc, pr, pd, px, rv, date1, date2, ref ri, ref di, ref eo); - vvd(ri, 2.710121572969038991, 1e-12, + //vvd(ri, 2.710121572969038991, 1e-12, + // "wwaAtci13", "ri", ref status); + //vvd(di, 0.1729371367218230438, 1e-12, + // "wwaAtci13", "di", ref status); + vvd(ri, 2.710121572968696744, 1e-12, "wwaAtci13", "ri", ref status); - vvd(di, 0.1729371367218230438, 1e-12, + vvd(di, 0.1729371367219539137, 1e-12, "wwaAtci13", "di", ref status); vvd(eo, -0.002900618712657375647, 1e-14, "wwaAtci13", "eo", ref status); @@ -1205,8 +1334,10 @@ static void t_atciq(ref int status) WWA.wwaAtciq(rc, dc, pr, pd, px, rv, ref astrom, ref ri, ref di); - vvd(ri, 2.710121572969038991, 1e-12, "wwaAtciq", "ri", ref status); - vvd(di, 0.1729371367218230438, 1e-12, "wwaAtciq", "di", ref status); + //vvd(ri, 2.710121572969038991, 1e-12, "wwaAtciq", "ri", ref status); + //vvd(di, 0.1729371367218230438, 1e-12, "wwaAtciq", "di", ref status); + vvd(ri, 2.710121572968696744, 1e-12, "wwaAtciq", "ri", ref status); + vvd(di, 0.1729371367219539137, 1e-12, "wwaAtciq", "di", ref status); } static void t_atciqn(ref int status) @@ -1276,9 +1407,10 @@ static void t_atciqn(ref int status) WWA.wwaAtciqn(rc, dc, pr, pd, px, rv, ref astrom, 3, b, ref ri, ref di); - vvd(ri, 2.710122008105325582, 1e-12, "wwaAtciqn", "ri", ref status); - vvd(di, 0.1729371916491459122, 1e-12, "wwaAtciqn", "di", ref status); - + //vvd(ri, 2.710122008105325582, 1e-12, "wwaAtciqn", "ri", ref status); + //vvd(di, 0.1729371916491459122, 1e-12, "wwaAtciqn", "di", ref status); + vvd(ri, 2.710122008104983335, 1e-12, "wwaAtciqn", "ri", ref status); + vvd(di, 0.1729371916492767821, 1e-12, "wwaAtciqn", "di", ref status); } static void t_atciqz(ref int status) @@ -1312,8 +1444,10 @@ static void t_atciqz(ref int status) WWA.wwaAtciqz(rc, dc, ref astrom, ref ri, ref di); - vvd(ri, 2.709994899247599271, 1e-12, "wwaAtciqz", "ri", ref status); - vvd(di, 0.1728740720983623469, 1e-12, "wwaAtciqz", "di", ref status); + //vvd(ri, 2.709994899247599271, 1e-12, "wwaAtciqz", "ri", ref status); + //vvd(di, 0.1728740720983623469, 1e-12, "wwaAtciqz", "di", ref status); + vvd(ri, 2.709994899247256984, 1e-12, "wwaAtciqz", "ri", ref status); + vvd(di, 0.1728740720984931891, 1e-12, "wwaAtciqz", "di", ref status); } static void t_atco13(ref int status) @@ -1361,11 +1495,17 @@ static void t_atco13(ref int status) phpa, tc, rh, wl, ref aob, ref zob, ref hob, ref dob, ref rob, ref eo); - vvd(aob, 0.09251774485358230653, 1e-12, "wwaAtco13", "aob", ref status); - vvd(zob, 1.407661405256767021, 1e-12, "wwaAtco13", "zob", ref status); - vvd(hob, -0.09265154431403157925, 1e-12, "wwaAtco13", "hob", ref status); - vvd(dob, 0.1716626560075591655, 1e-12, "wwaAtco13", "dob", ref status); - vvd(rob, 2.710260453503097719, 1e-12, "wwaAtco13", "rob", ref status); + //vvd(aob, 0.09251774485358230653, 1e-12, "wwaAtco13", "aob", ref status); + //vvd(zob, 1.407661405256767021, 1e-12, "wwaAtco13", "zob", ref status); + //vvd(hob, -0.09265154431403157925, 1e-12, "wwaAtco13", "hob", ref status); + //vvd(dob, 0.1716626560075591655, 1e-12, "wwaAtco13", "dob", ref status); + //vvd(rob, 2.710260453503097719, 1e-12, "wwaAtco13", "rob", ref status); + vvd(aob, 0.09251774485385390973, 1e-12, "wwaAtco13", "aob", ref status); + vvd(zob, 1.407661405256671703, 1e-12, "wwaAtco13", "zob", ref status); + vvd(hob, -0.09265154431430045141, 1e-12, "wwaAtco13", "hob", ref status); + vvd(dob, 0.1716626560074556029, 1e-12, "wwaAtco13", "dob", ref status); + vvd(rob, 2.710260453503366591, 1e-12, "wwaAtco13", "rob", ref status); + vvd(eo, -0.003020548354802412839, 1e-14, "wwaAtco13", "eo", ref status); viv(j, 0, "wwaAtco13", "j", ref status); @@ -1397,8 +1537,10 @@ static void t_atic13(ref int status) WWA.wwaAtic13(ri, di, date1, date2, ref rc, ref dc, ref eo); - vvd(rc, 2.710126504531374930, 1e-12, "wwaAtic13", "rc", ref status); - vvd(dc, 0.1740632537628342320, 1e-12, "wwaAtic13", "dc", ref status); + //vvd(rc, 2.710126504531374930, 1e-12, "wwaAtic13", "rc", ref status); + //vvd(dc, 0.1740632537628342320, 1e-12, "wwaAtic13", "dc", ref status); + vvd(rc, 2.710126504531716819, 1e-12, "wwaAtic13", "rc", ref status); + vvd(dc, 0.1740632537627034482, 1e-12, "wwaAtic13", "dc", ref status); vvd(eo, -0.002900618712657375647, 1e-14, "wwaAtic13", "eo", ref status); } @@ -1431,8 +1573,10 @@ static void t_aticq(ref int status) WWA.wwaAticq(ri, di, ref astrom, ref rc, ref dc); - vvd(rc, 2.710126504531374930, 1e-12, "wwaAticq", "rc", ref status); - vvd(dc, 0.1740632537628342320, 1e-12, "wwaAticq", "dc", ref status); + //vvd(rc, 2.710126504531374930, 1e-12, "wwaAticq", "rc", ref status); + //vvd(dc, 0.1740632537628342320, 1e-12, "wwaAticq", "dc", ref status); + vvd(rc, 2.710126504531716819, 1e-12, "wwaAticq", "rc", ref status); + vvd(dc, 0.1740632537627034482, 1e-12, "wwaAticq", "dc", ref status); } @@ -1494,8 +1638,10 @@ static void t_aticqn(ref int status) WWA.wwaAticqn(ri, di, ref astrom, 3, b, ref rc, ref dc); - vvd(rc, 2.709999575032685412, 1e-12, "wwaAtciqn", "rc", ref status); - vvd(dc, 0.1739999656317778034, 1e-12, "wwaAtciqn", "dc", ref status); + //vvd(rc, 2.709999575032685412, 1e-12, "wwaAtciqn", "rc", ref status); + //vvd(dc, 0.1739999656317778034, 1e-12, "wwaAtciqn", "dc", ref status); + vvd(rc, 2.709999575033027333, 1e-12, "wwaAtciqn", "rc", ref status); + vvd(dc, 0.1739999656316469990, 1e-12, "wwaAtciqn", "dc", ref status); } static void t_atio13(ref int status) @@ -1634,8 +1780,10 @@ static void t_atoc13(ref int status) j = WWA.wwaAtoc13(ref refR, ob1, ob2, utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl, ref rc, ref dc); - vvd(rc, 2.709956744661000609, 1e-12, "wwaAtoc13", "R/rc", ref status); - vvd(dc, 0.1741696500895398562, 1e-12, "wwaAtoc13", "R/dc", ref status); + //vvd(rc, 2.709956744661000609, 1e-12, "wwaAtoc13", "R/rc", ref status); + //vvd(dc, 0.1741696500895398562, 1e-12, "wwaAtoc13", "R/dc", ref status); + vvd(rc, 2.709956744660731630, 1e-12, "wwaAtoc13", "R/rc", ref status); + vvd(dc, 0.1741696500896438967, 1e-12, "wwaAtoc13", "R/dc", ref status); viv(j, 0, "wwaAtoc13", "R/j", ref status); ob1 = -0.09247619879782006106; @@ -1644,8 +1792,10 @@ static void t_atoc13(ref int status) j = WWA.wwaAtoc13(ref refH, ob1, ob2, utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl, ref rc, ref dc); - vvd(rc, 2.709956744661000609, 1e-12, "wwaAtoc13", "H/rc", ref status); - vvd(dc, 0.1741696500895398562, 1e-12, "wwaAtoc13", "H/dc", ref status); + //vvd(rc, 2.709956744661000609, 1e-12, "wwaAtoc13", "H/rc", ref status); + //vvd(dc, 0.1741696500895398562, 1e-12, "wwaAtoc13", "H/dc", ref status); + vvd(rc, 2.709956744660731630, 1e-12, "wwaAtoc13", "H/rc", ref status); + vvd(dc, 0.1741696500896438967, 1e-12, "wwaAtoc13", "H/dc", ref status); viv(j, 0, "wwaAtoc13", "H/j", ref status); ob1 = 0.09233952224794989993; @@ -1654,8 +1804,10 @@ static void t_atoc13(ref int status) j = WWA.wwaAtoc13(ref refA, ob1, ob2, utc1, utc2, dut1, elong, phi, hm, xp, yp, phpa, tc, rh, wl, ref rc, ref dc); - vvd(rc, 2.709956744661000609, 1e-12, "wwaAtoc13", "A/rc", ref status); - vvd(dc, 0.1741696500895398565, 1e-12, "wwaAtoc13", "A/dc", ref status); + //vvd(rc, 2.709956744661000609, 1e-12, "wwaAtoc13", "A/rc", ref status); + //vvd(dc, 0.1741696500895398565, 1e-12, "wwaAtoc13", "A/dc", ref status); + vvd(rc, 2.709956744660731630, 1e-12, "wwaAtoc13", "A/rc", ref status); + vvd(dc, 0.1741696500896438970, 1e-12, "wwaAtoc13", "A/dc", ref status); viv(j, 0, "wwaAtoc13", "A/j", ref status); } @@ -3904,8 +4056,11 @@ static void t_fk52h(ref int status) "wwaFk52h", "dd5", ref status); vvd(pxh, 0.37921, 1e-14, "wwaFk52h", "px", ref status); - vvd(rvh, -7.6000000940000254, 1e-10, - "iauFk52h", "rv", ref status); + //vvd(rvh, -7.6000000940000254, 1e-10, + // "iauFk52h", "rv", ref status); + vvd(rvh, -7.6000000940000254, 1e-11, + "wwaFk52h", "rv", ref status); + } static void t_fk5hip(ref int status) @@ -4538,8 +4693,10 @@ static void t_h2fk5(ref int status) "wwaH2fk5", "dd5", ref status); vvd(px5, 0.37921, 1e-13, "wwaH2fk5", "px", ref status); - vvd(rv5, -7.6000001309071126, 1e-10, - "wwaH2fk5", "rv", ref status); + //vvd(rv5, -7.6000001309071126, 1e-10, + // "wwaH2fk5", "rv", ref status); + vvd(rv5, -7.6000001309071126, 1e-11, + "wwaH2fk5", "rv", ref status); } @@ -6053,9 +6210,12 @@ static void t_pmpx(ref int status) WWA.wwaPmpx(rc, dc, pr, pd, px, rv, pmt, pob, pco); - vvd(pco[0], 0.2328137623960308440, 1e-12, "wwaPmpx", "1", ref status); - vvd(pco[1], 0.6651097085397855317, 1e-12, "wwaPmpx", "2", ref status); - vvd(pco[2], 0.7095257765896359847, 1e-12, "wwaPmpx", "3", ref status); + //vvd(pco[0], 0.2328137623960308440, 1e-12, "wwaPmpx", "1", ref status); + //vvd(pco[1], 0.6651097085397855317, 1e-12, "wwaPmpx", "2", ref status); + //vvd(pco[2], 0.7095257765896359847, 1e-12, "wwaPmpx", "3", ref status); + vvd(pco[0], 0.2328137623960308438, 1e-12, "wwaPmpx", "1", ref status); + vvd(pco[1], 0.6651097085397855328, 1e-12, "wwaPmpx", "2", ref status); + vvd(pco[2], 0.7095257765896359837, 1e-12, "wwaPmpx", "3", ref status); } @@ -6097,16 +6257,25 @@ static void t_pmsafe(ref int status) vvd(ra2, 1.234087484501017061, 1e-12, "wwaPmsafe", "ra2", ref status); - vvd(dec2, 0.7888249982450468574, 1e-12, - "wwaPmsafe", "dec2", ref status); + //vvd(dec2, 0.7888249982450468574, 1e-12, + // "wwaPmsafe", "dec2", ref status); + vvd(dec2, 0.7888249982450468567, 1e-12, + "wwaPmsafe", "dec2", ref status); vvd(pmr2, 0.9996457663586073988e-5, 1e-12, "wwaPmsafe", "pmr2", ref status); - vvd(pmd2, -0.2000040085106737816e-4, 1e-16, - "wwaPmsafe", "pmd2", ref status); - vvd(px2, 0.9999997295356765185e-2, 1e-12, + //vvd(pmd2, -0.2000040085106737816e-4, 1e-16, + // "wwaPmsafe", "pmd2", ref status); + //vvd(px2, 0.9999997295356765185e-2, 1e-12, + // "wwaPmsafe", "px2", ref status); + //vvd(rv2, 10.38468380113917014, 1e-10, + // "wwaPmsafe", "rv2", ref status); + vvd(pmd2, -0.2000040085106754565e-4, 1e-16, + "wwaPmsafe", "pmd2", ref status); + vvd(px2, 0.9999997295356830666e-2, 1e-12, "wwaPmsafe", "px2", ref status); - vvd(rv2, 10.38468380113917014, 1e-10, + vvd(rv2, 10.38468380293920069, 1e-10, "wwaPmsafe", "rv2", ref status); + viv(j, 0, "wwaPmsafe", "j", ref status); } @@ -7492,10 +7661,14 @@ static void t_pvstar(ref int status) vvd(ra, 0.1686756e-1, 1e-12, "wwaPvstar", "ra", ref status); vvd(dec, -1.093989828, 1e-12, "wwaPvstar", "dec", ref status); - vvd(pmr, -0.178323516e-4, 1e-16, "wwaPvstar", "pmr", ref status); - vvd(pmd, 0.2336024047e-5, 1e-16, "wwaPvstar", "pmd", ref status); + //vvd(pmr, -0.178323516e-4, 1e-16, "wwaPvstar", "pmr", ref status); + //vvd(pmd, 0.2336024047e-5, 1e-16, "wwaPvstar", "pmd", ref status); + vvd(pmr, -0.1783235160000472788e-4, 1e-16, "wwaPvstar", "pmr", ref status); + vvd(pmd, 0.2336024047000619347e-5, 1e-16, "wwaPvstar", "pmd", ref status); + vvd(px, 0.74723, 1e-12, "wwaPvstar", "px", ref status); - vvd(rv, -21.6, 1e-11, "wwaPvstar", "rv", ref status); + //vvd(rv, -21.6, 1e-11, "wwaPvstar", "rv", ref status); + vvd(rv, -21.60000010107306010, 1e-11, "wwaPvstar", "rv", ref status); viv(j, 0, "wwaPvstar", "j", ref status); @@ -8519,17 +8692,29 @@ static void t_starpm(ref int status) 2400000.5, 50083.0, 2400000.5, 53736.0, ref ra2, ref dec2, ref pmr2, ref pmd2, ref px2, ref rv2); - vvd(ra2, 0.01668919069414242368, 1e-13, + //vvd(ra2, 0.01668919069414242368, 1e-13, + // "wwaStarpm", "ra", ref status); + //vvd(dec2, -1.093966454217127879, 1e-13, + // "wwaStarpm", "dec", ref status); + //vvd(pmr2, -0.1783662682155932702e-4, 1e-17, + // "wwaStarpm", "pmr", ref status); + //vvd(pmd2, 0.2338092915987603664e-5, 1e-17, + // "wwaStarpm", "pmd", ref status); + //vvd(px2, 0.7473533835323493644, 1e-13, + // "wwaStarpm", "px", ref status); + //vvd(rv2, -21.59905170476860786, 1e-11, + // "wwaStarpm", "rv", ref status); + vvd(ra2, 0.01668919069414256149, 1e-13, "wwaStarpm", "ra", ref status); - vvd(dec2, -1.093966454217127879, 1e-13, + vvd(dec2, -1.093966454217127897, 1e-13, "wwaStarpm", "dec", ref status); - vvd(pmr2, -0.1783662682155932702e-4, 1e-17, + vvd(pmr2, -0.1783662682153176524e-4, 1e-17, "wwaStarpm", "pmr", ref status); - vvd(pmd2, 0.2338092915987603664e-5, 1e-17, + vvd(pmd2, 0.2338092915983989595e-5, 1e-17, "wwaStarpm", "pmd", ref status); - vvd(px2, 0.7473533835323493644, 1e-13, + vvd(px2, 0.7473533835317719243, 1e-13, "wwaStarpm", "px", ref status); - vvd(rv2, -21.59905170476860786, 1e-11, + vvd(rv2, -21.59905170476417175, 1e-11, "wwaStarpm", "rv", ref status); viv(j, 0, "wwaStarpm", "j", ref status); @@ -8573,11 +8758,17 @@ static void t_starpv(ref int status) vvd(pv[0, 2], -245251.2339876830091, 1e-10, "wwaStarpv", "13", ref status); - vvd(pv[1, 0], -0.4051854035740712739e-2, 1e-13, + //vvd(pv[1, 0], -0.4051854035740712739e-2, 1e-13, + // "wwaStarpv", "21", ref status); + //vvd(pv[1, 1], -0.6253919754866173866e-2, 1e-15, + // "wwaStarpv", "22", ref status); + //vvd(pv[1, 2], 0.1189353719774107189e-1, 1e-13, + // "wwaStarpv", "23", ref status); + vvd(pv[1, 0], -0.4051854008955659551e-2, 1e-13, "wwaStarpv", "21", ref status); - vvd(pv[1, 1], -0.6253919754866173866e-2, 1e-15, + vvd(pv[1, 1], -0.6253919754414777970e-2, 1e-15, "wwaStarpv", "22", ref status); - vvd(pv[1, 2], 0.1189353719774107189e-1, 1e-13, + vvd(pv[1, 2], 0.1189353714588109341e-1, 1e-13, "wwaStarpv", "23", ref status); viv(j, 0, "wwaStarpv", "j", ref status);