Developer API
api - The main API Module
Main interface to Basis Set Exchange internal basis sets
This module contains the interface for getting basis set data and references from the internal data store of basis sets. As much as possible, this is being kept separate from the typical reading/writing functionality of the library.
- basis_set_exchange.api.filter_basis_sets(substr=None, family=None, role=None, elements=None, data_dir=None)
Filter basis sets by some criteria
All parameters are ANDed together and are not case sensitive.
- Parameters:
substr (str) – Substring to search for in the basis set name
family (str) – Family the basis set belongs to
role (str) – Role of the basis set
elements (str or list) – List of elements that the basis set must include. Elements can be specified by Z-number (int or str) or by symbol (str). If this argument is a str (ie, ‘1-3,7-10’), it is expanded into a list. Z numbers and symbols (case insensitive) can be used interchangeably (see
basis_set_exchange.misc.expand_elements()
)data_dir (str) – Data directory with all the basis set information. By default, it is in the ‘data’ subdirectory of this project.
- Returns:
Basis set metadata that matches the search criteria
- Return type:
dict
- basis_set_exchange.api.fix_data_dir(data_dir)
If data_dir is None, returns the default data_dir. Otherwise, returns the data_dir parameter unmodified
- basis_set_exchange.api.get_all_basis_names(data_dir=None)
Obtain a list of all basis set names
The returned list is the internal representation of the basis set name.
The data is read from the METADATA.json file in the data directory.
- Parameters:
data_dir (str) – Data directory with all the basis set information. By default, it is in the ‘data’ subdirectory of this project.
- basis_set_exchange.api.get_basis(name, elements=None, version=None, fmt=None, uncontract_general=False, uncontract_spdf=False, uncontract_segmented=False, remove_free_primitives=False, make_general=False, optimize_general=False, augment_diffuse=0, augment_steep=0, get_aux=0, data_dir=None, header=True)
Obtain a basis set
This is the main function for getting basis set information. This function reads in all the basis data and returns it either as a string or as a python dictionary.
- Parameters:
name (str) – Name of the basis set. This is not case sensitive.
elements (str or list) –
List of elements that you want the basis set for. Elements can be specified by Z-number (int or str) or by symbol (str). If this argument is a str (ie, ‘1-3,7-10’), it is expanded into a list. Z numbers and symbols (case insensitive) can be used interchangeably (see
basis_set_exchange.misc.expand_elements()
)If an empty string or list is passed, or if None is passed (the default), all elements for which the basis set is defined are included.
version (int or str) – Obtain a specific version of this basis set. By default, the latest version is returned.
fmt (str) –
The desired output format of the basis set. By default, basis set information is returned as a python dictionary. Otherwise, if a format is specified, a string is returned. Use
basis_set_exchange.api.get_formats()
to programmatically obtain the available formats. The fmt argument is not case sensitive.Available formats are
bdf
gamess_us
gaussian94
json
nwchem
psi4
turbomole
uncontract_general (bool) – If True, remove general contractions by duplicating the set of primitive exponents with each vector of coefficients. Primitives with zero coefficient are removed, as are duplicate shells.
uncontract_spdf (bool) – If True, remove general contractions with combined angular momentum (sp, spd, etc) by duplicating the set of primitive exponents with each vector of coefficients. Primitives with zero coefficient are removed, as are duplicate shells.
uncontract_segmented (bool) – If True, remove segmented contractions by duplicating each primitive into new shells. Each coefficient is set to 1.0
make_general (bool) – If True, make the basis set as generally-contracted as possible. There will be one shell per angular momentum (for each element)
optimize_general (bool) – Optimize by removing general contractions that contain uncontracted functions (see
basis_set_exchange.manip.optimize_general()
)augment_diffuse (int) – Add n diffuse functions by even-tempered extrapolation
augment_steep (int) – Add n steep functions by even-tempered extrapolation
get_aux (int) – Instead of the orbital basis, get an auxiliary basis set. Options 0 (return orbital basis), 1 (return AutoAux basis), 2 (return Auto-ABS Coulomb fitting basis)
data_dir (str) – Data directory with all the basis set information. By default, it is in the ‘data’ subdirectory of this project.
- Returns:
The basis set in the desired format. If fmt is None, this will be a python dictionary. Otherwise, it will be a string.
- Return type:
str or dict
- basis_set_exchange.api.get_basis_family(basis_name, data_dir=None)
Lookup a family by a basis set name
- basis_set_exchange.api.get_data_dir()
Get the default data directory of this installation
- basis_set_exchange.api.get_formats(function_types=None)
Return information about the basis set formats available
The returned data is a map of format to display name. The format can be passed as the fmt argument to
get_basis()
If a list is specified for function_types, only those formats supporting the given function types will be returned.
- basis_set_exchange.api.get_reference_formats()
Return information about the reference/citation formats available
The returned data is a map of format to display name. The format can be passed as the fmt argument to
get_references()
- basis_set_exchange.api.get_references(basis_name, elements=None, version=None, fmt=None, data_dir=None)
Get the references/citations for a basis set
- Parameters:
basis_name (str) – Name of the basis set. This is not case sensitive.
elements (list) – List of element numbers that you want the basis set for. By default, all elements for which the basis set is defined are included.
version (int) – Obtain a specific version of this basis set. By default, the latest version is returned.
fmt (str) –
The desired output format of the basis set references. By default, basis set information is returned as a list of dictionaries. Use get_reference_formats() to programmatically obtain the available formats. The fmt argument is not case sensitive.
Available reference formats are
bib
txt
json
data_dir (str) – Data directory with all the basis set information. By default, it is in the ‘data’ subdirectory of this project.
- Returns:
The references for the given basis set in the desired format. If fmt is None, this will be a python dictionary. Otherwise, it will be a string.
- Return type:
str or dict
- basis_set_exchange.api.get_roles()
Return information about the available basis set roles available
The returned data is a map of role to display name. The format can be passed as the role argument to fmt argument to
lookup_basis_by_role()
- basis_set_exchange.api.lookup_basis_by_role(primary_basis, role, data_dir=None)
Lookup the name of an auxiliary basis set given a primary basis set and role
- Parameters:
primary_basis (str) – The primary (orbital) basis set that we want the auxiliary basis set for. This is not case sensitive.
role (str) –
Desired role/type of auxiliary basis set. Use
get_roles()
to programmatically obtain the available roles. The role argument is not case sensitive.Available roles are
jfit
jkfit
rifit
optri
admmfit
dftxfit
dftjfit
guess
data_dir (str) – Data directory with all the basis set information. By default, it is in the ‘data’ subdirectory of this project.
- Returns:
The name of the auxiliary basis set for the given primary basis and role.
- Return type:
str
- basis_set_exchange.api.version()
Obtain the version of the basis set exchange library (as a string)
bundle - Creation of bundles/archives
Functions for creating archives of all basis sets
- basis_set_exchange.bundle.create_bundle(outfile, fmt, reffmt, archive_type=None, data_dir=None)
Create a single archive file containing all basis sets in a given format
- Parameters:
outfile (str) – Path to the file to create. Existing files will be overwritten
fmt (str) – Format of the basis set to archive (nwchem, turbomole, …)
reffmt (str) – Format of the basis set references to archive (nwchem, turbomole, …)
archive_type (str) – Type of archive to create. Can be ‘zip’ or ‘tbz’. Default is None, which will autodetect based on the outfile name
data_dir (str) – Data directory with all the basis set information. By default, it is in the ‘data’ subdirectory of this project.
- Return type:
None
- basis_set_exchange.bundle.get_archive_types()
Return information related to the types of archives available
compose - Composition of basis set information
Functions related to composing basis sets from individual components
- basis_set_exchange.compose.compose_elemental_basis(file_relpath, data_dir)
Creates an ‘elemental’ basis from an elemental json file
This function reads the info from the given file, and reads all the component basis set information from the files listed therein. It then composes all the information together into one ‘elemental’ basis dictionary
convert - Conversion of formatted basis set data/files
Functions for basis set conversion
- basis_set_exchange.convert.convert_formatted_basis_file(file_path_in, file_path_out, in_fmt=None, out_fmt=None, encoding='utf-8-sig', make_gen=False)
Convert a formatted basis set file to another format
- Parameters:
file_path_in (str) – Path to the file to be read
file_path_out (str) – Path to the file to be written.
in_fmt (str) – The format of the basis to be read. If None, it is detected from the file name
out_fmt (str) – The format of the basis to be written. If None, it is detected from the file name
encoding (str) – The encoding of the input file
- Returns:
The basis set as a str with the new format
- Return type:
str
- basis_set_exchange.convert.convert_formatted_basis_str(basis_in, in_fmt, out_fmt)
Convert a formatted basis set to another format
- Parameters:
basis_in (str) – String representing the formatted input basis set input
in_fmt (str) – The format of the basis set stored in basis_in
out_fmt (str) – The desired output format
- Returns:
The basis set as a str with the new format
- Return type:
str
fileio - Input/Output of files (including json)
Functions for reading and writing the standard JSON-based basis set format
- basis_set_exchange.fileio.get_all_filelist(data_dir)
Returns a tuple containing the following (as lists)
All metadata files
All table basis files
All element basis files
All component basis files
The paths to all the files are returned as paths relative to data_dir
- basis_set_exchange.fileio.read_json_basis(file_path)
Reads generic basis set information from a JSON file
After reading, the MolSSI BSE schema information is searched for and if not found, an exception is raised.
This function works with basis set metadata, table, element, and json files.
- Parameters:
file_path (str) – Full path to the file to read
- basis_set_exchange.fileio.read_metadata(file_path)
Reads a file containing the metadata for all the basis sets
- Parameters:
file_path (str) – Full path to the file to read
- basis_set_exchange.fileio.read_notes_file(file_path)
Returns the contents of a notes file.
If the notes file does not exist, None is returned
- basis_set_exchange.fileio.read_references(file_path)
Read a JSON file containing info for all references
- Parameters:
file_path (str) – Full path to the file to read
- basis_set_exchange.fileio.read_schema(file_path)
Reads a JSON schema file
- Parameters:
file_path (str) – Full path to the file to read
- basis_set_exchange.fileio.write_json_basis(file_path, bs)
Write basis set information to a JSON file
This function works with basis set metadata, table, element, and json files.
- Parameters:
file_path (str) – Full path to the file to write to. It will be overwritten if it exists
bs (dict) – Basis set information to write
- basis_set_exchange.fileio.write_metadata(file_path, metadata)
Reads a file containing the metadata for all the basis sets
- Parameters:
file_path (str) – Full path to the file to write to. It will be overwritten if it exists
metadata (dict) – Metadata information for all basis sets
- basis_set_exchange.fileio.write_references(file_path, refs)
Write a dict containing info for all references to a JSON file
- Parameters:
file_path (str) – Full path to the file to write to. It will be overwritten if it exists
refs (dict) – Reference information to write
lut - Lookup tables element information
Functions for looking up element names, numbers, and symbols and for converting between angular momentum conventions
This module has functions for looking up element information by symbol, name, or number. It also has functions for converting angular momentum between integers (0, 1, 2) and letters (s, p, d).
- basis_set_exchange.lut.all_element_blocks()
Obtain a list of the blocks the elements belong to
- basis_set_exchange.lut.all_element_names()
Obtain a list of the names of all the elements
- basis_set_exchange.lut.amchar_to_int(amchar, hij=False)
Convert an angular momentum integer to a character
The return value is a list of integers (to handle sp, spd, … orbitals)
For example, converts ‘p’ to [1] and ‘sp’ to [0,1]
If hij is True, the ordering spdfghijkl is used. Otherwise, the ordering will be spdfghikl (skipping j)
- basis_set_exchange.lut.amint_to_char(am, hij=False, use_L=False)
Convert an angular momentum integer to a character
The input is a list (to handle sp, spd, … orbitals). The return value is a string
For example, converts [0] to ‘s’ and [0,1,2] to ‘spd’
If hij is True, the ordering spdfghijkl is used. Otherwise, the ordering will be spdfghikl (skipping j)
If use_L is True, sp shells ([0,1]) will return l instead
- basis_set_exchange.lut.electron_shells_start(nelectrons, max_am=20)
Return the starting principle quantum numbers of electron shells
For example, an ECP covering 10 electrons will covers 1s, 2s, 2p shells. The electrons shells will then start at 3s, 3p, 3d, and 4f (returned as [3, 3, 3, 4])
If an ECP covers 30 electrons, then the shells will start at [5, 4, 4, 4]
Only fully-covered shells are counted. If a shell is partly covered, an exception is raised.
The returned list is extended up to max_am.
Note: Since the main use of this is for ECPs, we only cover what can really be found on the periodic table. No excited states!
- Parameters:
nelectrons (int) – Number of electrons covered by an ECP
max_am (int) – Fill out the starting principal quantum numbers up to this am
- Returns:
The starting principal quantum numbers of s, p, d, and f shells.
- Return type:
list
- basis_set_exchange.lut.element_Z_from_name(name, as_str=False)
Obtain an element’s Z number given its name
If as_str is True, then a string is returned (ie, ‘1’ for Hydrogen)
An exception is thrown if the name is not found
- basis_set_exchange.lut.element_Z_from_sym(sym, as_str=False)
Obtain an element’s Z-number given its symbol
If as_str is True, then a string is returned (ie, ‘1’ for Hydrogen)
An exception is thrown if the symbol is not found
- basis_set_exchange.lut.element_data_from_Z(Z)
Obtain elemental data given a Z number
An exception is thrown if the Z number is not found
- basis_set_exchange.lut.element_data_from_name(name)
Obtain elemental data given an elemental name
The given name is not case sensitive
An exception is thrown if the name is not found
- basis_set_exchange.lut.element_data_from_sym(sym)
Obtain elemental data given an elemental symbol
The given symbol is not case sensitive
An exception is thrown if the symbol is not found
- basis_set_exchange.lut.element_name_from_Z(Z, normalize=False)
Obtain an element’s name from its Z number
An exception is thrown if the Z number is not found
If normalize is True, the first letter will be capitalized
- basis_set_exchange.lut.element_sym_from_Z(Z, normalize=False)
Obtain an element’s symbol from its Z number
An exception is thrown if the Z number is not found
If normalize is True, the first letter will be capitalized
manip - Manipulation of basis sets
Common basis set manipulations
This module contains functions for uncontracting and merging basis set data, as well as some other small functions.
- basis_set_exchange.manip.autoabs_basis(basis, lmaxinc=1, fsam=1.5)
Create a Coulomb fitting basis set for the given orbital basis set.
See also
R. Yang, A. P. Rendell, and M. J. Frisch‘Automatically generated Coulomb fitting basis sets:Design and accuracy for systems containing H to Kr’J. Chem. Phys. 127, 074102 (2007)- Parameters:
basis (dict) – Orbital basis set dictionary for which to generate the auxiliary basis
- basis_set_exchange.manip.autoaux_basis(basis)
Create an auxiliary basis set for the given orbital basis set for use with the resolution of the identity approximation. This is a simplified version of the routine where the electrons potentially contained in the ECP are disregarded, leading to slightly larger (but more accurate) auxiliary sets.
See also
G. L. Stoychev, A. A. Auer, and F. Neese‘Automatic Generation of Auxiliary Basis Sets’J. Chem. Theory Comput. 13, 554 (2017)- basisdict
Orbital basis set dictionary for which to generate the auxiliary basis
- basis_set_exchange.manip.create_element_data(bs_data, element_Z, key, key_exist_ok=False, element_exist_ok=True, create=<class 'list'>)
Creates an element and a subkey of the element in bs_data
Note that bs_data is modified!
- basis_set_exchange.manip.geometric_augmentation(basis, nadd, use_copy=True, as_component=False, steep=False)
Extends a basis set by adding extrapolated diffuse or steep functions.
For augmented Dunning sets (aug), the diffuse augmentation corresponds to multiple augmentation (aug -> daug, taug, …).
In order for the augmentation to make sense, the two outermost primitives have to be free i.e. uncontracted.
- Parameters:
basis (dict) – Basis set dictionary to work with
nadd (int) – Number of functions to add (must be >=1). For diffuse augmentation on an augmented set: 1 -> daug, 2 -> taug, etc
use_copy (bool) – If True, the input basis set is not modified.
steep (bool) – If True, the augmentation is done for steep functions instead of diffuse functions.
- basis_set_exchange.manip.make_general(basis, skip_spdf=False, use_copy=True)
Makes one large general contraction for each angular momentum
If use_copy is True, the input basis set is not modified.
The output of this function is not pretty. If you want to make it nicer, use sort_basis afterwards.
- basis_set_exchange.manip.merge_element_data(dest, sources, use_copy=True)
Merges the basis set data for an element from multiple sources into dest.
The destination is not modified, and a (shallow) copy of dest is returned with the data from sources added.
If use_copy is True, then the data merged into dest will be a (deep) copy of that found in sources. Otherwise, data may be shared between dest and sources
- basis_set_exchange.manip.optimize_general(basis, use_copy=True)
Optimizes the general contraction using the method of Hashimoto et al
See also
T. Hashimoto, K. Hirao, H. Tatewaki‘Comment on Dunning’s correlation-consistent basis set’Chemical Physics Letters v243, Issues 1-2, pp, 190-192 (1995)
- basis_set_exchange.manip.prune_basis(basis, use_copy=True)
Removes primitives that have a zero coefficient, and removes duplicate primitives and shells
This only finds EXACT duplicates, and is meant to be used after other manipulations
If use_copy is True, the input basis set is not modified.
- basis_set_exchange.manip.prune_shell(shell, use_copy=True)
Removes exact duplicates of primitives, and condenses duplicate exponents into general contractions
Also removes primitives if all coefficients are zero
- basis_set_exchange.manip.remove_free_primitives(basis, use_copy=True)
Removes any free primitives from a basis set as a way to generate a minimal basis
The input basis set is not modified. The returned basis may have functions with coefficients of zero and may have duplicate shells.
If use_copy is True, the input basis set is not modified.
- basis_set_exchange.manip.remove_primitive(electron_shell, idx_to_remove)
Removes a primitive (by index) of a electron_shell
The electron_shell passed in is modified
- basis_set_exchange.manip.truhlar_calendarize(basis, month, use_copy=True)
Create the truhlar “month” basis sets from the corresponding aug basis set
In Papajak 2011, removal of diffuse function stopped before removal of s and p functions. This, conceivably, extends to d functions for transition metals. However, you can keep extending to further in the year by removing these functions, although it may affect stability. This is implemented in Gaussian with the t(month) basis sets - tjul, tjun, etc. The ‘tmonth’ and regular ‘month’ basis sets are equivalent until the ‘maug’ basis set is reached (containg no diffuse functions on H,He, s,p,d on transition metals, and s, p on other elements).
Since the regular ‘month’ basis sets are equivalent until maug, we do not adopt the t(month) nomenclature. Instead, you can just go further backwards through the months until you run out of diffuse functions or run out of months.
- Parameters:
basis (dict) – Basis set dictionary to work with
month (str) – Month to create (‘apr’, ‘jul’, etc). Not case sensitive
use_copy (bool) – If True, the input basis set is not modified.
- basis_set_exchange.manip.uncontract_general(basis, use_copy=True)
Removes the general contractions from a basis set
The input basis set is not modified. The returned basis may have functions with coefficients of zero and may have duplicate shells.
If use_copy is True, the input basis set is not modified.
- basis_set_exchange.manip.uncontract_segmented(basis, use_copy=True)
Removes the segmented contractions from a basis set
This implicitly removes general contractions as well, but will leave sp, spd, … orbitals alone
The input basis set is not modified. The returned basis may have functions with coefficients of zero and may have duplicate shells.
If use_copy is True, the input basis set is not modified.
- basis_set_exchange.manip.uncontract_spdf(basis, max_am=0, use_copy=True)
Removes sp, spd, spdf, etc, contractions from a basis set
The general contractions are replaced by uncontracted versions
Contractions up to max_am will be left in place. For example, if max_am = 1, spd will be split into sp and d
The input basis set is not modified. The returned basis may have functions with coefficients of zero and may have duplicate shells.
If use_copy is True, the input basis set is not modified.
memo - Custom memoization decorator
Class/decorator for memoizing BSE functionality
misc - Miscellaneous helper functions
Miscellaneous helper functions
- basis_set_exchange.misc.basis_name_from_filename(filename)
Given a basis set name that was part of a filename, determine the basis set name
This is opposite of
transform_basis_name()
Pass only the part of the filename that contains the basis set name
- basis_set_exchange.misc.basis_name_to_filename(name)
Given a basis set name, transform it into a valid filename
This makes sure filenames don’t contain invalid characters
- basis_set_exchange.misc.compact_elements(elements)
Create a string (with ranges) given a list of element numbers
For example, [1, 2, 3, 6, 7, 8, 10] will return “H-Li,C-O,Ne”
- basis_set_exchange.misc.contraction_string(element, compact=False)
Forms a string specifying the contractions for an element
ie, (16s,10p) -> [4s,3p] or, if compact=True, 16s10p.4s3p
- basis_set_exchange.misc.expand_elements(compact_el, as_str=False)
Create a list of integers given a string or list of compacted elements
This is partly the opposite of compact_elements, but is more flexible.
compact_el can be a list or a string. If compact_el is a list, each element is processed individually as a string (meaning list elements can contain commas, ranges, etc) If compact_el is a string, it is split by commas and then each section is processed.
In all cases, element symbols (case insensitive) and Z numbers (as integers or strings) can be used interchangeably. Ranges are also allowed in both lists and strings.
- Some examples:
“H-Li,C-O,Ne” will return [1, 2, 3, 6, 7, 8, 10] “H-N,8,Na-12” will return [1, 2, 3, 4, 5, 6, 7, 8, 11, 12] [‘C’, ‘Al-15,S’, 17, ‘18’] will return [6, 13, 14, 15, 16, 17, 18]
If as_str is True, the list will contain strings of the integers (ie, the first example above will return [‘1’, ‘2’, ‘3’, ‘6’, ‘7’, ‘8’, ‘10’]
- basis_set_exchange.misc.max_am(shells)
Determine the maximum angular momentum of a list of shells or potentials
- basis_set_exchange.misc.transform_basis_name(name)
Transforms the name of a basis set to an internal representation
This makes comparison of basis set names easier by, for example, converting the name to all lower case.
- basis_set_exchange.misc.transpose_matrix(mat)
Transposes a matrix (list of lists) commonly done do coefficients
notes - Handling of notes
Functionality for handling basis set and family notes
- basis_set_exchange.notes.process_notes(notes, ref_data)
Add reference information to the bottom of a notes file
:ref: tags are removed and the actual reference data is appended
printing - Functions for printing/outputting pieces of basis sets
Helpers for printing pieces of basis sets
- basis_set_exchange.printing.component_basis_str(basis, elements=None)
Print a component basis set
If elements is not None, only the specified elements will be printed (see
bse.misc.expand_elements()
)
- basis_set_exchange.printing.ecp_pot_str(pot)
Return a string representing the data for an ECP potential
- basis_set_exchange.printing.electron_shell_str(shell, shellidx=None)
Return a string representing the data for an electron shell
If shellidx (index of the shell) is not None, it will also be printed
- basis_set_exchange.printing.element_data_str(z, eldata)
Return a string with all data for an element
This includes shell and ECP potential data
- Parameters:
z (int or str) – Element Z-number
eldata (dict) – Data for the element to be printed
references - Handling of reference data
Some helper functions related to handling of references/citations
- basis_set_exchange.references.compact_references(basis_dict, ref_data)
Creates a mapping of elements to reference keys
A list is returned, with each element of the list being a dictionary with entries ‘reference_info’ containing data for (possibly) multiple references, and ‘elements’ which is a list of element Z numbers that those references apply to
- Parameters:
basis_dict (dict) – Dictionary containing basis set information
ref_data (dict) – Dictionary containing all reference information
- basis_set_exchange.references.reference_text(key, ref)
Convert a single reference to plain text format
- Parameters:
key (str) – Reference key (authorname2009a, etc)
ref (dict) – Information about a single reference
skel - Creating of python object skeletons of basis set data
Functions for creating skeletons of dictionaries/JSON files
- basis_set_exchange.skel.create_skel(role)
Create the skeleton of a dictionary or JSON file
A dictionary is returned that contains the “molssi_bse_schema” key and other required keys, depending on the role
role can be either ‘component’, ‘element’, or ‘table’
sort - Sorting of basis set data
Sorting of BSE related dictionaries and data
- basis_set_exchange.sort.sort_basis(basis, use_copy=True)
Sorts all the information in a basis set into a standard order
If use_copy is True, the input basis set is not modified.
- basis_set_exchange.sort.sort_basis_dict(bs)
Sorts a basis set dictionary into a standard order
This, for example, allows the written file to be more easily read by humans by, for example, putting the name and description before more detailed fields.
This is generally for cosmetic reasons. However, users will generally like things in a consistent order
- basis_set_exchange.sort.sort_potentials(potentials, use_copy=True)
Sort a list of ECP potentials into a standard order
The order within a potential is not modified.
The order of the shell list is in increasing angular momentum, with the largest angular momentum being moved to the front.
If use_copy is True, the input potentials are not modified.
- basis_set_exchange.sort.sort_references_dict(refs)
Sorts a reference dictionary into a standard order
The keys of the references are also sorted, and the keys for the data for each reference are put in a more canonical order.
- basis_set_exchange.sort.sort_shell(shell, use_copy=True)
Sort a basis set shell into a standard order
If use_copy is True, the input shells are not modified.
- basis_set_exchange.sort.sort_shells(shells, use_copy=True)
Sort a list of basis set shells into a standard order
The order within a shell is by decreasing value of the exponent.
The order of the shell list is in increasing angular momentum, and then by decreasing number of primitives, then decreasing value of the largest exponent.
If use_copy is True, the input shells are not modified.
- basis_set_exchange.sort.sort_single_reference(ref_entry)
Sorts a dictionary containing data for a single reference into a standard order
validator - Validation of basis sets
Functions related to validating JSON files (including against schema)
- basis_set_exchange.validator.validate_data(file_type, bs_data)
Validates json basis set data against a schema
- Parameters:
file_type (str) – Type of the data to validate. May be ‘component’, ‘element’, ‘table’, ‘complete’, ‘minimal’, or ‘references’
bs_data – Data to be validated
- Raises:
RuntimeError – If the file_type is not valid (and/or a schema doesn’t exist)
ValidationError – If the given file does not pass validation
FileNotFoundError – If the file given by file_path doesn’t exist
- basis_set_exchange.validator.validate_data_dir(data_dir)
Validates all files in a data_dir
- basis_set_exchange.validator.validate_file(file_type, file_path)
Validates a file against a schema
- Parameters:
file_type (str) – Type of file to read. May be ‘component’, ‘element’, ‘table’, ‘complete’, ‘minimal’, or ‘references’
file_path – Full path to the file to be validated
- Raises:
RuntimeError – If the file_type is not valid (and/or a schema doesn’t exist)
ValidationError – If the given file does not pass validation
FileNotFoundError – If the file given by file_path doesn’t exist