.. _module_perturbation: 
 
.. program:: perturbation 
 
.. default-role:: option 
 
============
perturbation
============


All subroutines in ``*.irp.f`` starting with `pt2_` in the current directory are
perturbation computed using the routine `i_H_psi`. Other cases are not allowed.
The arguments of the `pt2_` are always:

.. code-block:: fortran

  subroutine pt2_...(                                          &
      psi_ref,                                                 &
      psi_ref_coefs,                                           &
      E_refs,                                                  &
      det_pert,                                                &
      c_pert,                                                  &
      e_2_pert,                                                &
      H_pert_diag,                                             &
      Nint,                                                    &
      Ndet,                                                    &
      N_st )


  integer          , intent(in)  :: Nint,Ndet,N_st
  integer(bit_kind), intent(in)  :: psi_ref(Nint,2,Ndet)
  double precision , intent(in)  :: psi_ref_coefs(Ndet,N_st)
  double precision , intent(in)  :: E_refs(N_st)
  integer(bit_kind), intent(in)  :: det_pert(Nint,2)
  double precision , intent(out) :: c_pert(N_st),e_2_pert(N_st),H_pert_diag


`psi_ref`
  bitstring of the determinants present in the various `N_st` states

`psi_ref_coefs`
  coefficients of the determinants on the various `N_st` states

`E_refs`
  Energy of the various `N_st` states

`det_pert`
  Perturber determinant

`c_pert`
  Perturbative coefficients for the various states

`e_2_pert`
  Perturbative energetic contribution for the various states

`H_pert_diag`
  Diagonal |H| matrix element of the perturber

`Nint`
  Should be equal to `N_int`

`Ndet`
  Number of determinants `i` in |Psi| on which we apply <det_pert | |H| | `i`>

`N_st`
  Number of states



 
 
 
EZFIO parameters 
---------------- 
 
.. option:: do_pt2
 
    If `True`, compute the |PT2| contribution
 
    Default: True
 
.. option:: pt2_max
 
    The selection process stops when the largest |PT2| (for all the state) is lower than `pt2_max` in absolute value
 
    Default: 0.0001
 
.. option:: variance_max
 
    The selection process stops when the largest variance (for all the state) is lower than `variance_max` in absolute value
 
    Default: 0.0
 
.. option:: pt2_relative_error
 
    Stop stochastic |PT2| when the relative error is smaller than `pT2_relative_error`
 
    Default: 0.002
 
.. option:: correlation_energy_ratio_max
 
    The selection process stops at a fixed correlation ratio (useful for getting same accuracy between molecules). Defined as :math:`(E_{CI}-E_{HF})/(E_{CI}+E_{PT2} - E_{HF})`.
 
    Default: 1.00
 
.. option:: h0_type
 
    Type of denominator in PT2. [EN | SOP | HF]
 
    Default: EN
 
 
Providers 
--------- 
 
.. c:var:: max_exc_pert


    File : :file:`perturbation/exc_max.irp.f`

    .. code:: fortran

        integer	:: max_exc_pert	




 
.. c:var:: selection_criterion


    File : :file:`perturbation/selection.irp.f`

    .. code:: fortran

        double precision	:: selection_criterion	
        double precision	:: selection_criterion_min	
        double precision	:: selection_criterion_factor	


    Threshold to select determinants. Set by selection routines.


 
.. c:var:: selection_criterion_factor


    File : :file:`perturbation/selection.irp.f`

    .. code:: fortran

        double precision	:: selection_criterion	
        double precision	:: selection_criterion_min	
        double precision	:: selection_criterion_factor	


    Threshold to select determinants. Set by selection routines.


 
.. c:var:: selection_criterion_min


    File : :file:`perturbation/selection.irp.f`

    .. code:: fortran

        double precision	:: selection_criterion	
        double precision	:: selection_criterion_min	
        double precision	:: selection_criterion_factor	


    Threshold to select determinants. Set by selection routines.


 
.. c:var:: var_pt2_ratio


    File : :file:`perturbation/var_pt2_ratio_provider.irp.f`

    .. code:: fortran

        double precision	:: var_pt2_ratio	


    The selection process stops when the energy ratio variational/(variational+PT2)
    is equal to var_pt2_ratio

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`correlation_energy_ratio_max`


 
 
Subroutines / functions 
----------------------- 
 
.. c:function:: fill_h_apply_buffer_selection:


    File : :file:`perturbation/selection.irp.f`

    .. code:: fortran

        subroutine fill_H_apply_buffer_selection(n_selected,det_buffer,e_2_pert_buffer,coef_pert_buffer, N_st,Nint,iproc,select_max_out)


    Fill the H_apply buffer with determiants for the selection

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`elec_alpha_num`
       * :c:data:`elec_beta_num`
       * :c:data:`h_apply_buffer_allocated`
       * :c:data:`n_det`
       * :c:data:`n_int`
       * :c:data:`selection_criterion`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`omp_set_lock`
       * :c:func:`omp_unset_lock`
       * :c:func:`resize_h_apply_buffer`

 
.. c:function:: perturb_buffer_by_mono_dummy:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_by_mono_dummy(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``dummy`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`pt2_dummy`

 
.. c:function:: perturb_buffer_by_mono_epstein_nesbet:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_by_mono_epstein_nesbet(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``epstein_nesbet`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`pt2_epstein_nesbet`

 
.. c:function:: perturb_buffer_by_mono_epstein_nesbet_2x2:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_by_mono_epstein_nesbet_2x2(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``epstein_nesbet_2x2`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`pt2_epstein_nesbet_2x2`

 
.. c:function:: perturb_buffer_by_mono_epstein_nesbet_2x2_no_ci_diag:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_by_mono_epstein_nesbet_2x2_no_ci_diag(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``epstein_nesbet_2x2_no_ci_diag`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`pt2_epstein_nesbet_2x2_no_ci_diag`

 
.. c:function:: perturb_buffer_by_mono_moller_plesset:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_by_mono_moller_plesset(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``moller_plesset`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`pt2_moller_plesset`

 
.. c:function:: perturb_buffer_by_mono_qdpt:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_by_mono_qdpt(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``qdpt`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`pt2_qdpt`

 
.. c:function:: perturb_buffer_dummy:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_dummy(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``dummy`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_microlist`
       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`getmobiles`
       * :c:func:`pt2_dummy`

 
.. c:function:: perturb_buffer_epstein_nesbet:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_epstein_nesbet(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``epstein_nesbet`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_microlist`
       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`getmobiles`
       * :c:func:`pt2_epstein_nesbet`

 
.. c:function:: perturb_buffer_epstein_nesbet_2x2:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_epstein_nesbet_2x2(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``epstein_nesbet_2x2`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_microlist`
       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`getmobiles`
       * :c:func:`pt2_epstein_nesbet_2x2`

 
.. c:function:: perturb_buffer_epstein_nesbet_2x2_no_ci_diag:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_epstein_nesbet_2x2_no_ci_diag(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``epstein_nesbet_2x2_no_ci_diag`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_microlist`
       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`getmobiles`
       * :c:func:`pt2_epstein_nesbet_2x2_no_ci_diag`

 
.. c:function:: perturb_buffer_moller_plesset:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_moller_plesset(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``moller_plesset`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_microlist`
       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`getmobiles`
       * :c:func:`pt2_moller_plesset`

 
.. c:function:: perturb_buffer_qdpt:


    File : :file:`perturbation/perturbation.irp.f_shell_13`

    .. code:: fortran

        subroutine perturb_buffer_qdpt(i_generator,buffer,buffer_size,e_2_pert_buffer,coef_pert_buffer,sum_e_2_pert,sum_norm_pert,sum_H_pert_diag,N_st,Nint,key_mask,fock_diag_tmp,electronic_energy)


    Apply pertubration ``qdpt`` to the buffer of determinants generated in the H_apply
    routine.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_generators`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_det_generators`
       * :c:data:`psi_selectors`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`create_microlist`
       * :c:func:`create_minilist`
       * :c:func:`create_minilist_find_previous`
       * :c:func:`getmobiles`
       * :c:func:`pt2_qdpt`

 
.. c:function:: pt2_dummy:


    File : :file:`perturbation/pt2_equations.irp.f_template_305`

    .. code:: fortran

        subroutine pt2_dummy (electronic_energy,det_ref,det_pert,fock_diag_tmp,c_pert,e_2_pert,H_pert_diag,Nint,ndet,N_st,minilist,idx_minilist,N_minilist)


    Dummy perturbation to add all connected determinants.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_selectors`
       * :c:data:`psi_selectors`
       * :c:data:`psi_selectors_size`
       * :c:data:`selection_criterion`

    Called by:

    .. hlist::
       :columns: 3

       * :c:func:`perturb_buffer_by_mono_dummy`
       * :c:func:`perturb_buffer_dummy`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`i_h_psi_minilist`

 
.. c:function:: pt2_epstein_nesbet:


    File : :file:`perturbation/pt2_equations.irp.f_template_305`

    .. code:: fortran

        subroutine pt2_epstein_nesbet (electronic_energy,det_ref,det_pert,fock_diag_tmp,c_pert,e_2_pert,H_pert_diag,Nint,ndet,N_st,minilist,idx_minilist,N_minilist)


    Compute the standard Epstein-Nesbet perturbative first order coefficient and
    second order energetic contribution for the various N_st states.
    
    `c_pert(i)` = $\frac{\langle i|H|\alpha \rangle}{ E_n - \langle \alpha|H|\alpha \rangle }$.
    
    `e_2_pert(i)` = $\frac{\langle i|H|\alpha \rangle^2}{ E_n - \langle \alpha|H|\alpha \rangle }$.
    

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_selectors`
       * :c:data:`psi_selectors_size`
       * :c:data:`selection_criterion`

    Called by:

    .. hlist::
       :columns: 3

       * :c:func:`perturb_buffer_by_mono_epstein_nesbet`
       * :c:func:`perturb_buffer_epstein_nesbet`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`i_h_psi_minilist`

 
.. c:function:: pt2_epstein_nesbet_2x2:


    File : :file:`perturbation/pt2_equations.irp.f_template_305`

    .. code:: fortran

        subroutine pt2_epstein_nesbet_2x2 (electronic_energy,det_ref,det_pert,fock_diag_tmp,c_pert,e_2_pert,H_pert_diag,Nint,ndet,N_st,minilist,idx_minilist,N_minilist)


    Computes the Epstein-Nesbet 2x2 diagonalization coefficient and energetic contribution
    for the various N_st states.
    
    `e_2_pert(i)` = $\frac{1}{2} ( \langle \alpha|H|\alpha \rangle -  E_n) - \sqrt{ (\langle \alpha|H|\alpha \rangle -  E_n)^2 + 4 \langle i|H|\alpha \rangle^2 }$.
    
    `c_pert(i)` = `e_2_pert(i)` $\times \frac{1}{ \langle i|H|\alpha \rangle}$.
    

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_selectors`
       * :c:data:`psi_selectors_size`

    Called by:

    .. hlist::
       :columns: 3

       * :c:func:`perturb_buffer_by_mono_epstein_nesbet_2x2`
       * :c:func:`perturb_buffer_epstein_nesbet_2x2`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`i_h_psi`

 
.. c:function:: pt2_epstein_nesbet_2x2_no_ci_diag:


    File : :file:`perturbation/pt2_equations.irp.f_template_305`

    .. code:: fortran

        subroutine pt2_epstein_nesbet_2x2_no_ci_diag(electronic_energy,det_ref,det_pert,fock_diag_tmp,c_pert,e_2_pert,H_pert_diag,Nint,ndet,N_st,minilist,idx_minilist,N_minilist)


    compute the Epstein-Nesbet 2x2 diagonalization coefficient and energetic contribution
    
    for the various N_st states.
    
    e_2_pert(i) = 0.5 * (( <det_pert|H|det_pert> -  E(i) )  - sqrt( ( <det_pert|H|det_pert> -  E(i)) ^2 + 4 <psi(i)|H|det_pert>^2  )
    
    c_pert(i) = e_2_pert(i)/ <psi(i)|H|det_pert>
    

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_energy`
       * :c:data:`psi_selectors`
       * :c:data:`psi_selectors_size`

    Called by:

    .. hlist::
       :columns: 3

       * :c:func:`perturb_buffer_by_mono_epstein_nesbet_2x2_no_ci_diag`
       * :c:func:`perturb_buffer_epstein_nesbet_2x2_no_ci_diag`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`i_h_psi`

 
.. c:function:: pt2_moller_plesset:


    File : :file:`perturbation/pt2_equations.irp.f_template_305`

    .. code:: fortran

        subroutine pt2_moller_plesset (electronic_energy,det_ref,det_pert,fock_diag_tmp,c_pert,e_2_pert,H_pert_diag,Nint,ndet,N_st,minilist,idx_minilist,N_minilist)


    Computes the standard Moller-Plesset perturbative first order coefficient and second
    order energetic contribution for the various N_st states.
    
    `c_pert(i)` = $\frac{\langle i|H|\alpha \rangle}{\text{difference of orbital energies}}$.
    
    `e_2_pert(i)` = $\frac{\langle i|H|\alpha \rangle^2}{\text{difference of orbital energies}}$.
    

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`fock_matrix_mo`
       * :c:data:`mo_num`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_selectors`
       * :c:data:`psi_selectors_size`
       * :c:data:`ref_bitmask`

    Called by:

    .. hlist::
       :columns: 3

       * :c:func:`perturb_buffer_by_mono_moller_plesset`
       * :c:func:`perturb_buffer_moller_plesset`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`decode_exc`
       * :c:func:`get_excitation`
       * :c:func:`i_h_psi_minilist`

 
.. c:function:: pt2_qdpt:


    File : :file:`perturbation/pt2_equations.irp.f_template_305`

    .. code:: fortran

        subroutine pt2_qdpt (electronic_energy,det_ref,det_pert,fock_diag_tmp,c_pert,e_2_pert,H_pert_diag,Nint,ndet,N_st,minilist,idx_minilist,N_minilist)


    Computes the QDPT first order coefficient and second order energetic contribution
    for the various N_st states.
    
    `c_pert(i)` = $\frac{\langle i|H|\alpha \rangle}{\langle i|H|i \rangle - \langle \alpha|H|\alpha \rangle}$.
    

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`mo_num`
       * :c:data:`n_det_selectors`
       * :c:data:`n_int`
       * :c:data:`psi_selectors`
       * :c:data:`psi_selectors_size`
       * :c:data:`selection_criterion`

    Called by:

    .. hlist::
       :columns: 3

       * :c:func:`perturb_buffer_by_mono_qdpt`
       * :c:func:`perturb_buffer_qdpt`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`get_excitation_degree`
       * :c:func:`i_h_j`
       * :c:func:`i_h_psi_minilist`

 
.. c:function:: remove_small_contributions:


    File : :file:`perturbation/selection.irp.f`

    .. code:: fortran

        subroutine remove_small_contributions


    Remove determinants with small contributions. N_states is assumed to be
    provided.

    Needs:

    .. hlist::
       :columns: 3

       * :c:data:`n_det`
       * :c:data:`n_det_generators`
       * :c:data:`n_int`
       * :c:data:`n_states`
       * :c:data:`psi_coef`
       * :c:data:`psi_det_sorted`
       * :c:data:`psi_det`
       * :c:data:`psi_det_size`
       * :c:data:`psi_det_sorted`
       * :c:data:`selection_criterion`

    Calls:

    .. hlist::
       :columns: 3

       * :c:func:`diagonalize_ci`
       * :c:func:`i_h_psi`
       * :c:func:`write_int`

    Touches:

    .. hlist::
       :columns: 3

       * :c:data:`ci_electronic_energy`
       * :c:data:`ci_electronic_energy`
       * :c:data:`ci_energy`
       * :c:data:`ci_electronic_energy`
       * :c:data:`n_det`
       * :c:data:`psi_coef`
       * :c:data:`psi_det`
       * :c:data:`psi_energy`
       * :c:data:`psi_energy`