首页/文章/ 详情

MacOS原生OpenFOAM App: 用户指南

5月前浏览13517

OpenFOAM是一款开源的CFD软件,功能很强大,而且可扩展性非常强。这里的可扩展性指的是在OpenFOAM的基础上可以自己开发各种求解器解决一些特定的问题。然而,OpenFOAM也存在开源软件的普遍问题:学习曲线较陡。尤其是软件安装,这第一步就会劝退一大批人。不论是OpenFOAM官网还是一些网上的教程,针对MacOS系统下的安装全都是基于Docker或者其他的虚拟机。其逻辑都是通过虚拟机虚拟出Linux系统,然后在虚拟的Linux系统里面使用OF。这种方式存在很多问题,最大的问题就是运行效率低,自己开发求解器的时候不容易调试。所以,最好的解决方案就是在MacOS系统下从OF源码编译出原生的程序,但是几乎所有平台都没有给出这种解决方案!即使找到了某种方式进行编译,也是非常麻烦,需要解决很多第三方依赖库和编译器的问题,非常浪费时间还不一定能搞定!「基于此,本人花了一些时间将OpenFOAM的主流的版本编译为原生的app,解决了以上所有的这些繁琐的问题,非常容易使用。尤其对于一些初学者或者编程不太熟悉的用户,以前可能从来无法实现或者需要很长时间才能实现的问题,现在可以在一分钟之内解决问题。本文主要介绍如何下载和使用OpenFOAM app」。下面是详细介绍文本,同时也配有亲手操作的演示视频。

1. 下载

下载很简单(如图1所示),查看可用版本并通过 「解锁」 按钮进行相应的下载操作(如下截图所示)。如果网站上没有列出您的目标版本,可以发送请求到进行私人定制。

图1: 访问https://www.scibyte.cn/zh/products/openfoam-macos/index_zh.html页面,轻轻点击[解锁]按钮即可通过说明步骤获取图1: 访问下载页面,轻轻点击[解锁] 按钮即可通过说明步骤获取

2. 安装

如果第一步完成,则相应的软件下载链接通过邮件发送给您。比如OpenFOAM-9的Apple Silicon芯片版本(下面的过程全部以此版本为例进行讲解),下载得到的app文件为 OpenFOAM-9-darwin-arm64.dmg 镜像文件。双击打开即可得到如下图所示的内容,与常规的MacOS的app安装一样,只需要简单地将OpenFOAM-9 拖入左边的 Applications目录即可完成安装。

图2: 镜像文件中的内容图2: OpenFOAM-9-darwin-arm64.dmg 镜像文件中的内容

拖入完成之后,即可在LaunchPad中发现OpenFOAM-9 app,如下图所示:

图3: app安装完成后即可出现在launchpad中图3: OpenFOAM-9-darwin-arm64.dmg app安装完成后即可出现在launchpad中

app的文件列表

安装完成之后的app位于路径 /Applications/OpenFOAM-9.app/Contents 中,其中的文件列表如下图所示。其中 MacOS 目录中存放初始化脚本; Resources/bin 中存放所有的可执行文件; Resources/lib 中存放所有的动态库文件; Resources/etc 中存放所有的环境配置文件; Resources/OpenFOAM-9.sparsebundle 为存放源代码的Case sensitive镜像文件(用于存放OpenFOAM源代码的,因为OF的源代码的文件名是区分大小写的,然而MacOS的默认文件系统是不区分文件名大小写的,所以通过创建一个区分大小写的disk image是比较明智的选择)。

图4:OpenFOAM-9app的路径和文件列表图4:OpenFOAM-9 app的路径和文件列表

「详细的文件列表请访问原文查看」

3. 加载OpenFOAM环境

完成以上步骤之后就跟其他所有系统或者平台下使用OpenFOAM没有区别了,只需要加载环境变量就行。

首次安装后的环境加载

首次安装后加载环境很容易,只需要打开lunchpad并用鼠标点击 OpenFOAM-9 app ( 图3 ) 即可。 然后会弹出一个小对话框(如下图所示),提示本需要用户进行安全确认。

图5: OpenFOAM-8-x86_64app首次打开的安全验证提示图5: OpenFOAM-8-x86_64 app首次打开的安全验证提示

对于所有不是App Store里面下载的软件,都会有此提示。只需要在系统的Security & Privacy里面点击允许即可。

  • Step 1
图6:在系统的安全&隐私管理里面允许运行OpenFOAMapp图6:在系统的安全&隐私管理里面允许运行OpenFOAM app
  • Step 2
图7:在系统的安全&隐私管理里面允许运行OpenFOAMapp图7:在系统的安全&隐私管理里面允许运行OpenFOAM app

细心的同学可能发现,上面的几个截图里面的app名字是OpenFOAM-8-x86_64,这是因为我写这篇博文的时候用的是M1芯片的MacBook,而举例使用的OpenFOAM-9-arm64 app就是本机器下编译的,所以不会出现安全验证的提示。为了给大家展示这个安全验证的提示信息,所以上面的截图运行的x86_64架构的app是另一个Inter芯片的MacBook上编译的。一般情况下,除了开发者自己的电脑,其他人安装app并第一次打开的时候都会出现以上的安全验证提示。

安全验证允许之后,会弹出一个终端窗口(如 图8 所示),在这个终端窗口里已经自动加载了OpenFOAM环境,可以运行OF自带的求解器,所有的相关的环境变量都有效。总之一句话,在这个终端窗口里可以做所有OpenFOAM的工作。

图8: 运行OpenFOAMapp所弹出的终端窗口图8: 运行OpenFOAM app所弹出的终端窗口

自动加载OpenFOAM环境

通过上面的方式(直接点击OpenFOAM app,在弹出的终端里面进行工作)可以工作,但是如果关闭这个窗口或者在其他的终端窗口里面是没有加载OF环境的,也就意味着无法运行OF的程序。我个人喜欢的一种方式就是在系统环境profile文件里面加入一段代码(如下所示),让其自动加载OpenFOAM环境:「随便打开一个终端都可以使用OpenFOAM」 。

# =========== OpenFOAM initialization start ===========
FOAM_DISK_IMAGE=/Applications/OpenFOAM-9.app/Contents/Resources/OpenFOAM-9.sparsebundle
FOAM_MOUNT_POINT=/Volumes/OpenFOAM-9
FOAM_VERSION=9
if [ ! -f ${FOAM_MOUNT_POINT}/etc/bashrc ]; then
   hdiutil attach -quiet -mountpoint ${FOAM_MOUNT_POINT} ${FOAM_DISK_IMAGE} && . ${FOAM_MOUNT_POINT}/etc/bashrc
else
   source ${FOAM_MOUNT_POINT}/etc/bashrc
fi
# =========== OpenFOAM initialization end ===========

只需要将以上代码添加到 ~/.bash_profile 文件中并保存即可。这样以后随便打开一个终端都能使用OpenFOAM了,就不用再在Launchpad里面点击OpenFOAM app了。

至此,在Mac系统安装原生OpenFOAM软件及加载环境的步骤就全部完成了,非常容易,一分钟之内就可以完成! 从此开始,在Mac系统下使用OpenFOAM与Linux系统下完全相同。


OpenFOAM二次开发代码&命令求解技术ESI 其他
著作权归作者所有,欢迎分享,未经许可,不得转载
首次发布时间:2022-02-03
最近编辑:5月前
CFDer
博士 签名征集中
获赞 0粉丝 2文章 1课程 0
点赞
收藏
未登录
还没有评论
课程
培训
服务
行家
VIP会员 学习 福利任务 兑换礼品
下载APP
联系我们
帮助与反馈