diff --git a/container/openeuler-bisheng2-bowtie2-2.4.5.def b/container/bowtie2/openeuler-bisheng2-bowtie2-2.4.5.def similarity index 100% rename from container/openeuler-bisheng2-bowtie2-2.4.5.def rename to container/bowtie2/openeuler-bisheng2-bowtie2-2.4.5.def diff --git a/container/openeuler-gcc-9.3.0-bowtie2-2.4.5.def b/container/bowtie2/openeuler-gcc-9.3.0-bowtie2-2.4.5.def similarity index 100% rename from container/openeuler-gcc-9.3.0-bowtie2-2.4.5.def rename to container/bowtie2/openeuler-gcc-9.3.0-bowtie2-2.4.5.def diff --git a/container/duns/openeuler-bisheng2-duns-2.7.1.def b/container/duns/openeuler-bisheng2-duns-2.7.1.def new file mode 100644 index 0000000000000000000000000000000000000000..626b6e9dbfef03420af28692b89bd40c3eecc5d5 --- /dev/null +++ b/container/duns/openeuler-bisheng2-duns-2.7.1.def @@ -0,0 +1,36 @@ +BootStrap: docker +From: openeuler/openeuler + +%environment + source /etc/profile || true + source /etc/profile.d/modules.sh + cd /hpcrunner + source env.sh + +%post + # Install the necessary development environment + yum install -y environment-modules git wget unzip make flex tar + # Install base gcc + yum install -y gcc gcc-c++ make cmake automake libX11-devel + source /etc/profile || true + git config --global http.sslVerify false + git clone https://gitee.com/openeuler/hpcrunner.git + cd hpcrunner + source ./init.sh + source /etc/profile.d/modules.sh + ./jarvis -i + # Switch config + ./jarvis -use templates/duns/2.7.1/data.duns.arm.cpu.config + # downloads duns + ./jarvis -d + # install dependency + ./jarvis -dp + # build duns + ./jarvis -b + # run duns + ./jarvis -r + # clean downloads directory + rm -rf downloads + +%labels + Author Zu \ No newline at end of file diff --git a/container/duns/openeuler-gcc-9.3.0-duns-2.7.1.def b/container/duns/openeuler-gcc-9.3.0-duns-2.7.1.def new file mode 100644 index 0000000000000000000000000000000000000000..3318438bc94359a4caec3b49d22083de5e3cecfc --- /dev/null +++ b/container/duns/openeuler-gcc-9.3.0-duns-2.7.1.def @@ -0,0 +1,36 @@ +BootStrap: docker +From: openeuler/openeuler + +%environment + source /etc/profile || true + source /etc/profile.d/modules.sh + cd /hpcrunner + source env.sh + +%post + # Install the necessary development environment + yum install -y environment-modules git wget unzip make flex tar + # Install base gcc + yum install -y gcc gcc-c++ make cmake automake libX11-devel + source /etc/profile || true + git config --global http.sslVerify false + git clone https://gitee.com/openeuler/hpcrunner.git + cd hpcrunner + source ./init.sh + source /etc/profile.d/modules.sh + ./jarvis -i + # Switch config + ./jarvis -use templates/duns/2.7.1/data.duns.x86.cpu.config + # downloads duns + ./jarvis -d + # install dependency + ./jarvis -dp + # build duns + ./jarvis -b + # run duns + ./jarvis -r + # clean downloads directory + rm -rf downloads + +%labels + Author Zu \ No newline at end of file diff --git a/container/openeuler-bisheng2-hmpi1-mfem-4.4.def b/container/mfem/openeuler-bisheng2-hmpi1-mfem-4.4.def similarity index 100% rename from container/openeuler-bisheng2-hmpi1-mfem-4.4.def rename to container/mfem/openeuler-bisheng2-hmpi1-mfem-4.4.def diff --git a/container/openeuler-bisheng2-hmpi1-qe-6.4-opt.def b/container/qe/openeuler-bisheng2-hmpi1-qe-6.4-opt.def similarity index 100% rename from container/openeuler-bisheng2-hmpi1-qe-6.4-opt.def rename to container/qe/openeuler-bisheng2-hmpi1-qe-6.4-opt.def diff --git a/container/openeuler-kgcc9-openmpi4-qe-6.4.def b/container/qe/openeuler-kgcc9-openmpi4-qe-6.4.def similarity index 100% rename from container/openeuler-kgcc9-openmpi4-qe-6.4.def rename to container/qe/openeuler-kgcc9-openmpi4-qe-6.4.def diff --git a/container/openeuler-bisheng2-hmpi1-qmcpack-3.13.0.def b/container/qmcpack/openeuler-bisheng2-hmpi1-qmcpack-3.13.0.def similarity index 100% rename from container/openeuler-bisheng2-hmpi1-qmcpack-3.13.0.def rename to container/qmcpack/openeuler-bisheng2-hmpi1-qmcpack-3.13.0.def diff --git a/container/openeuler-gcc-9.3.0-hmpi1-qmcpack-3.13.0.def b/container/qmcpack/openeuler-gcc-9.3.0-hmpi1-qmcpack-3.13.0.def similarity index 100% rename from container/openeuler-gcc-9.3.0-hmpi1-qmcpack-3.13.0.def rename to container/qmcpack/openeuler-gcc-9.3.0-hmpi1-qmcpack-3.13.0.def diff --git a/container/openeuler-bisheng2-trinity-2.14.0.def b/container/trinity/openeuler-bisheng2-trinity-2.14.0.def similarity index 100% rename from container/openeuler-bisheng2-trinity-2.14.0.def rename to container/trinity/openeuler-bisheng2-trinity-2.14.0.def diff --git a/container/openeuler-gcc-9.3.0-trinity-2.14.0.def b/container/trinity/openeuler-gcc-9.3.0-trinity-2.14.0.def similarity index 100% rename from container/openeuler-gcc-9.3.0-trinity-2.14.0.def rename to container/trinity/openeuler-gcc-9.3.0-trinity-2.14.0.def diff --git a/container/openeuler.wannier90.arm.cpu.config.def b/container/wannier90/openeuler.wannier90.arm.cpu.config.def similarity index 100% rename from container/openeuler.wannier90.arm.cpu.config.def rename to container/wannier90/openeuler.wannier90.arm.cpu.config.def diff --git a/container/openeuler.wannier90.x86.cpu.config.def b/container/wannier90/openeuler.wannier90.x86.cpu.config.def similarity index 100% rename from container/openeuler.wannier90.x86.cpu.config.def rename to container/wannier90/openeuler.wannier90.x86.cpu.config.def diff --git "a/doc/duns/\343\200\212\345\237\272\344\272\216openEuler\347\232\204duns\350\275\257\344\273\266\346\265\213\350\257\225\346\212\245\345\221\212\343\200\213.md" "b/doc/duns/\343\200\212\345\237\272\344\272\216openEuler\347\232\204duns\350\275\257\344\273\266\346\265\213\350\257\225\346\212\245\345\221\212\343\200\213.md" new file mode 100644 index 0000000000000000000000000000000000000000..1ee1e85872530a5ab98010067e49404dcec88197 --- /dev/null +++ "b/doc/duns/\343\200\212\345\237\272\344\272\216openEuler\347\232\204duns\350\275\257\344\273\266\346\265\213\350\257\225\346\212\245\345\221\212\343\200\213.md" @@ -0,0 +1,595 @@ +# 《基于openEuler的DUNS软件测试报告》 + +## 1.规范性自检 + +DUNS于2003年之后就停止更新,其代码更是由Fortran77编写,现网支持的fortran格式化工具fprettify也只支持f90以及更高的版本,因此这里无法对DUNS进行代码格式测试。 + +### 1.1.选择统计文件类型 + +统计项目文件类型及其文件数量 + +使用python编写脚本文件 + +```python +import os + +print(os.getcwd()) + +def getAllFiles(targetDir): + files = [] + listFiles = os.listdir(targetDir) + for i in range(0, len(listFiles)): + path = os.path.join(targetDir, listFiles[i]) + if os.path.isdir(path): + files.extend(getAllFiles(path)) + elif os.path.isfile(path): + files.append(path) + return files + +all_files = getAllFiles(os.curdir) +type_dict = dict() + +for each_file in all_files: + if os.path.isdir(each_file): + type_dict.setdefault("directory", 0) + type_dict["directory"] += 1 + else: + ext = os.path.splitext(each_file)[1] + type_dict.setdefault(ext, 0) + type_dict[ext] += 1 + +for each_type in dict(sorted(type_dict.items(), reverse=True, key=lambda item: item[1])).keys(): + print("当前文件夹下共有[%s]的文件%d个" % (each_type, type_dict[each_type])) +``` + +在duns项目根目录下运行,运行结果如下 + +```bash +python run.py +/root/duns-2.7.1 +当前文件夹下共有[.F]的文件80个 +当前文件夹下共有[]的文件31个 +当前文件夹下共有[.Inc]的文件28个 +当前文件夹下共有[.f]的文件19个 +当前文件夹下共有[.html]的文件10个 +当前文件夹下共有[.cpp]的文件6个 +当前文件夹下共有[.c]的文件2个 +当前文件夹下共有[.ps]的文件2个 +当前文件夹下共有[.inc]的文件1个 +当前文件夹下共有[.sgml]的文件1个 +当前文件夹下共有[.txt]的文件1个 +当前文件夹下共有[.eps]的文件1个 +当前文件夹下共有[.py]的文件1个 +当前文件夹下共有[.doc]的文件1个 +``` + +查看上述结果可知主要源码文件后缀名为 `.F`,`.Inc`,`.f` + +### 1.2.统计源码总行数 + +统计所有源码文件的代码行数 + +```bash + find ./ -regex ".*\.F90\|.*\.f90\|.*\.py"\|.*\.sh"\|.*\.gfort"\ + | xargs wc -l +``` + +统计结果 + +```bash + 48446 total +``` + +### 1.3 文件列表 + +```bash +duns-2.7.1 +|-- CHANGES +|-- COPYING +|-- doc +| |-- algorithm.ps +| |-- duns_tut-1.html +| |-- duns_tut-2.html +| |-- duns_tut-3.html +| |-- duns_tut-4.html +| |-- duns_tut-5.html +| |-- duns_tut-6.html +| |-- duns_tut-7.html +| |-- duns_tut-8.html +| |-- duns_tut-9.html +| |-- duns_tut.html +| |-- duns_tut.ps +| |-- duns_tut.sgml +| |-- duns_tut.txt +| `-- fig1.eps +|-- HISTORY +|-- INSTALL +|-- lib +| |-- acklib.f +| |-- amach.f +| |-- blocksolver.f +| |-- ckinterp.f +| |-- cklib.f +| |-- ckstrt.f +| |-- cmach.f +| |-- dmach.f +| |-- graficV3.f +| |-- grcomn.inc +| |-- grctrl.f +| |-- Makefile +| |-- math.f +| |-- mbgrafic.f +| |-- mbgrctrl.f +| |-- mcklib.f +| |-- pcmach.f +| |-- tranfit.f +| |-- tranlib.f +| |-- vode.f +| |-- xerror.f +| |-- Xnounderscore.c +| `-- Xunderscore.c +|-- makesystem +| |-- Makesystem_aix +| |-- Makesystem_aixpar +| |-- Makesystem_alpha +| |-- Makesystem_cray +| |-- Makesystem_hp +| |-- Makesystem_hp1 +| |-- Makesystem_linux +| |-- Makesystem_linuxf2c +| |-- Makesystem_linuxfpar +| |-- Makesystem_linuxic +| |-- Makesystem_linuxpar +| |-- Makesystem_linuxRH7 +| `-- Makesystem_sgi +|-- pregrid +| |-- assemble.F +| |-- bcassemble.F +| |-- config.F +| |-- corners.F +| |-- duns.F +| |-- getaxismap.F +| |-- getintgc.F +| |-- getside.F +| |-- getsurface.F +| |-- getsurfacen.F +| |-- gridread.F +| |-- include +| | |-- bounds.Inc +| | |-- dualtime.Inc +| | |-- execution.Inc +| | |-- flowfield.Inc +| | |-- grid.Inc +| | |-- parallel.Inc +| | |-- properties.Inc +| | |-- reactions.Inc +| | |-- solblock.Inc +| | |-- solver.Inc +| | |-- stab.Inc +| | |-- timestep.Inc +| | |-- turbulence.Inc +| | `-- variables.Inc +| |-- inprepar.F +| |-- inread.F +| |-- interp.F +| |-- main.cpp +| |-- Makefile +| |-- metric.F +| |-- parameters +| |-- parprepar.F +| |-- pregrid.F +| |-- prepar.F +| |-- rdist.F +| `-- readcom.F +|-- README +|-- REVISION +|-- set_me_up +|-- src +| |-- assemble.F +| |-- bcassemble.F +| |-- bc.F +| |-- blockadi.F +| |-- blockbc.F +| |-- blocklhs.F +| |-- blocksolver.F +| |-- boundwrite.F +| |-- calcwi.F +| |-- check.F +| |-- config.F +| |-- configplot.F +| |-- corners.F +| |-- diagadi.F +| |-- duns.F +| |-- dunsplot.F +| |-- eos.F +| |-- getaxismap.F +| |-- getintgc.F +| |-- getside.F +| |-- getsurface.F +| |-- gridread.F +| |-- inbc.F +| |-- include +| | |-- bounds.Inc +| | |-- dualtime.Inc +| | |-- execution.Inc +| | |-- flowfield.Inc +| | |-- grid.Inc +| | |-- parallel.Inc +| | |-- properties.Inc +| | |-- reactions.Inc +| | |-- solblock.Inc +| | |-- solver.Inc +| | |-- stab.Inc +| | |-- timestep.Inc +| | |-- turbulence.Inc +| | `-- variables.Inc +| |-- inprepar.F +| |-- inread.F +| |-- interp2.F +| |-- interp.F +| |-- interpold.F +| |-- intupdate.F +| |-- jaccal.F +| |-- lhs.F +| |-- lineq.F +| |-- main.cpp +| |-- mainplot.cpp +| |-- Makefile +| |-- metric.F +| |-- mocbc.F +| |-- outbc.F +| |-- parameters +| |-- parprepar.F +| |-- parupdate.F +| |-- plot.cpp +| |-- plot.doc +| |-- prepar.F +| |-- preset.F +| |-- qread.F +| |-- rdist.F +| |-- reactck.F +| |-- react.F +| |-- readcom.F +| |-- restart.F +| |-- rhsupwind.F +| |-- setsignals.cpp +| |-- sigaction.F +| |-- spropck.F +| |-- sprop.F +| |-- stabbc.F +| |-- stabprepar.F +| |-- step1.F +| |-- tecmovie.F +| |-- tecout.F +| |-- timer.cpp +| |-- timestp.F +| |-- turbeddy.F +| |-- turbsource.F +| |-- update.F +| |-- vnjac.F +| `-- wallbc.F +|-- TODO +|-- util +| |-- dunsdiff +| |-- dunssource +| `-- dunstest +`-- VERSION +``` + +## 2.功能性测试 + +官方给出诸多测试,如`airfoil`,`bfs`,`cduct`,`cylinder`等,这里对每个测试案例进行测试 + +### 2.1.测试脚本 + +每个测试用例下都有其各自的测试脚本,`bfs`下的测试脚本如下,其他测试脚本大致相同 + +```bash +#!/bin/sh + +DUNSSOURCE=$DUNSPATH27/util/dunssource +RETVAL=0 + +case "$1" in + + run ) + $DUNSSOURCE -d . 3d + cp parameters duns-3d + cd duns-3d + make duns-opt.e + make clean + cd .. + ./duns-3d/duns-opt.e -nv > out6.dat + ;; + + clean ) + \rm -rf core dunsout.* crash.* save.* out6.dat duns-3d + ;; + * ) + RETVAL=1 + echo "Usage: $0 run / clean" +esac + +exit $RETVAL +``` + +进行cduct目录下进行测试: +```bash +./testscript run +``` + +### 2.2.运行结果 + +```bash +[root@host trinityrnaseq-v2.14.0]# ./testscript run &> /dev/null && cat out.dat +DUNS Version 2.7.1 + + + + + + + +> grid +> formatted + + + + + + Number of blocks for grid = 3 + Block 1 30 21 21 + Block 2 30 21 21 + Block 3 30 21 21 + + Reading connectivity file duns.conn +B 1 s 1 0 0 b 0 2 123 s 3 0 0 s 4 0 0 s 5 0 0 s 6 0 0 +B 2 b 0 1 123 b 0 3 123 s 3 0 0 s 4 0 0 s 5 0 0 s 6 0 0 +B 3 b 2 0 123 s 2 0 0 s 3 0 0 s 4 0 0 s 5 0 0 s 6 0 0 + + Assembling sweep blocks + Sweep block: 1 + 1 1123 2 2123 3 3123 + 1 2 + 0 0 + Sweep block: 2 + 1 1213 + 3 4 + 0 0 + Sweep block: 3 + 2 2213 + 3 4 + 0 0 + Sweep block: 4 + 3 3213 + 3 4 + 0 0 + Sweep block: 5 + 1 1312 + 5 6 + 0 0 + Sweep block: 6 + 2 2312 + 5 6 + 0 0 + Sweep block: 7 + 3 3312 + 5 6 + 0 0 + + **** nmx: 45012 **** + **** iblkmx: 133100 **** + **** iimx: 89 **** + **** iimx2: 31 **** + + **** surfmax: 8160 **** + **** bindmax: 4576 **** + number of interior ghost cells : 1200 + Tolerance = 3.3870972E-06 +> flow-field +> viscous + + + + + +> gas-properties +> compressible +> gas-constant 287. +> gamma 1.4 +> viscosity 5.8e-2 +> prandtl-number 0.7 + + + + + +> initialize +> temperature 300. +> u-velocity 1. +> pressure 1e5 + + + + + +> boundary-conditions +> surface 1 +> subsonic-inflow +> velocity 15. +> temperature 315. +> surface 2 +> subsonic-outflow +> pressure 1e5 +> surface 3 4 5 6 +> viscous-wall +> adiabatic + + + + + +> spatial-accuracy +> third + + + + + +> precondition +> inviscid on +> viscous on +> pressure 1e5 +> velocity 15. + + + + + +> run +> min-cfl +> max-vnn +> cfl 2.0 +> vnn 2.0 +> print-conv 5 +> print-rstrt 100 +> steps 1000 + + + + + +Running for 1000 steps ntmn = 1 + ntmx = 1000 + Number of interpolated points: 852 + + dunsout output at step 100 + + Error reading in dunsout.v variables. Using defaults. + + dunsout output at step 200 + + + dunsout output at step 300 + + + dunsout output at step 400 + + + dunsout output at step 500 + + + dunsout output at step 600 + + + dunsout output at step 700 + + + dunsout output at step 800 + + + dunsout output at step 900 + + + dunsout output at step 1000 + + +cpu time for solution: 61.9410 sec + +cpu time/iteration/point: 1.376100 microsec + timestep: 0.067301 microsec + righthand side: 0.886477 microsec + lefthand side: 0.380931 microsec + stiff solver: 0.000000 microsec + equation of state: 0.012568 microsec + boundary condition: 0.006360 microsec + + Timings: 1.376 0.6730E-01 0.8865 0.3809 0.000 0.1257E-01 0.6360E-02 + +> save-restart +> filename save + + + + + +> save-plotting +> filename save +> cell-centered 0 +> variables p1 u v w t + + + save output at step 1000 + +> quit +Exiting DUNS program with value 0. +``` + +## 3.性能测试 + +### 3.1.测试平台信息对比 + +| | arm信息 | x86信息 | +| -------- | --------------------------------------------- | --------------------------- | +| 操作系统 | openEuler 20.09 | openEuler 20.09 | +| 内核版本 | 4.19.90-2110.8.0.0119.oe1.aarch64 | 4.19.90-2003.4.0.0036.oe1.x86_64 | + +### 3.2.测试软件环境信息对比 + +| | arm信息 | x86信息 | +| ----- | ------------- | --------- | +| gcc | bisheng 2.1.0 | gcc 9.3.0 | +| bowtie2 | 2.4.5 | 2.4.5 | +| trinity | 2.14.0 | 2.14.0 | + +### 3.3.测试硬件性能信息对比 + +| | arm信息 | x86信息 | +| ------ | ----------- | ---------- | +| cpu | Kunpeng 920 | Intel(R) Xeon(R) Platinum 8255C CPU| +| 核心数 | 8 | 4 | +| 内存 | 16 GB | 8 GB | +| 磁盘io | 1.3 GB/s | 1.3 MB/s | +| 虚拟化 | KVM | KVM | + +### 3.4.各测试用例比对 + +| airfoil | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 0m29.587s | 0m20.158s | +| 用户时间 | 0m29.019s | 0m19.566 | + +| bfs | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 0m16.917s | 0m10.420s | +| 用户时间 | 0m16.397s | 0m9.901s | + +| cduct | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 1m18.574s | 0m56.856s | +| 用户时间 | 1m18.163s | 0m56.247s | + +| cylinder | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 4m40.808s | 3m32.234s | +| 用户时间 | 4m39.537s | 3m30.153s | + +| cylinder-ext | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 1m23.231s | 1m1.296s | +| 用户时间 | 1m22.873s | 1m0.593s | + +| rbcc | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 2m49.730s | 1m59.213s | +| 用户时间 | 2m48.522s | 1m58.397s | + +| shear | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 2m49.730s | 1m59.213s | +| 用户时间 | 2m48.522s | 1m58.397s | + +| swirl | arm | x86 | +| ----------- | ---------- | --------- | +| 实际CPU时间 | 0m17.004s | 0m10.356s | +| 用户时间 | 0m16.471s | 0m9.803s | \ No newline at end of file diff --git "a/doc/duns/\343\200\212\345\237\272\344\272\216openEuler\347\232\204duns\350\275\257\344\273\266\347\247\273\346\244\215\346\214\207\345\215\227\343\200\213.md" "b/doc/duns/\343\200\212\345\237\272\344\272\216openEuler\347\232\204duns\350\275\257\344\273\266\347\247\273\346\244\215\346\214\207\345\215\227\343\200\213.md" new file mode 100644 index 0000000000000000000000000000000000000000..1fe257b75ac30641cd7a816d28301e4e533565e0 --- /dev/null +++ "b/doc/duns/\343\200\212\345\237\272\344\272\216openEuler\347\232\204duns\350\275\257\344\273\266\347\247\273\346\244\215\346\214\207\345\215\227\343\200\213.md" @@ -0,0 +1,260 @@ +# 《基于openEuler的duns软件移植指南》 + +## 1.介绍 + +- DUNS(对角化上风Navier-Stokes)代码是带有q-ω湍流模型的2D / 3D,结构化,多块,多种类,React性,稳定/不稳定的Navier Stokes流体动力学代码。 + +- 官方地址(含源码及指导手册):https://duns.sourceforge.net/ + +- 下载地址:https://sourceforge.net/projects/duns/files/duns/duns-2.7.1/duns-2.7.1-src.tar.bz2/download + +## 2.环境要求 + +- 操作系统:openeuler arm/x86 (本文档以 x86 架构为例) + +## 3.配置编译环境 + +配置环境指导,手动进行配置依赖环境。 + +### 3.1.环境总览 + +- 编译器:gcc + +- 其他类库:`Cmake` + +- 具体版本和下载地址如下 + +| 名称 | 版本 | 软件下载地址 | +| -------- | ------ | -------------------------------------------------------- | +| gcc | 9.3.0 | | +| gfortran | 9.3.0 | | + +### 3.2.创建文件夹 + +```bash +mkdir -p $HOME/build +mkdir -p $HOME/install +mkdir -p $HOME/tmp +``` + +### 3.3.安装预设 + +设置环境变量,方便修改自定义安装目录 + +- 编译目录为 $HOME/build , 根据实际情况进行修改 +- 软件安装目录为 $HOME/install , 根据实际情况进行修改 +- 下载目录为 $HOME/tmp , 根据实际情况进行修改 + +```bash +#为了方便自定义软件安装目录 +#环境变量DEP_INSTALL_DIR将在后文中作为软件安装目录的根目录 +export DEP_INSTALL_DIR=$HOME/install +#环境变量DEP_BUILD_DIR将在后文中作为编译的根目录 +export DEP_BUILD_DIR=$HOME/build +#环境变量DEP_DOWNLOAD_DIR将在后文中作为下载文件的保存目录 +export DEP_DOWNLOAD_DIR=$HOME/tmp + +#注: 以上变量只在一次会话中有效。如果中途断开ssh会话,则在后续的安装过程中不会生效,需要重新运行 +``` + +### 3.4.安装环境依赖和gcc编译器 + +```bash +#环境依赖 +yum -y install gcc gcc-c++ wget tar libatomic + +#安装gcc编译器 +wget -P $DEP_DOWNLOAD_DIR https://ftp.gnu.org/gnu/gcc/gcc-9.3.0/gcc-9.3.0.tar.gz +tar -xf $DEP_DOWNLOAD_DIR/gcc-9.3.0.tar.gz -C $DEP_INSTALL_DIR +sed -i "35s/ftp/http/g" ./contrib/download_prerequisites +./contrib/download_prerequisites +./configure --disable-multilib --enable-languages="c,c++,fortran" --prefix=$1 --disable-static --enable-shared +make -j && make install +#设置环境变量 +echo "export PATH=$DEP_INSTALL_DIR/gcc-9.3.0/bin:$PATH" >> ~/.bashrc && source ~/.bashrc +export CC=`which gcc` +export CXX=`which g++` +``` + +## 4.编译duns + +### 4.1.下载并编译duns + +获取duns软件源码并解压文件 +```bash +# 下载源码文件 +wget https://sourceforge.net/projects/duns/files/duns/duns-2.7.1/duns-2.7.1-src.tar.bz2 +tar -xjf duns-2.7.1-src.tar.bz2 -C $DEP_BUILD_DIR +cd $DEP_BUILD_DIR/duns-2.7.1 +export DUNSARCH=linux +export DUNSPATH27=`pwd` +export PATH=$DUNSPATH27/util:$PATH +sed -i '10s/g77/gfortran/' makesystem/Makesystem_linux +sed -i "28s#.*#SYSLIBS = -L${JARVIS_COMPILER}/gcc/9.3.0/lib64 -Wl,-Bdynamic -lgcc_s -lm -lgfortran#" makesystem/Makesystem_linux +sed -i '29s#.*#GRAFLIBS = -lmbgrafic -lgrafic -L/usr/lib -Wl,-Bdynamic -lX11#' makesystem/Makesystem_linux +sed -i 's/getline/getline1/g' `grep getline -rl --include="*" src/*` +cd lib +make && make install +cd .. +dunssource 3d all # 这里根据自己的需要构建程序 +cd duns-3d-all +line=`expr $(grep -n -m 1 "^c .*" assemble.f |awk -F: '{print $1}') - 1` +sed -i "1,${line}d" *.f *.c include/* +make -j +``` + +### 4.2. 运行测试文件 + +运行duns项目测试文件 + +```bash +cd $DEP_BUILD_DIR/duns-2.7.1 +wget https://sourceforge.net/projects/duns/files/duns/duns-2.7.1/duns-2.7.1-test.tar.bz2 +tar -xjf duns-2.7.1-test.tar.bz2 +cd test/serial/cduct +sed -i "/cd duns.*/a\ sed -i '1,42d' *.f include/*" testscript +./testscript run +``` + +## 附A:使用hpcrunner进行一键安装DUNS + +推荐使用hpcrunner进行安装DUNS + +### 1.克隆仓库 + +```bash +git clone https://gitee.com/openeuler/hpcrunner.git +``` + +## 2.初始化hpcrunner 和 安装必要软件包 + +初始化项目助手 + +```bash +cd hpcrunner +source init.sh +``` + +安装必要软件包 + +**arm / x86 需要的软件包不同,根据实际环境进行选择** + +```bash +# arm +yum install -y environment-odules git wget unzip make flex tar +# x86 +yum install -y environment-modules git wget unzip make flex tar +yum install -y gcc gcc-c++ gcc-gfortran glibc-devel libgfortran +yum install -y tcsh tcl lsof tk bc +``` + +### 3.选择平台对应配置文件 + +- arm平台的配置文件为 `templates/duns/2.7.1/data.duns.arm.cpu.config` + + ```bash + ./jarvis -use templates/duns/2.7.1/data.duns.arm.cpu.config + ``` + +- x86 平台的配置文件为 `templates/duns/2.7.1/data.duns.x86.cpu.config` + + ```bash + ./jarvis -use templates/duns/2.7.1/data.duns.x86.cpu.config + ``` + +### 4.下载duns源码 + +```bash +./jarvis -d +``` + +### 5.一键配置依赖环境 + +```bash +./jarvis -dp +``` + +### 6.一键进行编译 + +```bash +./jarvis -b +``` + +### 7.一键进行运行测试 + +```bash +./jarvis -r +``` + +## 附B:使用singularity运行容器 + +### 使用教程 + +### 下载容器镜像 + +通过链接下载: +[百度云盘](https://pan.baidu.com/s/1OVQQoe_U8qMMW9tXJ9UJig ) +提取码: 2514 + +或者扫码下载: + +![百度云]() + +#### 1.安装singularity + +安装singularity, + +具体步骤如下 + +```bash +mkdir -p ~/install +mkdir -p ~/build + +#安装编译所需依赖 +yum -y install libatomic libstdc++ libstdc++-devel libseccomp-devel glib2-devel gcc squashfs-tools tar + +#安装bisheng编译器 +cd ~/build +wget https://mirrors.huaweicloud.com/kunpeng/archive/compiler/bisheng_compiler/bisheng-compiler-2.1.0-aarch64-linux.tar.gz +tar -C ~/install -xf bisheng-compiler-2.1.0-aarch64-linux.tar.gz +echo "export PATH=$HOME/install/bisheng-compiler-2.1.0-aarch64-linux/bin:$PATH" >> ~/.bashrc && source ~/.bashrc +export CC=`which clang` +export CXX=`which clang++` + +#安装go编译器 +cd ~/build +wget https://go.dev/dl/go1.19.linux-arm64.tar.gz +tar -C ~/install -xf go1.19.linux-arm64.tar.gz +echo "export PATH=$HOME/install/go/bin:$PATH" >> ~/.bashrc && source ~/.bashrc + +#安装singularity +cd ~/build +wget https://github.com/sylabs/singularity/releases/download/v3.10.2/singularity-ce-3.10.2.tar.gz +tar -xf singularity-ce-3.10.2.tar.gz +cd singularity-ce-3.10.2 +./mconfig --prefix=$HOME/install/singularity +make -C ./builddir +make -C ./builddir install +echo "export PATH=$HOME/install/singularity/bin:$PATH" >> ~/.bashrc && source ~/.bashrc +``` + +#### 2.构建镜像 + +```shell +# x86 +singularity build ./name-of-image.sif openeuler-gcc-9.3.0-duns-2.7.1.def +# arm +singularity build ./name-of-image.sif openeuler-bisheng2-9.3.1-duns-2.7.1.def +# 转换为沙盒 +singularity build --sandbox image-sandbox name-of-image.sif +``` + +#### 3.在沙盒中运行 + +```shell +#进入沙盒 +singularity shell -w image-sandbox +#在沙盒中运行内置的测试案例 +cd /hpcrunner +./jarvis -r +``` \ No newline at end of file diff --git a/templates/duns/2.7.1/data.duns.arm.cpu.config b/templates/duns/2.7.1/data.duns.arm.cpu.config new file mode 100644 index 0000000000000000000000000000000000000000..ddc3e3a16747337fa9f9f54d3067e1eff2121936 --- /dev/null +++ b/templates/duns/2.7.1/data.duns.arm.cpu.config @@ -0,0 +1,56 @@ +[SERVER] +11.11.11.11 + +[DOWNLOAD] +duns/2.7.1 https://sourceforge.net/projects/duns/files/duns/duns-2.7.1/duns-2.7.1-src.tar.bz2 + +[DEPENDENCY] +set -e +set -x +./jarvis -install bisheng/2.1.0 com +module purge +module use ./software/modulefiles +module load bisheng2/2.1.0 +cd ${JARVIS_TMP} +tar -xvf ${JARVIS_DOWNLOAD}/duns-2.7.1-src.tar.bz2 -C ${JARVIS_TMP} +. ${DOWNLOAD_TOOL} -u https://sourceforge.net/projects/duns/files/duns/duns-2.7.1/duns-2.7.1-test.tar.bz2 +tar -xvf ${JARVIS_DOWNLOAD}/duns-2.7.1-test.tar.bz2 -C ${JARVIS_TMP} +cd ${JARVIS_TMP}/duns-2.7.1 +sed -i '10s/g77/flang/' makesystem/Makesystem_linux +sed -i '11s/gcc/clang/' makesystem/Makesystem_linux +sed -i '12s/g++/clang++/' makesystem/Makesystem_linux +sed -i '13s/gcc/clang/' makesystem/Makesystem_linux +sed -i '14s/gcc/clang/' makesystem/Makesystem_linux +sed -i "28s#.*#SYSLIBS = -L${JARVIS_COMPILER}/bisheng/2.1.0/lib -Wl,-Bdynamic -lgcc_s -lm -lflang -lpgmath#" makesystem/Makesystem_linux +sed -i '29s#.*#GRAFLIBS = -lmbgrafic -lgrafic -L/lib64 -Wl,-Bdynamic -lX11 -lflang#' makesystem/Makesystem_linux + +sed -i '339s/help()/help(0)/' src/main.cpp +sed -i '345s/help()/help(0)/' src/main.cpp +sed -i '349s/help()/help(0)/' src/main.cpp +sed -i 's/getline/getline1/g' `grep getline -rl --include="*" ./` + +[ENV] +module use ./software/modulefiles +module load bisheng2/2.1.0 +export DUNSARCH=linux +export DUNSPATH27=${JARVIS_TMP}/duns-2.7.1 +export PATH=$DUNSPATH27/util:$PATH + +[APP] +app_name = duns +build_dir = ${JARVIS_TMP}/duns-2.7.1 +binary_dir = +case_dir = ${JARVIS_TMP}/duns-2.7.1/test/serial/cduct + +[BUILD] +cd lib; make && make install +cd ..; dunssource 3d all +cd duns-3d-all +make +mkdir -p ${JARVIS_LIBS}/bisheng2/duns/2.7.1/bin +cp duns.e dunsplot.e ${JARVIS_LIBS}/bisheng2/duns/2.7.1/bin + +[RUN] +run = ./testscript run +binary = +nodes = 1 \ No newline at end of file diff --git a/templates/duns/2.7.1/data.duns.x86.cpu.config b/templates/duns/2.7.1/data.duns.x86.cpu.config new file mode 100644 index 0000000000000000000000000000000000000000..be330056069899f938975801382f5f0d16c82797 --- /dev/null +++ b/templates/duns/2.7.1/data.duns.x86.cpu.config @@ -0,0 +1,50 @@ +[SERVER] +11.11.11.11 + +[DOWNLOAD] +duns/2.7.1 https://sourceforge.net/projects/duns/files/duns/duns-2.7.1/duns-2.7.1-src.tar.bz2 + +[DEPENDENCY] +set -e +set -x +./jarvis -install gcc/9.3.0 com +module purge +module use ./software/modulefiles +module load gcc9/9.3.0 +cd ${JARVIS_TMP} +tar -xvf ${JARVIS_DOWNLOAD}/duns-2.7.1-src.tar.bz2 -C ${JARVIS_TMP} +. ${DOWNLOAD_TOOL} -u https://sourceforge.net/projects/duns/files/duns/duns-2.7.1/duns-2.7.1-test.tar.bz2 +tar -xvf ${JARVIS_DOWNLOAD}/duns-2.7.1-test.tar.bz2 -C ${JARVIS_TMP} +cd ${JARVIS_TMP}/duns-2.7.1 +sed -i '10s/g77/gfortran/' makesystem/Makesystem_linux +sed -i "28s#.*#SYSLIBS = -L${JARVIS_COMPILER}/gcc/9.3.0/lib64 -Wl,-Bdynamic -lgcc_s -lm -lgfortran#" makesystem/Makesystem_linux +sed -i '29s#.*#GRAFLIBS = -lmbgrafic -lgrafic -L/usr/lib -Wl,-Bdynamic -lX11#' makesystem/Makesystem_linux +sed -i 's/getline/getline1/g' `grep getline -rl --include="*" src/*` + +[ENV] +module use ./software/modulefiles +module load gcc9/9.3.0 +export DUNSARCH=linux +export DUNSPATH27=${JARVIS_TMP}/duns-2.7.1 +export PATH=$DUNSPATH27/util:$PATH + +[APP] +app_name = duns +build_dir = ${JARVIS_TMP}/duns-2.7.1 +binary_dir = +case_dir = ${JARVIS_TMP}/duns-2.7.1/test/serial/cduct + +[BUILD] +cd lib; make && make install +cd ..; dunssource 3d all +cd duns-3d-all +line=`expr $(grep -n -m 1 "^c .*" assemble.f |awk -F: '{print $1}') - 1` +sed -i "1,${line}d" *.f *.c include/* +make -j +mkdir -p ${JARVIS_LIBS}/bisheng2/duns/2.7.1/bin +cp duns.e dunsplot.e ${JARVIS_LIBS}/bisheng2/duns/2.7.1/bin + +[RUN] +run = sed -i "/cd duns.*/a\ sed -i '1,42d' *.f include/*" testscript && ./testscript run +binary = +nodes = 1 \ No newline at end of file diff --git a/test/test-duns.sh b/test/test-duns.sh new file mode 100644 index 0000000000000000000000000000000000000000..5e27a853296836e7330bcee1801a2d82bf000dd9 --- /dev/null +++ b/test/test-duns.sh @@ -0,0 +1,16 @@ +#!/bin/bash +cd .. +# release duns src code +rm -rf tmp/duns-2.7.1 +# copy templates +cp -rf templates/duns/2.7.1/data.duns.x86.cpu.config ./ +# switch to config +./jarvis -use data.duns.x86.cpu.config +# download duns src code +./jarvis -d +# install dependency +./jarvis -dp +# build +./jarvis -b +# run +./jarvis -r \ No newline at end of file