半正矢公式
半正矢公式是一種根據兩點的經度和緯度來確定大圓上兩點之間距離的計算方法,在導航有着重要地位。它是球面三角學中「半正矢定理」公式的特例,該定理涉及了球面三角形的邊和角。
儘管第一份英文版的半正矢表由詹姆斯·安德魯在1805年印刷出版[1],但弗洛里安·卡喬里相信José de Mendoza y Ríos在1801年就使用過類似的術語[2][3]。「半正矢」這個名字由詹姆斯·英曼在1835年創造[4][5]。
這個公式正如其名,用半正矢函數表達,通過 而來。該公式可以用半正矢函數的任意倍數表達,如正矢函數(半正矢函數的兩倍)。在計算機出現之前,為了計算簡便,人們會利用對數來計算乘積和利用半正矢函數計算距離,所以在十九和二十世紀初的導航和三角測量書中包含了半正矢值表和對數表。現在,將該公式用半正矢函數表達也很方便,因為它能避免 的係數。
半正矢公式
[編輯]對於任何球面上的兩點,圓心角的半正矢值可以通過如下公式計算:
- 是半正矢函數的縮寫:
- 是兩點之間的距離(沿大圓,見球面距離);
- 是球的半徑;
- :點 1 的緯度和點 2 的緯度,以弧度制度量;
- :點 1 的經度和點 2 的經度,以弧度制度量。
左邊的等號 是圓心角,以弧度來度量。
可以通過應用反半正矢函數(如果可以查到值)或通過使用反正弦函數來解出 :
,代入可得:
在使用這個公式時,必須確保 不超過 1 ( 只當 的值在 0 到 1 間才有意義)。 僅在球面上兩點連線過球心時才為 1 ,當測量精度有限時,會產生較大的計算誤差。 如果大到接近圓周的一半長度 時(這個情況並不常見),一個小錯誤通常是一個大問題在。雖然還有其他的大圓距離公式,能夠避免這個問題。上述公式有時候用反正切函數表達,但是 接近 1 時這個問題仍然存在。
但是仍有對策來避免上述問題。類似的公式可以使用餘弦函數表達(有時亦稱為球面餘弦定理,但是並非平面餘弦定理)而不是半正矢,但如果這兩點十分靠近(例如在地球上的一公里外)你可能得到的結果為 ,導致一系列的誤差。而由於半正矢式使用正弦函數,避免了這一問題。所以兩個公式應該互補使用。
因為地球是一個不完美的球體,故當其應用於地球時,無論哪一個公式只是做一個近似測算,「地球半徑」 在極點地區是 公里,在赤道地區為 公里。另外,半徑曲率在極點處( 公里)比在赤道處( 公里)大 1% ,所以半正矢公式或者球面餘弦定理是不能保證 0.5% 以內的誤差。更準確的方法,應該是使用考慮地球離心率的Vincenty的公式或其他有關地理距離的論文所給出方法。
半正矢定理
[編輯]給出一個單位球,一個在表面的球面三角形三個過三點 的大圓所圍出來的區域。如圖,這個球面三角形的三邊分別是 ( 至 ), ( 到 )和 ( 至 )並且角 對邊 那麼有如下關係
由於這是一個單位球,弧長 、 和 與兩端點同球心構成的圓心角(弧度制)相等。
為了從該定理中得到半正矢公式,只需要考慮一種特殊情況,即 是北極,而 和 是需要確定距離 兩個點。在這個情況下, 和 由 來計算(即 90° - 維度), 為經度分隔 和 為求得的。結合 ,半正矢公式即可推導得出。
或者可以從球面餘弦定理中得出
當 很小時,這個公式精度不高。所以我們可以用 來替換 ,並引用三角恆等式 ,半正矢定理就能推出。
另見
[編輯]參考文獻
[編輯]- ^ van Brummelen, Glen Robert. Heavenly Mathematics: The Forgotten Art of Spherical Trigonometry. Princeton University Press. 2013 [2015-11-10]. ISBN 9780691148922. 0691148929.
- ^ de Mendoza y Ríos, Joseph. Memoria sobre algunos métodos nuevos de calcular la longitud por las distancias lunares: y aplication de su teórica á la solucion de otros problemas de navegacion. Madrid, Spain: Imprenta Real. 1795 [2018-08-14]. (原始內容存檔於2017-11-07) (西班牙語).
- ^ Cajori, Florian. A History of Mathematical Notations 2 2 (3rd corrected printing of 1929 issue). Chicago, USA: Open court publishing company. 1952: 172 [1929] [2015-11-11]. ISBN 978-1-60206-714-1. 1602067147.
The haversine first appears in the tables of logarithmic versines of José de Mendoza y Rios (Madrid, 1801, also 1805, 1809), and later in a treatise on navigation of James Inman (1821).
- ^ Inman, James. Navigation and Nautical Astronomy: For the Use of British Seamen 3. London, UK: W. Woodward, C. & J. Rivington. 1835 [1821] [2015-11-09]. (原始內容存檔於2016-12-28).
- ^ Template:OED2
- ^ Korn, Grandino Arthur; Korn, Theresa M. Appendix B: B9. Plane and Spherical Trigonometry: Formulas Expressed in Terms of the Haversine Function. Mathematical handbook for scientists and engineers: Definitions, theorems, and formulas for reference and review 3. Mineola, New York, USA: Dover Publications, Inc. 2000: 892–893 [1922]. ISBN 978-0-486-41147-7.
延伸閱讀
[編輯]- 美國人口普查局的 地理信息系統的問題(內容已被轉移到 什麼是最好的方式來計算兩點間的距離?(頁面存檔備份,存於互聯網檔案館))
- R.W.Sinnott的"半正矢的優點", Sky and Telescope 68 (2), 159 (1984).
- 推導半正矢公式(頁面存檔備份,存於互聯網檔案館),Ask Dr.Math(Apr. 20–21,1999)。
- Romuald Ireneus'Scibor-Marchocki, 球三角形, 初等幾何(1997年)。
- W.Gellert,S.Gottwald,M.Hellwich,H.Kästner和H.Küstner的,The VNR Concise Encyclopedia of Mathematics,2nd ed., ch. 12(Van Nostrand Reinhold:紐約,1989年)。
外部連結
[編輯]- 用的91種程式語言rosettacode.org實現半正矢公式(頁面存檔備份,存於互聯網檔案館) 或 17種程式語言codecodex.com(頁面存檔備份,存於互聯網檔案館)
- 其它在 C++(頁面存檔備份,存於互聯網檔案館)、C(mac os)(頁面存檔備份,存於互聯網檔案館)、Pascal(頁面存檔備份,存於互聯網檔案館)、Python、Ruby (頁面存檔備份,存於互聯網檔案館)、JavaScript(頁面存檔備份,存於互聯網檔案館)、PHP(頁面存檔備份,存於互聯網檔案館)、Matlab(頁面存檔備份,存於互聯網檔案館)、MySQL中的實現。
- 由任何兩者之間的緯度和經度計算距離、方位等。http://www.movable-type.co.uk(頁面存檔備份,存於互聯網檔案館)