编译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

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

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