-
Notifications
You must be signed in to change notification settings - Fork 43
/
Copy pathtest3.cpp
133 lines (123 loc) · 4.36 KB
/
test3.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
/* Copyright (C) 2018, Project Pluto. See LICENSE. */
/*
* test3.cpp 8 October 2002
*
* A skeleton main() function to test the speed of SxPx
* functions, and the positional differences between SGPx and SDPx.
* (I was curious as to whether the extra code in SDPx made any really
* significant difference; it was starting to look as if SDPx was a
* waste of code. Turns out that it depends greatly on the satellite
* in question; I'll post results in a bit, when I find the time.)
*
* Also, this demonstrates how to use the new dynamically-loaded
* functions in 'dynamic.cpp'. This way, if your program can't
* find 'sat_code.dll', it'll gracefully give you a message about it.
* In the case of my own _Guide_ planetarium software, if it can't
* find the DLL, it can fall back on its own SGP4-only code.
*/
#include <stdio.h>
#include <math.h>
#include <string.h>
#include <stdlib.h>
#include <time.h>
#include "norad.h"
/* Main program */
int main( int argc, char **argv)
{
FILE *ifile = fopen( (argc == 1) ? "test.tle" : argv[1], "rb");
tle_t tle; /* Pointer to two-line elements set for satellite */
char line1[100], line2[100];
double t_since = atof( argv[2]);
double rms_diff = 0.;
int verbose = 0, n_found = 0, n_runs = 1, show_sdp = 1;
int ephem = 1; /* default to SGP4 */
int i, j; /* Index for loops etc */
clock_t t0;
if( !ifile)
{
printf( "Couldn't open input TLE file\n");
exit( -1);
}
for( i = 3; i < argc; i++)
if( argv[i][0] == '-')
switch( argv[i][1])
{
case 'v':
verbose = atoi( argv[i] + 2);
break;
case 'n':
n_runs = atoi( argv[i] + 2);
break;
case 's':
show_sdp = atoi( argv[i] + 2);
break;
default:
printf( "Option '%s' ignored\n", argv[i]);
break;
}
fgets( line1, sizeof( line1), ifile);
t0 = clock( );
while( fgets( line2, sizeof( line2), ifile))
{
if( line1[0] == '1' && line2[0] == '2' &&
parse_elements( line1, line2, &tle) >= 0) /* hey! we got a TLE! */
if( select_ephemeris( &tle) && show_sdp < 2)
{
double sgp_sat_params[N_SAT_PARAMS];
double sdp_sat_params[N_SAT_PARAMS];
double perigee;
#ifdef STATIC_LINK
SGP4_init( sgp_sat_params, &tle);
if( show_sdp)
SDP4_init( sdp_sat_params, &tle);
#else
if( SXPX_init( sgp_sat_params, &tle, 1))
{
printf( "Couldn't load 'sat_code.dll'\n");
exit( -1);
}
if( show_sdp)
SXPX_init( sdp_sat_params, &tle, 3);
#endif
perigee = sgp_sat_params[9] * (1. - tle.eo) - 1.;
line2[63] = '\0';
if( verbose)
printf( "%5ld %s", (long)( perigee * 6378.14), line2);
for( j = 0; j <= n_runs; j++)
{
double posn2[3], pos[3], vel[3];
double delta, d2 = 0.;
#ifdef STATIC_LINK
SGP4( t_since * (double)j, &tle, sgp_sat_params, posn2, vel);
if( show_sdp)
SDP4( t_since * (double)j, &tle, sdp_sat_params, pos, vel);
#else
SXPX( t_since * (double)j, &tle, sgp_sat_params, posn2, vel, 1);
if( show_sdp)
SXPX( t_since * (double)j, &tle, sdp_sat_params, pos, vel, 3);
#endif
if( !show_sdp)
memcpy( pos, posn2, 3 * sizeof( double));
for( i = 0; i < 3; i++)
{
delta = pos[i] - posn2[i];
d2 += delta * delta;
}
if( j == 1)
rms_diff += d2;
if( verbose)
printf( "%8.1lf%s", sqrt( d2), (j == n_runs ? "\n" : ""));
}
n_found++;
}
strcpy( line1, line2);
}
fclose( ifile);
t0 = clock( ) - t0;
printf( "%d deep-space objects found\n", n_found);
printf( "%lf seconds elapsed\n", (double)t0 / (double)CLOCKS_PER_SEC);
if( n_found)
printf( "RMS difference = %.1lf\n", sqrt( rms_diff / (double)n_found));
return(0);
} /* End of main() */
/*------------------------------------------------------------------*/