Zeus:Abaqus: Różnice pomiędzy wersjami

Z Komputery Dużej Mocy w ACK CYFRONET AGH
Skocz do:nawigacja, szukaj
 
(Nie pokazano 31 wersji utworzonych przez 4 użytkowników)
Linia 1: Linia 1:
 
{{DISPLAYTITLE:Abaqus}}
 
{{DISPLAYTITLE:Abaqus}}
Na klastrze [[Zeus]] zainstalowano pakiet Abaqus w wersji 6.10.
+
Na klastrze [[Zeus]] zainstalowano pakiet Abaqus w wersjiach 6.x, 2016, 2017.
  
 
= Informacje ogólne =
 
= Informacje ogólne =
  
Do ustawiania środowiska uruchomieniowego oprogramowania na klastrze [[Zeus]] służy narzędzie [[Modules]]. Pliki tymczasowe należy tworzyć używająć zasobu dyskowego [[Zeus:Lustre|Lustre]]. Do załadowania domyślnej wersji pakietu służy komenda:
+
Do ustawiania środowiska uruchomieniowego oprogramowania na klastrze [[Zeus]] służy narzędzie [[Modules]]. Pliki tymczasowe należy tworzyć używając katalogu $SCRATCH. Do załadowania domyślnej wersji pakietu służy komenda:
  
   <code>module add abaqus</code>
+
   <code>module add apps/abaqus</code>
  
Domyślna wersja to '''6.10'''.
+
Domyślna wersja to '''2017'''.
  
 
Program uruchamiany jest poleceniem <tt>abaqus</tt>.
 
Program uruchamiany jest poleceniem <tt>abaqus</tt>.
Linia 16: Linia 16:
 
Przegląd funkcji i poleceń dostępny zostanie wyświetlony po wykonaniu komendy <tt>abaqus help</tt>.
 
Przegląd funkcji i poleceń dostępny zostanie wyświetlony po wykonaniu komendy <tt>abaqus help</tt>.
  
=6.10=
+
=Wersje Abaqusa=
Zmienne środowiskowe ustawia się ładując moduł <tt>abaqus/6.10</tt>
+
Zmienne środowiskowe ustawia się ładując moduł <tt>apps/abaqus/''ver''</tt> gdzie
 +
''ver'' to wersja Abaqusa (10, 11, 12, 13, 14, 2016 lub 2017)
  
   <code>module add abaqus/6.10</code>
+
   <code>module add apps/abaqus/''ver''</code>
  
 
+
==== Przykładowe skrypty ====
==== Przykładowy skrypt ====
 
 
===== Obliczenia w trybie wątków ze współdzieloną pamięcią =====
 
===== Obliczenia w trybie wątków ze współdzieloną pamięcią =====
  
Linia 28: Linia 28:
  
 
<syntaxhighlight lang="bash">
 
<syntaxhighlight lang="bash">
#!/bin/sh
+
#!/bin/bash -l
#PBS -N abaqus_test
+
## Nazwa zlecenia
#PBS -q l_long
+
#SBATCH -J <nazwa_zadania>
#PBS -l mem=2gb
+
## Liczba alokowanych węzłów
#PBS -l nodes=1:ppn=4
+
#SBATCH -N 1
 
+
## Liczba zadań per węzeł (domyślnie jest to liczba alokowanych rdzeni na węźle)
# ustawienie sciezek do pakietu Abaqus
+
#SBATCH --ntasks-per-node=4
module load abaqus
+
## Ilość pamięci przypadającej na jeden rdzeń obliczeniowy (domyślnie 5GB na rdzeń)
 
+
#SBATCH --mem-per-cpu=1GB
# przejscie do katalogu, z ktorego wywolano skrypt PBS
+
## Maksymalny czas trwania zlecenia (format HH:MM:SS)
cd $PBS_O_WORKDIR
+
#SBATCH --time=01:00:00
 
+
## Nazwa grantu do rozliczenia zużycia zasobów
# zliczenie zadanych procesorow
+
#SBATCH -A <grant_id>
np=$(cat $PBS_NODEFILE | wc -l)
+
## Specyfikacja partycji
 +
#SBATCH -p plgrid-testing
 +
## Plik ze standardowym wyjściem
 +
#SBATCH --output="output.out"
 +
## Plik ze standardowym wyjściem błędów
 +
#SBATCH --error="error.err"
 +
 +
## przejscie do katalogu z ktorego wywolany zostal sbatch
 +
cd $SLURM_SUBMIT_DIR
  
# ustawianie dostepnej pamieci
+
input=<plik_wejsciowy>  
echo 'memory = "2 gb"' > abaqus_v6.env 
+
np=$SLURM_NTASKS
 
+
srun /bin/hostname
input=plik_z_danymi_wejsciowymi
+
module load plgrid/apps/abaqus/<ver>
 
+
abaqus j=$input cpus=$np mp_mode=threads interactive interactive  
abaqus job=$input cpus=$np mp_mode=threads interactive
 
 
</syntaxhighlight>
 
</syntaxhighlight>
  
===== Oblicznia w trybie MPI =====
+
===== Obliczenia w trybie MPI =====
  
Zadanie Abaqusa będzie się wykonywać na 4 węzłach i na każdym węźle będzie wykorzystywało 2 procesory
+
Zadanie Abaqusa będzie się wykonywać na 4 węzłach i na każdym węźle będzie wykorzystywało 2 procesory.
  
 
<syntaxhighlight lang="bash">
 
<syntaxhighlight lang="bash">
#!/bin/sh
+
#!/bin/bash -l
#PBS -N abaqus_test
+
## Nazwa zlecenia
#PBS -q l_long
+
#SBATCH -J <nazwa_zadania>
#PBS -l mem=6gb
+
## Liczba alokowanych węzłów
#PBS -l nodes=4:ppn=2
+
#SBATCH -N 4
 
+
## Liczba zadań per węzeł (domyślnie jest to liczba alokowanych rdzeni na węźle)
# ustawienie sciezek do pakietu Abaqus
+
#SBATCH --ntasks-per-node=2
module load Abaqus
+
## Ilość pamięci przypadającej na jeden rdzeń obliczeniowy (domyślnie 5GB na rdzeń)
 
+
#SBATCH --mem-per-cpu=1GB
# przejscie do katalogu, z ktorego wywolano skrypt PBS
+
## Maksymalny czas trwania zlecenia (format HH:MM:SS)
cd $PBS_O_WORKDIR
+
#SBATCH --time=01:00:00
 
+
## Nazwa grantu do rozliczenia zużycia zasobów
# ustawianie dostepnej pamieci
+
#SBATCH -A <grant_id>
echo 'memory = "6 gb"' > abaqus_v6.env 
+
## Specyfikacja partycji
echo "mp_mpirun_path = {HP:'/opt1/abaqus/6.11-2/External/mpi/hpmpi-2.3/bin/mpirun'}" >> abaqus_v6.env
+
#SBATCH -p plgrid-testing
 
+
## Plik ze standardowym wyjściem
# zliczenie zadanych procesorow
+
#SBATCH --output="output.out"
np=$(cat $PBS_NODEFILE | wc -l)
+
## Plik ze standardowym wyjściem błędów
 
+
#SBATCH --error="error.err"
input=plik_z_danymi_wejsciowymi
+
 +
## przejscie do katalogu z którego wywołany został sbatch
 +
cd $SLURM_SUBMIT_DIR
  
abaqus job=$input cpus=$np standard_parallel=all mp_mode=mpi interactive
+
input=<plik_wejsciowy>
 +
np=$SLURM_NTASKS
 +
srun /bin/hostname
 +
module load apps/abaqus/<ver>
 +
abaqus j=$input cpus=$np mp_mode=mpi interactive  
 
</syntaxhighlight>
 
</syntaxhighlight>

Aktualna wersja na dzień 12:29, 21 lut 2018

Na klastrze Zeus zainstalowano pakiet Abaqus w wersjiach 6.x, 2016, 2017.

Informacje ogólne

Do ustawiania środowiska uruchomieniowego oprogramowania na klastrze Zeus służy narzędzie Modules. Pliki tymczasowe należy tworzyć używając katalogu $SCRATCH. Do załadowania domyślnej wersji pakietu służy komenda:

 module add apps/abaqus

Domyślna wersja to 2017.

Program uruchamiany jest poleceniem abaqus.

Graficzne środowisko użytkownika uruchamiane jest poleceniem abaqus cae (Uwaga: należy pamiętać o przekierowaniu wyświetlania XWidnows).

Przegląd funkcji i poleceń dostępny zostanie wyświetlony po wykonaniu komendy abaqus help.

Wersje Abaqusa

Zmienne środowiskowe ustawia się ładując moduł apps/abaqus/ver gdzie ver to wersja Abaqusa (10, 11, 12, 13, 14, 2016 lub 2017)

 module add apps/abaqus/ver

Przykładowe skrypty

Obliczenia w trybie wątków ze współdzieloną pamięcią

Zadanie Abaqusa będzie się wykonywać na jednym węźle i będzie wykorzystywało 4 procesory.

#!/bin/bash -l
## Nazwa zlecenia
#SBATCH -J <nazwa_zadania>
## Liczba alokowanych węzłów
#SBATCH -N 1
## Liczba zadań per węzeł (domyślnie jest to liczba alokowanych rdzeni na węźle)
#SBATCH --ntasks-per-node=4
## Ilość pamięci przypadającej na jeden rdzeń obliczeniowy (domyślnie 5GB na rdzeń)
#SBATCH --mem-per-cpu=1GB
## Maksymalny czas trwania zlecenia (format HH:MM:SS)
#SBATCH --time=01:00:00 
## Nazwa grantu do rozliczenia zużycia zasobów
#SBATCH -A <grant_id>
## Specyfikacja partycji
#SBATCH -p plgrid-testing
## Plik ze standardowym wyjściem
#SBATCH --output="output.out"
## Plik ze standardowym wyjściem błędów
#SBATCH --error="error.err"
 
## przejscie do katalogu z ktorego wywolany zostal sbatch
cd $SLURM_SUBMIT_DIR

input=<plik_wejsciowy> 
np=$SLURM_NTASKS
srun /bin/hostname
module load plgrid/apps/abaqus/<ver>
abaqus j=$input cpus=$np mp_mode=threads interactive interactive
Obliczenia w trybie MPI

Zadanie Abaqusa będzie się wykonywać na 4 węzłach i na każdym węźle będzie wykorzystywało 2 procesory.

#!/bin/bash -l
## Nazwa zlecenia
#SBATCH -J <nazwa_zadania>
## Liczba alokowanych węzłów
#SBATCH -N 4
## Liczba zadań per węzeł (domyślnie jest to liczba alokowanych rdzeni na węźle)
#SBATCH --ntasks-per-node=2
## Ilość pamięci przypadającej na jeden rdzeń obliczeniowy (domyślnie 5GB na rdzeń)
#SBATCH --mem-per-cpu=1GB
## Maksymalny czas trwania zlecenia (format HH:MM:SS)
#SBATCH --time=01:00:00 
## Nazwa grantu do rozliczenia zużycia zasobów
#SBATCH -A <grant_id>
## Specyfikacja partycji
#SBATCH -p plgrid-testing
## Plik ze standardowym wyjściem
#SBATCH --output="output.out"
## Plik ze standardowym wyjściem błędów
#SBATCH --error="error.err"
 
## przejscie do katalogu z którego wywołany został sbatch
cd $SLURM_SUBMIT_DIR

input=<plik_wejsciowy> 
np=$SLURM_NTASKS
srun /bin/hostname
module load apps/abaqus/<ver>
abaqus j=$input cpus=$np mp_mode=mpi interactive