numpy操作技巧-范数篇

1. 第一范数

向量的各个元素的绝对值之和

import numpy as np
x = np.array([3, -4])
nor_x = np.linalg.norm(x, ord=1)

print('原始数据')
print(x)
print("第一范数计算结果:")
print(nor_x)
#######################################
'''
原始数据
[ 3 -4]
第一范数计算结果:
7.0
'''

2. 第二范数

向量的每个元素的平方和再开平方根

import numpy as np
x = np.array([3, 4])
nor_x = np.linalg.norm(x)

print('原始数据')
print(x)
print("第二范数计算结果:")
print(nor_x)
#######################################
'''
原始数据
[3 4]
第二范数计算结果
5.0
'''

3. 计算闵可夫斯基距离

在这里插入图片描述

def DistMinkov(xi, xj, p=2):
    '''
    计算两个向量的曼哈顿距离(第一范数)
    :param xi: 向量xi, <1*n>
    :param xj: 向量xj, <1*n>
    :return: xi与xj之间的曼哈顿距离
    '''
    x = xi - xj
    data = np.apply_along_axis(np.power, 0, x, p)
    sum_data = np.sum(data)
    return pow(sum_data, 1/p)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值