MPQC
3.0.0-alpha
ccsdt_t1.h
1
//
2
// ccsdt_t1.h --- compute the T1 residual vector for CCSDT
3
//
4
// Copyright (C) 2009 Toru Shiozaki
5
//
6
// Author: Toru Shiozaki <shiozaki.toru@gmail.com>
7
// Maintainer: TS
8
//
9
// This file is part of the SC Toolkit.
10
//
11
// The SC Toolkit is free software; you can redistribute it and/or modify
12
// it under the terms of the GNU Library General Public License as published by
13
// the Free Software Foundation; either version 2, or (at your option)
14
// any later version.
15
//
16
// The SC Toolkit is distributed in the hope that it will be useful,
17
// but WITHOUT ANY WARRANTY; without even the implied warranty of
18
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19
// GNU Library General Public License for more details.
20
//
21
// You should have received a copy of the GNU Library General Public License
22
// along with the SC Toolkit; see the file COPYING.LIB. If not, write to
23
// the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
24
//
25
// The U.S. Government is granted a limited license as per AL 91-7.
26
//
27
28
#ifndef _chemistry_qc_ccr12_ccsdt_t1_h
29
#define _chemistry_qc_ccr12_ccsdt_t1_h
30
31
#include <chemistry/qc/ccr12/ccr12_info.h>
32
33
34
namespace
sc
{
35
36
class
CCSDT_T1
{
37
38
protected
:
39
CCR12_Info
* z;
40
41
std::vector<Tensor*> in;
42
43
void
smith_0_1(
Ref<Tensor>
&);
//z->f1()=>out
44
void
offset_smith_0_2();
45
void
smith_0_2_0();
//z->f1()=>in.at(1)
46
void
offset_smith_1_4();
47
void
smith_1_4_0();
//z->f1()=>in.at(2)
48
void
smith_2_11();
//z->t1(),z->v2()=>in.at(2)
49
void
smith_1_4();
//z->t1(),in.at(2)=>in.at(1)
50
void
smith_1_7();
//z->t1(),z->v2()=>in.at(1)
51
void
smith_1_14();
//z->t2(),z->v2()=>in.at(1)
52
void
smith_0_2(
Ref<Tensor>
&);
//z->t1(),in.at(1)=>out
53
void
offset_smith_0_3();
54
void
smith_0_3_0();
//z->f1()=>in.at(1)
55
void
smith_1_8();
//z->t1(),z->v2()=>in.at(1)
56
void
smith_0_3(
Ref<Tensor>
&);
//z->t1(),in.at(1)=>out
57
void
offset_smith_0_5();
58
void
smith_0_5_0();
//z->f1()=>in.at(1)
59
void
smith_1_12();
//z->t1(),z->v2()=>in.at(1)
60
void
smith_0_5(
Ref<Tensor>
&);
//z->t2(),in.at(1)=>out
61
void
smith_0_6(
Ref<Tensor>
&);
//z->t1(),z->v2()=>out
62
void
offset_smith_0_9();
63
void
smith_0_9_0();
//z->v2()=>in.at(1)
64
void
smith_1_13();
//z->t1(),z->v2()=>in.at(1)
65
void
smith_0_9(
Ref<Tensor>
&);
//z->t2(),in.at(1)=>out
66
void
smith_0_10(
Ref<Tensor>
&);
//z->t2(),z->v2()=>out
67
void
smith_0_15(
Ref<Tensor>
&);
//z->t3(),z->v2()=>out
68
69
public
:
70
CCSDT_T1
(
CCR12_Info
* info);
71
~
CCSDT_T1
();
72
73
void
compute_amp(
Ref<Tensor>
& out);
74
75
};
76
77
78
79
}
80
81
#endif
82
83
sc::Ref
A template class that maintains references counts.
Definition:
ref.h:361
sc::CCSDT_T1
Definition:
ccsdt_t1.h:36
sc
Contains all MPQC code up to version 3.
Definition:
mpqcin.h:14
sc::CCR12_Info
CCR12_Info is the compilation of members that are used in CC and CC-R12 methods.
Definition:
ccr12_info.h:50
Generated at Sun Jan 26 2020 23:23:57 for
MPQC
3.0.0-alpha using the documentation package
Doxygen
1.8.16.