曼哈顿距离、切比雪夫距离
时间: 2023-06-25 07:02:54 浏览: 221
曼哈顿距离和切比雪夫距离都是用来衡量两个点之间距离的度量标准。
曼哈顿距离,也称为城市街区距离或者闵可夫斯基距离,是指在一个平面上,两个点之间的距离是它们在坐标系上的横、纵坐标差的绝对值的和。其计算公式为:d(x,y) = |x1-y1| + |x2-y2| + ... + |xn-yn|。
切比雪夫距离是指在一个平面上,两个点之间的距离是它们在坐标系上的横、纵坐标差的绝对值的最大值。其计算公式为:d(x,y) = max(|x1-y1|, |x2-y2|, ..., |xn-yn|)。
可以看出,曼哈顿距离和切比雪夫距离都是基于坐标系上的差值来计算的,只是计算方式不同。在实际应用中,曼哈顿距离常用于城市交通规划、电路板设计等领域,而切比雪夫距离常用于图像处理、模式识别等领域。
相关问题
曼哈顿距离和切比雪夫距离
曼哈顿距离和切比雪夫距离都是常见的距离度量方式。
曼哈顿距离又叫曼哈顿街区距离或者城市街区距离,它是两个点在标准坐标系上的绝对轴距总和。在二维平面坐标系中,两个点的曼哈顿距离为它们在 x 轴上的距离之差与在 y 轴上的距离之差的绝对值之和。在三维空间中,曼哈顿距离为两个点在三个坐标轴上的距离之和。
切比雪夫距离是指在坐标系中,两个点在各个坐标轴上的数值差的绝对值的最大值。在二维平面坐标系中,两个点的切比雪夫距离为两个点在 x 轴上的距离之差与在 y 轴上的距离之差的最大值。在三维空间中,切比雪夫距离为两个点在三个坐标轴上的距离之差的绝对值的最大值。
一般来说,曼哈顿距离更适合在城市街区等网格状结构下的距离度量,而切比雪夫距离更适合在棋盘格等网格状结构下的距离度量。
python曼哈顿距离
在Python中,可以使用以下函数来计算曼哈顿距离:
```python
import numpy as np
def Manhattan(vec1, vec2):
npvec1, npvec2 = np.array(vec1), np.array(vec2)
return np.abs(npvec1-npvec2).sum()
```
这段代码定义了一个函数`Manhattan`,它接受两个向量`vec1`和`vec2`作为参数,并返回它们之间的曼哈顿距离。在函数内部,我们首先将输入的两个向量转换为NumPy数组,然后使用NumPy的`abs`函数计算两个向量的差值的绝对值,再使用`sum`函数求和得到距离。最后,我们将距离返回。
所以,如果你想计算`[0,3,4,5]`和`[7,6,3,-1]`之间的曼哈顿距离,你可以使用上述代码调用函数`Manhattan([0,3,4,5],[7,6,3,-1])`,结果是`20`。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [Python 曼哈顿距离 切比雪夫距离 闵可夫斯基距离 标准化欧氏距离 马氏距离 编辑距离](https://blog.csdn.net/XC_LMH/article/details/86485257)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
阅读全文