Plutus项目中的goldenBudget测试改进:整合执行单元与脚本大小信息
2025-07-10 23:52:01作者:滑思眉Philip
背景介绍
在Plutus智能合约开发中,性能评估是至关重要的环节。Plutus项目目前使用两种独立的测试方法来评估智能合约的性能表现:goldenBudget测试和goldenSize测试。这两种测试分别关注不同的性能指标,但实际开发中开发者往往需要同时关注这两个指标。
当前测试机制分析
goldenBudget测试主要用于记录和验证智能合约的执行资源消耗,包括CPU和内存(MEM)的使用情况。测试结果以golden文件的形式保存,包含了合约执行时消耗的具体计算资源。
goldenSize测试则专注于测量脚本的二进制大小,这对于区块链环境尤为重要,因为链上存储和传输成本与脚本大小直接相关。在Plutus中,脚本大小会影响交易费用和链上存储效率。
问题识别
当前分离的测试机制存在几个明显问题:
- 开发者在修改编译器或脚本后,需要分别运行两个测试才能全面了解性能影响
- 维护两套测试机制增加了维护成本
- 测试结果分散,不利于整体性能分析
改进方案
建议将goldenBudget测试扩展为同时包含执行单元和脚本大小的综合性能测试。具体改进包括:
- 修改goldenBudget测试框架,使其在输出执行单元信息的同时,也输出脚本大小
- 保持现有goldenSize测试的独立性,用于仅需关注脚本大小的场景
- 统一测试结果的格式,便于自动化分析和比较
技术实现考量
实现这一改进需要考虑以下技术细节:
- 性能数据收集机制:需要确保同时收集执行单元和大小信息不会显著增加测试时间
- 结果格式设计:新的golden文件格式需要清晰区分不同性能指标
- 向后兼容性:确保现有测试基础设施能够处理新的测试输出格式
- 测试用例更新:需要更新所有现有的goldenBudget测试用例
预期收益
这一改进将带来多方面好处:
- 提高开发效率:开发者可以一次性获取完整的性能数据
- 增强性能分析能力:便于分析执行资源消耗和脚本大小之间的关联
- 降低维护成本:减少重复测试的执行次数
- 改善持续集成:更全面的性能监控有助于早期发现问题
结论
在Plutus智能合约开发中,执行资源消耗和脚本大小都是关键性能指标。将这两个指标整合到统一的测试框架中,不仅符合实际开发需求,也能提升项目的整体开发体验和效率。这一改进虽然看似简单,但对项目长期维护和开发者体验有着重要意义。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0174
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0100
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
BitCPM-CANN-8BBitCPM-CANN 是首个基于华为昇腾 NPU 原生构建的端到端 1.58 位(三值化)大语言模型训练系统。该系统将量化感知训练(QAT)集成到 Megatron-LM 框架中,并结合 MindSpeed 加速,覆盖了从自定义三值算子到基于昇腾 910B 的分布式并行训练的完整训练栈。Python00
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook04
inference通过更改一行代码,您可以在应用程序中用另一个大型语言模型(LLM)替换OpenAI GPT。Xinference赋予您使用任何所需LLM的自由。借助Xinference,您能够在云端、本地、甚至笔记本电脑上运行任何开源语言模型、语音识别模型和多模态模型的推理。Python02
项目优选
收起
暂无描述
Dockerfile
750
4.89 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
842
1.85 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
641
1.28 K
Ascend Extension for PyTorch
Python
693
841
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
452
423
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.02 K
1.05 K
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.61 K
174
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
962
567
昇腾LLM分布式训练框架
Python
174
214
暂无简介
Dart
1 K
253