STUMPY项目:为矩阵剖面添加命名属性的技术实现
2025-06-17 21:58:29作者:裘晴惠Vivianne
矩阵剖面(Matrix Profile)是一种强大的时间序列分析技术,能够有效地发现时间序列中的模式、异常和周期性。在STUMPY项目中,矩阵剖面通常由多个列组成,分别表示不同的计算结果,但直接使用列索引访问这些结果不够直观。本文将详细介绍如何通过子类化NumPy数组来为矩阵剖面添加命名属性,提升代码的可读性和易用性。
技术背景
在STUMPY项目中,核心函数如stump生成的矩阵剖面通常包含四列数据:
- 矩阵剖面值(profile)
- 最近邻索引(nearest neighbor index)
- 左索引(left index)
- 右索引(right index)
传统访问方式需要通过列索引(如mp[:, 0])来获取特定列,这种方式存在两个主要问题:
- 不够直观,需要记住各列的含义
- 代码可读性差,维护成本高
解决方案:NumPy数组子类化
通过创建NumPy数组的子类,我们可以为矩阵剖面添加命名属性,同时保留所有NumPy数组的功能。以下是实现的关键步骤:
1. 创建mparray子类
class mparray(np.ndarray):
def __new__(cls, input_array, m=None, k=1):
obj = np.asarray(input_array).view(cls)
obj.m = m
obj.k = k
return obj
def __array_finalize__(self, obj):
if obj is None: return
self.your_new_attr = getattr(obj, 'm', None)
这个子类在创建时接收输入数组,并添加了两个额外属性m和k,分别表示子序列长度和近邻数量。
2. 添加属性访问器
@property
def p(self):
return self[:, 0]
@property
def idx(self):
return self[:, 1]
通过属性装饰器,我们可以直接通过mp.p和mp.idx访问矩阵剖面值和索引,而不需要记住列顺序。
实际应用示例
使用改进后的接口,代码变得更加清晰:
T = np.random.rand(1000) # 随机生成时间序列
m = 50 # 子序列长度
mp = stumpy.stump(T, m) # 计算矩阵剖面
mp = mparray(mp, m=m) # 转换为增强型矩阵剖面对象
# 访问属性
print(mp.m) # 输出子序列长度
print(mp.p) # 输出矩阵剖面值
print(mp.idx) # 输出最近邻索引
技术优势
- 代码可读性提升:命名属性使代码意图更加明确
- 向后兼容:保留了所有NumPy数组的功能和方法
- 扩展性强:可以轻松添加更多属性和方法
- 维护成本低:接口清晰,减少使用错误
实现细节
- __new__方法:负责创建新实例并添加额外属性
- array_finalize:确保数组操作后属性得以保留
- 属性装饰器:提供友好的访问接口
总结
通过子类化NumPy数组并为矩阵剖面添加命名属性,STUMPY项目显著提升了API的易用性和代码的可读性。这种技术实现不仅适用于矩阵剖面,也可以推广到其他需要增强NumPy数组功能的场景中。对于时间序列分析领域的研究人员和开发者来说,这种改进使得算法实现更加直观,降低了学习和使用门槛。
登录后查看全文
热门项目推荐
相关项目推荐
ERNIE-4.5-VL-28B-A3B-ThinkingERNIE-4.5-VL-28B-A3B-Thinking 是 ERNIE-4.5-VL-28B-A3B 架构的重大升级,通过中期大规模视觉-语言推理数据训练,显著提升了模型的表征能力和模态对齐,实现了多模态推理能力的突破性飞跃Python00
Kimi-K2-ThinkingKimi K2 Thinking 是最新、性能最强的开源思维模型。从 Kimi K2 开始,我们将其打造为能够逐步推理并动态调用工具的思维智能体。通过显著提升多步推理深度,并在 200–300 次连续调用中保持稳定的工具使用能力,它在 Humanity's Last Exam (HLE)、BrowseComp 等基准测试中树立了新的技术标杆。同时,K2 Thinking 是原生 INT4 量化模型,具备 256k 上下文窗口,实现了推理延迟和 GPU 内存占用的无损降低。Python00
MiniMax-M2MiniMax-M2是MiniMaxAI开源的高效MoE模型,2300亿总参数中仅激活100亿,却在编码和智能体任务上表现卓越。它支持多文件编辑、终端操作和复杂工具链调用Python00
HunyuanVideo-1.5HunyuanVideo-1.5作为一款轻量级视频生成模型,仅需83亿参数即可提供顶级画质,大幅降低使用门槛。该模型在消费级显卡上运行流畅,让每位开发者和创作者都能轻松使用。本代码库提供生成创意视频所需的实现方案与工具集。00
MiniCPM-V-4_5MiniCPM-V 4.5 是 MiniCPM-V 系列中最新且功能最强的模型。该模型基于 Qwen3-8B 和 SigLIP2-400M 构建,总参数量为 80 亿。与之前的 MiniCPM-V 和 MiniCPM-o 模型相比,它在性能上有显著提升,并引入了新的实用功能Python00
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00
GOT-OCR-2.0-hf阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00
项目优选
收起
deepin linux kernel
C
24
7
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
62
20
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
384
3.7 K
暂无简介
Dart
633
143
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
650
271
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.12 K
627
React Native鸿蒙化仓库
JavaScript
243
316
Ascend Extension for PyTorch
Python
194
212