Project Icon

DeepLagrangianFluids

拉格朗日流体模拟的连续卷积神经网络方法

DeepLagrangianFluids项目实现了基于连续卷积的粒子流体模拟网络,源于ICLR 2020会议发表的研究成果。项目包含数据生成、模型训练和预训练模型运行的完整代码,支持PyTorch和TensorFlow框架,并集成Open3D等库实现高效模拟与可视化。这种新方法在流体动力学模拟的准确性和计算效率方面取得了显著进展。

基于拉格朗日方法的流体模拟与连续卷积

PyTorch徽章 TensorFlow徽章

本代码库包含了我们ICLR 2020论文的代码。 我们展示了如何使用连续卷积将基于粒子的流体模拟网络训练为CNN。该代码允许你生成数据、训练自己的模型或仅运行预训练模型。

峡谷视频

如果您觉得这份代码有用,请引用我们的论文(pdf)

@inproceedings{Ummenhofer2020Lagrangian,
        title     = {Lagrangian Fluid Simulation with Continuous Convolutions},
        author    = {Benjamin Ummenhofer and Lukas Prantl and Nils Thuerey and Vladlen Koltun},
        booktitle = {International Conference on Learning Representations},
        year      = {2020},
}

我们建议您关注此代码库以获取最新更新。

依赖项

这些版本与我们在Ubuntu 18.04系统上测试的配置相匹配。 生成训练数据需要SPlisHSPlasH 2.4.0(确保以Release模式编译)。 我们建议对所有其他包使用最新版本。

通过pip安装Open3D 0.11及更高版本

ML模块已包含在Open3D 0.11及更高版本中,可以简单地通过以下命令安装:

pip install open3d

确保您的ML框架版本与Open3D中ML操作构建时使用的版本匹配。 对于Open3D 0.11,这是CUDA 10.1、TensorFlow 2.3和PyTorch 1.6。 如果无法匹配此配置,建议从源代码构建Open3D。

从源代码构建包含ML模块的Open3D

目前,为了使本代码库中的代码正常工作,需要从源代码构建Open3D。要构建包含TensorFlow和PyTorch ML操作的Open3D,请执行以下步骤:

git clone --recursive https://github.com/intel-isl/Open3D.git
# 查看Open3D/util/scripts/install-deps-ubuntu.sh文件
# 了解依赖项并安装它们。更多说明请参阅Open3D文档

mkdir Open3D/build
cd Open3D/build

# 这将为TensorFlow和PyTorch构建ML操作。
# 如果您不需要两个框架,可以将不需要的框架设置为OFF。
cmake .. -DCMAKE_BUILD_TYPE=Release -DBUILD_TENSORFLOW_OPS=ON -DBUILD_PYTORCH_OPS=ON -DBUILD_CUDA_MODULE=ON -DGLIBCXX_USE_CXX11_ABI=OFF
make install-pip-package

运行预训练模型

预训练的网络权重文件位于TensorFlow的scripts/pretrained_model_weights.h5和PyTorch的scripts/pretrained_model_weights.pt中。

以下代码在示例场景上运行网络:

cd scripts
# 使用TensorFlow
./run_network.py --weights pretrained_model_weights.h5 \
                 --scene example_scene.json \
                 --output example_out \
                 --write-ply \
                 train_network_tf.py
# 或者使用PyTorch
./run_network.py --weights pretrained_model_weights.pt \
                 --scene example_scene.json \
                 --output example_out \
                 --write-ply \
                 train_network_torch.py

该脚本会将粒子位置以.ply文件格式输出点云,可以使用Open3D进行可视化。 请注意,从.obj文件采样初始流体体积需要使用SPlisHSPlasH。

训练网络

数据生成

数据生成脚本位于datasets子文件夹中。 要生成训练和验证数据,请按以下步骤操作:

  1. datasets/splishsplash_config.py脚本中设置SPlisHSPlasH的DynamicBoundarySimulator路径。
  2. 在datasets文件夹中运行脚本:
    cd datasets
    ./create_data.sh
    

数据下载

如果您想跳过数据生成步骤,可以从以下链接下载训练和验证数据。

默认数据34GB链接
DPI大坝崩溃24GB链接
6k盒子数据23GB链接

对于默认数据,训练集是使用本仓库中的脚本生成的,验证数据与论文中使用的数据相对应。

DPI大坝崩溃数据是使用DPI-Nets仓库的代码生成的。请注意,数据已经按比例缩放以匹配我们方法使用的粒子半径。有关缩放因子的更多信息,请参阅scripts/dambreak.yaml配置文件。

6k盒子数据是默认数据的简化版本,具有恒定数量的粒子,并始终使用简单的盒子作为环境。

训练脚本

要使用生成的数据训练模型,只需在scripts文件夹中运行train_network_x.py脚本之一即可。

cd scripts
# TensorFlow版本
./train_network_tf.py default.yaml
# PyTorch版本
./train_network_torch.py default.yaml

这些脚本将创建一个train_network_tf_defaulttrain_network_torch_default文件夹,其中包含快照和日志文件。可以使用Tensorboard查看日志文件。

评估网络

要评估网络,请按如下方式运行scripts/evaluate_network.py脚本:

./evaluate_network.py --trainscript train_network_tf.py --cfg default.yaml
# 或
./evaluate_network.py --trainscript train_network_torch.py --cfg default.yaml

这将创建train_network_{tf,torch}_default_eval_50000.json文件,其中包含帧对之间的各个误差。

脚本还将打印总体误差。如果您使用生成的数据,输出应该类似于: {'err_n1': 0.000859004137852537, 'err_n2': 0.0024183266885233934, 'whole_seq_err': 0.030323669719872864}

请注意,由于数据生成中的变化,这些数字与论文中的数字不同:

  • 我们使用Open3D采样表面点,以避免提供修改后的SPlisHSPlasH。
  • 数据生成中使用的伪随机数序列不同,这导致训练和测试的场景不同。

如果您下载了验证数据,那么输出应该与论文中的数字相似: {'err_n1': 0.000665973493194656, 'err_n2': 0.0018649007299291042, 'whole_seq_err': 0.03081335372162257}

渲染

有关如何创建和渲染类似峡谷的示例场景的说明,请参阅 scenes 目录。

许可证

代码和脚本采用 MIT 许可证。

datasets/models 目录中的数据文件和 scripts/pretrained_model_weights.{h5,pt} 文件采用 CDLA-Permissive-1.0 许可证。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号