DFTB+: Perbedaan antara revisi

Dari ALELEON by EFISON
(parapharsing di penjelasan MPI/OMP)
(overhaul DFTB+)
Baris 27: Baris 27:
|V
|V
|}
|}
== '''File Input DFTB+''' ==
Perlu diperhatikan bahwa user harus membuat file input DFTB+ dengan nama dan format '''dftb_in.hsd''' dan file input ini harus ditaruh pada satu direktori dengan SLURM Submit Script.
== '''Slater-Koster Files''' ==
File input dftb_in.hsd membutuhkan file Slater-Koster (SK) pada bagian Hamiltonian. User dapat mengunduh file SK dari web resmi DFTB+ pada tautan berikut:
* [https://dftb.org/parameters/download '''Halaman utama Download File SK''']
* [https://dftb.org/parameters/download/all-sk-files '''File SK dalam satu archive''']
Pastikan file input user pada bagian Hamiltonian menunjuk direktori file SK yang tepat sesuai direktori tempat user menyimpan file SK tersebut.


== '''Pilihan MPI atau Threading OpenMP pada DFTB+ versi CPU''' ==
== '''Pilihan MPI atau Threading OpenMP pada DFTB+ versi CPU''' ==
DFTB+ secara default berjalan dengan paralelisasi OpenMP (OMP). Sementara itu DFTB+ pada ALELEON Supercomputer dicompile dengan MPI sehingga dapat berjalan dengan paralelisasi hybrid MPI/OMP. ALELEON Supercomputer menyerahkan keputusan kepada user untuk memilih metode paralelisasi tersebut melalui konfigurasi pada [[Submit Script ALELEON Supercomputer|'''SLURM Submit Script''']]:
DFTB+ secara default berjalan dengan paralelisasi OpenMP (OMP). Sementara itu DFTB+ pada ALELEON Supercomputer dicompile dengan MPI sehingga dapat berjalan dengan paralelisasi hybrid MPI/OMP. ALELEON Supercomputer menyerahkan keputusan kepada user untuk memilih metode paralelisasi tersebut melalui konfigurasi pada SLURM Submit Script ''(lihat subbab Menjalankan DFTB+ di Compute Node)'':
* SBATCH ntasks mewakili jumlah task MPI sedangkan SBATCH cpus-per-task mewakili jumlah thread OMP.
* SBATCH ntasks mewakili jumlah task MPI sedangkan SBATCH cpus-per-task mewakili jumlah thread OMP.


Baris 64: Baris 53:
  '''#SBATCH --cpus-per-task='''''<isi-sesuai-keinginan>''
  '''#SBATCH --cpus-per-task='''''<isi-sesuai-keinginan>''


== '''Menjalankan DFTB+''' ==
== '''Menjalankan DFTB+ di Compute Node''' ==
User dapat menjalankan DFTB+ dengan pilihan cara menjalankan komputasi:
User dapat menjalankan komputasi dengan pilihan cara melalui tampilan terminal atau GUI web EFIRO.
===Mengecek Kredit Core Hour bagi Akun Perseorangan===
User dengan akun perseorangan disarankan untuk selalu mengecek sisa Kredit Core Hour sebelum melakukan job submission dengan menjalankan perintah pada terminal:
$ '''sausage'''
Bagi yang login ke web EFIRO, buka terminal pada menu '''<code>Clusters</code> > <code>Aleleon Shell Access</code>'''
===Terminal - SLURM sbatch===
[[Berkas:Sbatch Terminal.png|nirbing|500x500px]]


===[[Menggunakan ALELEON Supercomputer via EFIRO#3A%20-%20Menjalankan%20Komputasi%20ke%20Compute%20Node%20via%20Job%20Composer|EFIRO Job Composer]]===
Menjalankan komputasi pada terminal melalui job submission SLURM sbatch.
Menjalankan komputasi dengan tampilan grafis pada formulir job submission EFIRO Job Composer. Berikut adalah pilihan template DFTB+ yang tersedia:
{| class="wikitable mw-collapsible mw-collapsed"
{| class="wikitable"
! colspan="2" |Langkah Menjalankan CP2K via SLURM sbatch
!Nama Template
|-
!Penjelasan
| rowspan="2" |'''0'''
|Sebelum login, [[Koneksi VPN ALELEON Supercomputer|'''user harus terhubung ke jaringan VPN ALELEON Supercomputer''']].
|-
|Login dengan SSH:
*User OS Windows dan MacOS -> <code>'''$ ssh <''username''>@aleleon.hpc'''</code>
*User OS Linux -> <code>'''$ ssh <''username''>@10.192.50.10'''</code> 
|-
|'''1'''
|Siapkan file yang dibutuhkan untuk menjalankan komputasi user.
*[[Upload File dengan Aplikasi FTP|'''User dapat melakukan upload / download file dengan bantuan aplikasi FTP''']]
*Untuk kerapian data, disarankan untuk menaruh satu job pada satu folder tersendiri.  
|-
|'''2'''
|
==== File Input dftb_in.hsd ====
Buat / upload file input DFTB+ dengan nama dan format '''dftb_in.hsd.'''
* File input ini harus ditaruh pada satu direktori dengan SLURM Submit Script ''(langkah 4).''
|-
|-
|DFTB+ 22.2 (CPU)
|'''3A'''
|Menjalankan DFTB+ 22.2 versi CPU
|
|}
==== File Slaster-Koster (SK) ====
Setelah membuat ruang job, user dapat mengupload atau membuat file input dftb_in.hsd melalui menu '''Edit Files''' ''(lihat langkah tutorial Job Composer no 4).''
File input DFTB+ membutuhkan file '''Slater-Koster (SK)''' pada bagian Hamiltonian yang bisa didapatkan pada:
 
* [https://dftb.org/parameters/download '''Halaman utama Download File SK''']
===[[Menggunakan ALELEON Supercomputer via Terminal#3%20-%20Menjalankan%20Komputasi%20ke%20Compute%20Node%20via%20SLURM|SLURM sbatch via Terminal]]===
* [https://dftb.org/parameters/download/all-sk-files '''File SK dalam satu archive''']
Menjalankan komputasi pada terminal melalui job submission SLURM sbatch dengan ketentuan:
 
* User wajib menaruh file input DFTB+ dftb_in.hsd pada satu direktori dengan SLURM Submit Script yang akan dibuat.
* Berikut adalah contoh referensi Submit Script untuk menjalankan DFTB+:


File dalam format .tar sehingga perlu di ekstrak.
|-
|'''3B'''
|Admin menyarankan menaruh / upload folder SK pada direktori HOME supaya dapat diakses oleh banyak job.
'''$HOME'''''/<folder-file-SK-yang-dibutuhkan>''
Pastikan file input pada bagian Hamiltonian menunjuk direktori file SK spesifik pada HOME tersebut.
|-
|'''4'''
|
==== Menjalankan DFTB+ ====
Buat '''SLURM Submit Script''' yaitu 'formulir' untuk menjalankan job dengan panduan berikut:
* Nama script dibebaskan dengan format file .sh (bash), contoh ''<code>my_job_submission.sh</code>''
*Buat script pada direktori yang sama dengan file komputasi yang akan dijalankan.
*Ikuti panduan template berikut dan petunjuk pada NOTES di dalamnya.
{| class="wikitable"
{| class="wikitable"
!Contoh SLURM Submit Script DFTB+
! colspan="4" |Panduan nilai maks SBATCH untuk DFTB+''<sup>1</sup>''
|-
!Parameter SBATCH
!Fair policy usage''<sup>2</sup>''
!Multi-node MPI<sup>''3''</sup>
!High-mem node
epyc001'''<sup>''4''</sup>'''
|-
|ntasks (CPU) * cpus-per-task (OMP)
|128
|384
|128
|-
| mem (RAM)
|128GB
|240GB
|500GB
|-
|time (time limit)
| colspan="3" |3-00:00:00 atau 72:00:00
|-
| gpus (GPU)
|2
|0
|0
|}'''Note:'''
#Info SBATCH lebih detail lihat laman [[Submit Script ALELEON Supercomputer|'''Submit Script ALELEON Supercomputer''']]
#Limitasi fair policy usage untuk menjaga kualitas layanan ALELEON Supercomputer.
#*User dapat mengajukan permintaan membuka limitasi apabila job membutuhkan alokasi lebih.
#*Info lebih detail lihat laman [[Limitasi Fair Usage ALELEON Supercomputer|'''Limitasi Fair Usage ALELEON Supercomputer''']]
#DFTB+ mendukung komputasi paralel MPI untuk berjalan ''multi-node'' lebih dari 128 core thread.
#*Info lebih detail lihat laman [[MPI ALELEON Supercomputer|'''MPI ALELEON Supercomputer''']].
#User dapat menggunakan memori RAM hingga '''500GB''' pada node epyc001 saja.
#*Tambahkan parameter <code>'''#SBATCH --nodelist=epyc001'''</code>
{| class="wikitable mw-collapsible mw-collapsed"
!Template SLURM Submit Script DFTB+
|-
|-
|
|
  #!/bin/bash
  #!/bin/bash
   
   
  # ------------------------------------------------------------------------
  # -------------------------------------------------------------
  # | Template SLURM Submit Script
  # | Template SLURM Submit Script
  # | Software        : DFTB+
  # | Software        : DFTB+
# | Versi          : tergantung input user
  # | Update script  r: 06/10/2023
  # | Update script  r: 11/04/2023
  # |
  # |
  # | NOTES:  
  # | NOTES:  
  # | 1. Isi bagian yang ditandai 4 garing (////).
  # | 1. Isi bagian yang ditandai 4 garing (////).
  # | 2. Template ini adalah referensi - user dapat mengubah bagian yang
  # | 2. Template ini bersifat referensi.
  # |    sekiranya perlu diubah.
  # |    User dapat mengubah bagian yang sekiranya perlu diubah.
  # | 3. Panduan mengisi alokasi komputasi (SBATCH) menurut spesifikasi
  # | 3. Panduan menjalankan CP2K di ALELEON lihat:  
# |    ALELEON Supercomputer lihat:  
  # |    wiki.efisonlt.com/wiki/DFTB%2B
  # |    <nowiki>https://wiki.efisonlt.com/wiki/Submit_Script_ALELEON_Supercomputer</nowiki>
  # -------------------------------------------------------------
  # ------------------------------------------------------------------------
   
   
  # --------------------------------------------------
  # --------------------------------------------------
  # Alokasi komputasi, modul software, dan file input
  # Alokasi komputasi, modul software, dan file input
  # --------------------------------------------------
  # --------------------------------------------------
# Alokasi jumlah compute node
#SBATCH --nodes=////
   
   
  # Alokasi jumlah core thread CPU. mewakili jumlah task MPI
  # Alokasi jumlah core thread CPU. mewakili jumlah task MPI
Baris 121: Baris 172:
  #SBATCH --mem=////GB
  #SBATCH --mem=////GB
   
   
  # Alokasi limit waktu menjalankan job, format HH:MM:SS atau D-HH:MM:SS  
  # Alokasi limit waktu menjalankan job.
# Format HH:MM:SS atau D-HH:MM:SS  
  #SBATCH --time=////
  #SBATCH --time=////
   
   
Baris 130: Baris 182:
  #SBATCH --error=error-%j.txt  
  #SBATCH --error=error-%j.txt  
   
   
  # Memuat modul software DFTB+, pilih nama modul pada tabel dibawah ini
  # Memuat modul software DFTB+
# Daftar modul DFTB+ lihat subbab "Modul DFTB+" pada
# wiki.efisonlt.com/wiki/DFTB%2B
  module load dftbplus////
  module load dftbplus////
# DAFTAR MODUL DFTB+:
# -----------------------------------------------------
# | Nama modul                          | Versi DFTB+ |
# -----------------------------------------------------
# | dftbplus/22.2-GCC11.3-AOCL4.0      | 22.2 (CPU)  |
# -----------------------------------------------------
   
   
  # -------------------------------------------------
  # -------------------------------------------------
Baris 150: Baris 197:
  mpirun -np $SLURM_NTASKS dftb+
  mpirun -np $SLURM_NTASKS dftb+
|}
|}
=='''Notifikasi Status Jalannya Job Submission via email'''==
|-
SLURM ALELEON Supercomputer dapat mengirim notifikasi email kepada user '''untuk mengabarkan apabila job user sudah berjalan atau selesai'''. SLURM ALELEON Supercomputer menggunakan nama email '''Jojo''' untuk mengirim notifikasi email.
|'''5'''
|Jalankan job dengan perintah sbatch.
$ '''sbatch''' '''''<nama-SLURM-Submit-script>'''''
Contoh menjalankan nama script <code>my_job_submission.sh</code>.
$ sbatch my_job_submission.sh
|-
|'''6A'''
|User dapat melihat status jalannya job dengan perintah squeue berikut.
*Apabila tidak ada output artinya tidak ada job user yang berjalan / antri pada waktu itu.
$ '''squeue -ul $USER'''
Berikut adalah daftar STATE (ST) dari squeue yang menunjukkan status berjalannya job:
{| class="wikitable"
|+Daftar STATE squeue SLURM
!STATE
!Kepanjangan
!Penjelasan
|-
|R
|RUN
|Job berjalan
|-
|PD
|PENDING
|Job tertahan, lihat keterangan [[Daftar Reason NODELIST ALELEON Supercomputer|'''NODELIST(REASON)''']]
|-
|CG
|COMPLETING
|Job selesai dan dalam proses clean-up SLURM
|-
|CA
|CANCELED
|Job dibatalkan oleh user
|-
|PR
|PREEMPETED
|Job dibatalkan oleh admin EFISON, alasan dikabarkan melalui email
|-
|S
|SUSPENDED
|Job ditahan oleh admin EFISON
|}
|-
|'''6B'''
|Apabila user ingin membatalkan job, gunakan perintah scancel berdasarkan job ID.
*Job ID dapat dilihat melalui perintah squeue pada kolom JOBID.
*User hanya bisa membatalkan job submission milik user sendiri.
$ '''scancel <''job-ID-submission-user''>'''
Contoh user membatalkan job submission milik user dengan ID 231.
$ scancel 231
|}
===GUI Web - EFIRO Job Composer===
[[Berkas:Efirojobcomposer3.png|nirbing|500x500px]]


Silahkan tambahan SBATCH berikut pada SLURM Submit Script (dapat ditambahkan setelah SBATCH error) apabila user ingin menerima notifikasi email dari SLURM:
Menjalankan komputasi dengan tampilan grafis pada formulir job submission EFIRO Job Composer.
  #SBATCH --mail-user=<''alamat-email-user''>
{| class="wikitable mw-collapsible mw-collapsed"
! colspan="2" |Langkah Menjalankan CP2K via EFIRO Job Composer
|-
| rowspan="2" |'''0'''
|Sebelum login, [[Koneksi VPN ALELEON Supercomputer|'''user harus terhubung ke jaringan VPN ALELEON Supercomputer''']].
|-
|Buka alamat web '''<code><nowiki>http://aleleon.ood</nowiki></code>''' kemudian masukkan username dan password user.
*Bagi user Linux, buka alamat <code>'''<nowiki>http://10.192.50.11</nowiki>'''</code>
|-
|'''1'''
|Buka menu dashboard EFIRO '''<code>Jobs</code> > <code>Jobs Composer</code>'''
[[Berkas:Efirojobcomposermenu.png|nirbing|300x300px|al=]]
|-
|'''2'''
|Pilih '''<code>New Jobs</code> > <code>From Template</code>'''
[[Berkas:Jcnewjobmarked.png|al=|nirbing|180x180px]]
|-
|'''3'''
|[[Berkas:Jcselecttemplate3.png|al=|nir|jmpl|Pilih template DFTB+ yang diinginkan. Isi atau ganti <code>'''Job Name'''</code> sesuai keinginan user, kemudian klik <code>'''Create New Job'''</code>.|400x400px]]
{| class="wikitable"
! colspan="2" |Template DFTB+ yang tersedia
|-
!Nama Template
!Penjelasan
|-
|DFTB+ 22.2 (CPU)
|Menjalankan DFTB+ 22.2 versi CPU
|}
|-
|'''4'''
|[[Berkas:Jcjoboption3.png|nirbing|600x600px]]
 
==== File Input dftb_in.hsd ====
Gunakan menu '''<code>Edit Files</code>''' untuk upload / membuat file yang dibutuhkan termasuk file input'''.'''
*Buat / upload file input DFTB+ dengan nama dan format '''dftb_in.hsd.'''
*Laman Edit Files juga dapat melakukan view / download / edit / rename / delete file.
*''Fitur upload pada laman Edit Files '''mempunyai batasan ukuran upload 2GB per file'''.''
**''Gunakan [[Upload File dengan Aplikasi FTP|'''aplikasi FTP''']] apabila user hendak mengupload file tunggal diatas 2GB.''
|-
|'''5A'''
|
==== File Slaster-Koster (SK) ====
File input DFTB+ membutuhkan file '''Slater-Koster (SK)''' pada bagian Hamiltonian yang bisa didapatkan pada:
* [https://dftb.org/parameters/download '''Halaman utama Download File SK''']
* [https://dftb.org/parameters/download/all-sk-files '''File SK dalam satu archive''']
 
File dalam format .tar sehingga perlu di ekstrak.
|-
|'''5B'''
|Admin menyarankan untuk upload file SK pada direktori HOME melalui menu '''<code>Files > Home Directory</code>'''
[[Berkas:Homedirefiro.png|nirbing|200x200px]]
 
Pastikan file input pada bagian Hamiltonian menunjuk direktori file SK spesifik pada HOME tersebut:
'''$HOME'''''/<folder-file-SK-yang-dibutuhkan>''
|-
|'''6'''
|[[Berkas:Jceditor3.png|al=|nirbing|300x300px]]
 
==== Menjalankan DFTB+ ====
Melalui '''<code>Open Editor</code>''', lengkapi Submit Script dengan mengganti bagian yang di tandai 4 garis miring (////).
*''Jangan lupa klik <code>'''Save'''</code> setiap sekali mengubah script.''
*Template ini bersifat referensi, user dapat mengubah bagian yang sekiranya perlu diubah.
{| class="wikitable"
! colspan="4" |Panduan nilai maks SBATCH untuk DFTB+''<sup>1</sup>''
|-
!Parameter SBATCH
!Fair policy usage''<sup>2</sup>''
!Multi-node MPI<sup>''3''</sup>
!High-mem node
epyc001'''<sup>''4''</sup>'''
|-
|ntasks (CPU) * cpus-per-task (OMP)
|128
|384
|128
|-
| mem (RAM)
|128GB
|240GB
|500GB
|-
|time (time limit)
| colspan="3" |3-00:00:00 atau 72:00:00
|-
| gpus (GPU)
|2
|0
|0
|}'''Note:'''
#Info SBATCH lebih detail lihat laman [[Submit Script ALELEON Supercomputer|'''Submit Script ALELEON Supercomputer''']]
#Limitasi fair policy usage untuk menjaga kualitas layanan ALELEON Supercomputer.
#*User dapat mengajukan permintaan membuka limitasi apabila job membutuhkan alokasi lebih.
#*Info lebih detail lihat laman [[Limitasi Fair Usage ALELEON Supercomputer|'''Limitasi Fair Usage ALELEON Supercomputer''']]
#DFTB+ mendukung komputasi paralel MPI untuk berjalan ''multi-node'' lebih dari 128 core thread.
#*Info lebih detail lihat laman [[MPI ALELEON Supercomputer|'''MPI ALELEON Supercomputer''']].
#User dapat menggunakan memori RAM hingga '''500GB''' pada node epyc001 saja.
#*Tambahkan parameter <code>'''#SBATCH --nodelist=epyc001'''</code>
|-
|'''7A'''
|Jalankan job dengan klik tombol '''<code>Submit</code>'''.
[[Berkas:Jcsubmit2.png|al=|nirbing|600x600px]]
 
Berikut penjelasan kolom '''<code>Status</code>,''' pantau dengan refresh halaman job''':'''
{| class="wikitable"
!Status
!Arti
|-
|Not Submitted
|Job belum pernah dijalankan.
|-
|Running
|Job berjalan.
|-
|Queue
|Job mengantri dan belum berjalan.
|-
|Completed
|Job selesai berjalan.
|-
|Failed
|Job berhenti di tengah jalan, bisa karena di Stop atau Delete oleh user.
|}
|-
|'''7B'''
|Untuk menghentikan job yang tengah berjalan, klik tombol '''Stop'''.
[[Berkas:Stop.png|nirbing|600x600px]]
|-
|'''8A'''
|Hasil output job dapat dilihat pada kolom '''<code>Folder Contents</code>''' atau membuka halaman '''<code>Edit Pages</code>.'''[[Berkas:Jcfoldercontentsedit.png|al=|nir|jmpl|User dapat melihat semua file output yang keluar di kolom '''<code>Folder Contents</code>'''.]][[Berkas:Jcjoboption3.png|nir|jmpl|atau dengan membuka menu '''<code>Edit Files</code>'''.]]
|-
|'''8B'''
|User dapat '''menjalankan ulang ruang job yang sama''' dengan mengklik kembali tombol '''<code>Submit</code>'''.
|}
=='''Notifikasi Status Jalannya Komputasi via email'''==
SLURM ALELEON Supercomputer dapat mengirim notifikasi email kepada user dengan nama "Jojo" untuk mengabarkan status berjalannya job komputasi user. Silahkan tambahan SBATCH berikut pada SLURM Submit Script (dapat ditambahkan setelah SBATCH error) apabila user ingin menerima notifikasi email dari SLURM:
  #SBATCH --mail-user='''<''alamat-email-user''>'''
  #SBATCH --mail-type=begin
  #SBATCH --mail-type=begin
  #SBATCH --mail-type=end
  #SBATCH --mail-type=end
Keterangan:
*'''mail-user'''
*'''mail-user'''
**Alamat email user untuk menerima notifikasi SLURM
**Alamat email user untuk menerima notifikasi SLURM
*'''mail-type=begin'''
*'''mail-type=begin'''**Notifikasi email yang menginfokan job sudah berjalan.
**Notifikasi email yang menginfokan job sudah berjalan.
*'''mail-type=end'''
*'''mail-type=end'''
**Notifikasi email yang menginfokan job sudah selesai.
**Notifikasi email yang menginfokan job sudah selesai.
**Sekaligus memberikan cuplikan 20 baris terakhir dari file output SBATCH output dan error job user.
**Sekaligus memberikan cuplikan 20 baris terakhir dari file output SBATCH output dan error job user.
=='''Pelaporan Kendala dan Support'''==
Apabila menjumpai masalah teknis dalam menjalankan komputasi DFTB+, silahkan lapor dengan klik gambar berikut ini.
[[Berkas:Wiki-pelaporankendala.jpg|1000x1000px|link=https://efisonlt.com/aleleonbugreport]]
---
Bila terdapat pertanyaan lainnya, silahkan hubungi admin EFISON melalui email:
'''support@efisonlt.com'''

Revisi per 10 Oktober 2023 11.03

DFTB logo.png

DFTB+ adalah software package yang versatil untuk simulasi mechanical quantum. DFTB+ merupakan software tidak berbayar dengan lisensi GNU Lesser General Public License.

Modul DFTB+

Berikut adalah detail versi DFTB+ yang tersedia secara global di ALELEON Supercomputer:

Versi Nama modul Modul

DEFAULT

Dukungan hardware
CPU GPU OMP

Threading

MPI

multi-node

22.2 dftbplus/22.2-GCC11.3-AOCL4.0 V V - V V

Pilihan MPI atau Threading OpenMP pada DFTB+ versi CPU

DFTB+ secara default berjalan dengan paralelisasi OpenMP (OMP). Sementara itu DFTB+ pada ALELEON Supercomputer dicompile dengan MPI sehingga dapat berjalan dengan paralelisasi hybrid MPI/OMP. ALELEON Supercomputer menyerahkan keputusan kepada user untuk memilih metode paralelisasi tersebut melalui konfigurasi pada SLURM Submit Script (lihat subbab Menjalankan DFTB+ di Compute Node):

  • SBATCH ntasks mewakili jumlah task MPI sedangkan SBATCH cpus-per-task mewakili jumlah thread OMP.
#SBATCH --ntasks -> mewakili jumlah task MPI
#SBATCH --cpus-per-task -> mewakili jumlah thread OpenMP
  • Apabila ingin Pure MPI maka isi jumlah SBATCH cpus-per-task dengan 1.
# Pure MPI 
#SBATCH --ntasks=<isi-sesuai-keinginan>
#SBATCH --cpus-per-task=1
  • Apabila ingin Hybrid MPI/OMP maka isi kedua parameter tersebut. Perlu diingat bahwa total core CPU yang digunakan adalah ntasks * cpus-per-task. Contoh berikut menggunakan 2 proses MPI dan 4 thread OMP per MPI sehingga total menggunakan 8 core CPU:
# Hybrid MPI/OMP, contoh dengan 2 proses MPI dan 4 thread OMP per MPI.
#SBATCH --ntasks=2
#SBATCH --cpus-per-task=4
  • Apabila ingin Pure OMP maka isi jumlah ntasks dengan 1.
# Pure OMP 
#SBATCH --ntasks=1
#SBATCH --cpus-per-task=<isi-sesuai-keinginan>

Menjalankan DFTB+ di Compute Node

User dapat menjalankan komputasi dengan pilihan cara melalui tampilan terminal atau GUI web EFIRO.

Mengecek Kredit Core Hour bagi Akun Perseorangan

User dengan akun perseorangan disarankan untuk selalu mengecek sisa Kredit Core Hour sebelum melakukan job submission dengan menjalankan perintah pada terminal:

$ sausage

Bagi yang login ke web EFIRO, buka terminal pada menu Clusters > Aleleon Shell Access

Terminal - SLURM sbatch

Sbatch Terminal.png

Menjalankan komputasi pada terminal melalui job submission SLURM sbatch.

Langkah Menjalankan CP2K via SLURM sbatch
0 Sebelum login, user harus terhubung ke jaringan VPN ALELEON Supercomputer.
Login dengan SSH:
  • User OS Windows dan MacOS -> $ ssh <username>@aleleon.hpc
  • User OS Linux -> $ ssh <username>@10.192.50.10
1 Siapkan file yang dibutuhkan untuk menjalankan komputasi user.
2

File Input dftb_in.hsd

Buat / upload file input DFTB+ dengan nama dan format dftb_in.hsd.

  • File input ini harus ditaruh pada satu direktori dengan SLURM Submit Script (langkah 4).
3A

File Slaster-Koster (SK)

File input DFTB+ membutuhkan file Slater-Koster (SK) pada bagian Hamiltonian yang bisa didapatkan pada:

File dalam format .tar sehingga perlu di ekstrak.

3B Admin menyarankan menaruh / upload folder SK pada direktori HOME supaya dapat diakses oleh banyak job.
$HOME/<folder-file-SK-yang-dibutuhkan>

Pastikan file input pada bagian Hamiltonian menunjuk direktori file SK spesifik pada HOME tersebut.

4

Menjalankan DFTB+

Buat SLURM Submit Script yaitu 'formulir' untuk menjalankan job dengan panduan berikut:

  • Nama script dibebaskan dengan format file .sh (bash), contoh my_job_submission.sh
  • Buat script pada direktori yang sama dengan file komputasi yang akan dijalankan.
  • Ikuti panduan template berikut dan petunjuk pada NOTES di dalamnya.
Panduan nilai maks SBATCH untuk DFTB+1
Parameter SBATCH Fair policy usage2 Multi-node MPI3 High-mem node

epyc0014

ntasks (CPU) * cpus-per-task (OMP) 128 384 128
mem (RAM) 128GB 240GB 500GB
time (time limit) 3-00:00:00 atau 72:00:00
gpus (GPU) 2 0 0
Note:
  1. Info SBATCH lebih detail lihat laman Submit Script ALELEON Supercomputer
  2. Limitasi fair policy usage untuk menjaga kualitas layanan ALELEON Supercomputer.
  3. DFTB+ mendukung komputasi paralel MPI untuk berjalan multi-node lebih dari 128 core thread.
  4. User dapat menggunakan memori RAM hingga 500GB pada node epyc001 saja.
    • Tambahkan parameter #SBATCH --nodelist=epyc001
Template SLURM Submit Script DFTB+
#!/bin/bash

# -------------------------------------------------------------
# | Template SLURM Submit Script
# | Software        : DFTB+
# | Update script  r: 06/10/2023
# |
# | NOTES: 
# | 1. Isi bagian yang ditandai 4 garing (////).
# | 2. Template ini bersifat referensi.
# |    User dapat mengubah bagian yang sekiranya perlu diubah.
# | 3. Panduan menjalankan CP2K di ALELEON lihat: 
# |    wiki.efisonlt.com/wiki/DFTB%2B 
# -------------------------------------------------------------

# --------------------------------------------------
# Alokasi komputasi, modul software, dan file input
# --------------------------------------------------

# Alokasi jumlah core thread CPU. mewakili jumlah task MPI
#SBATCH --ntasks=////

# Alokasi jumlah thread OMP per task MPI
#SBATCH --cpus-per-task=////

# Alokasi jumlah memori RAM (satuan GB)
#SBATCH --mem=////GB

# Alokasi limit waktu menjalankan job.
# Format HH:MM:SS atau D-HH:MM:SS 
#SBATCH --time=////

# Definisi file untuk menampung output terminal
#SBATCH --output=result-%j.txt

# Definisi file untuk menampung output error log    
#SBATCH --error=error-%j.txt 

# Memuat modul software DFTB+
# Daftar modul DFTB+ lihat subbab "Modul DFTB+" pada
# wiki.efisonlt.com/wiki/DFTB%2B 
module load dftbplus////

# -------------------------------------------------
# RUN SCRIPT
# -------------------------------------------------

# Definisi threading OMP 
export OMP_NUM_THREADS=$SLURM_CPUS_PER_TASK

# Perintah menjakankan DFTB+
mpirun -np $SLURM_NTASKS dftb+
5 Jalankan job dengan perintah sbatch.
$ sbatch <nama-SLURM-Submit-script>

Contoh menjalankan nama script my_job_submission.sh.

$ sbatch my_job_submission.sh
6A User dapat melihat status jalannya job dengan perintah squeue berikut.
  • Apabila tidak ada output artinya tidak ada job user yang berjalan / antri pada waktu itu.
$ squeue -ul $USER

Berikut adalah daftar STATE (ST) dari squeue yang menunjukkan status berjalannya job:

Daftar STATE squeue SLURM
STATE Kepanjangan Penjelasan
R RUN Job berjalan
PD PENDING Job tertahan, lihat keterangan NODELIST(REASON)
CG COMPLETING Job selesai dan dalam proses clean-up SLURM
CA CANCELED Job dibatalkan oleh user
PR PREEMPETED Job dibatalkan oleh admin EFISON, alasan dikabarkan melalui email
S SUSPENDED Job ditahan oleh admin EFISON
6B Apabila user ingin membatalkan job, gunakan perintah scancel berdasarkan job ID.
  • Job ID dapat dilihat melalui perintah squeue pada kolom JOBID.
  • User hanya bisa membatalkan job submission milik user sendiri.
$ scancel <job-ID-submission-user>

Contoh user membatalkan job submission milik user dengan ID 231.

$ scancel 231

GUI Web - EFIRO Job Composer

Efirojobcomposer3.png

Menjalankan komputasi dengan tampilan grafis pada formulir job submission EFIRO Job Composer.

Langkah Menjalankan CP2K via EFIRO Job Composer
0 Sebelum login, user harus terhubung ke jaringan VPN ALELEON Supercomputer.
Buka alamat web http://aleleon.ood kemudian masukkan username dan password user.
  • Bagi user Linux, buka alamat http://10.192.50.11
1 Buka menu dashboard EFIRO Jobs > Jobs Composer

2 Pilih New Jobs > From Template

3
Pilih template DFTB+ yang diinginkan. Isi atau ganti Job Name sesuai keinginan user, kemudian klik Create New Job.
Template DFTB+ yang tersedia
Nama Template Penjelasan
DFTB+ 22.2 (CPU) Menjalankan DFTB+ 22.2 versi CPU
4 Jcjoboption3.png

File Input dftb_in.hsd

Gunakan menu Edit Files untuk upload / membuat file yang dibutuhkan termasuk file input.

  • Buat / upload file input DFTB+ dengan nama dan format dftb_in.hsd.
  • Laman Edit Files juga dapat melakukan view / download / edit / rename / delete file.
  • Fitur upload pada laman Edit Files mempunyai batasan ukuran upload 2GB per file.
    • Gunakan aplikasi FTP apabila user hendak mengupload file tunggal diatas 2GB.
5A

File Slaster-Koster (SK)

File input DFTB+ membutuhkan file Slater-Koster (SK) pada bagian Hamiltonian yang bisa didapatkan pada:

File dalam format .tar sehingga perlu di ekstrak.

5B Admin menyarankan untuk upload file SK pada direktori HOME melalui menu Files > Home Directory

Homedirefiro.png

Pastikan file input pada bagian Hamiltonian menunjuk direktori file SK spesifik pada HOME tersebut:

$HOME/<folder-file-SK-yang-dibutuhkan>
6

Menjalankan DFTB+

Melalui Open Editor, lengkapi Submit Script dengan mengganti bagian yang di tandai 4 garis miring (////).

  • Jangan lupa klik Save setiap sekali mengubah script.
  • Template ini bersifat referensi, user dapat mengubah bagian yang sekiranya perlu diubah.
Panduan nilai maks SBATCH untuk DFTB+1
Parameter SBATCH Fair policy usage2 Multi-node MPI3 High-mem node

epyc0014

ntasks (CPU) * cpus-per-task (OMP) 128 384 128
mem (RAM) 128GB 240GB 500GB
time (time limit) 3-00:00:00 atau 72:00:00
gpus (GPU) 2 0 0
Note:
  1. Info SBATCH lebih detail lihat laman Submit Script ALELEON Supercomputer
  2. Limitasi fair policy usage untuk menjaga kualitas layanan ALELEON Supercomputer.
  3. DFTB+ mendukung komputasi paralel MPI untuk berjalan multi-node lebih dari 128 core thread.
  4. User dapat menggunakan memori RAM hingga 500GB pada node epyc001 saja.
    • Tambahkan parameter #SBATCH --nodelist=epyc001
7A Jalankan job dengan klik tombol Submit.

Berikut penjelasan kolom Status, pantau dengan refresh halaman job:

Status Arti
Not Submitted Job belum pernah dijalankan.
Running Job berjalan.
Queue Job mengantri dan belum berjalan.
Completed Job selesai berjalan.
Failed Job berhenti di tengah jalan, bisa karena di Stop atau Delete oleh user.
7B Untuk menghentikan job yang tengah berjalan, klik tombol Stop.

Stop.png

8A Hasil output job dapat dilihat pada kolom Folder Contents atau membuka halaman Edit Pages.
User dapat melihat semua file output yang keluar di kolom Folder Contents.
atau dengan membuka menu Edit Files.
8B User dapat menjalankan ulang ruang job yang sama dengan mengklik kembali tombol Submit.

Notifikasi Status Jalannya Komputasi via email

SLURM ALELEON Supercomputer dapat mengirim notifikasi email kepada user dengan nama "Jojo" untuk mengabarkan status berjalannya job komputasi user. Silahkan tambahan SBATCH berikut pada SLURM Submit Script (dapat ditambahkan setelah SBATCH error) apabila user ingin menerima notifikasi email dari SLURM:

#SBATCH --mail-user=<alamat-email-user>
#SBATCH --mail-type=begin
#SBATCH --mail-type=end

Keterangan:

  • mail-user
    • Alamat email user untuk menerima notifikasi SLURM
  • mail-type=begin**Notifikasi email yang menginfokan job sudah berjalan.
  • mail-type=end
    • Notifikasi email yang menginfokan job sudah selesai.
    • Sekaligus memberikan cuplikan 20 baris terakhir dari file output SBATCH output dan error job user.

Pelaporan Kendala dan Support

Apabila menjumpai masalah teknis dalam menjalankan komputasi DFTB+, silahkan lapor dengan klik gambar berikut ini.

Wiki-pelaporankendala.jpg

---

Bila terdapat pertanyaan lainnya, silahkan hubungi admin EFISON melalui email:

support@efisonlt.com