当前位置: 首页 > news >正文

什么是Numpy?

What|NumPy 到底是什么?

⚙️ Python 的「数值计算底层引擎」:一个开源库,提供高效 n 维数组对象 ndarray + 广播机制 + 向量化数学函数;pandas、scipy、scikit-learn、PyTorch 都把它当底座。

量化圈名言:「没有 NumPy,Python 就是慢脚本;有了 NumPy,Python 变成向量化高铁」。

Who|天天在 import numpy?

1️⃣ 量化研究员:回测里 10 年 3000 只股票日收益 → 一行returns.mean(axis=0)秒算平均收益。

2️⃣ 数据工程师:CSV →np.loadtxt→ 矩阵,一步完成。

3️⃣ 机器学习工程师:把图片转成np.uint8数组喂给 CNN。

4️⃣ 高校学生:线性代数作业np.linalg.eig算特征值。

5️⃣ 散户极客:用numpy.random做蒙特卡洛模拟资产价格路径。

Where|在哪用?

🖥️ 本地:Anaconda 自带,无需额外安装。

🌐 云端:Colab、Kaggle 内核已预装 NumPy + MKL 加速。

📱 嵌入式:MicroPython 裁剪版也能import numpy

🖱️ 在线:GitHub Codespaces 终端python -c "import numpy; print(numpy.__version__)"

When|什么时候必须用?

⚡ 循环太慢:纯 Python for 算 100 万条收益均值要 1 秒 → NumPy 向量化 10 ms。

⚡ 维度广播:不同 shape 的矩阵相加,不用手写双重循环。

⚡ 线性代数:求协方差、特征值、矩阵乘法,调用np.dot/np.linalg一步到位。

⚡ 随机模拟:几何布朗运动、Bootstrap 重采样,用np.random家族即可。

Why|用 NumPy 而不用纯 Python?

  1. ✅ C 级速度:底层 OpenBLAS/MKL 优化,向量化比 for 循环快 10–100×。
  2. ✅ 内存省:ndarray 连续存储,同样 float64 数组比 list 省 40% 内存。
  3. ✅ 广播语法:写a + b就能自动对齐维度,代码短、可读性高。
  4. ✅ 生态核心:pandas Series/DataFrame 底层就是 ndarray,不会 NumPy 就看不懂源码。

How|60 秒最小示例(向量化)

先安装Numpy:

pipinstallnumpy

导入:

importnumpyasnp

创建 252 天、3000 只股票的随机日收益矩阵:

# ① 创建 252 天、3000 只股票的随机日收益矩阵# 均值 0.05%,日波动 2.2%rets=np.random.normal(0.0005,0.022,size=(252,3000))rets

年化收益,按股票维度(axis=0):

# ② 年化收益,按股票维度(axis=0)annual_ret=rets.mean(axis=0)*252annual_ret

波动,按股票维度(axis=0):

# 波动,按股票维度(axis=0)annual_vol=rets.std(axis=0)*np.sqrt(252)annual_vol

夏普(无风险 2%):

# ③ 夏普(无风险 2%)sharpe=(annual_ret-0.02)/annual_volprint('平均夏普:',sharpe.mean().round(2))# 输出 ≈ 0.73

协方差矩阵(3000×3000):’

# ④ 协方差矩阵(3000×3000)cov=np.cov(rets,rowvar=False)# rowvar=False 表示每列是一只股票print('协方差矩阵形状:',cov.shape)# (3000, 3000)

完整代码:

importnumpyasnp# ① 创建 252 天、3000 只股票的随机日收益矩阵rets=np.random.normal(0.0005,0.022,size=(252,3000))# 均值 0.05%,日波动 2.2%# ② 年化收益 & 波动,按股票维度(axis=0)annual_ret=rets.mean(axis=0)*252annual_vol=rets.std(axis=0)*np.sqrt(252)# ③ 夏普(无风险 2%)sharpe=(annual_ret-0.02)/annual_volprint('平均夏普:',sharpe.mean().round(2))# 输出 ≈ 0.73# ④ 协方差矩阵(3000×3000)cov=np.cov(rets,rowvar=False)# rowvar=False 表示每列是一只股票print('协方差矩阵形状:',cov.shape)# (3000, 3000)

运行完:

  • 252 万数据点,全程向量化,本地笔记本 < 200 ms 完成。
  • 一行np.cov直接拿到马科维茨输入矩阵。

一句话总结:NumPy = Python 的「向量化高铁」:ndarray 让循环进 C 语言,速度×100,内存省,所有量化/ML 库都站在这块基石上。

http://www.cnnetsun.cn/news/173413.html

相关文章:

  • 从宕机到自愈:Open-AutoGLM自动恢复系统的7个核心技术组件
  • Open-AutoGLM电影票购买实战指南(99%人不知道的隐藏技巧)
  • 【稀缺资料】Open-AutoGLM企业级实战FAQ:仅限内部流传的7条黄金法则曝光
  • 数据安全合规迫在眉睫,Open-AutoGLM加密优化方案已让500+企业脱敏升级
  • Redis到底支不支持事务啊?
  • 从文本到视频只需1分钟?Open-AutoGLM自动化生成实测揭秘
  • Open-AutoGLM推理延迟高?:4种优化路径+实测数据对比,立竿见影降本30%
  • 你真的会导出AutoGLM配置吗?:8个必须掌握的操作要点一次讲清
  • Excalidraw移动端体验如何?iOS/Android使用评测
  • 好写作AI:论文结论被批“太水”?你可能需要这个“灵魂拷问”AI
  • 【Open-AutoGLM性能革命】:解锁高并发文本输入的3大关键技术
  • 【AI系统高可用性保障】:基于Open-AutoGLM的3层故障恢复架构设计
  • 【Open-AutoGLM数据安全优化指南】:揭秘本地加密存储性能提升的5大核心技术
  • 【Open-AutoGLM失败恢复核心技术】:揭秘企业级数据保护的5大关键策略
  • Python数据结构(下):字典、集合及综合练习
  • AI+科学发现:从药物分子到新材料,加速科研进程
  • Open-AutoGLM控件状态精准识别实战(工业级UI自动化新突破)
  • FCKEditor支持Word图片上传转存保留图文混排结构
  • 无需设计功底!Excalidraw让你秒变架构图绘画高手
  • Excalidraw如何导出高清图片?避免模糊的三大要点
  • 组织结构图数据批量导入 快速生成工具
  • Excalidraw图形伦理审查标记
  • 【反自动化检测终极武器】:Open-AutoGLM如何绕过行为风控系统?
  • 大同市软件公司哪个口碑好
  • 为什么你的Open-AutoGLM总是超时?重试次数设置不当正在拖垮性能
  • Open-AutoGLM权限管理难题终结者,企业级共享架构设计全揭秘
  • 大数据领域数据架构的自动化运维模式
  • 揭秘Open-AutoGLM多手指同步机制:从延迟优化到事件分发的底层逻辑
  • Open-AutoGLM文本生成提速全攻略(内部优化模型首次公开)
  • 从零构建控件识别系统,基于Open-AutoGLM的自动化测试进阶之路