Both sides previous revision Previous revision Next revision | Previous revision |
basis_input [2024/02/14 10:50] – external edit 127.0.0.1 | basis_input [2024/10/25 16:12] (current) – remove links to basis.php may |
---|
Basis functions are used in Molpro not just for representing orbitals, but also for providing auxiliary sets for density fitting (see [[density fitting]]) and for simplifying integrals through approximate identity resolution in explicitly-correlated methods (see [[explicitly correlated methods]]). In order to accommodate this, the program maintains internally a number of different //sets//. The first of these always has the name ''ORBITAL'' and is the primary basis set for representing orbitals, and others can be defined as necessary as described below, or else are constructed automatically by the program when required. In the latter case, the density-fitting and other modules attempt to guess a reasonable library fitting basis that should be appropriate for the orbital basis set; it is advisable to check the choice when using anything other than a standard orbital basis set. | Basis functions are used in Molpro not just for representing orbitals, but also for providing auxiliary sets for density fitting (see [[density fitting]]) and for simplifying integrals through approximate identity resolution in explicitly-correlated methods (see [[explicitly correlated methods]]). In order to accommodate this, the program maintains internally a number of different //sets//. The first of these always has the name ''ORBITAL'' and is the primary basis set for representing orbitals, and others can be defined as necessary as described below, or else are constructed automatically by the program when required. In the latter case, the density-fitting and other modules attempt to guess a reasonable library fitting basis that should be appropriate for the orbital basis set; it is advisable to check the choice when using anything other than a standard orbital basis set. |
| |
The basis sets may either be taken from the [[https://www.molpro.net/info/basis.php|library,]] or may be specified explicitly, or any combination. Optionally, the basis function type can be chosen using the ''CARTESIAN'' or ''SPHERICAL'' commands. | The basis sets may either be taken from the library, or may be specified explicitly, or any combination. Optionally, the basis function type can be chosen using the ''CARTESIAN'' or ''SPHERICAL'' commands. |
| |
===== Cartesian and spherical harmonic basis functions ===== | ===== Cartesian and spherical harmonic basis functions ===== |
===== The basis set library ===== | ===== The basis set library ===== |
| |
The basis set library consists of a set of plain text files that constitute a database of commonly-used basis sets (primitive gaussians and associated contractions) and effective core potentials. These files can be found in the source tree as ''%%lib/*.libmol%%'', but it is usually more convenient to query the database using the [[https://www.molpro.net/info/basis.php|web interface]]. | The basis set library consists of a set of plain text files that constitute a database of commonly-used basis sets (primitive gaussians and associated contractions) and effective core potentials. These files can be found in the source tree as ''%%lib/*.libmol%%''. |
| |
Many of the basis sets are taken directly from the Basis Set Exchange [[https://www.basissetexchange.org|database]], but there are others, notably the Stuttgart [[http://www.tc.uni-koeln.de/PP/index.en.html|effective core potentials and bases]] and Grant Hill's database for correlation consistent basis sets, [[http://www.grant-hill.group.shef.ac.uk/ccrepo|ccRepo]]. | Many of the basis sets are taken directly from the Basis Set Exchange [[https://www.basissetexchange.org|database]], but there are others, notably the Stuttgart [[http://www.tc.uni-koeln.de/PP/index.en.html|effective core potentials and bases]] and Grant Hill's database for correlation consistent basis sets, [[http://www.grant-hill.group.shef.ac.uk/ccrepo|ccRepo]]. |
''BASIS=''//basis// | ''BASIS=''//basis// |
| |
//basis// is looked up in the file ''%%lib/defbas%%'', which generates an appropriate request for a complete contracted set, together in some cases with an ECP, from the [[https://www.molpro.net/info/basis.php|library]]. This mapping includes the following commonly-used basis sets: | //basis// is looked up in the file ''%%lib/defbas%%'', which generates an appropriate request for a complete contracted set, together in some cases with an ECP, from the library. This mapping includes the following commonly-used basis sets: |
| |
* All of the Dunning correlation consistent basis sets, through the use of either the standard name of the basis set (''cc-pVXZ'', ''aug-cc-pVXZ'') or an abbreviation (''VXZ'', ''AVXZ''). For Al-Ar the tight-d augmented sets are obtained through the standard name ''%%cc-pV(X+d)Z%%'', ''%%aug-cc-pV(X+d)Z%%'' or ''%%VXZ+d%%'', ''%%AVXZ+d%%''. Sets X=D,T,Q,5 are available for H-Kr with X=6 available for B-Ne and Al-Ar. | * All of the Dunning correlation consistent basis sets, through the use of either the standard name of the basis set (''cc-pVXZ'', ''aug-cc-pVXZ'') or an abbreviation (''VXZ'', ''AVXZ''). For Al-Ar the tight-d augmented sets are obtained through the standard name ''%%cc-pV(X+d)Z%%'', ''%%aug-cc-pV(X+d)Z%%'' or ''%%VXZ+d%%'', ''%%AVXZ+d%%''. Sets X=D,T,Q,5 are available for H-Kr with X=6 available for B-Ne and Al-Ar. |
| |
are equivalent to the above. Note that the default basis has to be specified before any atom specific sets. | are equivalent to the above. Note that the default basis has to be specified before any atom specific sets. |
| |
| Since Molpro2024.2 one can also define basis sets for ranges of atoms. The range is given as atom1-atom2, where Z(atom2)>Z(atom1), for example |
| |
| ''%%basis,default=awcvtz,h=vtz,b-cl=avtz %%'' |
| |
| |
===== Basis blocks ===== | ===== Basis blocks ===== |
//type,atom,name//,[''SCALE=''//scale//|''SCALE2=''//scale2//],[''NPRIM=''//nprim//|''DELETE=''//ndel//]; | //type,atom,name//,[''SCALE=''//scale//|''SCALE2=''//scale2//],[''NPRIM=''//nprim//|''DELETE=''//ndel//]; |
| |
Load basis named //name// from the [[https://www.molpro.net/info/basis.php|library]] | Load basis named //name// from the library. |
| |
If //scale// or //scale2// is present, all exponents are scaled by //scale// or //scale%%**%%2//, respectively. If //nprim// is specified, the first //nprim// exponents only are taken from the [[https://www.molpro.net/info/basis.php|library]]. If //nprim// is negative or //ndel// is given, the last |nprim| (ndel) basis functions from the [[https://www.molpro.net/info/basis.php|library]] set are deleted. Associated with the library basis may be a set of default contraction coefficients which may be accessed in subsequent contraction cards. //type// can include several types, e.g., ''SPD'' or ''DF''. This usually makes sense only with default contractions, i.e., such cards should be followed only by “''%% C%%''” without any other specifications for contractions. | If //scale// or //scale2// is present, all exponents are scaled by //scale// or //scale%%**%%2//, respectively. If //nprim// is specified, the first //nprim// exponents only are taken from the library. If //nprim// is negative or //ndel// is given, the last |nprim| (ndel) basis functions from the library set are deleted. Associated with the library basis may be a set of default contraction coefficients which may be accessed in subsequent contraction cards. //type// can include several types, e.g., ''SPD'' or ''DF''. This usually makes sense only with default contractions, i.e., such cards should be followed only by “''%% C%%''” without any other specifications for contractions. |
| |
b) Explicit basis input: | b) Explicit basis input: |
b) ''C''; | b) ''C''; |
| |
Use default contractions from the [[https://www.molpro.net/info/basis.php|library]]. This applies to both the number of contracted primitives and also to the number of different contraction sets. | Use default contractions from the library. This applies to both the number of contracted primitives and also to the number of different contraction sets. |
| |
c) n''C'',//first.last//; | c) n''C'',//first.last//; |
| |
n contracted functions taken from [[https://www.molpro.net/info/basis.php|library]]. //first.last// defines the range of primitives to be contracted. If n is omitted and //first.last// is specified, n=1. If //first.last// is omitted, the library default values are used. If both n and //first.last// are omitted, default values for both are used. | n contracted functions taken from library. //first.last// defines the range of primitives to be contracted. If n is omitted and //first.last// is specified, n=1. If //first.last// is omitted, the library default values are used. If both n and //first.last// are omitted, default values for both are used. |
| |
d) n''C'',//first.last,record.file,orb.sym//; | d) n''C'',//first.last,record.file,orb.sym//; |
} | } |
hf | hf |
| </code> |
| |
| The following example shows how to code the vtz basis set explicitly (exponents + contraction): |
| |
| <code - examples/h2o_scf_vtz_explicitbasisinput.inp> |
| gprint,basis |
| r=1.85,theta=104 !set geometry parameters |
| geometry={O; !z-matrix geometry input |
| H1,O,r; |
| H2,O,r,H1,theta} |
| !use VTZ basis, explicitly give exponents and contraction coefficients |
| basis={ |
| s,1,15330.000000,2299.000000,522.400000,147.300000,47.550000,16.760000,6.207000,1.752000,0.688200,0.238400; |
| c,1.10,0.000508,0.003929,0.020243,0.079181,0.230687,0.433118,0.350260,0.042728,-0.008154,0.002381; |
| c,1.10,-0.000115,-0.000895,-0.004636,-0.018724,-0.058463,-0.136463,-0.175740, 0.160934, 0.603418, 0.378765; |
| c,8.8,1.0 |
| c,10.10,1.0 |
| p,1,34.460000,7.749000,2.280000,0.715600,0.214000 |
| c,1.5,0.015928,0.099740,0.310492,0.491026,0.336337 |
| c,4.4,1.0 |
| c,5.5,1.0 |
| d,1,2.314000,0.645000 |
| f,1,1.428000 |
| |
| s,2,33.870000,5.095000,1.159000,0.325800,0.102700 |
| c,1.5,0.006068,0.045308,0.202822,0.503903,0.383421 |
| c,4.4,1.0 |
| c,5.5,1.0 |
| p,2,1.407000,0.388000 |
| d,2,1.057000 |
| |
| s,3,33.870000,5.095000,1.159000,0.325800,0.102700 |
| c,1.5,0.006068,0.045308,0.202822,0.503903,0.383421 |
| c,4.4,1.0 |
| c,5.5,1.0 |
| p,3,1.407000,0.388000 |
| d,3,1.057000 |
| } |
| hf !closed-shell scf |
</code> | </code> |
| |
See [[explicitly_correlated_methods#basis_sets|basis sets for explicitly correlated methods]] for examples when using explicitly correlated methods. | See [[explicitly_correlated_methods#basis_sets|basis sets for explicitly correlated methods]] for examples when using explicitly correlated methods. |
| |