NAME
NBI::Opts - A class for representing a the SLURM options for NBI::Slurm
VERSION
version 0.4.1
SYNOPSIS
SLURM Options for NBI::Slurm, to be passed to a NBI::Job object.
use NBI::Opts;
my $opts = NBI::Opts->new(
-queue => "short",
-threads => 4,
-memory => 8,
-opts => []
);
DESCRIPTION
The NBI::Opts
module provides a class for representing the SLURM options used by NBI::Slurm for job submission. It allows you to set various options such as the queue, number of threads, allocated memory, execution time, and more.
METHODS
new()
Create a new instance of CNBI::Opts.
my $opts = NBI::Opts->new(
-queue => "short",
-threads => 4,
-memory => 8,
-opts => ["--option=Value"],
);
This method creates a new NBI::Opts
object with the specified options. The following parameters are supported:
-queue (string, optional)
The SLURM queue to submit the job to. If not provided, the default queue will be used.
-threads (integer, optional)
The number of threads to allocate for the job. If not provided, the default value is 1.
-memory (string or integer (Mb), optional)
The allocated memory for the job. It can be specified as a bare number representing megabytes (e.g., 1024), or with a unit suffix (e.g., 1GB). If not provided, the default value is 100 megabytes.
-opts (arrayref, optional)
An array reference containing additional SLURM options to be passed to the job script. Each option should be specified as a string. For example, ["--output=TestJob.out", "--mail-user user@nmsu.edu"]. If not provided, no additional options will be added.
NOTE that some options are set by other methods (like
output_file
andemail_address
): do not specify them manually.
queue
Accessor method for the SLURM queue.
$opts->queue = "long";
my $queue = $opts->queue;
This method allows you to get or set the SLURM queue for the job. If called with an argument, it sets the queue to the specified value. If called without an argument, it returns the current queue value.
threads
Accessor method for the number of threads.
$opts->threads = 8;
my $threads = $opts->threads;
This method allows you to get or set the number of threads allocated for the job. If called with an argument, it sets the number of threads to the specified value. If called without an argument, it returns the current number of threads.
memory
Accessor method for the allocated memory.
$opts->memory = 16;
my $memory = $opts->memory;
This method allows you to get or set the allocated memory for the job. If called with an argument, it sets the memory to the specified value. If called without an argument, it returns the current allocated memory.
email_address
Accessor method for the email address.
$opts->email_address = "user@example.com";
my $email_address = $opts->email_address;
This method allows you to get or set the email address to which job notifications will be sent. If called with an argument, it sets the email address to the specified value. If called without an argument, it returns the current email address.
email_type
Accessor method for the email type.
$opts->email_type = "end";
my $email_type = $opts->email_type;
This method allows you to get or set the type of email notifications to receive. Possible values are "none" (no email notifications), "begin" (send email at the start of the job), "end" (send email at the end of the job), or "all" (send email for all job events). If called with an argument, it sets the email type to the specified value. If called without an argument, it returns the current email type.
hours
Accessor method for the execution time in hours.
$opts->hours = 24;
my $hours = $opts->hours;
This method allows you to get or set the execution time for the job in hours. If called with an argument, it sets the execution time to the specified value. If called without an argument, it returns the current execution time.
tmpdir
Accessor method for the temporary directory.
$opts->tmpdir = "/path/to/tmpdir";
my $tmpdir = $opts->tmpdir;
This method allows you to get or set the temporary directory path where temporary files for the job will be stored. If called with an argument, it sets the temporary directory to the specified value. If called without an argument, it returns the current temporary directory.
opts
Accessor method for the additional SLURM options.
$opts->opts = ["--output=TestJob.out", "--mail-user user@nmsu.edu"];
my $opts_array = $opts->opts;
This method allows you to get or set the additional SLURM options for the job. The options should be specified as an array reference, where each element is a string representing a single option. If called with an argument, it sets the additional options to the specified array reference. If called without an argument, it returns the current additional options.
add_option
Add an additional SLURM option.
$opts->add_option("--output=TestJob.out");
This method allows you to add an additional SLURM option to the options list.
opts_count
Get the number of additional SLURM options.
my $count = $opts->opts_count;
This method returns the number of additional SLURM options specified for the job.
view
Get a string representation of the options.
my $str = $opts->view;
This method returns a string representation of the CNBI::Opts object, including all the options and their values.
header
Generate the SLURM header for the job script.
my $header = $opts->header;
This method generates the SLURM header for the job script based on the current options and returns it as a string.
timestring
Get the execution time as a formatted string.
my $timestring = $opts->timestring;
This method returns the execution time as a formatted string in the format "DD-HH:MM:SS", where "DD" is the number of days, "HH" is the number of hours (in 2 digits), "MM" is the number of minutes, and "SS" is the number of seconds.
AUTHOR
Andrea Telatin <proch@cpan.org>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2023 by Andrea Telatin.
This is free software, licensed under:
The MIT (X11) License