위도와 경도를 이용한 거리 계산: 코딩 오류 해결
위도와 경도를 기준으로 거리를 구하는 공식을 구현하려고 하던 중, 사용자가 예상치 못한 결과를 겪었습니다. 참조된 애플릿에 제공된 공식은 제공된 테스트 포인트에 대해 올바르게 작동했습니다. 그런데 사용자의 코드가 부정확한 거리 값을 반환했습니다.
코드 검사
코드를 검사한 결과 사용자가 더 이상 사용되지 않는 Vincenty 거리 계산 방법을 사용하고 있는 것으로 나타났습니다. , GeoPy 버전 1.13에서는 보다 정확한 geopy.distance.distance() 함수로 대체되었습니다. 사용자 코드가 활용한 Haversine 공식은 구형 지구 모델을 가정하고 최대 0.5%의 오류가 발생할 수 있습니다.
gepy.distance 사용
해결 방법 문제가 있는 경우 거리 계산을 위해 보다 정확한 geopy.distance.geodesic() 함수를 사용하도록 전환하는 것이 좋습니다. 이 기능은 WGS-84와 같은 타원체 모델을 활용하여 보다 정확한 결과를 제공합니다.
<code class="python">import geopy.distance coords_1 = (52.2296756, 21.0122287) coords_2 = (52.406374, 16.9251681) distance = geopy.distance.geodesic(coords_1, coords_2).km print(distance)</code>
수정된 코드를 사용하면 두 점 사이의 거리가 279.352km로 정확하게 계산됩니다.
위 내용은 위도/경도 거리 계산이 잘못된 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!