35 use sufr_constants,
only: set_sufr_constants, homedir
36 use sufr_system,
only: error,quit_program_error
40 integer,
parameter :: ntrials = 11
42 character :: tryPaths(ntrials)*(99)
45 call set_sufr_constants()
56 trypaths(2) = trim(homedir)//
'/share/libTheSky/'
57 trypaths(3) = trim(homedir)//
'/local/share/libTheSky/'
58 trypaths(4) = trim(homedir)//
'/usr/share/libTheSky/'
59 trypaths(5) = trim(homedir)//
'/usr/local/share/libTheSky/'
60 trypaths(6) = trim(homedir)//
'/opt/share/libTheSky/'
61 trypaths(7) = trim(homedir)//
'/opt/local/share/libTheSky/'
64 trypaths(8) =
'/usr/share/libTheSky/'
65 trypaths(9) =
'/usr/local/share/libTheSky/'
66 trypaths(10) =
'/opt/share/libTheSky/'
67 trypaths(11) =
'/opt/local/share/libTheSky/'
77 call error(
'I could not find the libTheSky data directory. I tried the following possibilities:', 0)
79 write(0,
'(I4,2x,A)') try, trim(trypaths(try))
81 write(0,
'(A)')
'Please make sure you have the libTheSky data files installed. They can be found in the'
82 write(0,
'(A)')
'libthesky-data-<YYYYMMDD>.tar.bz2 tarball, which can be downloaded from libthesky.sf.net'
83 write(0,
'(A)')
'or github.com/astronomy/libTheSky. See the libTheSky INSTALL file for details.'
84 call quit_program_error(
'libTheSky: Data directory not found.', 1)
129 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_error_quit
130 use sufr_dummy,
only: dumstr
135 integer :: i,status, dn, ip
136 character :: infile*(199)
138 call find_free_io_unit(ip)
140 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
141 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
150 if(status.gt.0)
call file_read_error_quit(trim(infile), i, 1)
188 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_end_error
189 use sufr_dummy,
only: dumstr9
196 integer :: i,j, ip,status
197 character :: infile*(199)
200 call find_free_io_unit(ip)
202 open(ip, status=
'old', action=
'read', file=trim(infile), iostat=status)
203 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
209 read(ip,
'(A3,2x,A19,2x,A19,2x,A17,2x,A18)', iostat=status)
conabr(i),
latconnames(i),
genconnames(i), &
212 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
220 open(ip, status=
'old', action=
'read', file=trim(infile), iostat=status)
221 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
225 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
243 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_end_error
244 use sufr_kinds,
only: double
248 integer :: i,nu1(6),nu3, ip,status
249 real(double) :: nu2,nu4
250 character :: infile*(199)
252 call find_free_io_unit(ip)
254 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
255 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
258 read(ip,
'(5(I2),2x,I7,2x,F6.1,2x,I6,2x,F4.1)', iostat=status) nu1,nu2,nu3,nu4
259 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
277 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_end_error
278 use sufr_constants,
only: plana,au
283 integer :: pl, li, ip, status, powr,opowr, var, TOTnls(8)
284 character :: infile*(199)
286 vsopnls = reshape( (/ 2808,1620,2399, 671,426,585, 1080,349,997, &
287 2393,915,2175, 1484,530,1469, 2358,966,2435, 1578,516,1897, 681,290,959/), (/3,8/))
289 totnls(1:8) = sum(
vsopnls(:,1:8), 1)
292 vsoptruncs(1,:) = (/0.05d0, 0.5d0, 0.5d0, 0.5d0, 1.d0, 1.d0, 1.6d0, 1.d0/) * 1.d-9
297 call find_free_io_unit(ip)
299 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
300 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
307 read(ip,
'(I1,F18.11,F14.11,F20.11)', iostat=status) powr,
vsopdat(2:4,li,pl)
308 if(status.ne.0)
call file_read_end_error(trim(infile), li, status, 1, 1)
311 if(powr.ne.opowr)
then
312 if(powr.lt.opowr) var = var+1
331 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_end_error
336 integer :: i, ip, status
337 character :: infile*(199)
339 call find_free_io_unit(ip)
341 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
342 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
345 read(ip,
'(3I3,6I10)', iostat=status)
pluc(i,1),
pluc(i,2),
pluc(i,3),
plul(i,1),
plul(i,2),
plub(i,1),
plub(i,2), &
348 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
367 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_end_error
372 integer :: eq,pl,el, ip,status
373 character :: infile*(199)
375 call find_free_io_unit(ip)
377 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
378 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
383 if(eq.eq.2.and.(el.eq.2.or.el.eq.3)) cycle
385 read(ip,
'(F13.9, F18.10, 2F15.11)', iostat=status)
plelemdata(eq, pl, el, 0:3)
388 call file_read_end_error(trim(infile), 0, status, 0, 0)
416 use sufr_kinds,
only: double, dbl
417 use sufr_constants,
only: pi, pio2, d2r, as2r, r2as
418 use sufr_system,
only: find_free_io_unit,file_open_error_quit, file_read_end_error
419 use sufr_numerics,
only: dne
422 use thesky_moondata,
only:
nterm,
nrang,
pc1,
pc2,
pc3,
per1,
per2,
per3,
w,
ath
423 use thesky_moondata,
only:
eart,
peri,
p,
del,
zeta,
pre,
coef,
zone,
ilu,
ipla,
ideb,
c1,
c2
424 use thesky_moondata,
only:
p1,
p2,
p3,
p4,
p5,
q1,
q2,
q3,
q4,
q5,
prec0
427 integer :: i,ific,ir,itab,iv,j,k,iz, ip,status, filen(36),fl,il
428 real(double) :: prec,am,alpha,dtasm,precess, delnu,dele,delg,delnp,delep, xx,tgv,y,pha
429 character :: infile*(199)
431 filen = (/1023,918,704,347,316,237,14,11,8,14328,5233,6631,4384, &
432 833,1715,170,150,114,226,188,169,3,2,2,6,4,5,20,12,14,11,4,10,28,13,19/)
448 am = 0.074801329518d0
449 alpha = 0.002571881335d0
450 dtasm = 2.d0*alpha/(3.d0*am)
454 w(1,0) = (218.d0+18.d0*
c1 + 59.95571d0*
c2) * d2r
455 w(1,1) = 1732559343.73604d0 * as2r
457 w(1,2) = -6.8084d0 * as2r
466 w(1,3) = 0.6604d-2 * as2r
467 w(1,4) = -0.3169d-4 * as2r
470 w(2,0) = (83.d0+21.d0*
c1 + 11.67475d0*
c2) * d2r
471 w(2,1) = 14643420.2632d0 * as2r
472 w(2,2) = -38.2776d0 * as2r
473 w(2,3) = -0.45047d-1 * as2r
474 w(2,4) = 0.21301d-3 * as2r
477 w(3,0) = (125.d0+2.d0*
c1 + 40.39816d0*
c2) * d2r
478 w(3,1) = -6967919.3622d0 * as2r
479 w(3,2) = 6.3622d0 * as2r
480 w(3,3) = 0.7625d-2 * as2r
481 w(3,4) = -0.3586d-4 * as2r
485 eart(0) = (100.d0+27.d0*
c1 + 59.22059d0*
c2) * d2r
486 eart(1) = 129597742.2758d0 * as2r
487 eart(2) = -0.0202d0 * as2r
488 eart(3) = 0.9d-5 * as2r
489 eart(4) = 0.15d-6 * as2r
492 peri(0) = (102.d0+56.d0*
c1 + 14.42753d0*
c2) * d2r
493 peri(1) = 1161.2283d0 * as2r
494 peri(2) = 0.5327d0 * as2r
495 peri(3) = -0.138d-3 * as2r
500 precess = 5029.0966d0 * as2r
503 p(1,0) = (252.d0+15.d0*
c1+3.25986d0*
c2) * d2r
504 p(2,0) = (181.d0+58.d0*
c1+47.28305d0*
c2) * d2r
506 p(4,0) = (355.d0+25.d0*
c1+59.78866d0*
c2) * d2r
507 p(5,0) = (34.d0+21.d0*
c1+5.34212d0*
c2) * d2r
508 p(6,0) = (50.d0+4.d0*
c1+38.89694d0*
c2) * d2r
509 p(7,0) = (314.d0+3.d0*
c1+18.01841d0*
c2) * d2r
510 p(8,0) = (304.d0+20.d0*
c1+55.19575d0*
c2) * d2r
513 p(1,1) = 538101628.68898d0 * as2r
514 p(2,1) = 210664136.43355d0 * as2r
516 p(4,1) = 68905077.59284d0 * as2r
517 p(5,1) = 10925660.42861d0 * as2r
518 p(6,1) = 4399609.65932d0 * as2r
519 p(7,1) = 1542481.19393d0 * as2r
520 p(8,1) = 786550.32074d0 * as2r
523 delnu = +0.55604d0/
w(1,1) * as2r
524 dele = +0.01789d0 * as2r
525 delg = -0.08066d0 * as2r
526 delnp = -0.06424d0/
w(1,1) * as2r
527 delep = -0.12879d0 * as2r
532 del(4,i) =
w(1,i) -
w(3,i)
533 del(3,i) =
w(1,i) -
w(2,i)
539 zeta(1) =
w(1,1) + precess
561 call find_free_io_unit(ip)
563 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
564 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
566 if(dne(prec,
prec0))
then
568 pre(1) = prec * r2as - 1.d-12
569 pre(2) = prec * r2as - 1.d-12
576 iv = mod(ific-1,3) + 1
581 read(ip,
'(4I3,2x,F13.5,6(2x,F10.2))', iostat=status)
ilu,
coef
582 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
587 xx =
coef(1) + tgv*(delnp-am*delnu) +
coef(3)*delg +
coef(4)*dele +
coef(5)*delep
596 if(iv.eq.3)
zone(2) =
zone(2) + pio2
598 if(iv.eq.1)
pc1(i,ir) =
zone(i)
599 if(iv.eq.2)
pc2(i,ir) =
zone(i)
600 if(iv.eq.3)
pc3(i,ir) =
zone(i)
607 read(ip,
'(5I3,1x,F9.5,1x,F9.5)', iostat=status) iz,
ilu,pha,xx
608 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
613 if(k.eq.0) y = pha*d2r
621 j =
nrang(iv,itab-1)+ir
632 read(ip,
'(11I3,1x,F9.5,1x,F9.5)', iostat=status)
ipla,pha,xx
633 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
639 if(k.eq.0) y = pha*d2r
649 if(k.eq.0) y = pha*d2r
660 j =
nrang(iv,itab-1) + ir
694 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_end_error
695 use sufr_dummy,
only: dumstr
700 integer :: i, ip, status
701 character :: infile*(199)
703 call find_free_io_unit(ip)
705 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
706 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
714 if(status.ne.0)
call file_read_end_error(trim(infile), 3+i, status, 1, 1)
720 if(status.ne.0)
call file_read_end_error(trim(infile), 64+i, status, 1, 1)
737 integer,
intent(in) :: mode
738 integer,
intent(out) :: ierr
740 integer,
save :: modeInit = 999
745 if(mode.ne.modeinit)
then
787 use sufr_kinds,
only: double
788 use sufr_constants,
only: r2as, pi
789 use sufr_system,
only: quit_program_error
790 use thesky_elp_mpp02_constants,
only: w,eart,peri, zeta,del, p,delnu,dele,delg,delnp,delep,dtasm,am, p1,p2,p3,p4,p5, q1,q2,q3,q4,q5
793 integer,
intent(in) :: mode
795 real(double) :: bp(5,2), x2,x3,y2,y3, d21,d22,d23,d24,d25, d31,d32,d33,d34,d35, Cw2_1,Cw3_1
796 real(double) :: alpha,xa, Deart_0,Dperi, Dw1_1,Dgam,De, Deart_1,Dep, Dw1_0,Dw1_2,Dw2_0,Dw2_1,Dw3_0,Dw3_1
799 real(double),
parameter :: Dprec = -0.29965d0
802 data bp/ 0.311079095d0, -0.4482398d-2, -0.110248500d-2, 0.1056062d-2, 0.50928d-4, -0.103837907d0, 0.6682870d-3, -0.129807200d-2, -0.1780280d-3, -0.37342d-4 /
804 if(mode.lt.0 .or. mode.gt.1)
call quit_program_error(
'elp_mpp02_initialise(): mode must have value 0 or 1', 1)
808 alpha = 0.002571881d0
809 dtasm = (2*alpha)/(3*am)
850 w(1,1) = (1732559343.73604d0+dw1_1)/r2as
851 w(1,2) = ( -6.8084d0 +dw1_2)/r2as
852 w(1,3) = 0.66040d-2/r2as
853 w(1,4) = -0.31690d-4/r2as
857 w(2,1) = ( 14643420.3171d0 +dw2_1)/r2as
858 w(2,2) = ( -38.2631d0)/r2as
859 w(2,3) = -0.45047d-1/r2as
860 w(2,4) = 0.21301d-3/r2as
864 w(3,1) = ( -6967919.5383d0 +dw3_1)/r2as
865 w(3,2) = 6.3590d0/r2as
866 w(3,3) = 0.76250d-2/r2as
867 w(3,4) = -0.35860d-4/r2as
872 eart(1) = (129597742.29300d0 +deart_1)/r2as
873 eart(2) = -0.020200d0/r2as
874 eart(3) = 0.90000d-5/r2as
875 eart(4) = 0.15000d-6/r2as
879 peri(1) = 1161.24342d0/r2as
880 peri(2) = 0.529265d0/r2as
881 peri(3) = -0.11814d-3/r2as
882 peri(4) = 0.11379d-4/r2as
887 w(1,3) = w(1,3) - 0.00018865d0/r2as
888 w(1,4) = w(1,4) - 0.00001024d0/r2as
890 w(2,2) = w(2,2) + 0.00470602d0/r2as
891 w(2,3) = w(2,3) - 0.00025213d0/r2as
893 w(3,2) = w(3,2) - 0.00261070d0/r2as
894 w(3,3) = w(3,3) - 0.00010712d0/r2as
900 y2 = am*bp(1,1)+xa*bp(5,1)
901 y3 = am*bp(1,2)+xa*bp(5,2)
915 cw2_1 = d21*dw1_1+d25*deart_1+d22*dgam+d23*de+d24*dep
916 cw3_1 = d31*dw1_1+d35*deart_1+d32*dgam+d33*de+d34*dep
918 w(2,1) = w(2,1)+cw2_1/r2as
919 w(3,1) = w(3,1)+cw3_1/r2as
923 del(1,id) = w(1,id) - eart(id)
924 del(2,id) = w(1,id) - w(3,id)
925 del(3,id) = w(1,id) - w(2,id)
926 del(4,id) = eart(id) - peri(id)
928 del(1,0) = del(1,0) + pi
941 p(1,1) = 538101628.66888d0/r2as
942 p(2,1) = 210664136.45777d0/r2as
943 p(3,1) = 129597742.29300d0/r2as
944 p(4,1) = 68905077.65936d0/r2as
945 p(5,1) = 10925660.57335d0/r2as
946 p(6,1) = 4399609.33632d0/r2as
947 p(7,1) = 1542482.57845d0/r2as
948 p(8,1) = 786547.89700d0/r2as
955 zeta(1) = w(1,1) + (5029.0966d0+dprec)/r2as
961 delnu = (+0.55604d0+dw1_1)/r2as/w(1,1)
962 dele = (+0.01789d0+de)/r2as
963 delg = (-0.08066d0+dgam)/r2as
964 delnp = (-0.06424d0+deart_1)/r2as/w(1,1)
965 delep = (-0.12879d0+dep)/r2as
976 q1 = -0.113469002d-03
1000 use sufr_kinds,
only: double
1001 use sufr_constants,
only: pi2,pio2
1002 use sufr_system,
only: find_free_io_unit, file_open_error_quit
1005 use thesky_elp_mpp02_series,
only: cmpb,fmpb,nmpb, cper,fper,nper
1006 use thesky_elp_mpp02_constants,
only: zeta,del, p,delnu,dele,delg,delnp,delep,dtasm,am
1009 integer,
intent(out) :: ierr
1011 integer :: ip, i, ilu(4),ifi(16), icount,ipt,ir,it,iFile, k,iLine,nerr
1012 real(double) :: a,b(5),c, pha,s,tgv
1014 character :: filename*(199)
1023 inquire(file=trim(filename), exist=fexist)
1024 if(.not.fexist)
call file_open_error_quit(trim(filename), 1, 1)
1027 call find_free_io_unit(ip)
1028 open(ip,file=trim(filename),status=
'old',iostat=nerr)
1032 read(ip,
'(25x,I10)', iostat=nerr,
end=100) nmpb(iFile,1)
1033 if(nerr.ne.0)
return
1035 nmpb(ifile,2) = ir+1
1036 nmpb(ifile,3) = nmpb(ifile,1) + nmpb(ifile,2) - 1
1038 do iline=1,nmpb(ifile,1)
1040 read(ip,
'(4I3,2x,F13.5,5F12.2)', iostat=nerr,
end=100) ilu,a,b
1041 if(nerr.ne.0)
return
1044 tgv = b(1) + dtasm*b(5)
1045 if(ifile.eq.3) a = a - 2*a*delnu/3.d0
1046 cmpb(ir) = a + tgv*(delnp-am*delnu) + b(2)*delg + b(3)*dele + b(4)*delep
1051 fmpb(k,ir) = fmpb(k,ir) + ilu(i)*del(i,k)
1055 if(ifile.eq.3) fmpb(0,ir)=fmpb(0,ir)+pio2
1067 read(ip,
'(25x,2I10)', iostat=nerr,
end=100) nper(iFile,it,1),ipt
1069 if(nerr.ne.0)
return
1071 nper(ifile,it,2) = ir+1
1072 nper(ifile,it,3) = nper(ifile,it,1) + nper(ifile,it,2) - 1
1073 if(nper(ifile,it,1).eq.0) cycle
1075 do iline=1,nper(ifile,it,1)
1076 read(ip,
'(I5,2D20.13,16I3)', iostat=nerr,
end=100) icount,s,c,ifi
1078 if(nerr.ne.0)
return
1081 cper(ir) = sqrt(c**2+s**2)
1083 if(pha.lt.0.d0) pha = pha+pi2
1087 if(k.eq.0) fper(k,ir) = pha
1089 fper(k,ir) = fper(k,ir) + ifi(i)*del(i,k)
1092 fper(k,ir) = fper(k,ir) + ifi(i)*p(i-4,k)
1094 fper(k,ir) = fper(k,ir) + ifi(13)*zeta(k)
1130 use sufr_kinds,
only: double
1131 use sufr_constants,
only: d2r
1134 integer,
intent(in) :: deg, min
1135 real(double),
intent(in) :: sec
1156 use sufr_constants,
only: d2r
1157 use sufr_system,
only: find_free_io_unit, file_read_end_error
1158 use sufr_dummy,
only: dumstr9
1163 integer :: i,epoch, ip,status
1164 character :: infile*(199)
1166 call find_free_io_unit(ip)
1168 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
1169 if(status.ne.0)
then
1170 write(0,
'(/,A)')
' I could not open the file '//trim(infile)//
' - you will not be able to compute asteroid data.'
1171 write(0,
'(A,/)')
' Download http://sf.net/projects/libthesky/files/asteroids.dat.bz2 - unzip it and move it to '// &
1172 trim(infile)//
' to fix this.'
1180 read(ip,
'(7x,A18,I5,F11.7,F11.8,3F10.5,F12.7,F6.2,F5.2)', iostat=status)
asternames(i),epoch,
asterelems(i,2:9)
1181 if(status.ne.0)
call file_read_end_error(trim(infile), 2+i, status, 1, 1)
1183 if(status.ne.0)
then
1184 call file_read_end_error(trim(infile), 0, status, 0, 0)
1211 use sufr_kinds,
only: double
1212 use sufr_constants,
only: d2r, currentjd
1213 use sufr_system,
only: find_free_io_unit, quit_program_error, file_open_error_quit, file_read_error_quit
1214 use sufr_date_and_time,
only: cal2jd
1215 use sufr_dummy,
only: dumstr9
1221 integer :: ci,epoch, yr,mnt,idy, status, ip
1223 character :: tpstr*(14),epstr*(8), infile*(199)
1231 call find_free_io_unit(ip)
1235 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
1236 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
1242 read(ip,
'(A43,I8,F12.8,F11.8,3F10.5,1x,A14)', iostat=status)
cometnames(ci), epoch,
cometelems(ci,2),
cometelems(ci,3), &
1245 if(status.lt.0)
exit
1246 if(status.gt.0)
call file_read_error_quit(trim(infile), ci-10+2, 1)
1250 read(tpstr,
'(I4,I2,F8.5)', iostat=status) yr,mnt,dy
1251 if(status.ne.0)
call quit_program_error(
'readCometElements(): Error reading perihelion date from string', 1)
1259 open(ip, form=
'formatted', status=
'old', action=
'read', file=trim(infile), iostat=status)
1260 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
1263 read(ip,
'(A12, I6,I3,F8.4, 2F10.6,3F10.4, 2x,A8, F6.1,F5.1,2x,A56)', iostat=status) dumstr9, yr,mnt,dy, &
1266 if(status.lt.0)
exit
1267 if(status.gt.0)
call file_read_error_quit(trim(infile), ci-10, 1)
1272 read(epstr,
'(I4,I2,I2)', iostat=status) yr,mnt,idy
1273 if(status.ne.0)
call quit_program_error(
'readCometElements(): Error reading epoch from string', 1)
1275 if(len_trim(epstr).ne.8)
cometelems(ci,1) = currentjd
1281 call quit_program_error(
'readCometElements(): non-exisiting value of cometDatFile',0)
1300 use sufr_system,
only: find_free_io_unit, file_open_error_quit, file_read_error_quit, file_read_end_error
1301 use sufr_sorting,
only: sorted_index_list
1303 use thesky_bscdata,
only:
n_bsc,
bsc_abbr,
bsc_ra,
bsc_dec,
bsc_pma,
bsc_pmd,
bsc_rv,
bsc_vm,
bsc_par,
bsc_mult,
bsc_var
1308 integer :: i,rv,nsn,snr, ip,status
1309 character :: snam*(10), infile*(199)
1311 call find_free_io_unit(ip)
1313 open(ip, action=
'read', form=
'formatted', status=
'old', file=trim(infile), iostat=status)
1314 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
1317 read(ip,
'(A10,1x,2F10.6,1x,2F7.3,I5,F6.2,F6.3,A2,A10,2x,A20,I8,1x,3F6.2)', iostat=status) &
1318 bsc_abbr(i),
bsc_ra(i),
bsc_dec(i),
bsc_pma(i),
bsc_pmd(i),rv,
bsc_vm(i),
bsc_par(i),
bsc_mult(i),
bsc_var(i), &
1321 if(status.ne.0)
call file_read_end_error(trim(infile), i, status, 1, 1)
1336 open(ip, action=
'read', form=
'formatted', status=
'old', file=trim(infile), iostat=status)
1337 if(status.ne.0)
call file_open_error_quit(trim(infile), 1, 1)
1340 read(ip,
'(I4,2x,A10)', iostat=status) snr, snam
1341 if(status.lt.0)
exit
1342 if(status.gt.0)
call file_read_error_quit(trim(infile), i, 1)
Data from the Bright Star Catalogue (BSC)
integer, parameter n_bsc
Size of the Bright Star Catalogue (BSC)
real(double), dimension(n_bsc) bsc_bv
B-V colours of the BSC stars.
real(double), dimension(n_bsc) bsc_ub
U-B colours of the BSC stars.
real(double), dimension(n_bsc) bsc_dec
Declinations of the BSC stars.
real(double), dimension(n_bsc) bsc_par
Parallaxes of the BSC stars.
character, dimension(10) bsc_abbr
Abbreviated names/codes for the BSC stars.
real(double), dimension(n_bsc) bsc_vm
Visual magnitudes of the BSC stars.
character, dimension(n_bsc) bsc_mult
Multiplicity codes for the BSC stars.
real(double), dimension(n_bsc) bsc_pmd
Proper motions in declination of the BSC stars.
character, dimension(20) bsc_sptype
Spectral types of the BSC stars.
character, dimension(10) bsc_name
Proper names of the BSC stars.
real(double), dimension(n_bsc) bsc_rv
Radial velocities of the BSC stars.
real(double), dimension(n_bsc) bsc_pma
Proper motions in RA of the BSC stars.
real(double), dimension(n_bsc) bsc_ra
Right ascensions of the BSC stars.
integer, dimension(n_bsc) bsc_sao
SAO numbers of the BSC stars.
real(double), dimension(n_bsc) bsc_ri
R-I colours of the BSC stars.
integer, dimension(n_bsc) bsc_vm_indx
Index array for sorting to visual magnitude.
character, dimension(n_bsc) bsc_var
Variability codes for the BSC stars.
Data to compute comet positions.
integer, parameter ncometsmax
Size of comet database.
logical, dimension(ncometsmax) cometdiedatp
This comet died at perihelion (true/false)
real(double), dimension(ncometsmax, 9) cometelems
Orbital elements of the comets: 1: JD of epoch (often J2000), 2: Perihelion distance (AU?...
character, dimension(60) cometnames
Names of the comets.
integer ncomets
Actual number of comets in database.
integer cometdatfile
Data file to use 1: comets.dat (MANY comets, no magnitude info), 2: comets_mpc.dat (currently visible...
Constants used in libTheSky.
character, dimension(99) library_name
Name of this library.
integer thesky_verbosity
Verbosity of libTheSky output.
real(double) deltat_forced
Forced value for DeltaT, overriding computation.
integer, parameter deltat_nmax
Maximum number of Delta-T measurements. Need ~430 until 2000.
real(double) deltat_accel
Acceleration for DeltaT parabola.
integer deltat_minyr
Start year of DeltaT measurements.
real(double) deltat_change
Change for DeltaT parabola.
real(double) jd1820
JD of 1820.0, for DeltaT.
character, dimension(99) theskydatadir
Directory containing data files for libTheSky.
real(double), dimension(deltat_nmax) deltat_values
Values of DeltaT.
integer deltat_n
Actual number of DeltaT measurements.
real(double) deltat_0
Zero point for DeltaT parabola.
real(double), dimension(9, 63) nutationdat
Data for simple nutation function.
real(double), dimension(deltat_nmax) deltat_years
Years for DeltaT values.
integer deltat_maxyr
End year of DeltaT measurements.
Procedures to set constants and read data files.
subroutine readcometelements()
Read orbital-element data for the comets.
subroutine readmoondata()
Read ELP-82B periodic terms from moondata.dat.
subroutine readnutation()
Read nutation input files.
subroutine elp_mpp02_initialise_and_read_files(mode, ierr)
Initialise ELP-MPP02 data and read the data files.
subroutine readplanetelements()
Read the data needed to compute the orbital elements of the planets.
subroutine readconstellations()
Read constellation names: abbreviation, Latin, genitive, Dutch and English.
subroutine elp_mpp02_read_files(ierr)
Read the six data files containing the ELP/MPP02 series.
subroutine read_bsc
Read the Bright Star Catalogue.
subroutine elp_mpp02_initialise(mode)
Initialization of the constants and parameters used for the evaluation of the ELP/MPP02 series.
subroutine read_deltat()
Read deltat.dat with historical values for DeltaT.
subroutine readmoondata_la()
Read low-accuracy moon-position data from Meeus (moon_la.dat)
real(double) function elp_dms2rad(deg, min, sec)
Function for the conversion: sexagesimal degrees -> radians.
subroutine readpluto()
Read periodic terms for the position of Pluto.
subroutine set_thesky_constants()
Set the initial values of the variables and constants used in this package.
subroutine readasteroidelements()
Read orbital-element data for the asteroids.
subroutine thesky_readdata()
Read input data files.
subroutine readplanetdata()
Reads VSOP planet data from planets.dat.
ELP 2000-82B Moon data, needed to compute Moon positions.
real(double), dimension(4, 0:4) del
Delaunay's variables (https://en.wikipedia.org/wiki/Orbital_elements#Delaunay_variables)
real(double) q5
Precession cosine coefficient for ELP 2000-82B theory.
real(double) q3
Precession cosine coefficient for ELP 2000-82B theory.
real(double), dimension(3, 0:4) w
Constants for mean longitude.
integer, dimension(3, 0:12) nrang
CHECK: Number of terms? in ELP 2000-82B data file.
real(double), parameter c1
Constant for ELP 2000-82B theory (arcminutes to degrees)
real(double) p3
Precession sine coefficient for ELP 2000-82B theory.
real(double) q4
Precession cosine coefficient for ELP 2000-82B theory.
real(double), dimension(0:4) peri
Mean longitude of the perihelion of the Earth-Moon barycentre (EMB)
real(double), dimension(6, 704) pc3
CHECK: Something in ELP 2000-82B theory.
real(double), dimension(0:1) zeta
Mean longitude (w) + rate precession (?)
real(double) q2
Precession cosine coefficient for ELP 2000-82B theory.
real(double), dimension(6, 918) pc2
CHECK: Something in ELP 2000-82B theory.
real(double) prec0
CHECK: Something in ELP 2000-82B theory.
real(double), dimension(6, 1023) pc1
CHECK: Something in ELP 2000-82B theory.
real(double), dimension(3, 19537) per1
CHECK: Something in ELP 2000-82B theory.
integer ideb
Memorise whether this routine has been run before.
real(double), parameter ath
Constant for ELP 2000-82B theory (orbital separation?)
real(double), dimension(8, 0:1) p
Planetary arguments: mean longitudes and mean motions.
integer, dimension(3, 12) nterm
CHECK: Number of terms? in ELP 2000-82B data file.
real(double), dimension(3, 6766) per2
CHECK: Something in ELP 2000-82B theory.
integer, dimension(4) ilu
CHECK: Coefficients in ELP 2000-82B data file (integer)
real(double) p5
Precession sine coefficient for ELP 2000-82B theory.
real(double) p2
Precession sine coefficient for ELP 2000-82B theory.
real(double) p1
Precession sine coefficient for ELP 2000-82B theory.
real(double), dimension(0:4) eart
Earth-Moon barycentre (EMB) elements.
integer, dimension(11) ipla
CHECK: Coefficients in ELP 2000-82B data file (integer)
real(double), parameter c2
Constant for ELP 2000-82B theory (arcseconds to degrees)
real(double), dimension(6) zone
CHECK: Something in ELP 2000-82B theory.
real(double) q1
Precession cosine coefficient for ELP 2000-82B theory.
real(double), dimension(7) coef
CHECK: Coefficients in ELP 2000-82B data file (float)
real(double) p4
Precession sine coefficient for ELP 2000-82B theory.
real(double), dimension(3, 8924) per3
CHECK: Something in ELP 2000-82B theory.
real(double), dimension(3) pre
CHECK: does this actually do anything?
Planet data, needed to compute planet positions.
real(double), dimension(4, 6827, 10) vsopdat
Periodic terms for VSOP87.
integer(long), dimension(3, 60) moonla_lrb
L,B,R data for the low-accuracy (la) Moon position.
character, dimension(18) asternames
Names of the asteroids.
integer, dimension(43, 2) plub
Constants for the latitude of Pluto.
integer, dimension(3, 8) vsopnls
Numbers of lines in the VSOP input files (l,b,r x 8 pl)
integer, dimension(43, 2) plur
Constants for the distance of Pluto.
real(double), dimension(3, 8) vsoptruncs
Truncuate VSOP87 terms at these accuracies.
real(double), dimension(2, 8, 6, 0:3) plelemdata
Data to compute planet orbital elements.
integer, dimension(43, 3) pluc
Constants for the periodic terms for the position of Pluto.
integer, dimension(43, 2) plul
Constants for the longitude of Pluto.
integer, dimension(8, 60) moonla_arg
Arguments for the low-accuracy (la) Moon position.
integer, parameter nasteroids
Number of entries in the asteroids array. Nasteroids is actually much larger; look at the first Naste...
integer, dimension(0:5, 3, 8) vsopnblk
Line number in the VSOP data where the next block of (Planet, Variable (LBR), Power) starts.
real(double), dimension(nasteroids, 9) asterelems
Asteroid orbital elements.
Star and basic constellation data.
character, dimension(19) latconnames
Latin constellation names.
character, dimension(3) conidabr
Abbreviations of the constellation IDs.
character, dimension(17) nlconnames
Dutch constellation names.
integer, parameter nconid
Number of data points for constellation ID.
character, dimension(19) genconnames
Genitives of the Latin constellation names.
integer, parameter nconstel
Number of constellations.
real(double), dimension(nconid) coniddecl
Constellation lower declination boundary for ID.
character, dimension(18) enconnames
English constellation names.
real(double), dimension(nconid) conidrau
Constellation uppwer RA boundary for ID.
integer, dimension(nconid) conid
Constellation ID.
character, dimension(3) conabr
Abbreviations of the constellations.
real(double), dimension(nconid) conidral
Constellation lower RA boundary for ID.