LFortran 0.53.0版本发布:现代Fortran编译器的重要更新
2025-07-05 03:39:22作者:舒璇辛Bertina
LFortran是一个开源的现代Fortran编译器项目,旨在为科学计算和高性能计算领域提供高效、可靠的Fortran编译解决方案。该项目采用了创新的编译器架构,支持多种后端(如LLVM、C++等),并致力于实现完整的Fortran标准支持。
核心功能改进
内存管理增强
新版本对内存管理进行了多项重要改进。在move_alloc内部子程序方面,现在能够正确处理未分配变量的情况,并在赋值后正确释放变量。对于allocate语句,实现了对mold参数的完整支持,包括运行时维度的处理。这些改进使得Fortran的动态内存管理更加健壮和可靠。
类型系统优化
0.53.0版本对类型系统进行了显著增强:
- 实现了类可分配变量的支持
- 改进了类到类变量的赋值处理
- 正确处理了类指针在函数中的传递和返回
- 增强了多态类类型对象的比较操作
- 支持了类变量的
nullify操作
数组和字符串处理
数组和字符串处理能力得到全面提升:
- 实现了
transfer内部函数对数组源的正确处理 - 改进了
pack内部函数对运行时数组的支持 - 支持了不同大小非常数字符串的数组构造器
- 实现了字符数组长度与字符串长度不同的处理
- 增强了
eoshift对可分配数组的支持
性能优化
编译过程改进
- 引入了临时文件管理机制,优化生成的目标文件处理
- 改进了函数内联机制,支持带数组和
IntentOut/Out参数的函数调用 - 优化了嵌套函数同名处理,避免LLVM后端哈希映射冲突
- 实现了列优先循环顺序,提升性能
内部函数优化
- 实现了
nearest内部函数对运行时值的支持 - 改进了
ishft和ishftc内部函数的类型处理 - 优化了
matmul内部函数数组函数的分配大小设置
格式处理增强
新版本对Fortran格式处理进行了全面增强:
- 改进了G0格式输出,使其与gfortran在小量级上保持一致
- 实现了ES0.0E0和EN0.0E0格式支持
- 增强了指数格式(ES)的溢出处理
- 支持了带比例因子的浮点处理格式
- 改进了B格式的填充处理
- 实现了A格式支持
- 支持格式描述符的重复计数
OpenMP支持
0.53.0版本在OpenMP支持方面取得重要进展:
- 引入了OMPRegion节点表示区域构造
- 实现了Sections构造
- 修复了独立并行构造中Reduction子句的bug
- 实现了Single/Master构造
错误处理和诊断
- 改进了错误消息,特别是
pack内部函数的错误提示 - 捕获内部编译器错误(ICE)并提供友好的错误信息
- 增强了LLVM IR生成中的类型转换一致性检查
- 改进了外部符号和模块过程的处理
标准兼容性
- 增加了
numeric_storage_size和character_storage_size到iso_fortran_env - 支持了
--std=f23标志的更多测试用例 - 增强了
volatile属性的支持 - 改进了可选参数的处理
工具链集成
- LSP(语言服务器协议)增加了日志记录选项
- 改进了JSON_RPC版本信息显示
- 增强了预处理器的错误处理
这个版本标志着LFortran在Fortran编译器领域的又一重要进步,特别是在面向对象特性、内存管理和并行计算支持方面。这些改进使得LFortran更加适合现代科学计算和高性能计算应用开发。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
请把这个活动推给顶尖程序员😎本次活动专为懂行的顶尖程序员量身打造,聚焦AtomGit首发开源模型的实际应用与深度测评,拒绝大众化浅层体验,邀请具备扎实技术功底、开源经验或模型测评能力的顶尖开发者,深度参与模型体验、性能测评,通过发布技术帖子、提交测评报告、上传实践项目成果等形式,挖掘模型核心价值,共建AtomGit开源模型生态,彰显顶尖程序员的技术洞察力与实践能力。00
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
MiniMax-M2.5MiniMax-M2.5开源模型,经数十万复杂环境强化训练,在代码生成、工具调用、办公自动化等经济价值任务中表现卓越。SWE-Bench Verified得分80.2%,Multi-SWE-Bench达51.3%,BrowseComp获76.3%。推理速度比M2.1快37%,与Claude Opus 4.6相当,每小时仅需0.3-1美元,成本仅为同类模型1/10-1/20,为智能应用开发提供高效经济选择。【此简介由AI生成】Python00
Qwen3.5Qwen3.5 昇腾 vLLM 部署教程。Qwen3.5 是 Qwen 系列最新的旗舰多模态模型,采用 MoE(混合专家)架构,在保持强大模型能力的同时显著降低了推理成本。00- RRing-2.5-1TRing-2.5-1T:全球首个基于混合线性注意力架构的开源万亿参数思考模型。Python00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
567
3.84 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
68
20
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
暂无简介
Dart
799
199
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.37 K
780
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
349
200
Ascend Extension for PyTorch
Python
377
450
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
16
1