首页
/ Makani:大规模并行训练机器学习天气和气候模型

Makani:大规模并行训练机器学习天气和气候模型

2024-06-08 09:29:47作者:胡唯隽

项目简介

Makani,源于夏威夷语中的“风”,是一个专为在PyTorch中研究和开发基于机器学习的天气和气候预测模型而设计的实验性库。它起源于NVIDIA工程师和NERSC研究人员对FourCastNet的训练工作,并已用于前沿的研究项目。稳定的功能会定期移植到NVIDIA Modulus框架中,该框架用于在科学和工程领域训练Physics-ML模型。

SFNO Rollout Animation

技术剖析

Makani支持大规模并行训练,可在100+个GPU上运行,旨在推动下一代天气和气候模型的发展。这个库采用PyTorch编写,提供各种模型并行和数据并行方案,如异步数据加载、不可预见通道、自回归训练等。特别是,它被用来训练如Spherical Fourier Neural Operators (SFNO) 和 Adaptive Fourier Neural Operators (AFNO) 这样的模型。

应用场景

Makani的用途广泛,尤其适合于需要高效处理大量气象和气候数据的应用。它可以用于:

  • 实时或短期天气预报
  • 长期气候模式模拟
  • 大规模环境影响评估
  • 灾害预警系统
  • 能源管理(如风电场优化)

项目特点

  • 高度并行化:支持多达数百个GPU的并行训练,加速模型训练。
  • 灵活的架构:适应不同的机器学习模型,包括先进的神经网络架构。
  • 自动混合精度:通过自动混合精度训练减少内存需求,提高运算速度。
  • 异步数据加载:减少I/O瓶颈,提升训练效率。
  • 多种优化策略:支持CUDA图、激活检查点、多步训练等多种优化方式,以适应大型模型。

开始使用

要安装Makani,只需执行以下命令:

git clone git@github.com:NVIDIA/makani.git
cd makani
pip install -e .

训练模型可以运行train.py,并通过命令行参数指定配置文件和目标:

mpirun -np 8 --allow-run-as-root python -u makani.train --yaml_config="config/sfnonet.yaml" --config="sfno_linear_73chq_sc3_layers8_edim384_asgl2"

对于更复杂的模型,可通过组合上述优化策略来有效利用资源。

结论

Makani是机器学习应用于气象学领域的强大工具,其创新的并行计算能力和高效的训练方法为天气和气候建模带来了革命性的变革。无论是研究人员还是开发者,都可以借助Makani快速构建和训练大规模预测模型,探索地球大气的新理解。立即加入,开启您的天气与气候智能预测之旅吧!

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
860
511
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
595
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K