File: rckin.cpp

package info (click to toggle)
pluto-lunar 0.0~git20180825.e34c1d1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster, forky, sid, trixie
  • size: 1,584 kB
  • sloc: cpp: 18,100; makefile: 653; ansic: 368
file content (106 lines) | stat: -rw-r--r-- 3,616 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <stdio.h>
#include <ctype.h>
/* rckin.cpp: processes/reformats JPL 'rckin' files

Copyright (C) 2010, Project Pluto

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301, USA.    */

#include <string.h>
#include <stdlib.h>

/* Code to convert files such as 'rckin.ura091.txt',  etc.  from
   ftp://ssd.jpl.nasa.gov/pub/eph/satellites/rckin
   into the form used in 'rocks.cpp'.

   Of late,  JPL hasn't been updating these files.  I gather this is
because they are using integrated ephemerides for almost all "rocks".
So this may prove to be of historical interest only.  (Although when
I asked,  Bob Jacobson kindly provided updates to some of the files.)
*/

int main( const int argc, const char **argv)
{
   FILE *ifile = fopen( argv[1], "rb");
   char buff[200];
   char rock_name[80];

   if( !ifile)
      {
      printf( "%s not opened\n", argv[1]);
      return( -1);
      }

   while( fgets( buff, sizeof( buff), ifile))
      {
      char *tptr = strchr( buff + 19, '\'');

      if( tptr)
         *tptr = '\0';
      tptr = strchr( buff + 19, ',');
      if( tptr)
         *tptr = '\0';
      tptr = buff + 19;
      if( !memcmp( buff, "  RCKNAM", 8))
         {
         int i;

         strcpy( rock_name, tptr);
         for( i = 1; rock_name[i]; i++)
            rock_name[i] = tolower( rock_name[i]);
         }
      if( !memcmp( buff, "  RCKNUM", 8))
         printf( "\n   {  %d,             /* %s %s*/\n", atoi( buff + 17),
                    rock_name, (argc < 3 ? " " : argv[2]));
      if( !memcmp( buff, "  RCKEP", 7))
         {
         strcat( tptr, ",");
         printf( "      %-38s/* element epoch Julian date     */\n", tptr);
         }
      if( !memcmp( buff, "  RCKELT", 8))
         {
         const int field_no = atoi( buff + 9);
         const char *comment[10] = { NULL,
                      "a = semi-major axis (km)      ",
                      "h = e sin(periapsis longitude)",
                      "k = e cos(periapsis longitude)",
                      "l = mean longitude (deg)      ",
                      "p = tan(i/2) sin(node)        ",
                      "q = tan(i/2) cos(node)        ",
                      "apsis rate (deg/sec)          ",
                      "mean motion (deg/sec)         ",
                      "node rate (deg/sec)           " };

         if( field_no == 4 || field_no == 7 || field_no == 8 || field_no == 9)
            strcat( tptr, " * PI / 180.");
         strcat( tptr, ",");
         printf( "      %-38s/* %s*/\n", tptr,
                     comment[atoi( buff + 9)]);
         }
      if( !memcmp( buff, "  CTRRA", 7))
         {
         strcat( tptr, " * PI / 180.,");
         printf( "      %-38s/* Laplacian plane pole ra (deg) */\n", tptr);
         }
      if( !memcmp( buff, "  CTRDEC", 8))
         {
         strcat( tptr, " * PI / 180. },");
         printf( "      %-38s/* Laplacian plane pole dec (deg)*/\n", tptr);
         }
      }
   fclose( ifile);
   return( 0);
}