diff --git a/bin/lowdin b/bin/lowdin
index 3a709f9c..6377f7d1 100755
--- a/bin/lowdin
+++ b/bin/lowdin
@@ -204,6 +204,9 @@ if [ $extFile="lowdin" ]; then
else if(toupper($i)==toupper("m")){
printf("\tInputParticle_mass = %s\n",toupper($(i+2)) )
}
+ else if(toupper($i)==toupper("eta")){
+ printf("\tInputParticle_eta = %s\n",toupper($(i+2)) )
+ }
else if(toupper($i)==toupper("omega")){
printf("\tInputParticle_omega = %s\n",toupper($(i+2)) )
}
@@ -381,10 +384,10 @@ if [ $extFile="lowdin" ]; then
' | $SED "s/,/./g" >> $nameFile.aux
###########################################
- # Check custom basis sets in the input
+ # Check custom basis sets/potentials in the input
###########################################
- BASIS_NAMES=(`gawk '($1~/BASIS/){print toupper($2)}' $nameFile`)
+ BASIS_NAMES=(`gawk '($1~/^BASIS$/){print toupper($2)}' $nameFile`)
if [ ${#BASIS_NAMES[@]} -gt "0" ]
then
for BASIS_NAME in ${BASIS_NAMES[@]}
@@ -401,6 +404,23 @@ if [ $extFile="lowdin" ]; then
done
fi
+ POTENTIALS_NAMES=(`gawk '($1~/^POTENTIAL$/){print toupper($2)}' $nameFile`)
+ if [ ${#POTENTIALS_NAMES[@]} -gt "0" ]
+ then
+ for POTENTIALS_NAME in ${POTENTIALS_NAMES[@]}
+ do
+ if [ -e $LOWDIN_DATA/basis/$POTENTIALS_NAME ]
+ then
+ echo "## ERROR: ## The custom potential file already exists in " $LOWDIN_DATA/potentials/$POTENTIALS_NAME
+ echo "Modify the POTENTIALS block in your input and select a different name"
+ exit 1
+ fi
+ gawk '($1~/POTENTIALS/ && toupper($2)~/^'$POTENTIALS_NAME'$/){flag=1; next}
+ ($0~/END/){flag=0};
+ (flag==1){print toupper($0)}' $nameFile > $POTENTIALS_NAME.$PID
+ done
+ fi
+
###########################################
# Exec lowdin.x
@@ -421,6 +441,7 @@ if [ $extFile="lowdin" ]; then
cp $nameFile*.vec $LOWDIN_SCRATCH/$nameFile &> /dev/null
cp $nameFile*.plainvec $LOWDIN_SCRATCH/$nameFile &> /dev/null
+ cp $nameFile*.fchk $LOWDIN_SCRATCH/$nameFile &> /dev/null
cp $nameFile*.val $LOWDIN_SCRATCH/$nameFile &> /dev/null
cp $nameFile*.dens $LOWDIN_SCRATCH/$nameFile &> /dev/null
cp $nameFile*.sup $LOWDIN_SCRATCH/$nameFile &> /dev/null
@@ -432,7 +453,9 @@ if [ $extFile="lowdin" ]; then
mv $nameFile*.over $LOWDIN_SCRATCH/$nameFile &> /dev/null
mv $nameFile*.kin $LOWDIN_SCRATCH/$nameFile &> /dev/null
mv $nameFile*.coeff $LOWDIN_SCRATCH/$nameFile &> /dev/null
- #PID to avoid basis duplicates in simultaneous calculations
+ cp $nameFile*.gms.bs $LOWDIN_SCRATCH/$nameFile &> /dev/null
+
+ #PID to avoid basis/potentials duplicates in simultaneous calculations
if [ ${#BASIS_NAMES[@]} -gt "0" ]
then
for BASIS_NAME in ${BASIS_NAMES[@]}
@@ -440,12 +463,14 @@ if [ $extFile="lowdin" ]; then
mv $BASIS_NAME.$PID $LOWDIN_SCRATCH/$nameFile/$BASIS_NAME &> /dev/null
done
fi
-
- if [ -e $nameFile.gms.bs ]
+ if [ ${#POTENTIALS_NAMES[@]} -gt "0" ]
then
- cp $nameFile.gms.bs $LOWDIN_SCRATCH/$nameFile
+ for POTENTIALS_NAME in ${POTENTIALS_NAMES[@]}
+ do
+ mv $POTENTIALS_NAME.$PID $LOWDIN_SCRATCH/$nameFile/$POTENTIALS_NAME &> /dev/null
+ done
fi
-
+
# setting default number of cores for OpenMP
if [ -z "$OMP_NUM_THREADS" ]; then
@@ -515,6 +540,7 @@ if [ $extFile="lowdin" ]; then
mv $LOWDIN_SCRATCH/$nameFile/$nameFile*.47 $currentPath &> 2
mv $LOWDIN_SCRATCH/$nameFile/*.vec $currentPath &> 2
mv $LOWDIN_SCRATCH/$nameFile/*.plainvec $currentPath &> 2
+ mv $LOWDIN_SCRATCH/$nameFile/*.fchk $currentPath &> 2
# mv $LOWDIN_SCRATCH/$nameFile/*.val $currentPath &> 2
mv $LOWDIN_SCRATCH/$nameFile/*.NOCI.coords $currentPath &> 2
mv $LOWDIN_SCRATCH/$nameFile/*.NOCI.s* $currentPath &> 2
diff --git a/lib/basis/H2O-1S1P1D b/lib/basis/H2O-1S1P1D
deleted file mode 100644
index cc7027ba..00000000
--- a/lib/basis/H2O-1S1P1D
+++ /dev/null
@@ -1,44 +0,0 @@
-O-HYDROGEN H_1 (1S) BASIS TYPE: 2
-3
-1 0 1
-14.509888498676842 1.0
-2 1 1
-6.885507269761004 1.0
-3 2 1
-9.023681376783887 1.0
-
-O-HYDROGEN H-A_1 (1S) BASIS TYPE: 2
-3
-1 0 1
-14.509888498676842 1.0
-2 1 1
-6.885507269761004 1.0
-3 2 1
-9.023681376783887 1.0
-
-O-HYDROGEN H-B_1 (1S) BASIS TYPE: 2
-3
-1 0 1
-14.509888498676842 1.0
-2 1 1
-6.885507269761004 1.0
-3 2 1
-9.023681376783887 1.0
-
-O-H-TIP X0.5+ (1S) BASIS TYPE: 2
-3
-1 0 1
-14.509888498676842 1.0
-2 1 1
-6.885507269761004 1.0
-3 2 1
-9.023681376783887 1.0
-
-O-H-TIP Y0.5+ (1S) BASIS TYPE: 2
-3
-1 0 1
-14.509888498676842 1.0
-2 1 1
-6.885507269761004 1.0
-3 2 1
-9.023681376783887 1.0
diff --git a/lib/basis/PSX-DZ b/lib/basis/PSX-DZ
index 35b403de..0d5600b6 100644
--- a/lib/basis/PSX-DZ
+++ b/lib/basis/PSX-DZ
@@ -1,5 +1,53 @@
-O-POSITRON E+ (5S) BASIS TYPE: 3
-# (5S)-[5S]
+O-POSITRON E+ (5S3P2D) BASIS TYPE: 3
+# (5S3P2D)-[5S3P2D]
+10
+1 0 1
+.0189693659 1.0
+1 0 1
+.05186863351164733038 1.0
+1 0 1
+.14182630861506996771 1.0
+1 0 1
+.38780088183468771642 1.0
+1 0 1
+1.06037818667291718709 1.0
+1 1 1
+.0590955656 1.0
+1 1 1
+.16127967470846848928 1.0
+1 1 1
+.44015372744092004227 1.0
+1 2 1
+.11654481880000000000 1.0
+1 2 1
+.31287113568838127412 1.0
+
+O-POSITRON E+A (5S3P2D) BASIS TYPE: 3
+# (5S3P2D)-[5S3P2D]
+10
+1 0 1
+.0189693659 1.0
+1 0 1
+.05186863351164733038 1.0
+1 0 1
+.14182630861506996771 1.0
+1 0 1
+.38780088183468771642 1.0
+1 0 1
+1.06037818667291718709 1.0
+1 1 1
+.0590955656 1.0
+1 1 1
+.16127967470846848928 1.0
+1 1 1
+.44015372744092004227 1.0
+1 2 1
+.11654481880000000000 1.0
+1 2 1
+.31287113568838127412 1.0
+
+O-POSITRON E+B (5S3P2D) BASIS TYPE: 3
+# (5S3P2D)-[5S3P2D]
10
1 0 1
.0189693659 1.0
diff --git a/lib/dataBases/constantsOfCoupling.lib b/lib/dataBases/constantsOfCoupling.lib
index bda5b291..1f940075 100644
--- a/lib/dataBases/constantsOfCoupling.lib
+++ b/lib/dataBases/constantsOfCoupling.lib
@@ -4525,19 +4525,3 @@
LAMBDA = 2.0
PARTICLESFRACTION = 0.5
/
-&SPECIE
- NAME = "HA-TIP"
- SYMBOL = "X0.5+"
- KAPPA = -1.0
- ETA = 1.0
- LAMBDA = 1.0
- PARTICLESFRACTION = 1
-/
-&SPECIE
- NAME = "HB-TIP"
- SYMBOL = "Y0.5+"
- KAPPA = -1.0
- ETA = 1.0
- LAMBDA = 1.0
- PARTICLESFRACTION = 1
-/
diff --git a/lib/dataBases/elementalParticles.lib b/lib/dataBases/elementalParticles.lib
index d6630a9b..54376343 100644
--- a/lib/dataBases/elementalParticles.lib
+++ b/lib/dataBases/elementalParticles.lib
@@ -171,7 +171,7 @@
SYMBOL = "HEA3"
CATEGORY = "LEPTON"
CHARGE = 1
- MASS = 5494.892576965
+ MASS = 5495.8851
SPIN = 0.5
/
&PARTICLE
@@ -179,7 +179,7 @@
SYMBOL = "HEB3"
CATEGORY = "LEPTON"
CHARGE = 1
- MASS = 5494.892576965
+ MASS = 5495.8851
SPIN = 0.5
/
&PARTICLE
@@ -187,7 +187,7 @@
SYMBOL = "HES3"
CATEGORY = "LEPTON"
CHARGE = 1
- MASS = 5494.892576965
+ MASS = 5495.8851
SPIN = 0.5
/
&PARTICLE
@@ -195,7 +195,7 @@
SYMBOL = "HEA4"
CATEGORY = "LEPTON"
CHARGE = 1
- MASS = 7292.327967297
+ MASS = 7294.2994
SPIN = 0.5
/
&PARTICLE
@@ -203,7 +203,7 @@
SYMBOL = "HEB4"
CATEGORY = "LEPTON"
CHARGE = 1
- MASS = 7292.327967297
+ MASS = 7294.2994
SPIN = 0.5
/
&PARTICLE
@@ -211,31 +211,7 @@
SYMBOL = "HES4"
CATEGORY = "LEPTON"
CHARGE = 1
- MASS = 7292.327967297
- SPIN = 0.5
-/
-&PARTICLE
- NAME = "HA-TIP"
- SYMBOL = "X0.5+"
- CATEGORY = "LEPTON"
- CHARGE = 0.5564
- MASS = 1836.15267247
- SPIN = 0.5
-/
-&PARTICLE
- NAME = "HB-TIP"
- SYMBOL = "Y0.5+"
- CATEGORY = "LEPTON"
- CHARGE = 0.5564
- MASS = 1836.15267247
- SPIN = -0.5
-/
-&PARTICLE
- NAME = "M-TIP"
- SYMBOL = "X1.1-"
- CATEGORY = "LEPTON"
- CHARGE = -1.1128
- MASS = 1836.15267247
+ MASS = 7294.2994
SPIN = 0.5
/
&PARTICLE
diff --git a/src/core/ConstantsOfCoupling.f90 b/src/core/ConstantsOfCoupling.f90
index 3e3bba2c..0c190802 100644
--- a/src/core/ConstantsOfCoupling.f90
+++ b/src/core/ConstantsOfCoupling.f90
@@ -71,59 +71,53 @@ subroutine ConstantsOfCoupling_load( this, symbolSelected )
!! Looking for library
inquire(file=trim(CONTROL_instance%DATA_DIRECTORY)//"/dataBases/constantsOfCoupling.lib", exist=existFile)
- if ( existFile ) then
-
- !! Open library
- open(unit=10, file=trim(CONTROL_instance%DATA_DIRECTORY)//"/dataBases/constantsOfCoupling.lib", status="old", form="formatted" )
-
- !! Read information
- symbol = "NONE"
- stat = 0
-
- do while(trim(symbol) /= trim(symbolSelected))
-
- !! Setting defaults
- name = "NONE"
- kappa = 0
- eta = 0
- particlesFraction = 1
-
- if (stat == -1 ) then
-
- call ConstantsOfCoupling_exception( ERROR, "Elemental particle: "//trim(symbolSelected)//" NOT found!!", "In ConstantsOfCoupling at load function.")
- this%isInstanced = .false.
+ if ( .not. existFile ) call ConstantsOfCoupling_exception( ERROR, "LOWDIN library not found!! please export lowdinvars.sh file.", "In ConstantsOfCoupling at load function.")
+
+ !! Open library
+ open(unit=10, file=trim(CONTROL_instance%DATA_DIRECTORY)//"/dataBases/constantsOfCoupling.lib", status="old", form="formatted" )
- end if
-
- read(10,NML=specie, iostat=stat)
-
- if (stat > 0 ) then
-
- call ConstantsOfCoupling_exception( ERROR, "Failed reading ConstantsOfCouplings.lib file!! please check this file.", "In ConstantsOfCoupling at load function.")
-
- end if
+ !! Read information
+ symbol = "NONE"
+ stat = 0
- end do
+ do while(trim(symbol) /= trim(symbolSelected))
- !! Set object variables
- this%name = name
- this%symbol = symbol
- this%kappa = kappa
- this%eta = eta
- this%lambda = lambda
- this%particlesFraction = particlesFraction
-
- !! Debug information.
- !! call ConstantsOfCoupling_show(this)
-
- close(10)
+ !! Setting defaults
+ name = "NONE"
+ kappa = 0
+ eta = 0
+ particlesFraction = 1
- else
+ if (stat == -1 ) then
- call ConstantsOfCoupling_exception( ERROR, "LOWDIN library not found!! please export lowdinvars.sh file.", "In ConstantsOfCoupling at load function.")
+ ! call ConstantsOfCoupling_exception( WARNING, "Elemental particle: "//trim(symbolSelected)//" NOT found!!", "Setting default values")
+ this%isInstanced=.false.
+ exit
+ end if
- end if
+ read(10,NML=specie, iostat=stat)
+ if (stat > 0 ) then
+
+ call ConstantsOfCoupling_exception( ERROR, "Failed reading ConstantsOfCouplings.lib file!! please check this file.", "In ConstantsOfCoupling at load function.")
+
+ end if
+
+ end do
+
+ !! Set object variables
+ this%name = name
+ this%symbol = symbol
+ this%kappa = kappa
+ this%eta = eta
+ this%lambda = lambda
+ this%particlesFraction = particlesFraction
+
+ !! Debug information.
+ ! call ConstantsOfCoupling_show(this)
+
+ close(10)
+
!! Done
end subroutine ConstantsOfCoupling_load
diff --git a/src/core/ElementalParticle.f90 b/src/core/ElementalParticle.f90
index ce1b69b9..5b961321 100644
--- a/src/core/ElementalParticle.f90
+++ b/src/core/ElementalParticle.f90
@@ -40,6 +40,7 @@ module ElementalParticle_
real(8) :: mass
real(8) :: charge
real(8) :: spin
+ logical :: custom
end type ElementalParticle
public :: &
@@ -59,6 +60,7 @@ subroutine ElementalParticle_load( this, symbolSelected )
character(*) :: symbolSelected
logical :: existFile
+ logical :: custom
integer :: stat
integer :: i
@@ -81,59 +83,64 @@ subroutine ElementalParticle_load( this, symbolSelected )
!! Looking for library
inquire(file=trim(CONTROL_instance%DATA_DIRECTORY)//trim(CONTROL_instance%ELEMENTAL_PARTICLES_DATABASE), exist=existFile)
- if ( existFile ) then
+ if ( .not. existFile ) call ElementalParticle_exception( ERROR, "LOWDIN library not found!! please export lowdinvars.sh file.", "In ElementalParticle at load function.")
- !! Open library
- open(unit=10, file=trim(CONTROL_instance%DATA_DIRECTORY)//trim(CONTROL_instance%ELEMENTAL_PARTICLES_DATABASE), status="old", form="formatted" )
-
- !! Read information
- symbol = "NONE"
- stat = 0
-
- do while(trim(symbol) /= trim(symbolSelected))
+ !! Open library
+ open(unit=10, file=trim(CONTROL_instance%DATA_DIRECTORY)//trim(CONTROL_instance%ELEMENTAL_PARTICLES_DATABASE), status="old", form="formatted" )
+
+ !! Read information
+ symbol = "NONE"
+ stat = 0
+
+ do while(trim(symbol) /= trim(symbolSelected))
+
+ !! Setting defaults
+ name = "NONE"
+ category = "NONE"
+ mass = -1
+ charge = 0
+ spin = 0
+ custom = .false.
- !! Setting defaults
- name = "NONE"
- category = "NONE"
- mass = -1
- charge = 0
- spin = 0
-
- if (stat == -1 ) then
-
- call ElementalParticle_exception( ERROR, "Elemental particle: "//trim(symbolSelected)//" NOT found!!", "In ElementalParticle at load function.")
+ if (stat == -1 ) then
- end if
+ ! call ElementalParticle_exception( WARNING, "Elemental particle: "//trim(symbolSelected)//" NOT found in ElementalParticles.lib", "Setting default values")
+ name = trim(symbolSelected)
+ symbol = trim(symbolSelected)
+ category = "FERMION"
+ mass = 1.0
+ charge = 1.0
+ spin = 0.5
+ custom = .true.
+
+ exit
- read(10,NML=particle, iostat=stat)
-
- if (stat > 0 ) then
-
- call ElementalParticle_exception( ERROR, "Failed reading ElementalParticles.lib file!! please check this file.", "In ElementalParticle at load function.")
-
- end if
+ end if
- end do
-
- !! Set object variables
- this%name = name
- this%symbol = symbol
- this%category = category
- this%mass = mass
- this%charge = charge
- this%spin = spin
-
- !! Debug information.
- !! call ElementalParticle_show(this)
-
- close(10)
-
- else
+ read(10,NML=particle, iostat=stat)
+
+ if (stat > 0 ) then
+
+ call ElementalParticle_exception( ERROR, "Failed reading ElementalParticles.lib file!! please check this file.", "In ElementalParticle at load function.")
- call ElementalParticle_exception( ERROR, "LOWDIN library not found!! please export lowdinvars.sh file.", "In ElementalParticle at load function.")
+ end if
- end if
+ end do
+ !! Set object variables
+ this%name = name
+ this%symbol = symbol
+ this%category = category
+ this%mass = mass
+ this%charge = charge
+ this%spin = spin
+ this%custom = custom
+
+ !! Debug information.
+ ! call ElementalParticle_show(this)
+
+ close(10)
+
!! Done
end subroutine ElementalParticle_load
diff --git a/src/core/ExternalPotential.f90 b/src/core/ExternalPotential.f90
deleted file mode 100644
index f6459bfa..00000000
--- a/src/core/ExternalPotential.f90
+++ /dev/null
@@ -1,378 +0,0 @@
-!!******************************************************************************
-!! This code is part of LOWDIN Quantum chemistry package
-!!
-!! this program has been developed under direction of:
-!!
-!! Prof. A REYES' Lab. Universidad Nacional de Colombia
-!! http://www.qcc.unal.edu.co
-!! Prof. R. FLORES' Lab. Universidad de Guadajara
-!! http://www.cucei.udg.mx/~robertof
-!!
-!! Todos los derechos reservados, 2013
-!!
-!!******************************************************************************
-
-!> @brief This module contains all the routines to handle external potentials
-!! @author E. F. Posada (efposadac@unal.edu.co)
-!! @version 2.0
-!! Creation data : 06-08-10
-!!
-!! History change:
-!!
-!! - 06-08-10 : Sergio A. Gonzalez ( sergmonic@gmail.com )
-!! -# Creacioon del modulo y metodos basicos
-!! - 2011-02-14 : Fernando Posada ( efposadac@unal.edu.co )
-!! -# Reescribe y adapta el módulo para su inclusion en Lowdin
-module ExternalPotential_
- use ContractedGaussian_
- use String_
- use Matrix_
- use Units_
- use Exception_
- implicit none
-
- type, public :: ExternalPot
- character(20) :: name
- character(50) :: specie
- character(50) :: ttype
- character(50) :: units
- integer :: numOfComponents
- integer :: iter
- type(ContractedGaussian), allocatable :: gaussianComponents(:)
- end type
-
- type, public :: ExternalPotential
- integer :: ssize
- type(ExternalPot), allocatable :: potentials(:)
- logical :: isInstanced
- end type
-
- type(ExternalPotential), public, target :: ExternalPotential_instance
-
-contains
-
-
- !>
- !! @brief Constructor by default
- !! @param this
- subroutine ExternalPotential_constructor(numberOfPotentials)
- implicit none
-
- integer :: numberOfPotentials
-
- ExternalPotential_instance%ssize = numberOfPotentials
- allocate(ExternalPotential_instance%potentials(numberOfPotentials))
- ExternalPotential_instance%isInstanced = .true.
-
- end subroutine ExternalPotential_constructor
-
- !>
- !! @brief Destroys the object
- !! @param this
- subroutine ExternalPotential_destructor()
- implicit none
-
- integer :: i
-
- do i = 1, ExternalPotential_instance%ssize
- if (allocated(ExternalPotential_instance%potentials(i)%gaussianComponents)) deallocate(ExternalPotential_instance%potentials(i)%gaussianComponents)
- end do
-
- if (allocated(ExternalPotential_instance%potentials) ) deallocate(ExternalPotential_instance%potentials)
- ExternalPotential_instance%isInstanced=.false.
-
- end subroutine ExternalPotential_destructor
-
- !>
- !! @brief Shows information of the object
- !! @param this
- subroutine ExternalPotential_show()
- implicit none
- type(ExternalPot), pointer :: this
- integer :: potId, i
-
- do potId = 1, ExternalPotential_instance%ssize
- this => ExternalPotential_instance%potentials(potId)
-
- print *,""
- print *,"======="
- print *, "External Potential for ", trim(this%specie), " : ", trim(this%name)
- print *, "Type : ", trim(this%ttype)
- write(6,"(T10,A20,A10,A10,A10,A10,A20)") "Exponent", "l", "R_x", "R_y", "R_z", "Factor"
-
- do i=1,this%numOfComponents
- write(6,"(T10,F20.10,I10,F10.5,F10.5,F10.5,F20.10)") &
- this%gaussianComponents(i)%orbitalExponents(1), &
- this%gaussianComponents(i)%angularMoment, this%gaussianComponents(i)%origin(:), &
- this%gaussianComponents(i)%contractionCoefficients(1)
- end do
- end do
-
- end subroutine ExternalPotential_show
-
- !>
- !! @brief loads information from the input file
- !! @param this
- !! @author E. F. Posada, 2013
- subroutine ExternalPotential_load(potId, name, species)
- implicit none
- integer :: potId
- character(*) :: name
- character(*) :: species
-
- type(ExternalPot), pointer :: this
- integer :: status, i, j
- character(150) :: fileName
- character(20) :: token
- character(10) :: symbol
- logical :: existFile, found
-
- this => ExternalPotential_instance%potentials(potId)
-
- this%name= trim(name)
- this%specie= trim(species)
- this%ttype=""
- this%units="bohr"
- this%numOfComponents=0
- this%iter=1
-
- fileName = trim( trim( CONTROL_instance%DATA_DIRECTORY ) // &
- trim(CONTROL_instance%POTENTIALS_DATABASE)// String_getUppercase(trim(name)))
-
- inquire(file=trim(fileName), exist = existFile)
- if(existFile) then
-
- !! Open File
- open(unit=30, file=trim(fileName), status="old",form="formatted")
- rewind(30)
-
- found = .false.
-
- !! Open element and Find the proper potential
- do while(found .eqv. .false.)
- read(30,*, iostat=status) token
- symbol = token(3:)
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call ExternalPotential_exception(ERROR, &
- "ERROR reading ExternalPotential file: "//trim(this%name)//&
- " Please check that file!","ExternalPotential module at Load function.")
-
- end if
-
- if (status == -1 ) then
-
- call ExternalPotential_exception(ERROR, &
- "The ExternalPotential: "//trim(this%name)//&
- " for: "//trim(species)//&
- " was not found!","ExternalPotential module at Load function.")
-
- end if
-
- if(trim(token(1:2)) == "O-") then
- if(trim(symbol) == trim(species)) then
- found = .true.
-
- end if
-
- end if
-
- end do
-
- !! Neglect any comment
- token = "#"
- do while(trim(token(1:1)) == "#")
-
- read(30,*) token
-
- end do
-
- !! Start reading Potential
- backspace(30)
-
- read(30,*, iostat=status) this%numOfComponents
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call ExternalPotential_exception(ERROR, &
- "ERROR reading ExternalPotential file: "//trim(this%name)//&
- " Please check that file!","ExternalPotential module at Load function.")
-
- end if
-
- allocate(this%gaussianComponents(this%numOfComponents))
-
- do i = 1, this%numOfComponents
-
- read(30,*,iostat=status) this%gaussianComponents(i)%id, &
- this%gaussianComponents(i)%angularMoment
- this%gaussianComponents(i)%length = 1
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call ExternalPotential_exception(ERROR, &
- "ERROR reading ExternalPotential file: "//trim(this%name)//&
- " Please check that file!","ExternalPotential module at Load function.")
-
- end if
-
- allocate(this%gaussianComponents(i)%orbitalExponents(this%gaussianComponents(i)%length))
- allocate(this%gaussianComponents(i)%contractionCoefficients(this%gaussianComponents(i)%length))
-
- do j = 1, this%gaussianComponents(i)%length
-
- read(30,*,iostat=status) this%gaussianComponents(i)%orbitalExponents(j), &
- this%gaussianComponents(i)%contractionCoefficients(j)
- read(30,*,iostat=status) this%gaussianComponents(i)%origin
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call ExternalPotential_exception(ERROR, &
- "ERROR reading ExternalPotential file: "//trim(this%name)//&
- " Please check that file!","ExternalPotential module at Load function.")
-
- end if
-
- end do
-
-
- !! Calculates the number of Cartesian orbitals, by dimensionality
- select case(CONTROL_instance%DIMENSIONALITY)
- case(3)
- this%gaussianComponents(i)%numCartesianOrbital = ( ( this%gaussianComponents(i)%angularMoment + 1_8 )*( this%gaussianComponents(i)%angularMoment + 2_8 ) ) / 2_8
- case(2)
- this%gaussianComponents(i)%numCartesianOrbital = ( ( this%gaussianComponents(i)%angularMoment + 1_8 ) )
- case(1)
- this%gaussianComponents(i)%numCartesianOrbital = 1
- case default
- call ExternalPotential_exception( ERROR, &
- "Class object ExternalPotential in load function",&
- "This Dimensionality is not available")
- end select
-
- !! Normalize
- allocate(this%gaussianComponents(i)%contNormalization(this%gaussianComponents(i)%numCartesianOrbital))
- allocate(this%gaussianComponents(i)%primNormalization(this%gaussianComponents(i)%length, &
- this%gaussianComponents(i)%length*this%gaussianComponents(i)%numCartesianOrbital))
-
- this%gaussianComponents(i)%contNormalization = 1.0_8
- this%gaussianComponents(i)%primNormalization = 1.0_8
-
- call ContractedGaussian_normalizePrimitive(this%gaussianComponents(i))
- call ContractedGaussian_normalizeContraction(this%gaussianComponents(i))
-
- !! DEBUG
- ! call ContractedGaussian_showInCompactForm(ExternalPotential_instance%potentials(potId)%gaussianComponents(i))
-
- end do
-
- close(30)
-
- !!DONE
-
- else
-
- call ExternalPotential_exception(ERROR, &
- "The ExternalPotential file: "//trim(name)//&
- " was not found!","ExternalPotential module at Load function.")
-
- end if
-
- end subroutine ExternalPotential_load
-
-! !>
-! !! @brief
-! !! @param this
-! function ExternalPotential_getPotential( this, coords ) result(output)
-! implicit none
-! type(ExternalPotential) :: this
-! real(8) :: coords(3)
-! real(8) :: output
-
-! ! integer :: i
-
-! ! output=0.0
-
-! ! do i=1, this%gaussianComponents%length
-! ! output = output+( this%gaussianComponents%contractionCoefficients(i)* &
-! ! exp(-this%gaussianComponents%primitives(i)%orbitalExponent*( dot_product(coords,coords) ) ) )
-! ! end do
-
-! end function ExternalPotential_getPotential
-
-
-! ! function ExternalPotential_getInteractionMtx(this, contractions) result(output)
-! subroutine ExternalPotential_getInteractionMtx( this, contractions )
-! implicit none
-! type(ExternalPotential) :: this
-! type(ContractedGaussian) :: contractions(:)
-! type(Matrix) :: output
-
-! ! integer :: i, j, k, l, m, a, b
-! ! integer :: numContractions
-! ! real(8), allocatable :: auxVal(:)
-! ! type(ContractedGaussian) :: auxContract
-
-! ! do i = 1, size(contractions)
-! ! numContractions = numContractions + contractions(i)%numCartesianOrbital
-! ! end do
-
-! ! call Matrix_constructor(output,int(numContractions,8),int(numContractions,8))
-
-! ! a = 1
-! ! b = 1
-
-! ! do i=1, size(contractions)
-
-! ! call ContractedGaussian_product(contractions(i), &
-! ! this%gaussianComponents, auxContract)
-
-! ! do j=1, size(contractions)
-
-! ! call ContractedGaussian_overlapIntegral( auxContract, contractions(j), auxVal)
-
-! ! m = 0
-! ! do k = a, auxContract%numCartesianOrbital - 1
-! ! do l = b, contractions(j)%numCartesianOrbital - 1
-! ! m = m + 1
-! ! output%values(k,l)= auxVal(m)
-! ! end do
-! ! end do
-! ! b = b + contractions(j)%numCartesianOrbital
-! ! end do
-! ! a = a + auxContract%numCartesianOrbital
-! ! call ContractedGaussian_destructor(auxContract)
-! ! end do
-
-! ! call Matrix_show(output)
-
-! ! stop "ExternalPotential_getInteractionMtx"
-
-! ! ! end function ExternalPotential_getInteractionMtx
-! end subroutine ExternalPotential_getInteractionMtx
-
-
- !>
- !! @brief Maneja excepciones de la clase
- subroutine ExternalPotential_exception( typeMessage, description, debugDescription)
- implicit none
- integer :: typeMessage
- character(*) :: description
- character(*) :: debugDescription
-
- type(Exception) :: ex
-
- call Exception_constructor( ex , typeMessage )
- call Exception_setDebugDescription( ex, debugDescription )
- call Exception_setDescription( ex, description )
- call Exception_show( ex )
- call Exception_destructor( ex )
-
- end subroutine ExternalPotential_exception
-
-end module ExternalPotential_
diff --git a/src/core/GTFPotential.f90 b/src/core/GTFPotential.f90
new file mode 100644
index 00000000..4ac4b93a
--- /dev/null
+++ b/src/core/GTFPotential.f90
@@ -0,0 +1,309 @@
+!!******************************************************************************
+!! This code is part of LOWDIN Quantum chemistry package
+!!
+!! this program has been developed under direction of:
+!!
+!! Prof. A REYES' Lab. Universidad Nacional de Colombia
+!! http://www.qcc.unal.edu.co
+!! Prof. R. FLORES' Lab. Universidad de Guadajara
+!! http://www.cucei.udg.mx/~robertof
+!!
+!! Todos los derechos reservados, 2013
+!!
+!!******************************************************************************
+
+!> @brief This module contains all the routines to handle external and interal GTF potentials
+!! @author E. F. Posada (efposadac@unal.edu.co)
+!! @version 2.0
+!! Creation data : 06-08-10
+!!
+!! History change:
+!!
+!! - 06-08-10 : Sergio A. Gonzalez ( sergmonic@gmail.com )
+!! -# Creacioon del modulo y metodos basicos
+!! - 2011-02-14 : Fernando Posada ( efposadac@unal.edu.co )
+!! -# Reescribe y adapta el módulo para su inclusion en Lowdin
+!! - 2024-11-26 : Felix
+!! -# Merges ExternalPotential and InternalPotentials modules into a single file (GTFPotential)
+module GTFPotential_
+ use ContractedGaussian_
+ use String_
+ use Matrix_
+ use Units_
+ use Exception_
+ implicit none
+
+ type, public :: GaussPot
+ character(20) :: name
+ character(50) :: species
+ character(50) :: otherSpecies
+ character(50) :: ttype
+ character(50) :: units
+ integer :: numOfComponents
+ integer :: iter
+ type(ContractedGaussian), allocatable :: gaussianComponents(:)
+ end type GaussPot
+
+ type, public :: GTFPotential
+ integer :: ssize
+ type(GaussPot), allocatable :: potentials(:)
+ character(50) :: type
+ logical :: isInstanced
+ end type GTFPotential
+
+ type(GTFPotential), public, target :: ExternalPotential_instance, InterPotential_instance
+
+contains
+
+ !>
+ !! @brief Initializes the class
+ !! @param this, n
+ !! @author E. F. Posada, 2013
+ subroutine GTFPotential_constructor(this,numberOfPotentials,type)
+ implicit none
+ type(GTFPotential) :: this
+ integer :: numberOfPotentials
+ character(*) :: type
+
+
+ this%ssize = numberOfPotentials
+ allocate(this%potentials(numberOfPotentials))
+ this%isInstanced = .true.
+ this%type = type
+
+ end subroutine GTFPotential_constructor
+
+ !>
+ !! @brief Destroys the object
+ !! @param this
+ subroutine GTFPotential_destructor(this)
+ implicit none
+ type(GTFPotential) :: this
+
+ integer :: i
+
+ do i = 1, this%ssize
+ if (allocated(this%potentials(i)%gaussianComponents)) deallocate(this%potentials(i)%gaussianComponents)
+ end do
+
+ if (allocated(this%potentials) ) deallocate(this%potentials)
+ this%isInstanced=.false.
+
+ end subroutine GTFPotential_destructor
+
+ !>
+ !! @brief loads information from the input file
+ !! @param this
+ !! @author E. F. Posada, 2013
+ subroutine GTFPotential_load(this, potId, name, species, otherSpecies)
+ implicit none
+ type(GTFPotential) :: this
+ integer :: potId
+ character(*) :: name
+ character(*) :: species
+ character(*), optional :: otherSpecies
+
+ if(present(otherSpecies)) then
+ call GaussPot_load(this%potentials(potId), potId, name, species, otherSpecies)
+ else
+ call GaussPot_load(this%potentials(potId), potId, name, species)
+ end if
+ end subroutine GTFPotential_load
+
+ !>
+ !! @brief Shows information of the object
+ !! @param this
+ subroutine GTFPotential_show(this)
+ implicit none
+ type(GTFPotential) :: this
+ integer :: i, j
+
+ do i=1,this%ssize
+ if( this%potentials(i)%ttype .eq. "INTERNAL") then
+ print *,""
+ print *,"======="
+ write(*,"(A30,A)") "GTF Interparticle potential: ", trim(this%potentials(i)%name)
+ write(*,"(A4,A10,A5,A10)") "for ", trim(this%potentials(i)%species) ," and ", trim(this%potentials(i)%otherSpecies)
+ write(*,"(T10,A10,A10)") "Units:", trim(this%potentials(i)%units)
+ write(*,"(T10,A16,A16)") "Exponent", "Factor"
+ do j=1,this%potentials(i)%numOfComponents
+ write(*,"(T10,E16.8,E16.8)") this%potentials(i)%gaussianComponents(j)%orbitalExponents, &
+ this%potentials(i)%gaussianComponents(j)%contractionCoefficients(1)
+ end do
+ else if( this%potentials(i)%ttype .eq. "EXTERNAL") then
+ print *,""
+ print *,"======="
+ write(*,"(A25,A20,A5,A10)") "GTF External potential: ", trim(this%potentials(i)%name), " for ", trim(this%potentials(i)%species)
+ write(*,"(T10,A10,A10)") "Units:", trim(this%potentials(i)%units)
+ write(*,"(T10,A16,A10,A10,A10,A16)") "Exponent", "R_x", "R_y", "R_z", "Factor"
+
+ do j=1,this%potentials(i)%numOfComponents
+ write(*,"(T10,E16.8,F10.5,F10.5,F10.5,E16.8)") &
+ this%potentials(i)%gaussianComponents(j)%orbitalExponents(1), &
+ this%potentials(i)%gaussianComponents(j)%origin(:), &
+ this%potentials(i)%gaussianComponents(j)%contractionCoefficients(1)
+ end do
+ end if
+ end do
+
+ end subroutine GTFPotential_show
+
+ !>
+ !! @brief loads information from the input file
+ !! @param this
+ !! @author Felix, 2024
+ subroutine GaussPot_load(this, potId, name, species, otherSpecies)
+ type(GaussPot) :: this
+ integer :: potId
+ character(*) :: name
+ character(*) :: species
+ character(*), optional :: otherSpecies
+
+ integer :: status, i, j
+ character(150) :: fileName
+ character(20) :: token
+ character(50) :: symbol
+ logical :: existFile, found
+
+ this%name= trim(name)
+ this%species= trim(species)
+ this%units="BOHR"
+ this%numOfComponents=0
+ this%iter=1
+
+ this%ttype="EXTERNAL"
+ this%otherSpecies=""
+ if(present(otherSpecies) ) then
+ this%ttype="INTERNAL"
+ this%otherSpecies=otherSpecies
+ end if
+
+ fileName = trim( trim( CONTROL_instance%DATA_DIRECTORY ) // &
+ trim(CONTROL_instance%POTENTIALS_DATABASE)// String_getUppercase(trim(name)))
+
+ !! Open Potential file from library
+ inquire(file=trim(fileName), exist = existFile)
+ if(existFile) then
+ open(unit=30, file=trim(fileName), status="old",form="formatted")
+ else
+ !! Open Potential file from directory
+ inquire(file=trim(this%name), exist = existFile)
+ if(existFile) then
+ open(unit=30, file=trim(this%name), status="old",form="formatted")
+ else
+ !! File not found
+ call Exception_stopError("The GTFPotential file: "//trim(this%name)//&
+ " was not found!","GTFPotential module at Load function.")
+ end if
+ end if
+
+ !! Open File
+ rewind(30)
+
+ found = .false.
+
+ !! Open element and Find the proper potential
+ do while(found .eqv. .false.)
+ read(30,*, iostat=status) token
+ symbol = token(3:)
+
+ !! Some debug information in case of error!
+ if (status > 0 ) call Exception_stopError("ERROR reading InterPotential file: "//trim(this%name)//&
+ " Please check that file!","GTFPotential module at Load function.")
+
+ if (status == -1 ) call Exception_stopError("The InterPotential: "//trim(this%name)//&
+ " for: "//trim(species)//trim(otherSpecies)//&
+ " was not found!","GTFPotential module at Load function.")
+
+ if(trim(token(1:2)) == "O-") then
+ if(this%ttype=="EXTERNAL" .and. trim(symbol) == trim(species)) found = .true.
+ if(this%ttype=="INTERNAL" .and. trim(symbol) == trim(species)//trim(otherSpecies)) found = .true.
+ end if
+ end do
+
+ !! Neglect any comment
+ token = "#"
+ do while(trim(token(1:1)) == "#")
+ read(30,*) token
+ end do
+
+ !! Start reading Potential
+ backspace(30)
+ read(30,*, iostat=status) this%numOfComponents
+
+ !! Some debug information in case of error!
+ if (status > 0 ) call Exception_stopError("ERROR reading InternalPotential file: "//trim(this%name)//&
+ " Please check that file!","GTFPotential module at Load function.")
+
+ allocate(this%gaussianComponents(this%numOfComponents))
+
+ do i = 1, this%numOfComponents
+ read(30,*,iostat=status) this%gaussianComponents(i)%id, &
+ this%gaussianComponents(i)%angularMoment
+
+ if(this%gaussianComponents(i)%angularMoment .gt. 0) then
+ print *, "Warning! you provided a non-zero angular momentum for a GTFpotential ", this%name ,"this feature is not yet implemented, will be ignored and set to zeo"
+ this%gaussianComponents(i)%angularMoment=0
+ end if
+
+ this%gaussianComponents(i)%length = 1
+
+ !! Some debug information in case of error!
+ if (status > 0 ) call Exception_stopError("ERROR reading InternalPotential file: "//trim(this%name)//&
+ " Please check that file!","GTFPotential module at Load function.")
+
+ allocate(this%gaussianComponents(i)%orbitalExponents(this%gaussianComponents(i)%length))
+ allocate(this%gaussianComponents(i)%contractionCoefficients(this%gaussianComponents(i)%length))
+
+ do j = 1, this%gaussianComponents(i)%length
+
+ read(30,*,iostat=status) this%gaussianComponents(i)%orbitalExponents(j), &
+ this%gaussianComponents(i)%contractionCoefficients(j)
+ read(30,*,iostat=status) this%gaussianComponents(i)%origin
+
+ !! Some debug information in case of error!
+ if (status > 0 ) call Exception_stopError("ERROR reading InternalPotential file: "//trim(this%name)//&
+ " Please check that file!","GTFPotential module at Load function.")
+
+ end do
+
+ if(this%ttype=="INTERNAL" .and. sum(this%gaussianComponents(i)%origin(:)**2) .gt. CONTROL_instance%DOUBLE_ZERO_THRESHOLD) then
+ print *, "Warning! you provided a non-zero origin for interpotential ", this%name ,"this feature is not yet implemented, will be ignored and set to zeo"
+ this%gaussianComponents(i)%origin=0.0_8
+ end if
+
+ !! Calculates the number of Cartesian orbitals, by dimensionality
+ select case(CONTROL_instance%DIMENSIONALITY)
+ case(3)
+ this%gaussianComponents(i)%numCartesianOrbital = ( ( this%gaussianComponents(i)%angularMoment + 1_8 )*( this%gaussianComponents(i)%angularMoment + 2_8 ) ) / 2_8
+ case(2)
+ this%gaussianComponents(i)%numCartesianOrbital = ( ( this%gaussianComponents(i)%angularMoment + 1_8 ) )
+ case(1)
+ this%gaussianComponents(i)%numCartesianOrbital = 1
+ case default
+ call Exception_stopError("Class object InternalPotential in load function",&
+ "This Dimensionality is not available")
+ end select
+
+ !! Normalize
+ allocate(this%gaussianComponents(i)%contNormalization(this%gaussianComponents(i)%numCartesianOrbital))
+ allocate(this%gaussianComponents(i)%primNormalization(this%gaussianComponents(i)%length, &
+ this%gaussianComponents(i)%length*this%gaussianComponents(i)%numCartesianOrbital))
+
+ this%gaussianComponents(i)%contNormalization = 1.0_8
+ this%gaussianComponents(i)%primNormalization = 1.0_8
+
+ call ContractedGaussian_normalizePrimitive(this%gaussianComponents(i))
+ call ContractedGaussian_normalizeContraction(this%gaussianComponents(i))
+
+ !! DEBUG
+ ! call ContractedGaussian_showInCompactForm(InterPotential_instance%potentials(potId)%gaussianComponents(i))
+
+ end do
+
+ close(30)
+
+ !!DONE
+ end subroutine GaussPot_load
+
+end module GTFPotential_
diff --git a/src/core/InputManager.f90 b/src/core/InputManager.f90
index e5a0abde..506a89fb 100644
--- a/src/core/InputManager.f90
+++ b/src/core/InputManager.f90
@@ -23,8 +23,7 @@ module InputManager_
use Exception_
use Particle_
use MolecularSystem_
- use InterPotential_
- use ExternalPotential_
+ use GTFPotential_
implicit none
@@ -344,6 +343,7 @@ subroutine InputManager_loadGeometry()
real(8):: InputParticle_origin(3)
real(8) :: InputParticle_charge
real(8) :: InputParticle_mass
+ integer :: InputParticle_eta
real(8) :: InputParticle_omega
character(15):: InputParticle_qdoCenterOf
character(3):: InputParticle_fixedCoordinates
@@ -359,6 +359,7 @@ subroutine InputManager_loadGeometry()
InputParticle_basisSetName, &
InputParticle_charge, &
InputParticle_mass, &
+ InputParticle_eta, &
InputParticle_omega, &
InputParticle_qdoCenterOf, &
InputParticle_origin, &
@@ -538,6 +539,7 @@ subroutine InputManager_loadGeometry()
InputParticle_basisSetName = "NONE"
InputParticle_charge=0.0_8
InputParticle_mass=0.0_8
+ InputParticle_eta=0
InputParticle_omega=0.0_8
InputParticle_qdoCenterOf = "NONE"
InputParticle_origin=0.0_8
@@ -620,7 +622,8 @@ subroutine InputManager_loadGeometry()
spin="ALPHA", &
id = particlesID(speciesID), &
charge = InputParticle_charge, &
- mass = InputParticle_mass, &
+ mass = InputParticle_mass, &
+ eta = InputParticle_eta, &
omega = InputParticle_omega )
!!BETA SET
@@ -644,6 +647,7 @@ subroutine InputManager_loadGeometry()
id = particlesID(speciesID), &
charge = InputParticle_charge, &
mass = InputParticle_mass, &
+ eta = InputParticle_eta, &
omega = InputParticle_omega )
else
@@ -671,6 +675,7 @@ subroutine InputManager_loadGeometry()
id = particlesID(speciesID), &
charge = InputParticle_charge, &
mass = InputParticle_mass, &
+ eta = InputParticle_eta, &
omega = InputParticle_omega )
end if
@@ -750,7 +755,7 @@ subroutine InputManager_loadPotentials()
! Load interpotentials
if(CONTROL_instance%IS_THERE_INTERPARTICLE_POTENTIAL) then
- call InterPotential_constructor(Input_instance%numberOfInterPots)
+ call GTFPotential_constructor(InterPotential_instance, Input_instance%numberOfInterPots,"INTERNAL")
!! Reload input file
rewind(4)
@@ -760,10 +765,10 @@ subroutine InputManager_loadPotentials()
read(4,NML=InterPot, iostat=stat)
if( stat > 0 ) then
- call InputManager_exception( ERROR, "check the TASKS block in your input file", "InputManager loadTask function" )
+ call InputManager_exception( ERROR, "check the INTERPOTENTIAL block in your input file", "InputManager loadTask function" )
end if
- call InterPotential_load(potId, trim(InterPot_name), trim(InterPot_specie), trim(InterPot_otherSpecie))
+ call GTFPotential_load(InterPotential_instance, potId, trim(InterPot_name), trim(InterPot_specie), trim(InterPot_otherSpecie))
end do
@@ -772,7 +777,7 @@ subroutine InputManager_loadPotentials()
! Load External Potentials
if(CONTROL_instance%IS_THERE_EXTERNAL_POTENTIAL) then
- call ExternalPotential_constructor(Input_instance%numberOfExternalPots)
+ call GTFPotential_constructor(ExternalPotential_instance, Input_instance%numberOfExternalPots,"EXTERNAL")
!! Reload input file
rewind(4)
@@ -782,10 +787,10 @@ subroutine InputManager_loadPotentials()
read(4,NML=ExternalPot, iostat=stat)
if( stat > 0 ) then
- call InputManager_exception( ERROR, "check the TASKS block in your input file", "InputManager loadTask function" )
+ call InputManager_exception( ERROR, "check the EXTERPOTENTIAL block in your input file", "InputManager loadTask function" )
end if
- call ExternalPotential_load(potId, trim(ExternalPot_name), trim(ExternalPot_specie))
+ call GTFPotential_load(ExternalPotential_instance, potId, trim(ExternalPot_name), trim(ExternalPot_specie))
end do
end if
diff --git a/src/core/InterPotential.f90 b/src/core/InterPotential.f90
deleted file mode 100644
index f30008e7..00000000
--- a/src/core/InterPotential.f90
+++ /dev/null
@@ -1,298 +0,0 @@
-!!******************************************************************************
-!! This code is part of LOWDIN Quantum chemistry package
-!!
-!! this program has been developed under direction of:
-!!
-!! Prof. A REYES' Lab. Universidad Nacional de Colombia
-!! http://www.qcc.unal.edu.co
-!! Prof. R. FLORES' Lab. Universidad de Guadajara
-!! http://www.cucei.udg.mx/~robertof
-!!
-!! Todos los derechos reservados, 2013
-!!
-!!******************************************************************************
-
-!> @brief This module contains all the routines to handle inter particle potentials
-!! @author E. F. Posada (efposadac@unal.edu.co)
-!! @version 2.0
-
-module InterPotential_
- use ContractedGaussian_
- use String_
- use Exception_
- implicit none
-
- type, public :: InterPot
- character(20) :: name
- character(50) :: specie
- character(50) :: otherSpecie
- character(50) :: ttype
- character(50) :: units
- integer :: numOfComponents
- integer :: iter
- type(ContractedGaussian), allocatable :: gaussianComponents(:)
- end type
-
- type, public :: InterPotential
- integer :: ssize
- type(InterPot), allocatable :: Potentials(:)
- logical :: isInstanced
- end type
-
- type(InterPotential), public, target :: InterPotential_instance
-
-contains
-
- !>
- !! @brief Initializes the class
- !! @param this
- !! @author E. F. Posada, 2013
- subroutine InterPotential_constructor(numberOfPotentials)
- implicit none
- integer :: numberOfPotentials
-
- InterPotential_instance%ssize = numberOfPotentials
- allocate(InterPotential_instance%potentials(numberOfPotentials))
- InterPotential_instance%isInstanced = .true.
-
- end subroutine InterPotential_constructor
-
- !>
- !! @brief destroy the class
- !! @param this
- !! @author E. F. Posada, 2013
- subroutine InterPotential_destructor()
- implicit none
-
- integer :: i
-
- do i = 1, InterPotential_instance%ssize
- if (allocated(InterPotential_instance%potentials(i)%gaussianComponents) ) deallocate(InterPotential_instance%potentials(i)%gaussianComponents)
- end do
-
- if (allocated(InterPotential_instance%potentials) )deallocate(InterPotential_instance%potentials)
-
- end subroutine InterPotential_destructor
-
- !>
- !! @brief Shows information of the object
- !! @param this
- subroutine InterPotential_show()
- implicit none
- integer :: i, j
- type(InterPot), pointer :: this
-
- do i=1,InterPotential_instance%ssize
- this => InterPotential_instance%potentials(i)
- print *,""
- print *,"======="
- print *, "InterParticle Potential for ", trim(this%specie) ," and ", trim(this%otherSpecie), " : ", trim(this%name)
- print *, "Type : ", trim(this%ttype)
- write(6,"(T10,A20,A10,A10,A10,A20)") "Exponent", "l", "Factor"
- do j=1,this%numOfComponents
- write(6,"(T10,F20.15,I10,F20.15)") this%gaussianComponents(j)%orbitalExponents, &
- this%gaussianComponents(j)%angularMoment, this%gaussianComponents(j)%contractionCoefficients(1)
- end do
- end do
-
- end subroutine InterPotential_show
-
-
- !>
- !! @brief loads information from the input file
- !! @param this
- !! @author E. F. Posada, 2015
- subroutine InterPotential_load(potId, name, species, otherSpecies)
- implicit none
- integer :: potId
- character(*) :: name
- character(*) :: species
- character(*) :: otherSpecies
-
- type(InterPot), pointer :: this
- integer :: status, i, j
- character(150) :: fileName
- character(20) :: token
- character(20) :: symbol
- logical :: existFile, found
-
- this => InterPotential_instance%potentials(potId)
-
- this%name= trim(name)
- this%specie= trim(species)
- this%otherSpecie= trim(otherSpecies)
- this%ttype=""
- this%units="bohr"
- this%numOfComponents=0
- this%iter=1
-
- fileName = trim( trim( CONTROL_instance%DATA_DIRECTORY ) // &
- trim(CONTROL_instance%POTENTIALS_DATABASE)// String_getUppercase(trim(name)))
-
-
- inquire(file=trim(fileName), exist = existFile)
- if(existFile) then
-
- !! Open File
- open(unit=30, file=trim(fileName), status="old",form="formatted")
- rewind(30)
-
- found = .false.
-
- !! Open element and Find the proper potential
- do while(found .eqv. .false.)
- read(30,*, iostat=status) token
- symbol = token(3:)
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call InterPotential_exception(ERROR, &
- "ERROR reading InterPotential file: "//trim(this%name)//&
- " Please check that file!","InternalPotential module at Load function.")
-
- end if
-
- if (status == -1 ) then
-
- call InterPotential_exception(ERROR, &
- "The InterPotential: "//trim(this%name)//&
- " for: "//trim(species)//trim(otherSpecies)//&
- " was not found!","InternalPotential module at Load function.")
-
- end if
-
- if(trim(token(1:2)) == "O-") then
- if(trim(symbol) == trim(species)//trim(otherSpecies)) then
- found = .true.
-
- end if
-
- end if
-
- end do
-
- !! Neglect any comment
- token = "#"
- do while(trim(token(1:1)) == "#")
-
- read(30,*) token
-
- end do
-
- !! Start reading Potential
- backspace(30)
-
- read(30,*, iostat=status) this%numOfComponents
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call InterPotential_exception(ERROR, &
- "ERROR reading InternalPotential file: "//trim(this%name)//&
- " Please check that file!","InternalPotential module at Load function.")
-
- end if
-
- allocate(this%gaussianComponents(this%numOfComponents))
-
- do i = 1, this%numOfComponents
-
- read(30,*,iostat=status) this%gaussianComponents(i)%id, &
- this%gaussianComponents(i)%angularMoment
- this%gaussianComponents(i)%length = 1
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call InterPotential_exception(ERROR, &
- "ERROR reading InternalPotential file: "//trim(this%name)//&
- " Please check that file!","InternalPotential module at Load function.")
-
- end if
-
- allocate(this%gaussianComponents(i)%orbitalExponents(this%gaussianComponents(i)%length))
- allocate(this%gaussianComponents(i)%contractionCoefficients(this%gaussianComponents(i)%length))
-
- do j = 1, this%gaussianComponents(i)%length
-
- read(30,*,iostat=status) this%gaussianComponents(i)%orbitalExponents(j), &
- this%gaussianComponents(i)%contractionCoefficients(j)
- read(30,*,iostat=status) this%gaussianComponents(i)%origin
-
- !! Some debug information in case of error!
- if (status > 0 ) then
-
- call InterPotential_exception(ERROR, &
- "ERROR reading InternalPotential file: "//trim(this%name)//&
- " Please check that file!","InternalPotential module at Load function.")
-
- end if
-
- end do
-
-
- !! Calculates the number of Cartesian orbitals, by dimensionality
- select case(CONTROL_instance%DIMENSIONALITY)
- case(3)
- this%gaussianComponents(i)%numCartesianOrbital = ( ( this%gaussianComponents(i)%angularMoment + 1_8 )*( this%gaussianComponents(i)%angularMoment + 2_8 ) ) / 2_8
- case(2)
- this%gaussianComponents(i)%numCartesianOrbital = ( ( this%gaussianComponents(i)%angularMoment + 1_8 ) )
- case(1)
- this%gaussianComponents(i)%numCartesianOrbital = 1
- case default
- call InterPotential_exception( ERROR, &
- "Class object InternalPotential in load function",&
- "This Dimensionality is not available")
- end select
-
- !! Normalize
- allocate(this%gaussianComponents(i)%contNormalization(this%gaussianComponents(i)%numCartesianOrbital))
- allocate(this%gaussianComponents(i)%primNormalization(this%gaussianComponents(i)%length, &
- this%gaussianComponents(i)%length*this%gaussianComponents(i)%numCartesianOrbital))
-
- this%gaussianComponents(i)%contNormalization = 1.0_8
- this%gaussianComponents(i)%primNormalization = 1.0_8
-
- call ContractedGaussian_normalizePrimitive(this%gaussianComponents(i))
- call ContractedGaussian_normalizeContraction(this%gaussianComponents(i))
-
- !! DEBUG
- ! call ContractedGaussian_showInCompactForm(InterPotential_instance%potentials(potId)%gaussianComponents(i))
-
- end do
-
- close(30)
-
- !!DONE
-
- else
-
- call InterPotential_exception(ERROR, &
- "The InternalPotential file: "//trim(name)//&
- " was not found!","InternalPotential module at Load function.")
-
- end if
-
- end subroutine InterPotential_load
-
-
- !>
- !! @brief Handles class exceptions
- !<
- subroutine InterPotential_exception( typeMessage, description, debugDescription)
- implicit none
- integer :: typeMessage
- character(*) :: description
- character(*) :: debugDescription
-
- type(Exception) :: ex
-
- call Exception_constructor( ex , typeMessage )
- call Exception_setDebugDescription( ex, debugDescription )
- call Exception_setDescription( ex, description )
- call Exception_show( ex )
- call Exception_destructor( ex )
-
- end subroutine InterPotential_exception
-end module InterPotential_
diff --git a/src/core/MolecularSystem.f90 b/src/core/MolecularSystem.f90
index b5a766fe..32dced1b 100644
--- a/src/core/MolecularSystem.f90
+++ b/src/core/MolecularSystem.f90
@@ -38,8 +38,7 @@ module MolecularSystem_
use Matrix_
use Vector_
use InternalCoordinates_
- use ExternalPotential_
- use InterPotential_
+ use GTFPotential_
implicit none
type , public :: MolecularSystem
@@ -343,9 +342,10 @@ subroutine MolecularSystem_showInformation(this)
print *," MOLECULAR SYSTEM: ",trim(system%name)
print *,"-----------------"
print *,""
- write (6,"(T5,A16,A)") "DESCRIPTION : ", trim( system%description )
- write (6,"(T5,A16,I3)") "CHARGE : ",system%charge
- write (6,"(T5,A16,A4)") "PUNTUAL GROUP : ", "NONE"
+ write (6,"(T5,A16,A)") "DESCRIPTION : ", trim( system%description )
+ write (6,"(T5,A16,I3)") "CHARGE : ",system%charge
+ write (6,"(T5,A16,F12.4)") "MASS (m_e) : ", MolecularSystem_getTotalMass(system)
+ write (6,"(T5,A16,A4)") "PUNTUAL GROUP : ", "NONE"
print *,""
@@ -382,9 +382,9 @@ subroutine MolecularSystem_showParticlesInformation(this)
!!
print *,""
print *," INFORMATION OF QUANTUM SPECIES "
- write (6,"(T5,A70)") "---------------------------------------------------------------------------------------------"
+ write (6,"(T5,A85)") "------------------------------------------------------------------------------------------------------------"
write (6,"(T10,A2,A4,A8,A12,A4,A5,A6,A5,A6,A5,A4,A5,A12)") "ID", " ","Symbol", " ","mass", " ","charge", " ","omega","","spin","","multiplicity"
- write (6,"(T5,A70)") "---------------------------------------------------------------------------------------------"
+ write (6,"(T5,A85)") "------------------------------------------------------------------------------------------------------------"
do i = 1, system%numberOfQuantumSpecies
write (6,'(T8,I3.0,A5,A10,A5,F10.4,A5,F5.2,A5,F5.2,A5,F5.2,A5,F5.2)') &
@@ -415,16 +415,16 @@ subroutine MolecularSystem_showParticlesInformation(this)
print *,""
print *," BASIS SET FOR SPECIES "
- write (6,"(T7,A60)") "------------------------------------------------------------"
- write (6,"(T10,A8,A10,A8,A5,A12,A5,A9)") "Symbol", " ","N. Basis", " ","N. Particles"," ","Basis Set"
- write (6,"(T7,A60)") "------------------------------------------------------------"
+ write (6,"(T7,A70)") "----------------------------------------------------------------------"
+ write (6,"(T10,A8,A10,A8,A5,A12,A5,A20)") "Symbol", " ","N. Basis", " ","N. Particles"," ","Basis Set"
+ write (6,"(T7,A70)") "----------------------------------------------------------------------"
!! Only shows the basis-set name of the first particle by specie.
do i = 1, system%numberOfQuantumSpecies
if( system%species(i)%isElectron .and. CONTROL_instance%IS_OPEN_SHELL ) then
- write (6,'(T10,A10,A5,I8,A5,I12,A5,A10)') &
+ write (6,'(T10,A10,A5,I8,A5,I12,A5,A20)') &
trim(system%species(i)%symbol)," ",&
!MolecularSystem_getTotalNumberOfContractions(i)," ",&
system%species(i)%basisSetSize," ",&
@@ -434,7 +434,7 @@ subroutine MolecularSystem_showParticlesInformation(this)
else
- write (6,'(T10,A10,A5,I8,A5,I12,A5,A10)') &
+ write (6,'(T10,A10,A5,I8,A5,I12,A5,A20)') &
trim(system%species(i)%symbol)," ",&
!MolecularSystem_getTotalNumberOfContractions(i)," ",&
system%species(i)%basisSetSize," ",&
@@ -501,7 +501,7 @@ subroutine MolecularSystem_showParticlesInformation(this)
if(CONTROL_instance%IS_THERE_EXTERNAL_POTENTIAL) then
print *,""
print *," INFORMATION OF EXTERNAL POTENTIALS "
- call ExternalPotential_show()
+ call GTFPotential_show(ExternalPotential_instance)
print *,""
print *," END INFORMATION OF EXTERNAL POTENTIALS"
print *,""
@@ -510,7 +510,7 @@ subroutine MolecularSystem_showParticlesInformation(this)
if(CONTROL_instance%IS_THERE_INTERPARTICLE_POTENTIAL) then
print *,""
print *," INFORMATION OF INTER-PARTICLE POTENTIALS "
- call InterPotential_show()
+ call GTFPotential_show(InterPotential_instance)
print *,""
print *," END INFORMATION OF INTER-PARTICLE POTENTIALS"
print *,""
@@ -671,7 +671,7 @@ subroutine MolecularSystem_saveToFile(targetFilePrefix)
do i = 1, ExternalPotential_instance%ssize
write(40,*) i
write(40,*) ExternalPotential_instance%potentials(i)%name
- write(40,*) ExternalPotential_instance%potentials(i)%specie
+ write(40,*) ExternalPotential_instance%potentials(i)%species
end do
end if
@@ -681,8 +681,8 @@ subroutine MolecularSystem_saveToFile(targetFilePrefix)
do i = 1, InterPotential_instance%ssize
write(40,*) i
write(40,*) InterPotential_instance%potentials(i)%name
- write(40,*) InterPotential_instance%potentials(i)%specie
- write(40,*) InterPotential_instance%potentials(i)%otherSpecie
+ write(40,*) InterPotential_instance%potentials(i)%species
+ write(40,*) InterPotential_instance%potentials(i)%otherSpecies
end do
end if
@@ -950,16 +950,14 @@ subroutine MolecularSystem_loadFromFile( form, targetPrefix )
if(CONTROL_instance%IS_THERE_EXTERNAL_POTENTIAL) then
read(40,*) auxValue
- call ExternalPotential_constructor(auxValue)
-
- !! FELIX TODO: create function to get potential ID
+ call GTFPotential_constructor(ExternalPotential_instance,auxValue,"EXTERNAL")
do j = 1, ExternalPotential_instance%ssize
read(40,*) i
read(40,*) name
read(40,*) species
- call ExternalPotential_load(i, name, species)
+ call GTFPotential_load(ExternalPotential_instance, i, name, species)
end do
@@ -968,7 +966,7 @@ subroutine MolecularSystem_loadFromFile( form, targetPrefix )
if(CONTROL_instance%IS_THERE_INTERPARTICLE_POTENTIAL) then
read(40,*) auxValue
- call InterPotential_constructor(auxValue)
+ call GTFPotential_constructor(InterPotential_instance,auxValue,"INTERNAL")
do j = 1, InterPotential_instance%ssize
read(40,*) i
@@ -976,7 +974,7 @@ subroutine MolecularSystem_loadFromFile( form, targetPrefix )
read(40,*) species
read(40,*) otherSpecies
- call InterPotential_load(i, name, species, otherSpecies)
+ call GTFPotential_load(InterPotential_instance, i, name, species, otherSpecies)
end do
@@ -1979,13 +1977,14 @@ end subroutine MolecularSystem_changeOrbitalOrder
!>
!! @brief Lee la matriz de densidad y los orbitales de un archivo fchk tipo Gaussian
- subroutine MolecularSystem_readFchk( fileName, coefficients, densityMatrix, nameOfSpecies )
+ subroutine MolecularSystem_readFchk( fileName, coefficients, densityMatrix, nameOfSpecies, readSuccess )
implicit none
character(*), intent(in) :: fileName
type(Matrix), intent(inout) :: coefficients
type(Matrix), intent(inout) :: densityMatrix
character(*) :: nameOfSpecies
+ logical, optional :: readSuccess
integer :: speciesID
integer :: numberOfContractions
@@ -2006,9 +2005,15 @@ subroutine MolecularSystem_readFchk( fileName, coefficients, densityMatrix, name
speciesID=MolecularSystem_getSpecieID(nameOfSpecies)
numberOfContractions=MolecularSystem_getTotalnumberOfContractions( speciesID )
inquire(FILE = trim(fileName), EXIST = existFchk )
- if ( .not. existFchk ) call MolecularSystem_exception( ERROR, "I did not find any .fchk coefficients file", "At MolecularSystem_readFchk")
+ if ( .not. existFchk .and. present(readSuccess)) then
+ readSuccess=.false.
+ call MolecularSystem_exception( WARNING, "I did not find the "//trim(filename)//" coefficients file for "//trim(nameOfSpecies), "At MolecularSystem_readFchk")
+ return
+ end if
+ if ( .not. existFchk) then
+ call MolecularSystem_exception( ERROR, "I did not find the "//trim(filename)//" coefficients file for "//trim(nameOfSpecies), "At MolecularSystem_readFchk")
+ end if
-
fchkUnit = 50
open(unit=fchkUnit, file=filename, status="old", form="formatted", access='sequential', action='read')
@@ -2097,8 +2102,8 @@ subroutine MolecularSystem_readFchk( fileName, coefficients, densityMatrix, name
! print *, "density matrix from orbitals read"
! call Matrix_show(densityMatrix)
-
close(fchkUnit)
+ if(present(readSuccess)) readSuccess=.true.
end subroutine MolecularSystem_readFchk
@@ -2783,6 +2788,9 @@ function MolecularSystem_getTotalMass( this, unid ) result( output )
case("AMU")
output = output * AMU
+ case("DALTON")
+ output = output * DALTON
+
case default
end select
diff --git a/src/core/Particle.f90 b/src/core/Particle.f90
index 7a845404..f927d006 100644
--- a/src/core/Particle.f90
+++ b/src/core/Particle.f90
@@ -32,6 +32,7 @@
module Particle_
use Exception_
use CONTROL_
+ use Units_
use PhysicalConstants_
use AtomicElement_
use ElementalParticle_
@@ -49,6 +50,7 @@ module Particle_
real(8) :: origin(3) !< Posicion espacial
real(8) :: charge !< Carga asociada a la particula.
real(8) :: mass !< Masa asociada a la particula.
+ real(8) :: eta !< Particles per orbital
real(8) :: omega !< harmonic oscillator frequency
real(8) :: spin !< Especifica el espin de la particula
real(8) :: totalCharge !< Carga total asociada a la particula.
@@ -83,7 +85,7 @@ module Particle_
!! -Re-written and Verified, 2013. E. F. Posada
!! @version 2.0
subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
- addParticles, subsystem, translationCenter, rotationPoint, rotateAround, spin, id, charge, mass, omega, qdoCenterOf )
+ addParticles, subsystem, translationCenter, rotationPoint, rotateAround, spin, id, charge, mass, eta, omega, qdoCenterOf )
implicit none
type(particle) :: this
character(*), intent(in) :: name
@@ -101,6 +103,7 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
integer, intent(in) :: id
real(8), intent(in), optional :: charge
real(8), intent(in), optional :: mass
+ integer, intent(in), optional :: eta
real(8), intent(in), optional :: omega
type(AtomicElement) :: element
@@ -120,6 +123,7 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
real(8) :: auxOrigin(3)
real(8) :: auxCharge
real(8) :: auxMass
+ integer :: auxEta
real(8) :: auxOmega
real(8) :: auxMultiplicity
logical :: isDummy
@@ -137,6 +141,9 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
auxMass=0.0_8
if ( present(mass) ) auxMass= mass
+ auxEta=0
+ if ( present(eta) ) auxEta= eta
+
auxOmega=0.0_8
if ( present(omega) ) auxOmega= omega
@@ -219,6 +226,7 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
origin=auxOrigin, &
charge=auxCharge, &
mass=auxMass, &
+ eta=auxEta, &
omega=auxOmega, &
basisSetName=trim(baseName), &
elementSymbol=trim(elementSymbol), &
@@ -309,6 +317,7 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
origin = auxOrigin,&
charge = auxCharge,&
mass = auxMass,&
+ eta=auxEta, &
omega=auxOmega, &
basisSetName = trim(baseName), &
elementSymbol = trim(elementSymbol), &
@@ -330,10 +339,10 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
this%charge = element%atomicNumber
end if
- if ( auxMass == 0.0_8) then
- this%mass = element%massicNumber * PhysicalConstants_NEUTRON_MASS &
+ if ( auxMass .eq. 0.0_8 .and. element%atomicWeight .eq. 0.0_8 ) &
+ this%mass = element%massicNumber * PhysicalConstants_NEUTRON_MASS &
+ element%atomicNumber * (PhysicalConstants_PROTON_MASS - PhysicalConstants_NEUTRON_MASS)
- end if
+ if ( auxMass .eq. 0.0_8 ) this%mass = element%atomicWeight*DALTON - element%atomicNumber*PhysicalConstants_ELECTRON_MASS
this%totalCharge = element%atomicNumber
this%internalSize = 1 + auxAdditionOfParticles
@@ -393,8 +402,14 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
this%charge = element%atomicNumber
this%totalCharge = element%atomicNumber
end if
- this%mass = element%massicNumber * PhysicalConstants_NEUTRON_MASS &
- + element%atomicNumber * (PhysicalConstants_PROTON_MASS - PhysicalConstants_NEUTRON_MASS)
+
+
+ if ( element%atomicWeight .eq. 0.0_8 ) then
+ this%mass = element%massicNumber * PhysicalConstants_NEUTRON_MASS &
+ + element%atomicNumber * (PhysicalConstants_PROTON_MASS - PhysicalConstants_NEUTRON_MASS)
+ else
+ this%mass = element%atomicWeight*DALTON - element%atomicNumber*PhysicalConstants_ELECTRON_MASS
+ end if
this%internalSize = 1 + auxAdditionOfParticles
this%id = id
@@ -439,8 +454,14 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
if ( auxCharge == 0.0_8) then
this%charge = element%atomicNumber
end if
- this%mass = element%massicNumber * PhysicalConstants_NEUTRON_MASS &
- + element%atomicNumber * (PhysicalConstants_PROTON_MASS - PhysicalConstants_NEUTRON_MASS)
+
+ if ( element%atomicWeight .eq. 0.0_8 ) then
+ this%mass = element%massicNumber * PhysicalConstants_NEUTRON_MASS &
+ + element%atomicNumber * (PhysicalConstants_PROTON_MASS - PhysicalConstants_NEUTRON_MASS)
+ else
+ this%mass = element%atomicWeight*DALTON - element%atomicNumber*PhysicalConstants_ELECTRON_MASS
+ end if
+
this%totalCharge = element%atomicNumber
this%internalSize = 1 + auxAdditionOfParticles
this%id = id
@@ -468,12 +489,19 @@ subroutine Particle_load( this, name, baseName, origin, fix, multiplicity, &
else if ( present(baseName) .and. trim(baseName) /= "DIRAC" .and. trim(baseName) /= "MM") then
call ElementalParticle_load( eparticle, trim(name) )
+
+ if(eparticle%custom .and. auxMass .ne. 0.0_8 .and. auxCharge .ne. 0.0_8) &
+ print *, "I'm loading a custom particle from the input", trim(name), "with mass", auxMass, "and charge", auxCharge
+ if(eparticle%custom .and. auxMass .eq. 0.0_8 .and. auxCharge .eq. 0.0_8) &
+ call Particle_exception( ERROR, "Elemental particle: "//trim(name)//&
+ " NOT found in ElementalParticles.lib. If you want to use a custom particle, provide at least its mass and charge in the input", "In Particle_load routine")
call Particle_build( this = this, &
isQuantum = .true., &
origin = auxOrigin, &
charge = auxCharge, &
mass = auxMass, &
+ eta=auxEta, &
omega = auxOmega, &
basisSetName = trim(baseName), &
elementSymbol = trim(elementSymbol), &
@@ -586,7 +614,7 @@ end subroutine Particle_load
!! @param this Quantum particle or point charge
!! @author S. A. Gonzalez (before known as Particle_constructor)
subroutine Particle_build( this, name, symbol, basisSetName, elementSymbol, nickname, &
- origin, mass, omega, qdoCenterOf, charge, totalCharge, spin, &
+ origin, mass, eta, omega, qdoCenterOf, charge, totalCharge, spin, &
owner, subsystem, translationCenter, rotationPoint, rotateAround, massNumber, isQuantum, isDummy)
implicit none
@@ -600,6 +628,7 @@ subroutine Particle_build( this, name, symbol, basisSetName, elementSymbol, nick
character(*), optional, intent(in) :: qdoCenterOf
real(8), optional, intent(in) :: origin(3)
real(8), optional, intent(in) :: mass
+ integer, optional, intent(in) :: eta
real(8), optional, intent(in) :: omega
real(8), optional, intent(in) :: charge
real(8), optional, intent(in) :: totalCharge
@@ -621,6 +650,7 @@ subroutine Particle_build( this, name, symbol, basisSetName, elementSymbol, nick
this%isQuantum = .false.
this%origin = 0.0_8
this%mass = PhysicalConstants_ELECTRON_MASS
+ this%eta = 0
this%omega = 0.0_8
this%qdoCenterOf = "NONE"
this%charge = PhysicalConstants_ELECTRON_CHARGE
@@ -646,6 +676,7 @@ subroutine Particle_build( this, name, symbol, basisSetName, elementSymbol, nick
!! Loads optional information
if ( present(origin) ) this%origin = origin
if ( present( mass ) ) this%mass = mass
+ if ( present( eta ) ) this%eta = eta
if ( present( omega ) ) this%omega = omega
if ( present( qdoCenterOf ) ) this%qdoCenterOf = qdoCenterOf
if ( present(charge) ) this%charge = charge
@@ -722,6 +753,7 @@ subroutine Particle_destroy( this )
this%origin = 0.0_8
this%charge = 0
this%mass = 0.0_8
+ this%eta = 0
this%omega = 0.0_8
this%spin = 0.0_8
this%totalCharge = 0
@@ -760,6 +792,7 @@ subroutine Particle_show( this )
write (6,"(T10,A16,I8)") "Owner : ",this%owner
write (6,"(T10,A16,F8.2)") "Charge : ",this%charge
write (6,"(T10,A16,F8.2)") "Mass : ",this%mass
+ write (6,"(T10,A16,I8)") "Eta : ",this%eta
write (6,"(T10,A16,F8.2)") "Omega : ",this%omega
write (6,"(T10,A16,F8.2)") "QDO center of : ",this%qdoCenterOf
write (6,"(T10,A16,F8.2)") "Spin : ",this%spin
@@ -828,6 +861,7 @@ subroutine Particle_saveToFile( this, unit )
write(unit,*) this%origin
write(unit,*) this%charge
write(unit,*) this%mass
+ write(unit,*) this%eta
write(unit,*) this%omega
write(unit,*) this%qdoCenterOf
write(unit,*) this%spin
@@ -888,6 +922,7 @@ subroutine Particle_loadFromFile( this, unit )
read(unit,*) this%origin
read(unit,*) this%charge
read(unit,*) this%mass
+ read(unit,*) this%eta
read(unit,*) this%omega
read(unit,*) this%qdoCenterOf
read(unit,*) this%spin
diff --git a/src/core/Species.f90 b/src/core/Species.f90
index 061113e8..e4d0de4c 100644
--- a/src/core/Species.f90
+++ b/src/core/Species.f90
@@ -93,9 +93,9 @@ subroutine Species_setSpecie( this, speciesID)
if(trim(this%statistics) == "FERMION") then
this%kappa = -1.0_8
- this%eta = 2.0_8
- this%lambda = 2.0_8
- this%particlesFraction = 0.5_8
+ this%eta = 1.0_8
+ this%lambda = 1.0_8
+ this%particlesFraction = 1.0_8
else
@@ -151,6 +151,13 @@ subroutine Species_setSpecie( this, speciesID)
!! Adjust multiplicity
this%multiplicity = this%multiplicity + 1
+ !! Adjust eta
+ if(this%particles(1)%eta .ne. 0) then
+ this%eta = this%particles(1)%eta
+ this%lambda = this%particles(1)%eta
+ this%particlesFraction = 1.0_8/this%particles(1)%eta
+ end if
+
!! Adjust Occupation number
this%ocupationNumber = this%ocupationNumber * this%particlesFraction
diff --git a/src/core/Units.f90 b/src/core/Units.f90
index 3a51a81d..7f111dde 100644
--- a/src/core/Units.f90
+++ b/src/core/Units.f90
@@ -38,6 +38,7 @@ module Units_
real(8) , parameter :: DEBYES = 2.541764_8
real(8) , parameter :: ELECTRON_REST = 1.0_8
real(8) , parameter :: AMU = 1.0_8/1822.88850065855_8
+ real(8) , parameter :: DALTON = 1822.88850065855_8
real(8) , parameter :: kg = 9.109382616D-31
real(8) , parameter :: DEGREES = 57.29577951_8
real(8) , parameter :: CM_NEG1 = 219476.0_8
diff --git a/src/ints/DirectIntegralManager.f90 b/src/ints/DirectIntegralManager.f90
index 4733500f..6d98d24c 100644
--- a/src/ints/DirectIntegralManager.f90
+++ b/src/ints/DirectIntegralManager.f90
@@ -32,7 +32,7 @@ module DirectIntegralManager_
use RysQuadrature_
use Matrix_
use Stopwatch_
- use ExternalPotential_
+ use GTFPotential_
use String_
!# use RysQInts_ !! Please do not remove this line
@@ -866,8 +866,8 @@ subroutine DirectIntegralManager_getExternalPotentialIntegrals(molSystem,species
do i= 1, ExternalPotential_instance%ssize
!if( trim(potential(i)%specie)==trim(interactNameSelected) ) then ! This does not work for UHF
! if ( String_findSubstring(trim( molSystem%species(speciesID)%name ), &
- ! trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%specie)))) == 1 ) then
- if ( trim( molSystem%species(speciesID)%symbol) == trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%specie))) ) then
+ ! trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%species)))) == 1 ) then
+ if ( trim( molSystem%species(speciesID)%symbol) == trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%species))) ) then
potID=i
exit
end if
diff --git a/src/ints/G12Integrals.f90 b/src/ints/G12Integrals.f90
index 19446252..1bfc7d4b 100644
--- a/src/ints/G12Integrals.f90
+++ b/src/ints/G12Integrals.f90
@@ -29,7 +29,7 @@ module G12Integrals_
use CONTROL_
use MolecularSystem_
use ContractedGaussian_
- use InterPotential_
+ use GTFPotential_
implicit none
#define contr(n,m) contractions(n)%contractions(m)
@@ -253,7 +253,7 @@ subroutine G12Integrals_diskIntraSpecie(specieID)
!Get potential ID
do i=1, InterPotential_instance%ssize
- if ( trim( MolecularSystem_instance%species(specieID)%symbol) == trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. trim( MolecularSystem_instance%species(specieID)%symbol) == trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie))) ) then
+ if ( trim( MolecularSystem_instance%species(specieID)%symbol) == trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. trim( MolecularSystem_instance%species(specieID)%symbol) == trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies))) ) then
potID=i
exit
end if
@@ -918,14 +918,14 @@ subroutine G12Integrals_G12diskInterSpecie(nameOfSpecie, otherNameOfSpecie, spe
!Get potential ID
do i=1, InterPotential_instance%ssize
if ( (trim(MolecularSystem_instance%species(specieID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim(MolecularSystem_instance%species(otherSpecieID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) .or. &
(trim( MolecularSystem_instance%species(otherSpecieID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim( MolecularSystem_instance%species(specieID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) &
) then
potID=i
diff --git a/src/ints/IntegralManager.f90 b/src/ints/IntegralManager.f90
index 4c669083..ebba8eed 100644
--- a/src/ints/IntegralManager.f90
+++ b/src/ints/IntegralManager.f90
@@ -37,7 +37,7 @@ module IntegralManager_
use Matrix_
use CosmoCore_
use Stopwatch_
- use ExternalPotential_
+ use GTFPotential_
use HarmonicIntegrals_
use FirstDerivativeIntegrals_
@@ -929,8 +929,8 @@ subroutine IntegralManager_writeThreeCenterIntegralsByProduct()
do i= 1, ExternalPotential_instance%ssize
!if( trim(potential(i)%specie)==trim(interactNameSelected) ) then ! This does not work for UHF
! if ( String_findSubstring(trim( MolecularSystem_instance%species(f)%name ), &
- ! trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%specie)))) == 1 ) then
- if ( trim( MolecularSystem_instance%species(f)%symbol) == trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%specie))) ) then
+ ! trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%species)))) == 1 ) then
+ if ( trim( MolecularSystem_instance%species(f)%symbol) == trim(String_getUpperCase(trim(ExternalPotential_instance%potentials(i)%species))) ) then
potID=i
exit
end if
diff --git a/src/ints/Libint2Interface.f90 b/src/ints/Libint2Interface.f90
index 23f5ffa1..78cc9d13 100644
--- a/src/ints/Libint2Interface.f90
+++ b/src/ints/Libint2Interface.f90
@@ -26,7 +26,7 @@
module Libint2Interface_
use, intrinsic :: iso_c_binding
use MolecularSystem_
- use InterPotential_
+ use GTFPotential_
use ContractedGaussian_
! use Matrix_
@@ -824,9 +824,9 @@ subroutine Libint2Interface_computeG12Intraspecies_disk(speciesID)
!Get potential ID
do i=1, InterPotential_instance%ssize
if ( trim( MolecularSystem_instance%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim( MolecularSystem_instance%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie))) ) then
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies))) ) then
potID=i
exit
end if
@@ -883,14 +883,14 @@ subroutine Libint2Interface_computeG12Interspecies_disk(speciesID,otherSpeciesID
!Get potential ID
do i=1, InterPotential_instance%ssize
if ( (trim(MolecularSystem_instance%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim(MolecularSystem_instance%species(otherSpeciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) .or. &
(trim( MolecularSystem_instance%species(otherSpeciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim( MolecularSystem_instance%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) &
) then
potID=i
@@ -965,9 +965,9 @@ subroutine Libint2Interface_computeG12Intraspecies_direct(speciesID, density, tw
!Get potential ID
do i=1, InterPotential_instance%ssize
if ( trim( molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim( molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie))) ) then
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies))) ) then
potID=i
exit
end if
@@ -1027,14 +1027,14 @@ subroutine Libint2Interface_computeG12Interspecies_direct(speciesID,otherSpecies
!Get potential ID
do i=1, InterPotential_instance%ssize
if ( (trim(molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim(molSys%species(otherSpeciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) .or. &
(trim(molSys%species(otherSpeciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim(molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) &
) then
potID=i
@@ -1088,9 +1088,9 @@ subroutine Libint2Interface_compute2BodyIntraspecies_direct_all(speciesID, densi
!Get potential ID
do i=1, InterPotential_instance%ssize
if ( trim( molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim( molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie))) ) then
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies))) ) then
potID=i
exit
end if
@@ -1142,14 +1142,14 @@ subroutine Libint2Interface_compute2BodyInterspecies_direct_all(speciesID, other
!Get potential ID
do i=1, InterPotential_instance%ssize
if ( (trim(molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim(molSys%species(otherSpeciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) .or. &
(trim( molSys%species(otherSpeciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%specie))) .and. &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%species))) .and. &
trim( molSys%species(speciesID)%symbol) == &
- trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecie)) ) &
+ trim(String_getUpperCase(trim(InterPotential_instance%potentials(i)%otherSpecies)) ) &
) &
) then
potID=i
diff --git a/src/scf/DensityMatrixSCFGuess.f90 b/src/scf/DensityMatrixSCFGuess.f90
index a64a9a3a..f3a279a3 100644
--- a/src/scf/DensityMatrixSCFGuess.f90
+++ b/src/scf/DensityMatrixSCFGuess.f90
@@ -54,7 +54,7 @@ subroutine DensityMatrixSCFGuess_getGuess( speciesID, hcoreMatrix, transformatio
type(MolecularSystem), pointer :: molSys
type(Matrix) :: auxMatrix
- character(30) :: nameOfSpecies
+ character(30) :: nameOfSpecies, symbolOfSpecies
integer(8) :: orderOfMatrix, occupationNumber
logical :: existPlain, existBinnary, readSuccess
character(50) :: guessType
@@ -71,6 +71,7 @@ subroutine DensityMatrixSCFGuess_getGuess( speciesID, hcoreMatrix, transformatio
orderOfMatrix = MolecularSystem_getTotalnumberOfContractions(speciesID,molSys)
nameOfSpecies = molSys%species(speciesID)%name
+ symbolOfSpecies = molSys%species(speciesID)%symbol
occupationNumber = MolecularSystem_getOcupationNumber(speciesID,molSys)
readSuccess=.false.
@@ -79,11 +80,12 @@ subroutine DensityMatrixSCFGuess_getGuess( speciesID, hcoreMatrix, transformatio
call Matrix_constructor(densityMatrix, int(orderOfMatrix,8), int(orderOfMatrix,8), 0.0_8 )
call Matrix_constructor(orbitals, int(orderOfMatrix,8), int(orderOfMatrix,8), 0.0_8 )
-
+
+ readSuccess=.false.
!!Verifica el archivo que contiene los coeficientes para una especie dada
if ( CONTROL_instance%READ_FCHK ) then
- call MolecularSystem_readFchk(trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".fchk", orbitals, densityMatrix, nameOfSpecies )
- return
+ wfnFile=trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".fchk"
+ call MolecularSystem_readFchk(wfnFile, orbitals, densityMatrix, nameOfSpecies, readSuccess)
else if ( CONTROL_instance%READ_COEFFICIENTS ) then
wfnUnit = 30
@@ -107,10 +109,7 @@ subroutine DensityMatrixSCFGuess_getGuess( speciesID, hcoreMatrix, transformatio
end if
end if
end if
-
- !check if the orbitals were read correctly
- if(.not. allocated(orbitals%values) ) readSuccess=.false.
-
+
if(readSuccess .and. printInfo ) print *, "Combination coefficients for ", trim(nameOfSpecies), " were read from ", trim(wfnFile)
if(.not. readSuccess) then
diff --git a/src/scf/OrbitalLocalizer.f90 b/src/scf/OrbitalLocalizer.f90
index 28e4ca88..006ab893 100644
--- a/src/scf/OrbitalLocalizer.f90
+++ b/src/scf/OrbitalLocalizer.f90
@@ -109,7 +109,7 @@ subroutine OrbitalLocalizer_erkaleLocal(speciesID,densityMatrix,fockMatrix,orbit
type(Matrix) :: orbitalCoefficients
type(Vector) :: orbitalEnergies
- character(30) :: nameOfSpecies
+ character(30) :: nameOfSpecies, symbolOfSpecies
integer :: statusSystem
integer :: numberOfContractions
@@ -118,11 +118,12 @@ subroutine OrbitalLocalizer_erkaleLocal(speciesID,densityMatrix,fockMatrix,orbit
!! Convert lowdin fchk files to erkale chk files
nameOfSpecies=MolecularSystem_getNameOfSpecies(speciesID)
+ symbolOfSpecies=MolecularSystem_getSymbolOfSpecies(speciesID)
numberOfContractions = MolecularSystem_getTotalNumberOfContractions(speciesID)
open(unit=30, file="erkale.read", status="replace", form="formatted")
- write(30,*) "LoadFChk ", trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".fchk"
- write(30,*) "SaveChk ", trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".chk"
+ write(30,*) "LoadFChk ", trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".fchk"
+ write(30,*) "SaveChk ", trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".chk"
write(30,*) "Reorthonormalize true"
close(30)
@@ -132,8 +133,8 @@ subroutine OrbitalLocalizer_erkaleLocal(speciesID,densityMatrix,fockMatrix,orbit
!! Localize orbitals
open(unit=30, file="erkale.local", status="replace", form="formatted")
- write(30,*) "LoadChk ", trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".chk"
- write(30,*) "SaveChk ", trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".local.chk"
+ write(30,*) "LoadChk ", trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".chk"
+ write(30,*) "SaveChk ", trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".local.chk"
write(30,*) "Method ", trim(CONTROL_instance%ERKALE_LOCALIZATION_METHOD)
write(30,*) "Virtual false"
write(30,*) "Maxiter 5000"
@@ -149,15 +150,15 @@ subroutine OrbitalLocalizer_erkaleLocal(speciesID,densityMatrix,fockMatrix,orbit
!!Convert erkale chk files to lowdin fchk files
open(unit=30, file="erkale.write", status="replace", form="formatted")
- write(30,*) "LoadChk ", trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".local.chk"
- write(30,*) "SaveFChk ", trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".local.fchk"
+ write(30,*) "LoadChk ", trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".local.chk"
+ write(30,*) "SaveFChk ", trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".local.fchk"
close(30)
call system("erkale_fchkpt erkale.write")
!! Read orbital coefficients from fchk files
- call MolecularSystem_readFchk(trim(CONTROL_instance%INPUT_FILE)//trim(nameOfSpecies)//".local.fchk", orbitalCoefficients, densityMatrix, nameOfSpecies )
+ call MolecularSystem_readFchk(trim(CONTROL_instance%INPUT_FILE)//trim(symbolOfSpecies)//".local.fchk", orbitalCoefficients, densityMatrix, nameOfSpecies )
orbitalEnergies%values=0.0
!! Molecular orbital fock operator expected value
diff --git a/src/scf/SingleSCF.f90 b/src/scf/SingleSCF.f90
index 6cb85fd1..16c219fb 100644
--- a/src/scf/SingleSCF.f90
+++ b/src/scf/SingleSCF.f90
@@ -508,7 +508,7 @@ subroutine SingleSCF_readFrozenOrbitals(wfObject)
if (CONTROL_instance%READ_FCHK) then
call Matrix_constructor (auxiliaryMatrix, numberOfContractions, numberOfContractions)
- call MolecularSystem_readFchk( trim(CONTROL_instance%INPUT_FILE)//trim(wfObject%name)//".fchk", &
+ call MolecularSystem_readFchk( trim(CONTROL_instance%INPUT_FILE)//trim(wfObject%molSys%species(wfObject%species)%symbol)//".fchk", &
wfObject%waveFunctionCoefficients, auxiliaryMatrix, wfObject%name )
call Matrix_destructor(auxiliaryMatrix)
diff --git a/test/CHDTHemu.massTest.lowdin b/test/CHDTHemu.massTest.lowdin
new file mode 100644
index 00000000..85916399
--- /dev/null
+++ b/test/CHDTHemu.massTest.lowdin
@@ -0,0 +1,23 @@
+
+GEOMETRY
+e-(C) NAKAI-CC-PVTZ 0.0000000 0.0000000 0.0000000
+e-(H) NAKAI-CC-PVTZ 0.6283310 0.6283310 0.6283310
+e-(H) NAKAI-CC-PVTZ -0.6283310 -0.6283310 0.6283310
+e-(H) NAKAI-CC-PVTZ -0.6283310 0.6283310 -0.6283310
+e-(H) NAKAI-CC-PVTZ 0.6283310 -0.6283310 -0.6283310
+U- HEMU 0.6283310 0.6283310 0.6283310
+C_12 NAKAI-3-SP 0.0000000 0.0000000 0.0000000
+He_4 NAKAI-3-SP 0.6283310 0.6283310 0.6283310
+H_1 DZSPNB -0.6283310 -0.6283310 0.6283310
+H_2 DZSPNB -0.6283310 0.6283310 -0.6283310
+H_3 DZSPNB 0.6283310 -0.6283310 -0.6283310
+END GEOMETRY
+
+TASKS
+ method = "RHF"
+END TASKS
+
+CONTROL
+ readCoefficients=F
+ removeTranslationalContamination=T
+END CONTROL
diff --git a/test/CHDTHemu.massTest.py b/test/CHDTHemu.massTest.py
new file mode 100644
index 00000000..e1d5f5a4
--- /dev/null
+++ b/test/CHDTHemu.massTest.py
@@ -0,0 +1,84 @@
+#!/usr/bin/env python
+from __future__ import print_function
+import os
+import sys
+from colorstring import *
+
+if len(sys.argv)==2:
+ lowdinbin = sys.argv[1]
+else:
+ lowdinbin = "lowdin2"
+
+testName = sys.argv[0][:-3]
+inputName = testName + ".lowdin"
+outputName = testName + ".out"
+# Reference values and tolerance
+
+refValues = {
+ "Total mass" : [40383.2869, 5E-4],
+ "E- Kinetic energy" : [36.558549208752,1E-6],
+ "MUON Kinetic energy" : [4.823223401186,1E-6],
+ "C_12 Kinetic energy" : [0.020362665915,1E-6],
+ "HE_4 Kinetic energy" : [0.042798597334,1E-6],
+ "H_1 Kinetic energy" : [0.018810346458,1E-6],
+ "H_2 Kinetic energy" : [0.013654378944,1E-6],
+ "H_3 Kinetic energy" : [0.011128664979,1E-6],
+ "HF energy" : [-74.168958869716,1E-8]
+}
+
+testValues = dict(refValues) #copy
+for value in testValues: #reset
+ testValues[value] = 0 #reset
+
+# Run calculation
+
+status = os.system(lowdinbin + " -i " + inputName)
+
+if status:
+ print(testName + str_red(" ... NOT OK"))
+ sys.exit(1)
+
+output = open(outputName, "r")
+outputRead = output.readlines()
+
+# Values
+checkArray=[0,0,0,0]
+for i in range(0,len(outputRead)):
+ line = outputRead[i]
+ if "TOTAL ENERGY =" in line:
+ testValues["HF energy"] = float(line.split()[3])
+ if "MASS (m_e)" in line:
+ testValues["Total mass"] = float(line.split()[3])
+ if "E- Kinetic energy" in line:
+ testValues["E- Kinetic energy"] = float(line.split()[4])
+ if "MUON Kinetic energy" in line:
+ testValues["MUON Kinetic energy"] = float(line.split()[4])
+ if "C_12 Kinetic energy" in line:
+ testValues["C_12 Kinetic energy"] = float(line.split()[4])
+ if "HE_4 Kinetic energy" in line:
+ testValues["HE_4 Kinetic energy"] = float(line.split()[4])
+ if "H_1 Kinetic energy" in line:
+ testValues["H_1 Kinetic energy"] = float(line.split()[4])
+ if "H_2 Kinetic energy" in line:
+ testValues["H_2 Kinetic energy"] = float(line.split()[4])
+ if "H_3 Kinetic energy" in line:
+ testValues["H_3 Kinetic energy"] = float(line.split()[4])
+
+output.close()
+
+passTest = True
+
+for value in refValues:
+ diffValue = abs(refValues[value][0] - testValues[value])
+ if ( diffValue <= refValues[value][1] ):
+ passTest = passTest * True
+ else :
+ passTest = passTest * False
+ print("%s %.8f %.8f %.2e" % ( value, refValues[value][0], testValues[value], diffValue))
+
+if passTest :
+ print(testName + str_green(" ... OK"))
+else:
+ print(testName + str_red(" ... NOT OK"))
+ sys.exit(1)
+
diff --git a/test/He2-C60potential-NOCI.lowdin b/test/He2-C60potential-NOCI.lowdin
index c06d7379..4883911f 100644
--- a/test/He2-C60potential-NOCI.lowdin
+++ b/test/He2-C60potential-NOCI.lowdin
@@ -2,8 +2,8 @@ SYSTEM_DESCRIPTION='H'
GEOMETRY
N0 dirac 0.0 0.0 0.0 rotationPoint=1
-HEA3 HE2-1S 1.818207 0.0 -0.347193 rotateAround=1
-HEB3 HE2-1S -1.818207 0.0 0.347193 rotateAround=1
+HEA3 HE2-1S 1.818207 0.0 -0.347193 rotateAround=1 m=5494.8926
+HEB3 HE2-1S -1.818207 0.0 0.347193 rotateAround=1 m=5494.8926
END GEOMETRY
TASKS
diff --git a/test/He3-C60potential-NOCI.lowdin b/test/He3-C60potential-NOCI.lowdin
index 16870c5d..a5efe877 100644
--- a/test/He3-C60potential-NOCI.lowdin
+++ b/test/He3-C60potential-NOCI.lowdin
@@ -2,9 +2,9 @@ SYSTEM_DESCRIPTION='H'
GEOMETRY
N0 dirac 0.0 0.0 0.0 rotationPoint=1
-HEA3 HE2-1S 2.159 0.0 0.0 rotateAround=1
-HEA3 HE2-1S 0.0 2.159 0.0 rotateAround=1
-HEB3 HE2-1S 0.0 0.0 2.159 rotateAround=1
+HEA3 HE2-1S 2.159 0.0 0.0 rotateAround=1 m=5494.8926
+HEA3 HE2-1S 0.0 2.159 0.0 rotateAround=1 m=5494.8926
+HEB3 HE2-1S 0.0 0.0 2.159 rotateAround=1 m=5494.8926
END GEOMETRY
TASKS
diff --git a/test/Ps2F2.RHF-customEta.lowdin b/test/Ps2F2.RHF-customEta.lowdin
new file mode 100644
index 00000000..2484865d
--- /dev/null
+++ b/test/Ps2F2.RHF-customEta.lowdin
@@ -0,0 +1,17 @@
+GEOMETRY
+ e-(F) aug-cc-pvdz 0.00 0.00 -1.33 addParticles=1
+ e-(F) aug-cc-pvdz 0.00 0.00 1.33 addParticles=1
+ e+ PSX-DZ 0.00 0.00 -1.33 eta=2
+ e+ PSX-DZ 0.00 0.00 1.33
+ F dirac 0.00 0.00 -1.33
+ F dirac 0.00 0.00 1.33
+END GEOMETRY
+
+TASKS
+ method = "RHF"
+END TASKS
+
+CONTROL
+ readCoefficients=F
+END CONTROL
+
diff --git a/test/Ps2F2.RHF-customEta.py b/test/Ps2F2.RHF-customEta.py
new file mode 100644
index 00000000..a812ee62
--- /dev/null
+++ b/test/Ps2F2.RHF-customEta.py
@@ -0,0 +1,68 @@
+#!/usr/bin/env python
+from __future__ import print_function
+import os
+import sys
+from colorstring import *
+
+if len(sys.argv)==2:
+ lowdinbin = sys.argv[1]
+else:
+ lowdinbin = "lowdin2"
+
+testName = sys.argv[0][:-3]
+inputName = testName + ".lowdin"
+outputName = testName + ".out"
+
+# Reference values and tolerance
+refValues = {
+ "HF energy" : [-199.213740198536,1E-8],
+ "eta e+" : [2.0,1E-8],
+ "occupation e+" : [1.0,1E-8]
+}
+
+testValues = dict(refValues) #copy
+for value in testValues: #reset
+ testValues[value] = 0 #reset
+
+# Run calculation
+
+status = os.system(lowdinbin + " -i " + inputName)
+
+if status:
+ print(testName + str_red(" ... NOT OK"))
+ sys.exit(1)
+
+output = open(outputName, "r")
+outputRead = output.readlines()
+
+# Values
+flagC=0
+for i in range(0,len(outputRead)):
+ line = outputRead[i]
+ if "TOTAL ENERGY =" in line:
+ testValues["HF energy"] = float(line.split()[3])
+ if "CONSTANTS OF COUPLING" in line:
+ flagC=1
+ if "E+" in line and flagC==1:
+ testValues["eta e+"] = float(line.split()[2])
+ testValues["occupation e+"] = float(line.split()[4])
+ flagC=0
+output.close()
+
+passTest = True
+
+for value in refValues:
+ diffValue = abs(refValues[value][0] - testValues[value])
+ if ( diffValue <= refValues[value][1] ):
+ passTest = passTest * True
+ else :
+ passTest = passTest * False
+ print("%s %.8f %.8f %.2e" % ( value, refValues[value][0], testValues[value], diffValue))
+
+if passTest :
+ print(testName + str_green(" ... OK"))
+else:
+ print(testName + str_red(" ... NOT OK"))
+ sys.exit(1)
+
+output.close()
diff --git a/test/TIP4P-dimer-singlet-NOCI.lowdin b/test/TIP4P-dimer-singlet-NOCI.lowdin
index d886158d..213f2093 100644
--- a/test/TIP4P-dimer-singlet-NOCI.lowdin
+++ b/test/TIP4P-dimer-singlet-NOCI.lowdin
@@ -2,12 +2,12 @@ SYSTEM_DESCRIPTION='H'
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 translationCenter=1
-Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 translationCenter=2
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 translationCenter=1 q=0.5564 m=1836.15267247
+Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 translationCenter=2 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -36,3 +36,452 @@ INTERPOTENTIAL
X0.5+ Y0.5+ VHH-CCSDT
Y0.5+ Y0.5+ VHH-CCSDT
END INTERPOTENTIAL
+
+EXTERPOTENTIAL
+ X0.5+ VOH-CCSDT
+ Y0.5+ VOH-CCSDT
+END EXTERPOTENTIAL
+
+INTERPOTENTIAL
+ X0.5+ X0.5+ VHH-CCSDT
+ X0.5+ Y0.5+ VHH-CCSDT
+ Y0.5+ Y0.5+ VHH-CCSDT
+END INTERPOTENTIAL
+
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+
+O-H-TIP Y0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+
+O-Y0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-X0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-Y0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-singlet-direct.lowdin b/test/TIP4P-dimer-singlet-direct.lowdin
index 9e5e2eaa..3788cc16 100644
--- a/test/TIP4P-dimer-singlet-direct.lowdin
+++ b/test/TIP4P-dimer-singlet-direct.lowdin
@@ -1,11 +1,11 @@
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200
-Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 q=0.5564 m=1836.15267247
+Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -31,3 +31,440 @@ INTERPOTENTIAL
Y0.5+ Y0.5+ VHH-CCSDT
END INTERPOTENTIAL
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+
+O-H-TIP Y0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+
+O-Y0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-X0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-Y0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-singlet-direct.py b/test/TIP4P-dimer-singlet-direct.py
index f3b406ea..bc41eaa3 100644
--- a/test/TIP4P-dimer-singlet-direct.py
+++ b/test/TIP4P-dimer-singlet-direct.py
@@ -17,11 +17,11 @@
refValues = {
"HF energy" : [-0.651377267238,1E-8],
-"HA-TIP Ext Pot" : [0.005339817047,1E-4],
-"HB-TIP Ext Pot" : [0.005265789260,1E-4],
-"HA-TIP/HB-TIP Hartree" : [0.003393498016,1E-4],
-"HA-TIP/Fixed interact." : [-0.025239485153,1E-4],
-"HB-TIP/Fixed interact." : [-0.010156190638,1E-4]
+"X0.5+ Ext Pot" : [0.005339817047,1E-4],
+"Y0.5+ Ext Pot" : [0.005265789260,1E-4],
+"X0.5+/Y0.5+ Hartree" : [0.003393498016,1E-4],
+"X0.5+/Fixed interact." : [-0.025239485153,1E-4],
+"Y0.5+/Fixed interact." : [-0.010156190638,1E-4]
}
testValues = dict(refValues) #copy
@@ -44,16 +44,16 @@
line = outputRead[i]
if "TOTAL ENERGY =" in line:
testValues["HF energy"] = float(line.split()[3])
- if "HA-TIP Ext Pot" in line:
- testValues["HA-TIP Ext Pot"] = float(line.split()[5])
- if "HB-TIP Ext Pot" in line:
- testValues["HB-TIP Ext Pot"] = float(line.split()[5])
- if "HA-TIP/HB-TIP Hartree" in line:
- testValues["HA-TIP/HB-TIP Hartree"] = float(line.split()[4])
- if "HA-TIP/Fixed interact." in line:
- testValues["HA-TIP/Fixed interact."] = float(line.split()[4])
- if "HB-TIP/Fixed interact." in line:
- testValues["HB-TIP/Fixed interact."] = float(line.split()[4])
+ if "X0.5+ Ext Pot" in line:
+ testValues["X0.5+ Ext Pot"] = float(line.split()[5])
+ if "Y0.5+ Ext Pot" in line:
+ testValues["Y0.5+ Ext Pot"] = float(line.split()[5])
+ if "X0.5+/Y0.5+ Hartree" in line:
+ testValues["X0.5+/Y0.5+ Hartree"] = float(line.split()[4])
+ if "X0.5+/Fixed interact." in line:
+ testValues["X0.5+/Fixed interact."] = float(line.split()[4])
+ if "Y0.5+/Fixed interact." in line:
+ testValues["Y0.5+/Fixed interact."] = float(line.split()[4])
passTest = True
diff --git a/test/TIP4P-dimer-singlet-memory.lowdin b/test/TIP4P-dimer-singlet-memory.lowdin
index bc275bf3..1dc863f5 100644
--- a/test/TIP4P-dimer-singlet-memory.lowdin
+++ b/test/TIP4P-dimer-singlet-memory.lowdin
@@ -1,11 +1,11 @@
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200
-Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 q=0.5564 m=1836.15267247
+Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -31,3 +31,440 @@ INTERPOTENTIAL
Y0.5+ Y0.5+ VHH-CCSDT
END INTERPOTENTIAL
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+
+O-H-TIP Y0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+
+O-Y0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-X0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-Y0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-singlet-memory.py b/test/TIP4P-dimer-singlet-memory.py
index f3b406ea..bc41eaa3 100644
--- a/test/TIP4P-dimer-singlet-memory.py
+++ b/test/TIP4P-dimer-singlet-memory.py
@@ -17,11 +17,11 @@
refValues = {
"HF energy" : [-0.651377267238,1E-8],
-"HA-TIP Ext Pot" : [0.005339817047,1E-4],
-"HB-TIP Ext Pot" : [0.005265789260,1E-4],
-"HA-TIP/HB-TIP Hartree" : [0.003393498016,1E-4],
-"HA-TIP/Fixed interact." : [-0.025239485153,1E-4],
-"HB-TIP/Fixed interact." : [-0.010156190638,1E-4]
+"X0.5+ Ext Pot" : [0.005339817047,1E-4],
+"Y0.5+ Ext Pot" : [0.005265789260,1E-4],
+"X0.5+/Y0.5+ Hartree" : [0.003393498016,1E-4],
+"X0.5+/Fixed interact." : [-0.025239485153,1E-4],
+"Y0.5+/Fixed interact." : [-0.010156190638,1E-4]
}
testValues = dict(refValues) #copy
@@ -44,16 +44,16 @@
line = outputRead[i]
if "TOTAL ENERGY =" in line:
testValues["HF energy"] = float(line.split()[3])
- if "HA-TIP Ext Pot" in line:
- testValues["HA-TIP Ext Pot"] = float(line.split()[5])
- if "HB-TIP Ext Pot" in line:
- testValues["HB-TIP Ext Pot"] = float(line.split()[5])
- if "HA-TIP/HB-TIP Hartree" in line:
- testValues["HA-TIP/HB-TIP Hartree"] = float(line.split()[4])
- if "HA-TIP/Fixed interact." in line:
- testValues["HA-TIP/Fixed interact."] = float(line.split()[4])
- if "HB-TIP/Fixed interact." in line:
- testValues["HB-TIP/Fixed interact."] = float(line.split()[4])
+ if "X0.5+ Ext Pot" in line:
+ testValues["X0.5+ Ext Pot"] = float(line.split()[5])
+ if "Y0.5+ Ext Pot" in line:
+ testValues["Y0.5+ Ext Pot"] = float(line.split()[5])
+ if "X0.5+/Y0.5+ Hartree" in line:
+ testValues["X0.5+/Y0.5+ Hartree"] = float(line.split()[4])
+ if "X0.5+/Fixed interact." in line:
+ testValues["X0.5+/Fixed interact."] = float(line.split()[4])
+ if "Y0.5+/Fixed interact." in line:
+ testValues["Y0.5+/Fixed interact."] = float(line.split()[4])
passTest = True
diff --git a/test/TIP4P-dimer-singlet.lowdin b/test/TIP4P-dimer-singlet.lowdin
index 9d540025..7ffc1cfe 100644
--- a/test/TIP4P-dimer-singlet.lowdin
+++ b/test/TIP4P-dimer-singlet.lowdin
@@ -1,11 +1,11 @@
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200
-Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 q=0.5564 m=1836.15267247
+Y0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -31,3 +31,440 @@ INTERPOTENTIAL
Y0.5+ Y0.5+ VHH-CCSDT
END INTERPOTENTIAL
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+
+O-H-TIP Y0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+
+O-Y0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-X0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-Y0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-singlet.py b/test/TIP4P-dimer-singlet.py
index f3b406ea..bc41eaa3 100644
--- a/test/TIP4P-dimer-singlet.py
+++ b/test/TIP4P-dimer-singlet.py
@@ -17,11 +17,11 @@
refValues = {
"HF energy" : [-0.651377267238,1E-8],
-"HA-TIP Ext Pot" : [0.005339817047,1E-4],
-"HB-TIP Ext Pot" : [0.005265789260,1E-4],
-"HA-TIP/HB-TIP Hartree" : [0.003393498016,1E-4],
-"HA-TIP/Fixed interact." : [-0.025239485153,1E-4],
-"HB-TIP/Fixed interact." : [-0.010156190638,1E-4]
+"X0.5+ Ext Pot" : [0.005339817047,1E-4],
+"Y0.5+ Ext Pot" : [0.005265789260,1E-4],
+"X0.5+/Y0.5+ Hartree" : [0.003393498016,1E-4],
+"X0.5+/Fixed interact." : [-0.025239485153,1E-4],
+"Y0.5+/Fixed interact." : [-0.010156190638,1E-4]
}
testValues = dict(refValues) #copy
@@ -44,16 +44,16 @@
line = outputRead[i]
if "TOTAL ENERGY =" in line:
testValues["HF energy"] = float(line.split()[3])
- if "HA-TIP Ext Pot" in line:
- testValues["HA-TIP Ext Pot"] = float(line.split()[5])
- if "HB-TIP Ext Pot" in line:
- testValues["HB-TIP Ext Pot"] = float(line.split()[5])
- if "HA-TIP/HB-TIP Hartree" in line:
- testValues["HA-TIP/HB-TIP Hartree"] = float(line.split()[4])
- if "HA-TIP/Fixed interact." in line:
- testValues["HA-TIP/Fixed interact."] = float(line.split()[4])
- if "HB-TIP/Fixed interact." in line:
- testValues["HB-TIP/Fixed interact."] = float(line.split()[4])
+ if "X0.5+ Ext Pot" in line:
+ testValues["X0.5+ Ext Pot"] = float(line.split()[5])
+ if "Y0.5+ Ext Pot" in line:
+ testValues["Y0.5+ Ext Pot"] = float(line.split()[5])
+ if "X0.5+/Y0.5+ Hartree" in line:
+ testValues["X0.5+/Y0.5+ Hartree"] = float(line.split()[4])
+ if "X0.5+/Fixed interact." in line:
+ testValues["X0.5+/Fixed interact."] = float(line.split()[4])
+ if "Y0.5+/Fixed interact." in line:
+ testValues["Y0.5+/Fixed interact."] = float(line.split()[4])
passTest = True
diff --git a/test/TIP4P-dimer-triplet-NOCI.lowdin b/test/TIP4P-dimer-triplet-NOCI.lowdin
index b8411434..8a88242a 100644
--- a/test/TIP4P-dimer-triplet-NOCI.lowdin
+++ b/test/TIP4P-dimer-triplet-NOCI.lowdin
@@ -2,12 +2,12 @@ SYSTEM_DESCRIPTION='H'
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 translationCenter=1
-X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 translationCenter=2
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 translationCenter=1 q=0.5564 m=1836.15267247
+X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 translationCenter=2 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -33,3 +33,441 @@ END EXTERPOTENTIAL
INTERPOTENTIAL
X0.5+ X0.5+ VHH-CCSDT
END INTERPOTENTIAL
+
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+
+O-H-TIP Y0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+
+O-Y0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-X0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+
+O-Y0.5+Y0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-triplet-direct.lowdin b/test/TIP4P-dimer-triplet-direct.lowdin
index 15ab0abb..2db120e6 100644
--- a/test/TIP4P-dimer-triplet-direct.lowdin
+++ b/test/TIP4P-dimer-triplet-direct.lowdin
@@ -1,11 +1,11 @@
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200
-X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 q=0.5564 m=1836.15267247
+X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -28,3 +28,186 @@ INTERPOTENTIAL
X0.5+ X0.5+ VHH-CCSDT
END INTERPOTENTIAL
+
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-triplet-direct.py b/test/TIP4P-dimer-triplet-direct.py
index 41f2ebc4..d13b500b 100644
--- a/test/TIP4P-dimer-triplet-direct.py
+++ b/test/TIP4P-dimer-triplet-direct.py
@@ -17,10 +17,10 @@
refValues = {
"HF energy" : [-0.651377261423,1E-8],
- "HA-TIP Ext Pot" : [0.010606635479,1E-4],
- "HA-TIP/HA-TIP Hartree" : [1.217813835967,1E-4],
- "HA-TIP Exchange" : [-1.214419735313,1E-4],
- "HA-TIP/Fixed interact." : [-0.035396418562,1E-4]
+ "X0.5+ Ext Pot" : [0.010606635479,1E-4],
+ "X0.5+/X0.5+ Hartree" : [1.217813835967,1E-4],
+ "X0.5+ Exchange" : [-1.214419735313,1E-4],
+ "X0.5+/Fixed interact." : [-0.035396418562,1E-4]
}
testValues = dict(refValues) #copy
@@ -43,14 +43,14 @@
line = outputRead[i]
if "TOTAL ENERGY =" in line:
testValues["HF energy"] = float(line.split()[3])
- if "HA-TIP Ext Pot" in line:
- testValues["HA-TIP Ext Pot"] = float(line.split()[5])
- if "HA-TIP/HA-TIP Hartree" in line:
- testValues["HA-TIP/HA-TIP Hartree"] = float(line.split()[4])
- if "HA-TIP Exchange" in line:
- testValues["HA-TIP Exchange"] = float(line.split()[4])
- if "HA-TIP/Fixed interact." in line:
- testValues["HA-TIP/Fixed interact."] = float(line.split()[4])
+ if "X0.5+ Ext Pot" in line:
+ testValues["X0.5+ Ext Pot"] = float(line.split()[5])
+ if "X0.5+/X0.5+ Hartree" in line:
+ testValues["X0.5+/X0.5+ Hartree"] = float(line.split()[4])
+ if "X0.5+ Exchange" in line:
+ testValues["X0.5+ Exchange"] = float(line.split()[4])
+ if "X0.5+/Fixed interact." in line:
+ testValues["X0.5+/Fixed interact."] = float(line.split()[4])
passTest = True
diff --git a/test/TIP4P-dimer-triplet-memory.lowdin b/test/TIP4P-dimer-triplet-memory.lowdin
index c37e1e48..5d36490e 100644
--- a/test/TIP4P-dimer-triplet-memory.lowdin
+++ b/test/TIP4P-dimer-triplet-memory.lowdin
@@ -1,11 +1,11 @@
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200
-X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 q=0.5564 m=1836.15267247
+X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -28,3 +28,194 @@ INTERPOTENTIAL
X0.5+ X0.5+ VHH-CCSDT
END INTERPOTENTIAL
+EXTERPOTENTIAL
+ X0.5+ VOH-CCSDT
+END EXTERPOTENTIAL
+
+INTERPOTENTIAL
+ X0.5+ X0.5+ VHH-CCSDT
+END INTERPOTENTIAL
+
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-triplet-memory.py b/test/TIP4P-dimer-triplet-memory.py
index 41f2ebc4..d13b500b 100644
--- a/test/TIP4P-dimer-triplet-memory.py
+++ b/test/TIP4P-dimer-triplet-memory.py
@@ -17,10 +17,10 @@
refValues = {
"HF energy" : [-0.651377261423,1E-8],
- "HA-TIP Ext Pot" : [0.010606635479,1E-4],
- "HA-TIP/HA-TIP Hartree" : [1.217813835967,1E-4],
- "HA-TIP Exchange" : [-1.214419735313,1E-4],
- "HA-TIP/Fixed interact." : [-0.035396418562,1E-4]
+ "X0.5+ Ext Pot" : [0.010606635479,1E-4],
+ "X0.5+/X0.5+ Hartree" : [1.217813835967,1E-4],
+ "X0.5+ Exchange" : [-1.214419735313,1E-4],
+ "X0.5+/Fixed interact." : [-0.035396418562,1E-4]
}
testValues = dict(refValues) #copy
@@ -43,14 +43,14 @@
line = outputRead[i]
if "TOTAL ENERGY =" in line:
testValues["HF energy"] = float(line.split()[3])
- if "HA-TIP Ext Pot" in line:
- testValues["HA-TIP Ext Pot"] = float(line.split()[5])
- if "HA-TIP/HA-TIP Hartree" in line:
- testValues["HA-TIP/HA-TIP Hartree"] = float(line.split()[4])
- if "HA-TIP Exchange" in line:
- testValues["HA-TIP Exchange"] = float(line.split()[4])
- if "HA-TIP/Fixed interact." in line:
- testValues["HA-TIP/Fixed interact."] = float(line.split()[4])
+ if "X0.5+ Ext Pot" in line:
+ testValues["X0.5+ Ext Pot"] = float(line.split()[5])
+ if "X0.5+/X0.5+ Hartree" in line:
+ testValues["X0.5+/X0.5+ Hartree"] = float(line.split()[4])
+ if "X0.5+ Exchange" in line:
+ testValues["X0.5+ Exchange"] = float(line.split()[4])
+ if "X0.5+/Fixed interact." in line:
+ testValues["X0.5+/Fixed interact."] = float(line.split()[4])
passTest = True
diff --git a/test/TIP4P-dimer-triplet.lowdin b/test/TIP4P-dimer-triplet.lowdin
index 75996651..18fd85c8 100644
--- a/test/TIP4P-dimer-triplet.lowdin
+++ b/test/TIP4P-dimer-triplet.lowdin
@@ -1,11 +1,11 @@
GEOMETRY
N0 dirac 0 0 0
-X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200
-X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570
+X0.5+ H2O-1S1P1D -0.151399 0.000276 1.807200 q=0.5564 m=1836.15267247
+X0.5+ H2O-1S1P1D -1.715032 0.000843 -0.589570 q=0.5564 m=1836.15267247
N0 dirac 0.0 0.0 6.0
-X1.1- dirac 0.0 0.0 6.292152
-X0.5+ dirac 0.0 1.430429 7.107157
-X0.5+ dirac 0.0 -1.430429 7.107157
+X1.1- dirac 0.0 0.0 6.292152 q=-1.1128
+X0.5+ dirac 0.0 1.430429 7.107157 q=0.5564
+X0.5+ dirac 0.0 -1.430429 7.107157 q=0.5564
END GEOMETRY
TASKS
@@ -28,3 +28,186 @@ INTERPOTENTIAL
X0.5+ X0.5+ VHH-CCSDT
END INTERPOTENTIAL
+
+BASIS H2O-1S1P1D
+#optimized exponents
+O-H-TIP X0.5+ (1S) BASIS TYPE: 2
+3
+1 0 1
+14.509888498676842 1.0
+2 1 1
+6.885507269761004 1.0
+3 2 1
+9.023681376783887 1.0
+END BASIS
+
+POTENTIAL VOH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant RHH
+O-X0.5+
+27
+1 0
+13.892336977 9.839539381
+0.0 0.0 0.0
+2 0
+10.000000000 15.916259785
+0.0 0.0 0.0
+3 0
+7.498942093 -18.199008237
+0.0 0.0 0.0
+4 0
+5.623413252 6.723316202
+0.0 0.0 0.0
+5 0
+4.216965034 4.671467422
+0.0 0.0 0.0
+6 0
+3.162277660 1.703771884
+0.0 0.0 0.0
+7 0
+2.371373706 0.297676262
+0.0 0.0 0.0
+8 0
+1.778279410 0.967600283
+0.0 0.0 0.0
+9 0
+1.333521432 1.034932150
+0.0 0.0 0.0
+10 0
+1.000000000 0.657621305
+0.0 0.0 0.0
+11 0
+0.749894209 -0.327381267
+0.0 0.0 0.0
+12 0
+0.562341325 0.221528399
+0.0 0.0 0.0
+13 0
+0.421696503 -0.255694044
+0.0 0.0 0.0
+14 0
+0.316227766 0.097853405
+0.0 0.0 0.0
+15 0
+0.237137371 0.744489008
+0.0 0.0 0.0
+16 0
+0.177827941 -0.750090202
+0.0 0.0 0.0
+17 0
+0.133352143 -0.309090719
+0.0 0.0 0.0
+18 0
+0.100000000 -0.998800172
+0.0 0.0 0.0
+19 0
+0.074989421 0.718795407
+0.0 0.0 0.0
+20 0
+0.056234133 0.228002288
+0.0 0.0 0.0
+21 0
+0.042169650 0.573744431
+0.0 0.0 0.0
+22 0
+0.031622777 -0.056969092
+0.0 0.0 0.0
+23 0
+0.023713737 -0.392241803
+0.0 0.0 0.0
+24 0
+0.017782794 -0.569609681
+0.0 0.0 0.0
+25 0
+0.013335214 0.759323484
+0.0 0.0 0.0
+26 0
+0.010000000 -0.194525832
+0.0 0.0 0.0
+27 0
+0.000000000 0.138912412
+0.0 0.0 0.0
+END POTENTIAL
+
+POTENTIAL VHH-CCSDT
+#Fitted from CCSD(T)/def2-TZVPPD with constant ROH
+O-X0.5+X0.5+
+26
+1 0
+10.000000000 1.313644267
+0.0 0.0 0.0
+2 0
+7.498942093 3.312208762
+0.0 0.0 0.0
+3 0
+5.623413252 -4.290599715
+0.0 0.0 0.0
+4 0
+4.216965034 -2.400490962
+0.0 0.0 0.0
+5 0
+3.162277660 6.160643793
+0.0 0.0 0.0
+6 0
+2.371373706 2.406172066
+0.0 0.0 0.0
+7 0
+1.778279410 -6.852617537
+0.0 0.0 0.0
+8 0
+1.333521432 -1.043562213
+0.0 0.0 0.0
+9 0
+1.000000000 7.556790649
+0.0 0.0 0.0
+10 0
+0.749894209 0.777037995
+0.0 0.0 0.0
+11 0
+0.562341325 -8.976316536
+0.0 0.0 0.0
+12 0
+0.421696503 0.575296040
+0.0 0.0 0.0
+13 0
+0.316227766 8.672468936
+0.0 0.0 0.0
+14 0
+0.237137371 -0.855388714
+0.0 0.0 0.0
+15 0
+0.177827941 -6.271012179
+0.0 0.0 0.0
+16 0
+0.133352143 1.152328020
+0.0 0.0 0.0
+17 0
+0.100000000 3.403807143
+0.0 0.0 0.0
+18 0
+0.074989421 -1.745300340
+0.0 0.0 0.0
+19 0
+0.056234133 -1.349326021
+0.0 0.0 0.0
+20 0
+0.042169650 1.605561812
+0.0 0.0 0.0
+21 0
+0.031622777 -0.267553445
+0.0 0.0 0.0
+22 0
+0.023713737 0.034566428
+0.0 0.0 0.0
+23 0
+0.017782794 -0.185356609
+0.0 0.0 0.0
+24 0
+0.013335214 -0.103128899
+0.0 0.0 0.0
+25 0
+0.010000000 0.128087663
+0.0 0.0 0.0
+26 0
+0.000000000 0.085213897
+0.0 0.0 0.0
+END POTENTIAL
diff --git a/test/TIP4P-dimer-triplet.py b/test/TIP4P-dimer-triplet.py
index 41f2ebc4..d13b500b 100644
--- a/test/TIP4P-dimer-triplet.py
+++ b/test/TIP4P-dimer-triplet.py
@@ -17,10 +17,10 @@
refValues = {
"HF energy" : [-0.651377261423,1E-8],
- "HA-TIP Ext Pot" : [0.010606635479,1E-4],
- "HA-TIP/HA-TIP Hartree" : [1.217813835967,1E-4],
- "HA-TIP Exchange" : [-1.214419735313,1E-4],
- "HA-TIP/Fixed interact." : [-0.035396418562,1E-4]
+ "X0.5+ Ext Pot" : [0.010606635479,1E-4],
+ "X0.5+/X0.5+ Hartree" : [1.217813835967,1E-4],
+ "X0.5+ Exchange" : [-1.214419735313,1E-4],
+ "X0.5+/Fixed interact." : [-0.035396418562,1E-4]
}
testValues = dict(refValues) #copy
@@ -43,14 +43,14 @@
line = outputRead[i]
if "TOTAL ENERGY =" in line:
testValues["HF energy"] = float(line.split()[3])
- if "HA-TIP Ext Pot" in line:
- testValues["HA-TIP Ext Pot"] = float(line.split()[5])
- if "HA-TIP/HA-TIP Hartree" in line:
- testValues["HA-TIP/HA-TIP Hartree"] = float(line.split()[4])
- if "HA-TIP Exchange" in line:
- testValues["HA-TIP Exchange"] = float(line.split()[4])
- if "HA-TIP/Fixed interact." in line:
- testValues["HA-TIP/Fixed interact."] = float(line.split()[4])
+ if "X0.5+ Ext Pot" in line:
+ testValues["X0.5+ Ext Pot"] = float(line.split()[5])
+ if "X0.5+/X0.5+ Hartree" in line:
+ testValues["X0.5+/X0.5+ Hartree"] = float(line.split()[4])
+ if "X0.5+ Exchange" in line:
+ testValues["X0.5+ Exchange"] = float(line.split()[4])
+ if "X0.5+/Fixed interact." in line:
+ testValues["X0.5+/Fixed interact."] = float(line.split()[4])
passTest = True