Gaussian 16 Installation Instructions

This is preinstalled on all 64-bit managed Linux workstations. You need to be the 'gaussian' Unix group to access this software but this should happen automatically. It is also preinstalled on the majority of local compute servers.

Install GAUSS 21 in Silent Mode (Silent Install) To install GAUSS in Silent Mode, you should be able to use the /quiet or /qn options with msiexec to perform a silent install. MSI packages export public properties, which you can set with the PROPERTY=value syntax on the end of the msiexec parameters. Make the job easy with Bruce hardwood installation instructions. Get step-by-step instructions plus warranty information, certifications, ideas, and more. This is the Gaussian 16 and GaussView software, copied from the discs. I cannot provide these files. Place them in the same directory as this repository. How do I use this? You'll need to make some modifications. First, check out addgaussianuser.applescript. The installation manual specifies that you'll need to create a specific group of users for this software. Gaussview/Gaussian Guide and Exercise Manual Introduction In this manual some of the principal features of the Gaussview and Gaussian programs are highlighted to enable the student to start working productively with both programs. The examples/descriptions are inevitably brief and do not aim to be a comprehensive guide.

If you are a member of the Chemistry department and want to use Gaussian 03 on a Linux machine that is not managed by the Chemistry computer officers please contact us. Our licence only permits us to install the software on machines that are physically located in the university.

On managed Linux workstations or compute clusters, load the gaussianmodule to access the software. The program itself is called g03.

Our version of Gaussian 03 only does shared memory parallelization, and only up to 8 threads. This means you can only parallelize within a single computer. Use the %nproc directive in the Gaussian input file to turn on parallelization. There is no need to set OMP_NUM_THREADS as well as %nproc.

We also have Gaussview 5 (a graphical frontend to Gaussian) available. Loading the gaussian module will also make gaussview available in your environment. Type gview to start it.

Some research groups also have access to a newer version of Gaussian which is called Gaussian 09.

Instructions

Proprietary commercial software. The University of Cambridge has a site licence for a particular release of Gaussian 03 that covers 'staff, students, and faculty'.

There is an online manual. Immediate help is provided by the ghelp command.

Gaussian group

Access to Gaussian is restricted by a Unix group which is stored in Admitto for most machines. Some of the clusters have the group locally. New users are supposed to be added automatically.

Installing

I followed the installation instructions by translating them into bash. It is necessary to have certain environment variables set for Gaussian to run (and on my system they didn't quite match the ones in the install instructions). They are GAUSS_EXEDIR, GAUSS_SCRDIR, and g03root. The gaussian modulefile is mildly interesting in that it works out the correct per-user scratch directory. It also warns the user if they are not in the Unix group 'gaussian', as they will not be able to use the software.

With the E01 release things seemed a bit different. Again I translated the installer into bash. The media came with TCP Linda which allows you to run Gaussian in parallel. We do not have a licence for it so I didn't do that part of the install, or set the Linda environment variable GAUSS_LEXEDIR.

The Gaussian installation comes with a file g03.login to be sourced for C-shell users, and a g03.profile which isn't mentioned in the docs. While one might think it was just the equivalent thing for Bourne shell users it sets a slightly different set of environment variables so I am not sure what it's for. I just set (most of) the stuff from g03.login in the module for Gaussian E01. I skipped LD_LIBRARY_PATH because as far as I can see it's totally superfluous and I want to discourage its use. I did add the same directory to the MANPATH that g03.login does, but I cannot see that it achieves anything at all as it doesn't contain any manpages. I also didn't set any of the PGI stuff or anything that was tagged as being for compiling Gaussian.

To test the installation pick a test input file out of the tests/com subdirectory of the program directory. Run

and compare your output with the examples in the 'tests/ia64' subdirectory. I don't know why there's only test output for Itanium in our distro.

Gaussian is a versatile program for electronic structure modelling.

Homepage: www.gaussian.com

NSC can help you with how to run your Gaussian jobs and to some extend help you with how to set up your Gaussian jobs. We can, for example, help with setting up scripts for running your jobs and help with trouble shooting if you experience issues with running your jobs. If you suspect that you have found a bug in Gaussian, then please contact NSC, so we can investigate and submit a bug report to Gaussian, Inc.

Please contact NSC Support (support at nsc dot liu dot se) if you have any questions or problems.

Important differences compared with Triolith

These are the most important differences regarding Gaussian compared with Triolith:

  • The module names are different
  • We use other default settings in the installations
  • Specifying Linda parallel jobs are different
  • There are no separate modules for GaussView
  • Jobs can be submitted directly from GaussView
  • There is a command line utility (sgausbatch) for easy generation and submission of Gaussian run scripts

See the sections below for more details.

Gaussian modules

Use the module avail gaussian command to find available Gaussian installations:

Gaussian run scripts from Triolith should also work on Tetralith after the module load line has been updated with a new module name.

Default settings

We use the following default settings for the installations on Tetralith/Sigma:

SettingValue
-M- (%Mem)1GB
-P- (%NProcShared)1

These settings are suitable for small serial (i.e. 1 core) Gaussian jobs. For parallel jobs, you need to explicitly specify %Mem and %NProcShared (or %CPU), as well as %LindaWorkers if you are running large multi-node Gaussian jobs.

Note: On Triolith the defaults were set for utilizing one whole compute node per job.

Recommendation for specifying memory

Normal Tetralith compute nodes:

Memory fat Tetralith compute nodes:

Examples

Example 1 - memory specification for a job using 16 cores on a normal Tetralith compute node:

Hence, we get the following Link 0 command settings:

Example 2 - memory specification for a job using one normal Tetralith compute node (i.e. 32 cores):

Link 0 command settings:

Example 3 - memory specification for a job using one memory fat Tetralith compute node (i.e. 32 cores):

Link 0 command settings:

Linda Parallel jobs

To start Linda parallel jobs, you should now use the %LindaWorkers Link 0 command. This command has the following syntax:

Where node1, node2, etc. are names of the compute nodes that the Linda workers should run on and n1, n2, etc. are the number of workers to start on respective compute node. However, as you cannot know the real node names when you setup and submit the job, NSC has a run time wrapper that translates a dummy list into a corresponding list with real node names.

Example Link 0 command settings for a Linda parallel job running on two compute nodes:

It doesn't really matter what you call the nodes in the node list, so just use simple dummy names like node1, node2, etc. What matters is the number of nodes in the list and the number of workers to start for each node. The default is to start one worker per node!

Note: Always use the same number of workers for each node in the %LindaWorkers list! NSC recommends using one worker per node, but do your own benchmarking to see what works well for your jobs.
Note: Remember to adjust %NProcShared if you run more than one worker per node. Linda workers on a node multiplied by the %NProcShared setting should not be higher than 32!

%NProcSharedvs.%CPU

For Gaussian 16, you can also use the new %CPU Link 0 command, which binds processes to explicit cores. Valid syntaxes:

which can also be written as

or, using every second core

which can also be written as

Note: Unless you allocate a whole compute node, you cannot control which cores you get access to.

If your job allocation is less than one whole compute node, then the NSC run time wrapper will change the %CPU core list to the list of actually allocated cores. For example, if you specify %CPU=0,1,2,3,4,5 and allocate six cores for the job, then the NSC run time wrapper will change this list at run time to exactly the cores that were allocated by Slurm for your job.

We have so far not observed any significant performance benefits from using %CPU compared with using %NProcShared, however do your own benchmarking to see if there are any benefits for your jobs.

Gaussian 16 Installation Instructions Free

Starting Gaussian jobs

You can start Gaussian jobs in several ways:

  • Directly from GaussView
  • From the command line using our utility called sgausbatch
  • With your own batch scripts

When using your own batch scripts, please take extra care to always match the sbatch options (e.g.#SBATCH --ntasks) with the Gaussian Link 0 commands (e.g.%NProcShared). One of the common issues we observe for Gaussian jobs is that either too many or too few cores or compute nodes are allocated compared with the Link 0 commands given to Gaussian. For example, a batch script that allocates four whole Tetralith compute nodes with #SBATCH --nodes=4 and then runs a Gaussian job that only sets %NProcShared=32 and no %LindaWorkers command, which then leads to a job that only uses one of the four allocated compute nodes. As these types of mistakes are quite easy to make, we recommend generating your Gaussian batch scripts with the sgausbatch utility, which is developed to help you avoid such mismatch mistakes.

Starting jobs from GaussView

Note: NSC recommends using ThinLinc when running graphical applications.

To start GaussView, you should first load a Gaussian module:

To start jobs from GaussView, you first need to make sure that the 'Job Setup' preference is set to 'Execute indirectly through script using default command line'. Open the 'GaussView Preferences' window (File▸Preferences…) then click on 'Job Setup', choose 'Execute indirectly through script using default command line' and click 'Ok'.

Build a structure or read one in from a file and then open the 'Gaussian Calculation Setup' window (Calculate▸Gaussian Calculation Setup…). Once you have chosen the desired specifications and parameters for the job, simply click the 'Submit…' button. If you have not already done so, GaussView will ask you to save the input file and then open the 'Submit Job' window. Click 'Yes' to submit the job.

The job then gets submitted to the queue with the sgausbatch utility (see below). When sgausbatch is called from GaussView it launches a small GUI for setting the wall-time for the job as well as the project to charge the core-hours to. Choose the wall-time and project you want for your job and click 'OK' to submit the job.

Please see the sections below regarding sgausbatchconfiguration for instructions that will allow you to control some other settings that you might also like to specify for your jobs. For most use this is not needed, though.

You can check whether the job is queued or running from the 'Jobs Log' window, which is opened from the 'Job Manager' window that in turn is opened from the 'Calculate' menu (Calculate▸Current Jobs…). Unfortunately, the 'Jobs Log' window doesn't update automatically, so to check if there is a change in the job status, you have to close and re-open the 'Jobs Log' window. You can, of course, also check the status of the job from the command line in a terminal using the squeue -u $USER command.

Once the job has started, you can stream the output from within GaussView (Results▸Stream Output File). However, it is probably more convenient to follow the progress of a calculation from a terminal using various command line tools.

For geometry optimization jobs, you can read (File▸Open…) the intermediate (or finished) output into GaussView with the option 'Read Intermediate Geometries' checked and use that to inspect the progress of the calculation.

If the job is still running, GaussView will give a warning, but just click 'OK' to open the file. You can inspect the progress of the geometry optimization by opening the 'Optimization Plot' window (Results▸Optimization…).

Using sgausbatch to submit Gaussian jobs

Gaussian 16 Installation Instructions Download

sgausbatch is an NSC developed command line utility for easy generation and submission of Gaussian run scripts

sgausbatch takes a Gaussian input file and generates a batch script with an appropriate SLURM allocation based on the Link 0 commands in the input. It then automatically submits the job script to the scheduler. If not all required parameters are specified (command line, config file, or sbatch environment variables) sgausbatch will interactively ask for the parameters.

sgausbatch is also used to submit jobs directly from GaussView.

The fundamentals of sgausbatch were developed by Lukas Tallund during a summer internship at NSC in 2014.

Currently developed and maintained by Rickard Armiento and Torben Rasmussen.

For help with using sgausbatch please contact NSC Support (support at nsc dot liu dot se). Feedback and feature requests are also welcomed. Please also report all problems, issues, and bugs to NSC Support (support at nsc dot liu dot se).

Examples

To get access to sgausbatch, you first need to load a Gaussian module:

Then to submit a Gaussian job with default wall-time limit simply do:

Note that you will be prompted for the project (SLURM account) to use if multiple such options are available to you.

Command line options

The above example will submit the gaussian_input.com Gaussian job to the queue with a wall-time limit of 1 hour.

This example will submit the Gaussian job and generate the job script based on the template myTemplate.sh which must be supplied in the same folder as the gaussian_input.com file. Please see below for more information about the template file.

To see all available command line options, use the -h option:

Configuration file

Values for many options can also be set in a configuration file. This optional user configuration file should be put in your home directory and named sgausbatch_user.cfg. For example, if you always use the same wall time, you can add that to the configuration file. See more information about the configuration file below.

The following format is used in the config file:

More Details

sgausbatch parses the Gaussian input file for Link 0 commands and completes a batch script template with appropriate sbatch options. Required options that are not specified on the command line or in the configuration file will be prompted for.

sgausbatch uses the following Link 0 commands in your Gaussian input file to define an appropriate allocation:

  • %Mem
  • %NProcShared (or %Cpu)
  • %LindaWorkers (or %NprocLinda)

sgausbatch also uses the %Chk command to handle the checkpoint file. With the default template file, defined checkpoint files that exist in the submit directory are copied from submit directory to run directory and from run directory to submit directory.

If a Link 0 command is not set, sgausbatch checks it's default value in the Default.Route file from the chosen Gaussian module.

Priority of the various ways to set options

When using sgausbatch a number of options can be set. Many options can be set in different ways to make sure you can use the type of setup you prefer. These are the ways to set sgausbatch options:

  1. command line
  2. configuration file
  3. sbatch environment variables (only a subset - not recommended)

Options that are set in several of these places will always be used with the priority listed above. For example, if time is set both on command line and in the configuration file, the command line option will have priority.

Configuration file parameters

The following parameters can be set in the configuration file:

  • account=account_name

    Specifies which SLURM account (i.e. SNIC or LiU project) that should be used for the job.

  • exclusive=False|True

    If set to True, sgaubatch will always send the --exclusive flag to sbatch. Generally not recommended!

    Default: False

  • fatmem=False|True

    If set to True, sgaubatch will auto-accept using fat-memory nodes.

    Default: False

  • jobname=name_of_job

    Name that will be used for the job. By default the filename of the input file (without suffix) will be used.

  • nosub=False|True

    If set to True, sgausbatch will only generate the batch script, but not submit it to the scheduler.

    Default: False

  • overwrite=False|True

    If set to True, sgausbatch will overwrite the script file if it already exists, otherwise sgausbatch will generate a script with the name filename_1.sh.

    Default: False

  • notest=False|True

    If set to True, sgausbatch will not check the gaussian inputfile with testrt.

    Default: False

  • template=full_path_to_script_template

    Specifies the template file that will be used to generate the batch script. If not specified, the default template file will be used.

  • time=HH:MM:SS

    Wall time limit for the job.

  • output_mode=verbose|silent|batch

    verbose: Verbose output.

    silent: No output, except questions if needed.

    batch: No interaction. Options not set will be ignored. Intended for use in batch scripts.

  • sbatchoptions=blank separated list of sbatch options

    List extra sbatch options to include in the job script. Generally not needed unless you want to use a specific reservation.

Examples

Set a default for job wall time and project to use for the job allocation:

Note that setting the account to use for a job allocation is only needed if you are included in several projects.

Use your own batch script template:

Add a few more sbatch options to the job batch script:

Note that sbatch options can also be added by editing the batch script template.

SBATCH environment variables

Installation Instructions Gm

Gaussian 16 Installation Instructions

sgausbatch will check and use these sbatch environment variables, but they have lower priority than command line options and options set in the user configuration file:

Gaussian 16 Installation Instructions Pdf

  • SBATCH_ACCOUNT
  • SBATCH_EXCLUSIVE
  • SBATCH_JOBNAME
  • SBATCH_TIMELIMIT

Script template file

Gaussian 16 Installation Instructions Pdf

Default batch script template file used by sgausbatch:

Gaussian 16 Installation Instructions

The script template is based on Mako Templates for Python, so look at that if you want to make substantial changes.