自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Python生成小數(shù)序列竟如此簡單!np.arange為何碾壓range?一文徹底講透

開發(fā) 前端
用Python的range生成0.1間隔序列直接報錯?np.arange為何能輕松實現(xiàn)毫秒級數(shù)據(jù)生成?本文通過詳細示例,徹底揭秘range與np.arange的底層差異!

用Python的range生成0.1間隔序列直接報錯?np.arange為何能輕松實現(xiàn)毫秒級數(shù)據(jù)生成?本文通過詳細示例,徹底揭秘range與np.arange的底層差異!文末附數(shù)值計算避坑指南,讓你告別浮點誤差!

一、痛點直擊:range的小數(shù)步長之殤

# 經(jīng)典報錯場景:試圖生成0.1步長的序列
try:
    range(0, 1, 0.1)  # 直接崩潰!
except Exception as e:
    print(f"報錯信息:{e}")  # TypeError: 'float' cannot be interpreted as an integer

# 使用np.arange輕松解決
import numpy as np
print(np.arange(0, 1, 0.1))  # 完美輸出:[0.0, 0.1, 0.2, ..., 0.9]

二、參數(shù)詳解:range和np.arange的根本差異

參數(shù)

range

np.arange

起始值(start)

僅整數(shù)

支持int/float

結(jié)束值(stop)

嚴格小于stop

可包含stop邊界(通過精度調(diào)整)

步長(step)

必須為整數(shù)

支持任意小數(shù)

返回值類型

生成惰性迭代器

生成預分配的ndarray數(shù)組

內(nèi)存占用

固定48字節(jié)(動態(tài)生成)

預分配連續(xù)內(nèi)存(數(shù)據(jù)量×字節(jié)大小)

三、底層機制:為何np.arange能處理小數(shù)步長?

1. C語言級優(yōu)化

// NumPy底層C代碼簡化邏輯(arange實現(xiàn))
npy_arange(double start, double stop, double step) {
    length = ceil((stop - start) / step);  // 計算元素數(shù)量
    arr = numpy_array_alloc(length);       // 預分配內(nèi)存
    for (i=0; i<length; i++) {
        arr[i] = start + i*step;           // 直接計算存儲
    }
    return arr;
}

2. 浮點數(shù)處理策略

? 全程使用雙精度浮點運算(float64)

? 自動處理二進制截斷誤差

? 支持自定義數(shù)據(jù)類型(float32/int32等)

四、核心優(yōu)勢對比表格

特性

range

np.arange

小數(shù)步長支持

? 直接報錯

? 完美支持

內(nèi)存占用(1萬數(shù)據(jù))

48字節(jié)(固定)

80KB(float64類型)

生成速度(百萬級)

0.8秒(循環(huán)遍歷)

0.02秒(向量化計算)

科學計算兼容性

? 需轉(zhuǎn)換類型

? 無縫對接Matplotlib/Pandas

數(shù)據(jù)精度控制

? 僅整數(shù)

? 支持小數(shù)點后16位

多維數(shù)據(jù)生成

? 僅一維

? 可擴展至高維網(wǎng)格

五、精度陷阱與避坑指南

陷阱1:浮點顯示誤差

arr = np.arange(1.1, 1.5, 0.1)
print(list(arr))
# 輸出 [1.1, 1.2000000000000002, 1.3000000000000003, 1.4000000000000004]

解決方案

# 方法1:強制類型轉(zhuǎn)換
arr = np.arange(1.1, 1.5, 0.1).astype(np.float32)
print(list(arr))

# 方法2: 四舍五入(保留兩位小數(shù))(推薦)
arr = np.arange(1.1, 1.5, 0.1).round(2)
print(list(arr))

# 方法3:整數(shù)縮放法
arr = np.arange(11, 15, 1) / 10
print(list(arr))

陷阱2:超大范圍導致內(nèi)存溢出

# 錯誤示范(生成1e12數(shù)據(jù)直接崩潰)
# arr = np.arange(0, 1e12, 0.1) 
# 需要超大內(nèi)存!

# 正確方案:分塊生成器
def safe_arange(start, stop, step):
    current = start
    while current < stransform: translateY(  # 嚴格遵循左閉右開
        yield current
        current += step

# 逐塊處理
for num in safe_arange(0, 1000, 0.1):
    print(num)

陷阱3:與Python原生函數(shù)兼容問題

arr = np.arange(0.1, 0.5, 0.1)
print(0.3 in arr) 
# 返回False,原因讓我們來看一下生成的值
print(list(arr))
# 輸出 [0.1, 0.2, 0.30000000000000004, 0.4]

# 解決方案:容差判斷(也可通過陷阱1中的解決方案規(guī)避這個問題)
tol = 1e-10
print(any(abs(arr - 0.3) < tol))  
# True

陷阱4:步長參數(shù)導致空數(shù)組

# 當step方向與區(qū)間方向相反時
arr = np.arange(5.0, 1.0, 0.5)  
print(list(arr))
# [] 空數(shù)組!

# 正確寫法:
arr = np.arange(5.0, 1.0, -0.5) 
# [5.0, 4.5, 4.0, 3.5, 3.0, 2.5, 2.0, 1.5]

陷阱5:默認數(shù)據(jù)類型精度不足

arr = np.arange(0, 1, 0.1, dtype=np.float32)
print(arr[-1])  
# 0.90000004(精度丟失)

# 解決方案:強制高精度
arr = np.arange(0, 1, 0.1, dtype=np.float64)
print(arr[-1])  
# 0.9

六、為什么專業(yè)開發(fā)者都選擇np.arange?

  1. 1. IEEE 754標準支持:嚴格遵循浮點數(shù)國際標準
  2. 2. 底層C優(yōu)化:避免Python解釋器的性能損耗
  3. 3. 內(nèi)存預分配策略:連續(xù)內(nèi)存塊提升緩存命中率
  4. 4. GPU加速兼容:生成的數(shù)組可直接送入CUDA計算
  5. 5. 應(yīng)用場景廣泛:可用于 金融價格序列、科學實驗數(shù)據(jù)采樣、游戲動畫關(guān)鍵幀、地理坐標生成、物理仿真時間步、機器學習參數(shù)搜索、音頻信號處理等等場景
# 與PyTorch的無縫對接
import torch
tensor = torch.from_numpy(np.arange(0.0, 1.0, 0.1))
你在使用np.arange時踩過哪些坑?是遇到15.600000000000001的詭異數(shù)值?還是生成的數(shù)據(jù)總是少一個?
責任編輯:武曉燕 來源: 不止于python
相關(guān)推薦

2020-03-26 09:18:54

高薪本質(zhì)因素

2025-01-13 12:00:00

反射Java開發(fā)

2024-08-13 17:09:00

架構(gòu)分庫分表開發(fā)

2020-08-04 10:56:09

進程線程協(xié)程

2020-07-16 09:02:45

aPaaS云計算aPaaS平臺

2021-01-18 13:05:52

Serverless Serverfull FaaS

2020-12-01 11:34:14

Elasticsear

2023-11-09 08:41:25

DevOpsAIOps軟件

2023-05-04 08:24:52

ChatGPT產(chǎn)品經(jīng)理工業(yè)革命

2024-05-31 13:23:19

OceanBase單機版架構(gòu)

2024-08-07 10:54:59

正則表達式Java RegexJava

2023-11-06 09:06:54

分布式一致性數(shù)據(jù)

2020-05-20 09:55:42

Git底層數(shù)據(jù)

2024-07-10 12:00:42

2021-06-29 12:10:00

CRC校驗碼C語言

2021-06-30 08:45:02

內(nèi)存管理面試

2020-03-18 14:00:47

MySQL分區(qū)數(shù)據(jù)庫

2023-10-27 08:15:45

2022-06-07 10:13:22

前端沙箱對象

2020-12-07 06:19:50

監(jiān)控前端用戶
點贊
收藏

51CTO技術(shù)棧公眾號