Haversine (rtl)
De Wiki1000
(Différences entre les versions)
m (Remplacement du texte — « http://frp.sage.fr/wiki1000/medias/images/stock/versionlatest-32x32.png » par « http://frp.sage.fr/wiki1000/medias/images/stock/version650-32x32.png ») |
|||
Ligne 1 : | Ligne 1 : | ||
− | {{ | + | {{Version650}} |
<source lang='delphi'>Function haversine(lat1,long1,lat2,long2):double;</source> | <source lang='delphi'>Function haversine(lat1,long1,lat2,long2):double;</source> | ||
Version du 13 janvier 2015 à 10:47
Function haversine(lat1,long1,lat2,long2):double;
Cette fonction calcule la distance en kilomètre entre deux coordonnées de lieu exprimés en degré.
Result | La distance en KM entre les deux coordonnées. |
lat1,long1 | Le premier jeu de coordonné. |
lat2,long2 | Le second jeu de coordonné. |
Pseudo code :
const cEarthRadiusKM = 6371.0009; function haversine(lat1,long1,lat2,long2:Double; E:double=cEarthRadiusKM):double; var slon,slat,a,c:Double; begin lat1 := degToRad(lat1); long1 := degToRad(long1); lat2 := degToRad(lat2); long2 := degToRad(long2); // slon := sin((long2 - long1)/2); slat := sin((lat2 - lat1)/2); a := slat*slat + cos(lat1)*cos(lat2) * slon*slon; c := 2 * arctan2( sqrt(a), sqrt(1-a) ); Result := E * c; end;
Voir aussi: