Plutus 1.46.0.0 版本发布:核心编译器优化与GHC版本升级
Plutus 是 Cardano 区块链平台的智能合约开发框架,它基于 Haskell 语言构建,为开发者提供了在区块链上编写安全、可靠智能合约的工具链。本次发布的 1.46.0.0 版本带来了多项重要改进,主要集中在编译器优化和开发环境升级方面。
GHC 版本支持调整
本次更新最显著的变化是移除了对 GHC 8.10 的支持。GHC (Glasgow Haskell Compiler) 是 Haskell 的主要编译器,Plutus 框架基于它构建。现在,Plutus 主要支持 GHC 9.6 版本,同时兼容 9.8 和 9.10 版本。值得注意的是,plutus-tx-plugin 组件目前仅支持 GHC 9.6 版本。
这种版本调整反映了项目对现代化开发环境的追求,新版本 GHC 带来了更好的性能、更丰富的语言特性和更完善的工具支持。开发者需要相应升级他们的开发环境以适配这些变化。
编译器优化改进
Plutus-core 组件在本版本中实现了多项编译器优化:
-
条件分支中的延迟取消:在 #7042 变更中,实现了当延迟出现在 ifThenElse 条件分支下时的强制取消机制。这项优化可以减少不必要的计算延迟,提高合约执行效率。
-
日志保留与内联优化:当禁用日志保留功能时,编译器现在会对那些被确定为最终会被求值的"不纯"项进行内联优化。这种优化策略可以显著减少运行时开销,提升合约性能。
-
严格性分析增强:PIR 的 StrictifyBindings 过程现在加入了更强大的严格性分析能力,能够识别并优化更多非严格绑定,进一步降低运行时开销。
字符串处理修复
plutus-tx-plugin 组件修复了 HEX 编码字符串字面量的处理问题。在之前的版本中,某些情况下会导致出现"Use of fromString @ PlutusTx.Builtins.HasOpaque.BuiltinByteStringHex with inscrutable content"错误。这一修复使得开发者能够更可靠地处理十六进制编码的字节串。
对开发者的影响
对于使用 Plutus 进行智能合约开发的团队,本次更新需要注意以下几点:
-
开发环境需要升级到支持的 GHC 版本(9.6、9.8 或 9.10),特别是如果之前使用的是 8.10 版本。
-
编译器优化可能会影响合约的 gas 消耗计算,建议在升级后重新测试合约性能。
-
HEX 字符串处理的修复解决了之前的一些边界情况问题,开发者可以更放心地使用相关功能。
-
严格性分析的增强意味着编译器能够生成更高效的代码,但开发者也需要更注意代码中的严格性语义。
总体而言,Plutus 1.46.0.0 版本通过底层编译器的持续优化和开发环境的现代化,为 Cardano 智能合约开发者提供了更强大、更可靠的开发工具链。这些改进将有助于开发出性能更好、成本更低的智能合约应用。
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 Notebook099
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