Код, который я использую, содержит эти фрагменты кода. Я звоню в ThetaG_JD с аргументом 2455343.50000, который является просто примером юлианской даты. Каждый раз, когда я запускаю программу, я получаю EXC_BAD_ACCESS в указанной строке. При использовании gdb и распечатке промежуточных значений и передаче их через функцию floor я не получаю ошибки, но когда используется Frac (), она всегда возвращает ошибку.
double Frac(double arg)
{
/* Returns fractional part of double argument */
return arg - floor(arg);
}
double ThetaG_JD(double jd)
{
/* Reference: The 1992 Astronomical Almanac, page B6. */
double UT=0, TU=0, GMST=0;
//THIS LINE
UT=Frac(jd+0.5);
// THAT ONE ^^
jd=jd-UT;
TU=(jd-2451545.0)/36525;
GMST=24110.54841+TU*(8640184.812866+TU*(0.093104-TU*6.2E-6));
GMST=Modulus(GMST+secday*omega_E*UT,secday);
return (twopi*GMST/secday);
}