Étant donné un point existant en lat/long, la distance en (en KM) et le relèvement (en degrés convertis en radians), j'aimerais calculer la nouvelle lat/long. Le présent Le site de la Commission européenne revient sans cesse, mais je n'arrive pas à trouver la formule qui me convienne.
Les formules indiquées dans le lien ci-dessus sont les suivantes :
lat2 = asin(sin(lat1)*cos(d/R) + cos(lat1)*sin(d/R)*cos())
lon2 = lon1 + atan2(sin()*sin(d/R)*cos(lat1), cos(d/R)sin(lat1)*sin(lat2))
La formule ci-dessus s'applique à MSExcel où-
asin = arc sin()
d = distance (in any unit)
R = Radius of the earth (in the same unit as above)
and hence d/r = is the angular distance (in radians)
atan2(a,b) = arc tan(b/a)
is the bearing (in radians, clockwise from north);
Voici le code que j'ai en Python.
import math
R = 6378.1 #Radius of the Earth
brng = 1.57 #Bearing is 90 degrees converted to radians.
d = 15 #Distance in km
#lat2 52.20444 - the lat result I'm hoping for
#lon2 0.36056 - the long result I'm hoping for.
lat1 = 52.20472 * (math.pi * 180) #Current lat point converted to radians
lon1 = 0.14056 * (math.pi * 180) #Current long point converted to radians
lat2 = math.asin( math.sin(lat1)*math.cos(d/R) +
math.cos(lat1)*math.sin(d/R)*math.cos(brng))
lon2 = lon1 + math.atan2(math.sin(brng)*math.sin(d/R)*math.cos(lat1),
math.cos(d/R)-math.sin(lat1)*math.sin(lat2))
print(lat2)
print(lon2)
J'obtiens
lat2 = 0.472492248844
lon2 = 79.4821662373