"Sono un pessimo matematico, ma ho bisogno di tradurre la routine matematica PHP in Objective C, per calcolare nell'applicazione iOS.
Ho questo codice, in PHP, funziona bene:
function torad ( $arg ) { return ($arg * (pi() / 180.0)); }
function kepler ( $m, $ecc ) {
$EPSILON = 1e-6;
$m = torad( $m );
$e = $m;
do {
$delta = $e - $ecc * sin( $e ) - $m;
$e -= $delta / ( 1 - $ecc * cos($e) );
} while ( abs($delta) > $EPSILON );
return ( $e );
}
Questo è il codice che ho in Objective C (per iOS):
+ (double) toRad:(double)arg{
return (arg * (3.14159265 / 180.0)); // 3.14159265 = pi()
}
+ (double) kepler:(double)m ecc:(double)ecc {
double EPSILON = 1e-6;
double _m = [self toRad:m];
double e = _m;
double delta;
do {
delta = e - ecc * sin(e) - m;
e -= delta / (1 - ecc * cos(e));
} while (abs(delta) > EPSILON);
return e;
}
La funzione Kepler funziona male. Forse, puoi dire, dove ho sbagliato? Grazie.
risposte:
3 per risposta № 1Tu stai usando m
invece di _m
in questa linea:
delta = e - ecc * sin(e) - m;