Source code for pyscf.adc
# Copyright 2014-2022 The PySCF Developers. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Author: Samragni Banerjee <samragnibanerjee4@gmail.com>
# Alexander Sokolov <alexander.y.sokolov@gmail.com>
#
# TODO: Add description of the module
'''
===================================
Algebraic Diagrammatic Construction
===================================
'''
from pyscf import lib
from pyscf.adc import uadc
from pyscf.adc import radc
from pyscf.adc import radc_amplitudes
from pyscf.adc import uadc_amplitudes
from pyscf.adc import radc_ip
from pyscf.adc import radc_ip_cvs
from pyscf.adc import radc_ea
from pyscf.adc import uadc_ip
from pyscf.adc import uadc_ip_cvs
from pyscf.adc import uadc_ea
[docs]
def ADC(mf, frozen=None, mo_coeff=None, mo_occ=None):
if not (frozen is None or frozen == 0):
raise NotImplementedError
if mf.istype('UHF'):
return UADC(mf, frozen, mo_coeff, mo_occ)
#elif isinstance(mf, scf.rohf.ROHF):
# lib.logger.warn(mf, 'RADC method does not support ROHF reference. ROHF object '
# 'is converted to UHF object and UADC method is called.')
# mf = mf.to_uhf(mf)
# return UADC(mf, frozen, mo_coeff, mo_occ)
# TODO add ROHF functionality
elif mf.istype('RHF'):
return RADC(mf, frozen, mo_coeff, mo_occ)
else :
raise RuntimeError('ADC code only supports RHF, ROHF, and UHF references')
ADC.__doc__ = uadc.UADC.__doc__
[docs]
def UADC(mf, frozen=None, mo_coeff=None, mo_occ=None):
if not (frozen is None or frozen == 0):
raise NotImplementedError
mf = mf.remove_soscf()
if not mf.istype('UHF'):
mf = mf.to_uhf()
return uadc.UADC(mf, frozen, mo_coeff, mo_occ)
UADC.__doc__ = uadc.UADC.__doc__
[docs]
def RADC(mf, frozen=None, mo_coeff=None, mo_occ=None):
if not (frozen is None or frozen == 0):
raise NotImplementedError
mf = mf.remove_soscf()
if not mf.istype('RHF'):
mf = mf.to_rhf()
return radc.RADC(mf, frozen, mo_coeff, mo_occ)
RADC.__doc__ = radc.RADC.__doc__