ホームページ >バックエンド開発 >PHPチュートリアル >PHP は地球上の 2 点間の距離を計算します (詳細な例)

PHP は地球上の 2 点間の距離を計算します (詳細な例)

藏色散人
藏色散人オリジナル
2019-04-03 13:12:575120ブラウズ

経度と緯度を指定して、地球上の 2 点間の距離を求めます。まず問題の解決策を理解してから、PHP コードを使用して計算を実装する必要があります。

PHP は地球上の 2 点間の距離を計算します (詳細な例)

この問題は、ハバーサインの公式を使用して解決できます:

大円距離または直交距離は球 (または地球の表面上の 2 点間の最短距離。この方法を使用するには、点 A と点 B の座標が必要です。大圏法は他の方法よりも優れています。

まず、緯度と経度の値を 10 進度からラジアンに変換します。したがって、経度と緯度の値を両方とも 180/pi で除算します。円周率の値は 22/7 で、180/円周率の値は約 57.29577951 です。 2 つの場所間の距離をマイル単位で計算したい場合は、地球の半径である 3,963 を使用します。 2 つの場所間の距離をキロメートル単位で計算したい場合は、地球の半径である 6,378.8 を使用します。

求纬度值(以弧度为单位):
纬度值,单位为弧度,lat =纬度/ (180/pi)
或
纬度值,以弧度为单位,lat =纬度/ 57.29577951

求经度的弧度值:
经度值,单位为弧度,long =经度/ (180/pi)
或
经度值,单位为弧度,long =经度/ 57.29577951

点 A の緯度と経度の座標を見つけます。上記の変換方法を使用して、緯度と経度の値をラジアンに変換します。私はこれをlat1とlong1と呼んでいます。点Bの座標についても同じ処理を実行して、lat2とlong2を取得します。

ここで、点 A と点 B の間の距離を取得するには、次の式を使用します。

距离,d = 3963.0 * arccos[(sin(lat1) * sin(lat2)) + cos(lat1) * cos(lat2) * cos(long2 - long1)]

取得された距離 d の単位はマイルです。値をキロメートル単位にしたい場合は、d に 1.609344 を掛けます。

d(千米)= 1.609344 * d(英里)

したがって、大圏距離法を使用して、地球上の 2 つの場所間の最短距離を取得できます。

地球上の 2 点間の距離を計算するための PHP の実装コードは次のとおりです:

<?php 
         
      function twopoints_on_earth($latitudeFrom, $longitudeFrom, 
                                    $latitudeTo,  $longitudeTo) 
      { 
           $long1 = deg2rad($longitudeFrom); 
           $long2 = deg2rad($longitudeTo); 
           $lat1 = deg2rad($latitudeFrom); 
           $lat2 = deg2rad($latitudeTo); 
              
           $dlong = $long2 - $long1; 
           $dlati = $lat2 - $lat1; 
              
           $val = pow(sin($dlati/2),2)+cos($lat1)*cos($lat2)*pow(sin($dlong/2),2); 
              
           $res = 2 * asin(sqrt($val)); 
              
           $radius = 3958.756; 
              
           return ($res*$radius); 
      } 
  
      //经纬度两点
      $latitudeFrom = 19.017656 ; 
      $longitudeFrom = 72.856178; 
      $latitudeTo = 40.7127; 
      $longitudeTo = -74.0059; 
         
      // 孟买和纽约之间的距离
      print_r(twopoints_on_earth( $latitudeFrom, $longitudeFrom,  
                    $latitudeTo,  $longitudeTo).&#39; &#39;.&#39;miles&#39;);

出力:

2.0043678382716137 K.M

この記事は、PHP で地球上の 2 点間の距離を計算する方法の紹介です。必要な友人の役に立てば幸いです。

以上がPHP は地球上の 2 点間の距離を計算します (詳細な例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。