歐幾里得距離(Euclidean Distance)公式

歐幾里得距離公式

歐幾里得距離(Euclidean Distance)是計算兩點之間直線距離的一種方法。它是最常見的距離度量方式之一,廣泛應用于數學、物理、機器學習、計算機視覺等領域。


公式定義

1. 二維空間

在二維平面上,假設有兩個點 A(x1, y1) 和 B(x2, y2) ,它們之間的歐幾里得距離為:
d Euclidean ( A , B ) = ( x 2 ? x 1 ) 2 + ( y 2 ? y 1 ) 2 d_{\text{Euclidean}}(A, B) = \sqrt{(x_2 - x_1)^2 + (y_2 - y_1)^2} dEuclidean?(A,B)=(x2??x1?)2+(y2??y1?)2 ?

2. 三維空間

在三維空間中,假設兩個點 A(x1, y1, z1) 和 B(x2, y2, z2) ,它們之間的歐幾里得距離為:
d Euclidean ( A , B ) = ( x 2 ? x 1 ) 2 + ( y 2 ? y 1 ) 2 + ( z 2 ? z 1 ) 2 d_{\text{Euclidean}}(A, B) = \sqrt{(x_2 - x_1)^2 + (y_2 - y_1)^2 + (z_2 - z_1)^2} dEuclidean?(A,B)=(x2??x1?)2+(y2??y1?)2+(z2??z1?)2 ?

3. 高維空間

在 n 維空間中,假設兩個點 A(a1, a2, …, an) 和 B(b1, b2, …, bn) ,它們之間的歐幾里得距離為:
d Euclidean ( A , B ) = ∑ i = 1 n ( b i ? a i ) 2 d_{\text{Euclidean}}(A, B) = \sqrt{\sum_{i=1}^{n} (b_i - a_i)^2} dEuclidean?(A,B)=i=1n?(bi??ai?)2 ?


幾何意義

歐幾里得距離表示兩點之間的直線距離,也稱為“鳥瞰距離”。它是兩點間最短的路徑長度。


示例計算

示例 1:二維空間

設點 A(3, 4) 和點 B(7, 1) ,則歐幾里得距離為:
d Euclidean ( A , B ) = ( 7 ? 3 ) 2 + ( 1 ? 4 ) 2 = 4 2 + ( ? 3 ) 2 = 16 + 9 = 25 = 5 d_{\text{Euclidean}}(A, B) = \sqrt{(7 - 3)^2 + (1 - 4)^2} = \sqrt{4^2 + (-3)^2} = \sqrt{16 + 9} = \sqrt{25} = 5 dEuclidean?(A,B)=(7?3)2+(1?4)2 ?=42+(?3)2 ?=16+9 ?=25 ?=5

示例 2:三維空間

設點 A(1, 2, 3) 和點 B(4, 6, 8) ,則歐幾里得距離為:
d Euclidean ( A , B ) = ( 4 ? 1 ) 2 + ( 6 ? 2 ) 2 + ( 8 ? 3 ) 2 = 3 2 + 4 2 + 5 2 = 9 + 16 + 25 = 50 ≈ 7.07 d_{\text{Euclidean}}(A, B) = \sqrt{(4 - 1)^2 + (6 - 2)^2 + (8 - 3)^2} = \sqrt{3^2 + 4^2 + 5^2} = \sqrt{9 + 16 + 25} = \sqrt{50} \approx 7.07 dEuclidean?(A,B)=(4?1)2+(6?2)2+(8?3)2 ?=32+42+52 ?=9+16+25 ?=50 ?7.07


與其他距離公式的對比

1. 曼哈頓距離

  • 曼哈頓距離是沿著坐標軸方向移動的距離之和:
    d Manhattan ( A , B ) = ∣ x 2 ? x 1 ∣ + ∣ y 2 ? y 1 ∣ d_{\text{Manhattan}}(A, B) = |x_2 - x_1| + |y_2 - y_1| dManhattan?(A,B)=x2??x1?+y2??y1?
  • 曼哈頓距離通常比歐幾里得距離大,因為它不允許斜向移動。

2. 切比雪夫距離

  • 切比雪夫距離取各維度差值的最大值:
    d Chebyshev ( A , B ) = max ? ( ∣ x 2 ? x 1 ∣ , ∣ y 2 ? y 1 ∣ ) d_{\text{Chebyshev}}(A, B) = \max(|x_2 - x_1|, |y_2 - y_1|) dChebyshev?(A,B)=max(x2??x1?,y2??y1?)
  • 切比雪夫距離適合描述“棋盤上國王的移動距離”。

3. 閔可夫斯基距離

  • 歐幾里得距離是閔可夫斯基距離的一種特殊情況( p=2 ):
    d Minkowski ( A , B ) = ( ∑ i = 1 n ∣ b i ? a i ∣ p ) 1 / p d_{\text{Minkowski}}(A, B) = \left( \sum_{i=1}^{n} |b_i - a_i|^p \right)^{1/p} dMinkowski?(A,B)=(i=1n?bi??ai?p)1/p
    當 p=2 時為歐幾里得距離,當 p=1 時為曼哈頓距離。

總結

歐幾里得距離是一種直觀且廣泛應用的距離度量方法,適用于多種場景。它的核心思想是計算兩點之間的直線距離,簡單高效,但在高維空間中可能受到“維度災難”的影響。

d Euclidean ( A , B ) = ∑ i = 1 n ( b i ? a i ) 2 d_{\text{Euclidean}}(A, B) = \sqrt{\sum_{i=1}^{n} (b_i - a_i)^2} dEuclidean?(A,B)=i=1n?(bi??ai?)2 ?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/74860.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/74860.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/74860.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

機器學習——LightGBM

LightGBM(light gradient boosting machine,輕量梯度提升機)是對XGBoost進行改進的模型版本,其三者之間的演變關系為:GBDT-》XGBoost-》LightGBM,依次對性能進行優化,盡管XGBoost已經很高效了,但是仍然有缺…

內網服務器無法通過公網地址訪問映射到公網的內網服務

內網服務器無法通過公網地址訪問映射到公網的內網服務 問題現象問題原因解決方法總結 前幾天遇到一個網絡問題,在這里做下記錄,希望能幫助到有相同問題的朋友。 問題現象 網絡拓撲如上所示,服務器1和服務器2在同一內網,網段均為1…

python每日十題(13)

一般把計算機完成一條指令所花費的時間稱為一個指令周期。指令周期越短,指令執行就越快。本題答案為D選項。 順序程序具有順序性、封閉性和可再現性的特點,使得程序設計者能夠控制程序執行的過程(包括執行順序、執行時間),對程序執…

Python 裝飾器(Decorators)

什么是裝飾器? 裝飾器(Decorator)本質上是一個 修改其他函數功能的函數。它的核心思想是:不修改原函數代碼,動態添加新功能。比如: 記錄函數執行時間 檢查用戶權限 緩存計算結果 自動重試失敗操作 理解…

uWebSockets開發入門

一、常用C++ WebSocket開源庫 一些常用的 C++ WebSocket 開源庫,它們支持 WebSocket 協議的實現,適用于客戶端或服務器端開發。 1. Boost.Beast (推薦) 特點:基于 Boost.Asio 的高性能庫,支持 HTTP/WebSocket,屬于 Boost 官方庫的一部分,穩定且跨平臺。 適用場景:需要高…

多智能體功能分化的核心優勢是什么:提升效率,查漏補缺

多智能體功能分化的核心優勢是什么:提升效率,查漏補缺 在于通過分工協作提升整體效率、靈活性和魯棒性。 1. 提升效率與專業性 原理:單一智能體無需處理全流程,通過專業化分工減少冗余計算和決策延遲。 示例: 自動駕駛系統: 感知智能體:專門處理攝像頭、激光雷達等傳…

項目復盤:websocket不受跨域限制的原理

主要還是因為: 1、WebSocket 是獨立于 HTTP 的應用層協議,通過 HTTP 建立連接后,完全脫離 HTTP 語義約束。這意味著 不受 HTTP 同源策略限制 不需要預檢請求 不依賴 CORS 頭機制 2、建立連接時的握手請求仍使用 HTTP 格式,但…

COMPASS:通過殘差強化學習和技能合成實現跨具身移動策略

25年2月來自 Nvidia、UC Berkeley 和 UT Austin 的論文“COMPASS: Cross-embOdiment Mobility Policy via ResiduAl RL and Skill Synthesis”。 隨著機器人越來越多地部署在不同的應用領域,可泛化的跨具身移動策略變得越來越重要。雖然經典的移動棧已被證明在特定…

無人機,雷達定點飛行時,位置發散,位置很飄,原因分析

參考: 無人車傳感器 IMU與GPS數據融合進行定位機制_gps imu 組合定位原始數-CSDN博客 我的無人機使用雷達定位,位置模式很飄 雷達的更新頻率也是10HZ, 而px飛控的頻率是100HZ,沒有對兩者之間的頻率差異做出處理 所以才導致無人…

學習threejs,使用Sprite精靈、SpriteMaterial精靈材質

👨??? 主頁: gis分享者 👨??? 感謝各位大佬 點贊👍 收藏? 留言📝 加關注?! 👨??? 收錄于專欄:threejs gis工程師 文章目錄 一、🍀前言1.1 ??THREE.Sprite1.1.1 ??代碼…

外星人入侵(python設計小游戲)

這個游戲簡而言之就是操作一個飛機對前方的飛船進行射擊,和一款很久之前的游戲很像,這里是超級低配版那個游戲,先來看看效果圖: 由于設計的是全屏的,所以電腦不能截圖。。。。 下面的就是你操控的飛船,上面…

什么是CMS?常用CMS有哪些?

一、內容管理系統(Content Management System)? ?什么是CMS?:位于 Web 前端(服務器)和后端辦公系統之間的軟件系統,用于內容創建、編輯、審批和發布。支持文本、圖片、視頻、數據庫等各類數字內容的管理…

Go 語言規范學習(3)

文章目錄 Properties of types and valuesRepresentation of valuesUnderlying types【底層類型】Core types【核心類型】Type identityAssignabilityRepresentabilityMethod sets BlocksDeclarations and scopeLabel scopesBlank identifierPredeclared identifiersExported i…

在 Ubuntu 上安裝 Docker 的完整指南

1. 卸載舊版本(如有) 在安裝新版本前,建議先卸載舊版本: sudo apt remove docker docker-engine docker.io containerd runc 2. 安裝依賴包 更新軟件包索引并安裝必要的依賴: sudo apt update sudo apt install -y ca-certificates curl gnupg lsb-release 3. 添加 Do…

turtle的九個使用

一 import turtle as t color [red,green,blue,orange,pink] for i in range(len(color)):t.penup()t.goto(-20070*i,0)t.pendown()t.pencolor(color[i])t.circle(50, steps 5) t.done()二 #在____________上補充代碼 #不要修改其他代碼import random as r import turtle a…

23種設計模式-備忘錄(Memento)設計模式

備忘錄設計模式 🚩什么是備忘錄設計模式?🚩備忘錄設計模式的特點🚩備忘錄設計模式的結構🚩備忘錄設計模式的優缺點🚩備忘錄設計模式的Java實現🚩代碼總結🚩總結 🚩什么是…

利用虛擬化技術實現高級Hook

虛擬化技術為系統監控和Hook提供了更強大、更隱蔽的實現方式。以下是幾種基于虛擬化的Hook技術實現方法: 1. 基于VT-x/AMD-V的硬件虛擬化Hook 基本原理 利用CPU的硬件虛擬化擴展(Intel VT-x/AMD-V)在Ring -1層級監控系統行為,實現無法被常規方法檢測的…

某魚、某寶 sign 簽名算法分析記錄

【作者主頁】:小魚神1024 【知識星球】:小魚神的逆向編程圈 【擅長領域】:JS逆向、小程序逆向、AST還原、驗證碼突防、Python開發、瀏覽器插件開發、React前端開發、NestJS后端開發等等 本文章中所有內容僅供學習交流使用,不用于其…

Compose筆記(十三)--事件總線

這一節了解一下Compose中的事件總線,在Jetpack Compose里,官方沒有直接提供事件總線,但可以借助第三方庫或者自定義實現來達成事件總線的功能,進而在不同的 Compose 控件間同步數據。 自定義事件總線 import androidx.compose.r…

Python的inspect模塊

在Python編程中,**inspect**模塊是一個強大的工具包,它提供了一系列函數來獲取對象的信息,主要用于獲取對象的源代碼、參數信息、類繼承關系、方法屬性等。這對于調試、自動化文檔生成、代碼分析等場景都非常有用。本文將詳細介紹inspect模塊…