编译FVCOM

2024-03-28 20:08
文章标签 编译 fvcom

本文主要是介绍编译FVCOM,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. FVCOM编译

编译主要代码及其库:

  1. 打开一个终端。
  2. 设置MPI环境。在Fedora / Red Hat / CentOS上, yum install mpich 提供了一个mpich环境,可以将其加载 module load mpi/mpich-x86_64
  3. 更改下载FVCOM的目录并解压缩代码。
  4. 输入 FVCOM_source目录。
  5. 编辑  make.inc 文件以启用/禁用其他功能,例如润湿/干燥以满足您的要求。
  6. 将     TOPDIR 变量更改为您当前所在的路径(即 pwdLinux命令的输出)。
  7. 输入   libs 子目录。
  8. 输入  make 并等待编译完成。
  9. 切换回父  FVCOM_source 目录。
  10. 输入  make 并等待编译完成。
  11.  fvcom 二进制文件复制到模型输入目录,然后切换到该目录。
  12. 使用以下命令启动模型 mpirun
    mpirun -n $num_proc fvcom --casename test --dbg=0 --logfile=fvcom.log

$num_proc 处理器的数量 在哪里。

该 make.inc文件包含可能感兴趣的一系列环境变量,特别是编译器选项。参见第463-469行。对于gfortran,以下环境变量可make.inc用于Fedora。

#--------------------------------------------------------------------------
#  MPIF90/GFORTRAN Compiler Definitions (PML)
#--------------------------------------------------------------------------CPP      = cppCOMPILER = -DGFORTRANFC       = mpif90DEBFLGS  =OPT      = -O3 -L/usr/lib64/mpich-x86_64/lib -I/usr/include/mpich-x86_64 -I/usr/lib64/gfortran/modules/CLIB     =CC       = mpicc

2. 非静液压和半隐式FVCOM

Non-hydrostatic and semi-implicit FVCOM

2.1 依存关系

对于非静水,半隐式,数据同化,卡尔曼滤波器和波电流相互作用,FVCOM需要PETSc和HYPRE。FVCOM是根据PETSc库的2.3.3版本编写的; PETSc版本3.x不适用于FVCOM。反过来,PETSc依赖于HYPRE,并且我们已经成功使用了HYPRE 2.0.0版。

2.2 编译

在您的中make.inc,在TOPDIR声明之后添加一个新部分,其中包括两个新变量:

#--------------------------------------------------------------------------
#  PETSC library locations (for non-hydrostatic/semi-implicit/data assimilation)
#--------------------------------------------------------------------------PETSC_LIB     =  -L$(PETSC_DIR)/lib/linux-gnu-intel/PETSC_FC_INCLUDES =  -I$(PETSC_DIR) -I$(PETSC_DIR)/bmake/$(PETSC_ARCH) -I$(PETSC_DIR)/include

确保您的PETSc安装将PETSC_DIRPETSC_ARCH环境变量设置为PETSc安装的根目录(如果您自己编译了PETSc,PETSC_DIR则是使用--prefix in 指定的路径configure.py)。如果PETSC_ARCH未定义,则应该可以通过查找$PETSC_DIR/lib/; 来识别有效值。有效值将是该目录中目录的名称。

然后,对于非流体力学,请编辑您的内容make.inc以取消注释该FLAG_30 = -DNH行及其include $(PETSC_DIR)/bmake/common/variables下方以及该FLAG_9 = -DSEMI_IMPLICIT行。对于其他选项(非静液压,半隐式,数据同化,卡尔曼滤波器和波电流相互作用),请取消注释相关的FLAGs

最后,将PETSC_LIBPETSC_FC_INCLUDES变量附加到LIBSINCLUDES定义的末尾make.inc

            LIBS  = $(LIBDIR) $(CLIB)  $(PARLIB) $(IOLIBS)  $(DTLIBS)\$(MPILIB) $(GOTMLIB) $(KFLIB) $(BIOLIB) \$(OILIB) $(VISITLIB) $(PROJLIBS) $(PETSC_LIB)INCS  =     $(INCDIR) $(IOINCS) $(GOTMINCS) $(BIOINCS)\$(VISITINCPATH) $(PROJINCS) $(DTINCS) \$(PETSC_FC_INCLUDES)

要编译FVCOM,请make像往常一样键入。

 

3. FVCOM-GOTM

可在GOTM网站上找到GOTM的安装指南。

这些说明假定您使用的是Intel Fortran编译器(ifort)。

  • 按照上面网站上的说明下载并提取GOTM存档。
  • 打开一个终端窗口,将目录更改为GOTM源代码,然后键入以下内容:
    export NETCDFINC=/YOUR/FVCOM/LIBS/DIR/libs/install/includeexport NETCDFLIBNAME=/YOUR/FVCOM/LIBS/DIR/libs/install/lib/libnetcdf.aexport GOTMDIR=$(pwd)/gotm-4.0.0export FORTRAN_COMPILER=IFORTcd srcmake

 $TOPDIR 里面的make.incFVCOM中/YOUR/FVCOM/LIBS/DIR的值替换。 

  • 这将产生类似于上面网站所述的输出,以及一个名为  gotm_prod_IFORT
  • 通过从GOTM网站下载并运行测试用例来测试您的GOTM构建。

要将GOTM与FVCOM链接,您需要对FVCOM进行以下更改make.inc

    FLAG_11 = -DGOTMGOTMLIB       = -L/YOUR/GOTM/DIR/gotm-4.0.0/lib/IFORT/ -lturbulence_prod -lutil_prod -lmeanflow_prodGOTMINCS      = -I/YOUR/GOTM/DIR/gotm-4.0.0/modules/IFORT/

和以前一样,/YOUR/GOTM/DIR/使用包含GOTM版本的目录进行调整。

.nml文件中设置以下选项:

    BOTTOM_ROUGHNESS_TYPE           = 'gotm'

最后,将GOTM输入包含casename_gotmturb.inp在与其他FVCOM输入相同的目录中的文件中。

 

4. FVCOM-FABM:支持生物地球化学模型

要构建FVCOM-FABM,首先要编译FABM,然后将FVCOM链接到它。要下载FVCOM-FABM代码,请先向UMASSD 注册,然后向PML 注册,以访问FVCOM-FABM代码。注册后,FABM-ERSEM从PML GitLab存储库下载分支。

FABM

  1. 从https://github.com/fabm-model/fabm下载FABM 。
  2. 提取FABM源代码(以下示例代码将代码提取到$HOME/Code/fabm/src
  3. 如果您想将FVCOM-FABM与ERSEM结合使用,请注册访问ERSEM源代码,从PML GitLab下载稳定的代码,然后提取源代码(下面的示例代码将代码提取到$HOME/Code/ersem
  4. 确保已安装CMake 2.8.8或更高版本。
  5. 编译FABM:
cd $HOME/Code/fabm/src
mkdir build
cd build
cmake $HOME/Code/fabm/src -DFABM_HOST=fvcom -DFABM_ERSEM_BASE=$HOME/Code/ersem -DCMAKE_Fortran_COMPILER=$(which mpif90)
make install

-DFABM_ERSEM_BASE=...如果您不使用ERSEM,请 忽略该开关。

要启用调试版本,请将cmake命令更改为以下内容:

cmake $HOME/Code/fabm/src -DFABM_HOST=fvcom -DFABM_ERSEM_BASE=$HOME/Code/ersem -DCMAKE_Fortran_COMPILER=$(which mpif90) -DCMAKE_BUILD_TYPE=debug -DCMAKE_Fortran_FLAGS_DEBUG="-g -traceback -check all"

在上文中,的值-DCMAKE_Fortran_FLAGS_DEBUG特定于Intel Fortran编译器;如果您使用其他编译器,则将其替换为适合使用该编译器进行调试的标志。

默认情况下,FABM的构建具有双精度。如果-DDOUBLE_PRECISION在编译FVCOM时使用该标志,则这是适当的。如果您打算改用单精度,则需要添加-DFABM_REAL_KIND='SELECTED_REAL_KIND(6)'对的调用cmake

5. FVCOM-FABM

要在FABM支持下编译FVCOM,请FLAG_25按如下所示编辑make.inc并正常编译FVCOM。如果已将FABM安装到自定义位置,请根据需要调整BIOLIBBIOINCS路径。

            # Online configurationFLAG_25 = -DFABMBIOLIB       = -L$(HOME)/local/fabm/fvcom/lib -lfabmBIOINCS      = -I$(HOME)/local/fabm/fvcom/include

To enable offline FVCOM-ERSEM runs, change FLAG_25 to -DFABM -DOFFLINE_FABM.

这篇关于编译FVCOM的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/856578

相关文章

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码

Golang test编译使用

创建文件my_test.go package testsimport "testing"func TestMy(t *testing.T) {t.Log("TestMy")} 通常用法: $ go test -v -run TestMy my_test.go=== RUN TestMyTestMy: my_test.go:6: TestMy--- PASS: TestMy (0.

C++/《C/C++程序编译流程》

程序的基本流程如图:   1.预处理        预处理相当于根据预处理指令组装新的C/C++程序。经过预处理,会产生一个没有宏定义,没有条件编译指令,没有特殊符号的输出文件,这个文件的含义同原本的文件无异,只是内容上有所不同。 读取C/C++源程序,对其中的伪指令(以#开头的指令)进行处理将所有的“#define”删除,并且展开所有的宏定义处理所有的条件编译指令,如:“#if”、“

编译linux内核出现 arm-eabi-gcc: error: : No such file or directory

external/e2fsprogs/lib/ext2fs/tdb.c:673:29: warning: comparison between : In function 'max2165_set_params': -。。。。。。。。。。。。。。。。。。 。。。。。。。。。。。。。 。。。。。。。。 host asm: libdvm <= dalvik/vm/mterp/out/Inte

QT 编译报错:C3861: ‘tr‘ identifier not found

问题: QT 编译报错:C3861: ‘tr’ identifier not found 原因 使用tr的地方所在的类没有继承自 QObject 类 或者在不在某一类中, 解决方案 就直接用类名引用 :QObject::tr( )

hector_quadrotor编译总结 | ubuntu 16.04 ros-kinetic版本

hector_quadrotor编译总结 | ubuntu 16.04 ros-kinetic版本 基于Ubuntu 16.04 LTS系统所用ROS版本为 Kinetic hector_quadrotor ROS包主要用于四旋翼无人机的建模、控制和仿真。 1.安装依赖库 所需系统及依赖库 Ubuntu 16.04|ros-kinetic|Gazebo|gazebo_ros_pkgs|ge

hector_quadrotor编译总结 | ubuntu 14.04 ros-indigo版本

hector_quadrotor编译总结 | ubuntu 14.04 ros-indigo版本 基于Ubuntu 14.04 LTS系统所用ROS版本为 Indigo hector_quadrotor ROS包主要用于四旋翼无人机的建模、控制和仿真。 备注:两种安装方式可选:install the binary packages | install the source files

编译和链接那点事下

http://www.0xffffff.org/?p=357 上回书我们说到了链接以前,今天我们来研究最后的链接问题。         链接这个话题延伸之后完全可以跑到九霄云外去,为了避免本文牵扯到过多的话题导致言之泛泛,我们先设定本文涉及的范围。我们今天讨论只链接进行的大致步骤及其规则、静态链接库与动态链接库的创建和使用这两大块的问题。至于可执行文件的加载、可执行文件的运行时

编译和链接那点事上

http://www.0xffffff.org/?p=323  有位学弟想让我说说编译和链接的简单过程,我觉得几句话简单说的话也没什么意思,索性写篇博文稍微详细的解释一下吧。其实详细的流程在经典的《Linkers and Loaders》和《深入理解计算机系统》中均有描述,也有国产的诸如《程序员的自我修养——链接、装载与库》等大牛著作。不过,我想大家恐怕很难有足够的时间去研读这些厚如