編集不可のページ History 添付ファイル

 

ページ名: "HowToCompile"の差分
12と26のリビジョン間の差分 (その間の編集: 14回)
2021-09-25 08:23:34時点のリビジョン12
サイズ: 3431
編集者: yi041
コメント:
2025-06-09 02:58:08時点のリビジョン26
サイズ: 5238
編集者: yi041
コメント:
削除された箇所はこのように表示されます。 追加された箇所はこのように表示されます。
行 3: 行 3:
C/C++ で記述された計算プログラムをコンパイルするには,以下のコマンドを実行して下さい. C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
行 5: 行 5:
$ icc ソースファイル名 -o 出力するプログラム名 $ icx ソースファイル名 -o 出力するプログラム名
行 8: 行 8:
Fortran で記述された計算プログラムをコンパイルするには,以下のコマンドを実行してさい. C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行してください.
行 10: 行 10:
$ ifort ソースファイル名 -o 出力するプログラム名 $ icpx ソースファイル名 -o 出力するプログラム名
}}}

Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ ifx ソースファイル名 -o 出力するプログラム名
行 14: 行 19:
C/C++ で記述された計算プログラムをコンパイルするには,以下のコマンドを実行して下さい. C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
行 19: 行 24:
Fortran で記述された計算プログラムをコンパイルするには,以下のコマンドを実行して下さい. C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ g++ ソースファイル名 -o 出力するプログラム名
}}}

Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
行 24: 行 34:
== Intel MPI ==
C/C++ で記述された計算プログラムをコンパイルするには,以下のコマンドを実行して下さい.
== AMD コンパイラ (AOCC) ==
C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
行 27: 行 37:
$ mpiicc ソースファイル名 -o 出力するプログラム名 $ clang ソースファイル名 -o 出力するプログラム名
行 30: 行 40:
Fortran で記述された計算プログラムをコンパイルするには,以下のコマンドを実行して下さい. C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
行 32: 行 42:
$ mpiifort ソースファイル名 -o 出力するプログラム名 $ clang++ ソースファイル名 -o 出力するプログラム名
行 35: 行 45:
(例)<<BR>>Fortran で記述された計算プログラムをバッチジョブとしてコンパイルする場合の実行スクリプト Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
行 37: 行 47:
#!/bin/bash
#PBS -q gSrchq
#PBS -o out.intelmpi
#PBS -j oe
#PBS -l select=2:ncpus=2
#PBS -l walltime=1:00:00
#PBS -v DOCKER_IMAGE=prg-env:2019.10.02,DOCKER_OPTIONS="--network=overlaynw"
#PBS -N impitest
$ flang ソースファイル名 -o 出力するプログラム名
}}}
行 46: 行 50:
source /etc/profile
module load intel
module load intelmpi.intel
== Intel MPI (Intel コンパイラとの組み合わせ) ==
C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ mpiicc -cc=icx ソースファイル名 -o 出力するプログラム名
}}}
行 50: 行 56:
cd ${PBS_O_WORKDIR} C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ mpiicpc -cxx=icpx ソースファイル名 -o 出力するプログラム名
}}}
Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.
行 52: 行 62:
prog=mpi-ping-intelmpi.x
mpiicc mpi-ping.c -o $prog
mpirun -np 2 -ppn 1 -hostfile ${PBS_NODEFILE} hostname
mpirun -np 2 -ppn 1 -hostfile ${PBS_NODEFILE} ./$prog -B -r 1 1m
{{{
$ mpiifort -fc=ifx ソースファイル名 -o 出力するプログラム名
行 57: 行 65:
* ジョブの投入方法は,[[https://hpcportal.imc.tut.ac.jp/wiki/HowToSubmitJob |ジョブの実行]] を参照して下さい.
行 60: 行 67:
C/C++ で記述された計算プログラムをコンパイルするには,以下のコマンドを実行して下さい. Open MPIを使用する場合は,コンパイラのコマンドを環境変数で指定します.ここではGNUコンパイラの場合を示します.
C言語で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.
行 62: 行 70:
$ export OMPI_CC=gcc
行 65: 行 74:
Fortran で記述された計算プログラムをコンパイルするには,以下のコマンドを実行して下さい. C++ で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.
行 67: 行 76:
$ export OMPI_CXX=g++
$ mpicxx ソースファイル名 -o 出力するプログラム名
}}}

Fortran で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ export OMPI_FC=gfortran
行 69: 行 85:
行 71: 行 86:
$ export OMPI_F77=gfortran
行 74: 行 90:

(例)<<BR>>Fortran で記述された計算プログラムをバッチジョブとしてコンパイルする場合の実行スクリプト
== ROCm環境のコンパイル ==
計算サーバのAMD GPUを利用するためのコンパイルコマンドです.
事前にインタラクティブジョブにより計算サーバに移動してください.
行 78: 行 94:
#!/bin/bash
#PBS -q gSrchq
#PBS -o out.openmpi
#PBS -j oe
#PBS -l select=2:ncpus=2
#PBS -l walltime=1:00:00
#PBS -v DOCKER_IMAGE=prg-env:2019.10.02,DOCKER_OPTIONS="--network=overlaynw"
#PBS -N impitest

source /etc/profile
module load intel
module load openmpi.intel-4.0.1

cd ${PBS_O_WORKDIR}

prog=mpi-ping-openmpi.x
mpicc mpi-ping.c -o $prog
mpirun -np 2 -N 1 -hostfile ${PBS_NODEFILE} hostname
mpirun -np 2 -N 1 -hostfile ${PBS_NODEFILE} ./$prog -B -r 1 1m
$ qsub -I -q Eduq -l select=1:ncpus=1:ngpus=1 -v SINGULARITY_IMAGE=/common/Singularity_sif/prg_env_amd_2025.01.sif
行 99: 行 97:
* ジョブの投入方法は,[[https://hpcportal.imc.tut.ac.jp/wiki/HowToSubmitJob |ジョブの実行]] を参照して下さい. C言語もしくはC++で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ hipcc -I/opt/rocm/include -D__HIP_PLATFORM_AMD__ ソースファイル名 -o 出力するプログラム名
}}}

== NVIDIA HPCコンパイラ ==
IoT・AI基盤システムのNVIDIA GPUを利用するためのコンパイルコマンドです.
事前にインタラクティブジョブによりIoT・AI基盤システムの計算サーバに移動してください.
{{{
$ qsub -I -q iEduq -l select=1:ncpus=1:ngpus=1 -v SINGULARITY_IMAGE=/common/Singularity_sif/prg_env_intel_2025.01.sif
}}}

C言語で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ nvcc -ccbin gcc -I/usr/include ソースファイル名 -o 出力するプログラム名
}}}

Fortranで記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.
{{{
$ nvfortran -I/usr/include ソースファイル名 -o 出力するプログラム名
}}}

* ジョブの投入方法は,[[https://hpcportal.imc.tut.ac.jp/wiki/HowToSubmitJob|ジョブの実行]] を参照して下さい.

プログラムのコンパイル

Intel コンパイラ

C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ icx ソースファイル名 -o 出力するプログラム名

C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行してください.

$ icpx ソースファイル名 -o 出力するプログラム名

Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ ifx ソースファイル名 -o 出力するプログラム名

GNU コンパイラ

C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ gcc ソースファイル名 -o 出力するプログラム名

C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ g++ ソースファイル名 -o 出力するプログラム名

Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ gfortran ソースファイル名 -o 出力するプログラム名

AMD コンパイラ (AOCC)

C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ clang ソースファイル名 -o 出力するプログラム名

C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ clang++ ソースファイル名 -o 出力するプログラム名

Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ flang ソースファイル名 -o 出力するプログラム名

Intel MPI (Intel コンパイラとの組み合わせ)

C言語で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ mpiicc -cc=icx ソースファイル名 -o 出力するプログラム名

C++ で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ mpiicpc -cxx=icpx ソースファイル名 -o 出力するプログラム名

Fortran で記述されたソースコードをコンパイルするには,以下のコマンドを実行して下さい.

$ mpiifort -fc=ifx ソースファイル名 -o 出力するプログラム名

Open MPI

Open MPIを使用する場合は,コンパイラのコマンドを環境変数で指定します.ここではGNUコンパイラの場合を示します. C言語で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.

$ export OMPI_CC=gcc
$ mpicc ソースファイル名 -o 出力するプログラム名

C++ で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.

$ export OMPI_CXX=g++
$ mpicxx ソースファイル名 -o 出力するプログラム名

Fortran で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.

$ export OMPI_FC=gfortran
$ mpif90 ソースファイル名 -o 出力するプログラム名

$ export OMPI_F77=gfortran
$ mpif77 ソースファイル名 -o 出力するプログラム名

ROCm環境のコンパイル

計算サーバのAMD GPUを利用するためのコンパイルコマンドです. 事前にインタラクティブジョブにより計算サーバに移動してください.

$ qsub -I -q Eduq -l select=1:ncpus=1:ngpus=1 -v SINGULARITY_IMAGE=/common/Singularity_sif/prg_env_amd_2025.01.sif

C言語もしくはC++で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.

$ hipcc -I/opt/rocm/include -D__HIP_PLATFORM_AMD__ ソースファイル名 -o 出力するプログラム名

NVIDIA HPCコンパイラ

IoT・AI基盤システムのNVIDIA GPUを利用するためのコンパイルコマンドです. 事前にインタラクティブジョブによりIoT・AI基盤システムの計算サーバに移動してください.

$ qsub -I -q iEduq -l select=1:ncpus=1:ngpus=1 -v SINGULARITY_IMAGE=/common/Singularity_sif/prg_env_intel_2025.01.sif

C言語で記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.

$ nvcc -ccbin gcc -I/usr/include ソースファイル名 -o 出力するプログラム名

Fortranで記述されたプログラムをコンパイルするには,以下のコマンドを実行して下さい.

$ nvfortran -I/usr/include ソースファイル名 -o 出力するプログラム名

* ジョブの投入方法は,ジョブの実行 を参照して下さい.