===== Mathematica =====
==== Mathematica serial job ====
=== Execution of a Mathematica serial program ===
Script ''math-vrt.m'':
Print[Integrate[1/(x^4 - a^4), x]];
(*Prints all Mersenne PRime numbers less than 10000*)
Print[Select[Range[10000],PrimeQ[2^#-1]&]];
A = Sum[i, {i,1,100}];
B = Mean[{25, 36, 22, 16, 8, 42}];
Print[A + B];
Quit[];
Script ''slurm-math-vrt.sh'':
#!/bin/bash
#SBATCH --job-name=MathVRT
#SBATCH --output=%x.o%j
#SBATCH --error=%x.e%j
#SBATCH --ntasks=1
#SBATCH --partition=vrt
#SBATCH --qos=vrt
#SBATCH --mem=8G
#SBATCH --time=0-00:30:00
#SBATCH --account=
module load mathematica
math -script math-vrt.m
Submitting ''slurm-math-vrt.sh'':
sbatch slurm-math-vrt.sh
==== Mathematica parallel job ====
=== Execution of a parallel job with Mathematica ===
Script ''math-cpu.m'':
GetEnvironment["SLURM_NTASKS_PER_NODE"]
(*Limits Mathematica to requested resources*)
Unprotect[$ProcessorCount];
$ProcessorCount = ToExpression[Environment["SLURM_NTASKS_PER_NODE"]];
(*Prints the machine name that each kernel is running on*)
Print[ParallelEvaluate[$MachineName]];
(*Prints all Mersenne PRime numbers less than 10000*)
Print[Parallelize[Select[Range[10000],PrimeQ[2^#-1]&]]];
Quit[];
Script ''slurm-math-cpu.sh'':
#!/bin/bash
#SBATCH --job-name=MathCPU
#SBATCH --output=%x.o%j
#SBATCH --error=%x.e%j
#SBATCH --nodes=1
#SBATCH --ntasks-per-node=8
#SBATCH --partition=cpu
#SBATCH --qos=cpu
#SBATCH --mem=16G
#SBATCH --time=0-00:30:00
#SBATCH --account=
module load mathematica
math -script math-cpu.m
Submitting ''slurm-math-cpu.sh'':
sbatch slurm-math-cpu.sh