Python:将数组从一个范围等效到另一个范围

9 篇文章 0 订阅
8 篇文章 0 订阅

目录

问题表述

代码解释


问题表述

x_iter的取值范围为

np.array([[-1, 1], [-1, 1], [-1, 1], [-1, 1]])

实际x的取值范围是

np.array([[-10000, 10000], [-10000, 10000], [-10000, 10000], [-10000, 10000]])

已知一组x_iter值如下,需要将其等效为实际x的值:

[[ 0.1  0.5  0.5  0.9]
 [-0.9  0.3 -0.7  0.5]
 [-0.1  0.7 -0.5  0.7]
 [-0.5  0.9 -0.9 -0.7]
 [-0.3 -0.5  0.1 -0.9]
 [ 0.3 -0.7  0.3  0.3]
 [ 0.5 -0.1  0.7  0.1]
 [ 0.9  0.1 -0.3 -0.5]
 [-0.7 -0.3  0.9 -0.3]
 [ 0.7 -0.9 -0.1 -0.1]]

用以下代码:

# 取值范围
bounds = np.array([[-1, 1], [-1, 1], [-1, 1], [-1, 1]])
real_bounds = np.array([[-10000, 10000], [-10000, 10000], [-10000, 10000], [-10000, 10000]])
# 给定一组值
x_iter = np.array([[ 0.1,  0.5,  0.5,  0.9],
 [-0.9,  0.3, -0.7,  0.5],
 [-0.1,  0.7, -0.5,  0.7],
 [-0.5,  0.9, -0.9, -0.7],
 [-0.3, -0.5,  0.1, -0.9],
 [ 0.3, -0.7,  0.3,  0.3],
 [ 0.5, -0.1,  0.7,  0.1],
 [ 0.9,  0.1, -0.3, -0.5],
 [-0.7, -0.3,  0.9, -0.3],
 [ 0.7, -0.9, -0.1, -0.1]])
# 映射到真实范围中
rescaled_x = np.zeros(x_iter.shape)
for i in range(bounds.shape[0]):
    rescaled_x[:, i] = (x_iter[:, i] - bounds[i, 0]) / (bounds[i, 1] - bounds[i, 0]) * (real_bounds[i, 1] - real_bounds[i, 0]) + real_bounds[i, 0]
print(rescaled_x)

结果:

[[ 1000.  5000.  5000.  9000.]
 [-9000.  3000. -7000.  5000.]
 [-1000.  7000. -5000.  7000.]
 [-5000.  9000. -9000. -7000.]
 [-3000. -5000.  1000. -9000.]
 [ 3000. -7000.  3000.  3000.]
 [ 5000. -1000.  7000.  1000.]
 [ 9000.  1000. -3000. -5000.]
 [-7000. -3000.  9000. -3000.]
 [ 7000. -9000. -1000. -1000.]]

代码解释

用以下这种代码便于理解:

original_data = np.array([[ 0.1,  0.5,  0.5,  0.9],
 [-0.9,  0.3, -0.7,  0.5],
 [-0.1,  0.7, -0.5,  0.7],
 [-0.5,  0.9, -0.9, -0.7],
 [-0.3, -0.5,  0.1, -0.9],
 [ 0.3, -0.7,  0.3,  0.3],
 [ 0.5, -0.1,  0.7,  0.1],
 [ 0.9,  0.1, -0.3, -0.5],
 [-0.7, -0.3,  0.9, -0.3],
 [ 0.7, -0.9, -0.1, -0.1]])

min_old, max_old = -1, 1
min_new, max_new = -10000, 10000

rescaled_data = (original_data - min_old) / (max_old - min_old) * (max_new - min_new) + min_new

这段代码的目的是将矩阵original_data的所有元素从[-1,1]的范围等效转换到[-10000,10000]的范围。

这个公式 (original_data - min_old) / (max_old - min_old) * (max_new - min_new) + min_new 是一种被称为归一化的方法,它把数据从一个范围转换到另一个范围。

这是一种线性转换,它首先把元素从原始范围转换到[0,1](这一步通过(original_data - min_old) / (max_old - min_old)实现),然后再把元素从[0,1]转换到目标范围[ min_new, max_new]((max_new - min_new) + min_new进行这个转换)。

这个公式进行的变换是带有缩放和平移的线性变换,对每个元素都做同样的处理。这样做可以保证数据的最大值和最小值分别映射到目标范围的最大值和最小值。

最后,rescaled_data这个新矩阵就是将original_data的元素经过这种线性转换处理后的结果。

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是一个Python实现CRC16校验的示例程序: ```python def crc16(data): """ 计算CRC16校验和 """ # CRC16生成多项式,高16位为0xA001 crc = 0xFFFF for i in range(len(data)): crc ^= (ord(data[i]) << 8) for j in range(8): if crc & 0x8000: crc = ((crc << 1) ^ 0x1021) else: crc <<= 1 # 取反并交换高低字节得到校验码 crc = (~crc & 0xFFFF) crc = ((crc & 0xFF00) >> 8) | ((crc & 0x00FF) << 8) return crc ``` 这里使用的是CRC16-IBM算法,生成多项式为0x8005(或0xA001,因为它们是等效的),初始值为0xFFFF。函数接收一个字符串作为输入,并返回16位CRC校验和。在上面的实现中,将字符串中的每个字符视为一个字节,并依次将它们作为输入传递给CRC计算机。最后,通过将校验和取反并交换高低字节来生成最终的CRC校验码。 ### 回答2: CRC16是一种逐位计算的循环冗余校验码,可以用于对数据进行校验和验证。下面是一个使用Python编写的CRC16校验程序示例: ```python def crc16(data): crc = 0xFFFF # 初始化CRC16为0xFFFF polynomial = 0x1021 # 生成多项式,用于计算CRC校验码 for byte in data: crc ^= byte << 8 # 将当前字节与CRC16取异或 for _ in range(8): # 循环8次,处理每个字节的8位 if crc & 0x8000: # 如果CRC16的最高位为1 crc = (crc << 1) ^ polynomial # 将CRC16左移一位并与多项式取异或 else: crc <<= 1 # 否则,将CRC16左移一位 crc &= 0xFFFF # 取CRC16的低16位作为校验码 return crc # 示例使用 data = bytearray([0x01, 0x02, 0x03, 0x04]) checksum = crc16(data) print(f"CRC16校验码为:{checksum:04X}") ``` 以上示例中,crc16函数接受一个字节数组作为输入数据,并通过运算得出校验码。具体实现过程中,使用了位操作和异或运算,对每个字节的每一位进行计算,最终得出CRC16校验码。 ### 回答3: CRC(循环冗余校验)是一种常用于检测和纠正数据传输错误的校验方法。CRC16位校验是CRC的一种常用变种,用于对16位数据进行校验。下面是用Python一个CRC16位校验的程序: ```python def crc16(data): crc = 0xFFFF # 初始化CRC校验值为全1 poly = 0xA001 # 生成多项式,这里使用0xA001 for byte in data: crc ^= ord(byte) # 将数据字节与CRC值进行异或运算 for _ in range(8): if crc & 0x0001: crc >>= 1 crc ^= poly # 如果最低位为1,将CRC值右移一位并与多项式异或 else: crc >>= 1 return crc # 测试 data = "Hello, World!" # 待校验的数据 crc_value = crc16(data) print("CRC16校验值为:", hex(crc_value)) ``` 在这个程序中,我们定义了一个crc16()函数,它接受一个字符串参数data,并返回CRC16校验值。函数中使用了循环和位运算来计算CRC校验值。我们通过异或运算(^=)将数据字节与CRC值进行操作,然后根据最低位是0还是1来选择右移一位或者异或多项式进行操作。最后,我们通过调用crc16()函数并传入待校验的数据来获取CRC16校验值,并打印出来。 以上就是一个使用Python编写的CRC16位校验程序,希望对你有帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值