Heim > Backend-Entwicklung > Python-Tutorial > Wie kann ich die GPS-Entfernung und -Peilung mithilfe der Haversine-Formel genau berechnen?

Wie kann ich die GPS-Entfernung und -Peilung mithilfe der Haversine-Formel genau berechnen?

Mary-Kate Olsen
Freigeben: 2024-12-02 08:42:11
Original
1026 Leute haben es durchsucht

How Can I Accurately Calculate GPS Distance and Bearing Using the Haversine Formula?

Haversine-Formel für GPS-Berechnungen: Entfernung und Peilung

Problem:

Berechnung der Entfernung und die Peilung zwischen zwei GPS-Punkten erfordert häufig die Verwendung der Haversine-Entfernungsformel. Bei der Ermittlung der korrekten Peilung können jedoch Probleme auftreten, insbesondere wenn negative Werte ermittelt werden.

Lösung:

Zur Berechnung der Entfernung kann die Haversine-Formel verwendet werden:

from math import radians, cos, sin, asin, sqrt

def haversine(lon1, lat1, lon2, lat2):
    """
    Calculate the great circle distance in kilometers between two points 
    on the earth (specified in decimal degrees)
    """
    # convert decimal degrees to radians 
    lon1, lat1, lon2, lat2 = map(radians, [lon1, lat1, lon2, lat2])

    # haversine formula 
    dlon = lon2 - lon1 
    dlat = lat2 - lat1 
    a = sin(dlat/2)**2 + cos(lat1) * cos(lat2) * sin(dlon/2)**2
    c = 2 * asin(sqrt(a)) 
    r = 6371 # Radius of earth in kilometers. Use 3956 for miles. Determines return value units.
    return c * r
Nach dem Login kopieren

Um die Peilung zu bestimmen, passen Sie die Variable Bearing wie folgt an:

Bearing = atan2(sin(lon2-lon1)*cos(lat2), cos(lat1)*sin(lat2) - sin(lat1)*cos(lat2)*cos(lon2-lon1))
Bearing = degrees(Bearing)
Nach dem Login kopieren

Diese Änderung stellt sicher, dass die Die Peilung liegt zwischen 0 und 360 Grad.

Das obige ist der detaillierte Inhalt vonWie kann ich die GPS-Entfernung und -Peilung mithilfe der Haversine-Formel genau berechnen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage