SuperLU、BLAS、CUnit、YAML编译安装教程,使用Environment Modulefile管理版本

本文主要是介绍SuperLU、BLAS、CUnit、YAML编译安装教程,使用Environment Modulefile管理版本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

GRASP 是一种高精度的气溶胶反演算法,GRASP大量使用许多库进行数据准备和数值计算。在实验室服务器上配置GRASP运行环境,首先需要配置SuperLU库、BLAS库、CUnit以及YAML等依赖环境,出于版本管理的考虑,均采用编译安装方式进行,并使用Environment Modules软件管理依赖库环境。

服务器上已经搭建好git、intel fortran和environment modules等环境,服务器系统为CENTOS 8 OSTREAM。本文所有依赖库的安装位置均出于/opt/apps/libraryname/libraryversion目录下,modulefile位置部署予/usr/share/modulefiles/libraryname/libraryversion文件中,在root权限下进行。本文完整记录了整个环境搭建过程,按照此安装步骤可以成功完成SuperLU、BLAS、CUnit以及YAML等库的安装。

目录

参考资料

步骤一 安装依赖环境

导入FORTRAN环境

安装Cmake

安装SuperLU

使用Cmake Build安装SuperLU

安装Cunit

安装BLAS

安装YAML

步骤二 安装GRASP


参考资料

安装步骤参考以下官方文档,其中GitLab需要注册账户获得授权方可访问。

GRASP Framework Overview – GRASP Open

Sign in · GitLab

 GRASP 是一种高精度的气溶胶反演算法,可以处理无云环境中气溶胶和地表反射率的特性。它可以推断出近50个气溶胶和表面参数,包括颗粒大小分布、光谱折射率、球形度和吸收程度。该算法旨在通过光谱、多角度偏振遥感观测增强气溶胶特性的角色塑造。GRASP 在不同的条件下工作,包括像沙漠这样明亮的表面,那里的反射比气溶胶的信号还要强。GRASP 是高度通用的,并允许从各种各样的卫星和地面测量输入。

有关 GRASP 的详细资料,请参阅项目官方网页: GRASP-OPEN Home

有关用户文档的详细资料,请参阅: GRASP Framework Overview – GRASP Open

有关技术文档的详细资料,请参阅: GRASP Framework Overview – GRASP Open

步骤一 安装依赖环境

  • a C compiler (recommended gcc).
  • a Fortran compiler (known to work with gfortran and ifort).
  • a make command (provided on any POSIX system).
  • the cmake building software.
  • One of the four numerical packages:
    • SuperLU
    • SuperLU_MT (not included in the framework yet)
    • MUMPS
    • ViennaCL
  • a BLAS library (Netlib BLAS, ATLAS, GotoBLAS).
  • The LAPACK library.
  • ScaLAPACK (a requirement for the SuperLU and MUMPS numerical packages only).
  • ParMETIS (a requirement for the MUMPS numerical package only).
  • OpenMPI (optional).
  • The Gnome Library GLib (mostly used by the configuration manager).
  • The LibYAML library (YAML is the chosen format for GRASP configuration).
  • The C Unit Testing Framework: CUnit.

CentOS

yum install CUnit-devel SuperLU-devel blas-devel cmake gcc libyaml-devel zlib-devel

服务器需要配合environment module管理工具,故使用编译安装方式,步骤如下。

导入FORTRAN环境

module load compile/ifort/2021.5.0

服务器FORTRAN版本为IFORT 2021.5.0,如需其他版本需要另行安装。

安装Cmake

yum install cmake

安装SuperLU

官网:SuperLU: Home Page

wget https://github.com/xiaoyeli/superlu/archive/refs/tags/v5.3.0.tar.gz

使用Cmake Build安装SuperLU

1、解压 tar -zxvf v5.3.0.tar.gz

2、进入解压文件夹 cd superlu-5.3.0/

3、创建并进入编译文件夹 mkdir build | cd build

cmake .. -DCMAKE_INSTALL_PREFIX=/opt/apps/superLU/5.3.0

4、编译 make

5、编译测试 make test

注意以上编译过程都无错误发生才可进行下一步,否则需要删掉整个build文件夹,解决错误,重新编译。

6、编译安装make install (默认安装需要su权限)

7、编写modulefile

在modulefiles文件夹中新建 superLU文件夹,新建5.3.0文件并写入以下内容。

#%Moduleproc ModulesHelp { } {
puts stderr " This module loads SuperLU version 5.3.0"
puts stderr " into your local environment."
}module-whatis   "module for SuperLU 5.3.0"conflict superluif { ![ is-loaded superlu/5.3.0 ] } {module load "superlu/5.3.0"
}prepend-path "LD_LIBRARY_PATH" "/opt/apps/superLU/5.3.0/lib64"
prepend-path "LIBRARY_PATH" "/opt/apps/superLU/5.3.0/lib64"prepend-path "CPATH" "/opt/apps/superLU/5.3.0/include"prepend-path "CMAKE_PREFIX_PATH" "/opt/apps/superLU/5.3.0"

安装Cunit

官网:CUnit Home 

wget https://udomain.dl.sourceforge.net/project/cunit/CUnit/2.1-3/CUnit-2.1-3.tar.bz2

1、解压 tar -xjf CUnit-2.1-3.tar.bz2    

2、进入解压文件夹 cd CUnit-2.1-3/

3、mv configure.in configure.ac

4、aclocal

5、autoconf

6、autoheader

7、libtoolize

部分文章将libtoolize放在automake之后,会导致automake步骤时出现无法找到ltmain.h等问题。

8、automake --add-missing

9、autoconf

10、automake

11、./configure --prefix=/opt/apps/cunit/2.1.3

12、make

注意以上编译过程都无错误发生才可进行下一步,否则需要删掉整个解压文件夹,解决错误后重新编译。

13、make instal

14、编写modulefile

在modulefiles文件夹中新建 cunit 文件夹,新建2.1.3文件并写入以下内容。

#%Moduleproc ModulesHelp { } {
puts stderr " This module loads CUnit version 2.1.3"
puts stderr " into your local environment."
}module-whatis   "module for CUnit 2.1.3"conflict cunitprepend-path "LD_LIBRARY_PATH" "/opt/apps/cunit/2.1.3/lib"
prepend-path "LIBRARY_PATH" "/opt/apps/cunit/2.1.3/lib"prepend-path "CPATH" "/opt/apps/cunit/2.1.3/include"prepend-path "CMAKE_PREFIX_PATH" "/opt/apps/cunit/2.1.3"

安装BLAS

官网https://www.netlib.org/blas/

  wget http://www.netlib.org/blas/blas-3.10.0.tgz

1、解压tar -zxvf blas-3.10.0.tgz

2、进入文件夹cd BLAS-3.10.0/

3、make

默认生成文件blas$(PLAT).a,可修改make.inc把文件名修改成libblas.a,将生成文件移动至/opt/apps/blas/3.10.0文件夹中。

4、编写modulefile

在modulefiles文件夹中新建 BLAS文件夹,新建3.10.0文件并写入以下内容。

#%Moduleproc ModulesHelp { } {
puts stderr " This module loads BLAS version 3.10.0"
puts stderr " into your local environment."
}module-whatis   "module for BLAS 3.10.0"conflict blasprepend-path "LD_LIBRARY_PATH" "/opt/apps/blas/3.10.0/lib"
prepend-path "LIBRARY_PATH" "/opt/apps/blas/3.10.0/lib"prepend-path "CMAKE_PREFIX_PATH" "/opt/apps/blas/3.10.0"

安装YAML

1、tar -zxvf yaml-0.1.4.tar.gz

2、cd yaml-0.1.4/

3、./configure --prefix=/opt/apps/yaml/0.1.

4、make

5、make install

6、编写modulefile

在modulefiles文件夹中新建 yaml文件夹,新建0.1.4文件并写入以下内容。

#%Moduleproc ModulesHelp { } {
puts stderr " This module loads yaml version 0.1.4"
puts stderr " into your local environment."
}module-whatis   "module for yaml 0.1.4"conflict yamlprepend-path "LD_LIBRARY_PATH" "/opt/apps/yaml/0.1.4/lib"
prepend-path "LIBRARY_PATH" "/opt/apps/yaml/0.1.4/lib"prepend-path "CMAKE_PREFIX_PATH" "/opt/apps/yaml/0.1.4"prepend-path "CPATH" "/opt/apps/yaml/0.1.4/include"

步骤二 安装GRASP

1、cd /data/sjzhou/

2、unzip GRASP.zip

3、cd GRASP/grasp-master/

4、修改makefile prefix指定当前用户目录

5、module list

6、module avail

7、module load yaml/0.1.4  cunit/2.1.3  superlu/5.3.0 zlib/1.2.11

8、make

9、make install 

10、cd workspace/grasp/

11、./grasp

这篇关于SuperLU、BLAS、CUnit、YAML编译安装教程,使用Environment Modulefile管理版本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数