MPQC
3.0.0-alpha
ccsdt_t3.h
1
//
2
// ccsdt_t3.h --- compute the T3 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_t3_h
29
#define _chemistry_qc_ccr12_ccsdt_t3_h
30
31
#include <chemistry/qc/ccr12/ccr12_info.h>
32
33
namespace
sc
{
34
35
class
CCSDT_T3
{
36
37
protected
:
38
CCR12_Info
* z;
39
40
std::vector<Tensor*> in;
41
42
void
offset_smith_0_1();
43
void
smith_0_1_0();
//z->f1()=>in.at(1)
44
void
offset_smith_1_3();
45
void
smith_1_3_0();
//z->f1()=>in.at(2)
46
void
smith_2_31();
//z->t1(),z->v2()=>in.at(2)
47
void
smith_1_3();
//z->t1(),in.at(2)=>in.at(1)
48
void
smith_1_19();
//z->t1(),z->v2()=>in.at(1)
49
void
smith_1_41();
//z->t2(),z->v2()=>in.at(1)
50
void
smith_0_1(
Ref<Tensor>
&);
//z->t3(),in.at(1)=>out
51
void
offset_smith_0_2();
52
void
smith_0_2_0();
//z->f1()=>in.at(1)
53
void
smith_1_21();
//z->t1(),z->v2()=>in.at(1)
54
void
smith_1_43();
//z->t2(),z->v2()=>in.at(1)
55
void
smith_0_2(
Ref<Tensor>
&);
//z->t3(),in.at(1)=>out
56
void
offset_smith_0_4();
57
void
offset_smith_1_4();
58
void
smith_1_4_0();
//z->f1()=>in.at(2)
59
void
smith_2_33();
//z->t1(),z->v2()=>in.at(2)
60
void
smith_1_4();
//z->t3(),in.at(2)=>in.at(1)
61
void
offset_smith_1_10();
62
void
smith_1_10_0();
//z->v2()=>in.at(2)
63
void
smith_2_18();
//z->t1(),z->v2()=>in.at(2)
64
void
smith_2_38();
//z->t2(),z->v2()=>in.at(2)
65
void
smith_1_10();
//z->t2(),in.at(2)=>in.at(1)
66
void
offset_smith_1_17();
67
void
offset_smith_2_17();
68
void
smith_2_17_0();
//z->v2()=>in.at(3)
69
void
smith_3_30();
//z->t1(),z->v2()=>in.at(3)
70
void
smith_2_17();
//z->t2(),in.at(3)=>in.at(2)
71
void
smith_2_35();
//z->t3(),z->v2()=>in.at(2)
72
void
smith_1_17();
//z->t1(),in.at(2)=>in.at(1)
73
void
offset_smith_1_22();
74
void
smith_1_22_0();
//z->v2()=>in.at(2)
75
void
smith_2_34();
//z->t1(),z->v2()=>in.at(2)
76
void
smith_1_22();
//z->t3(),in.at(2)=>in.at(1)
77
void
smith_1_24();
//z->t3(),z->v2()=>in.at(1)
78
void
smith_0_4(
Ref<Tensor>
&);
//z->t1(),in.at(1)=>out
79
void
offset_smith_0_5();
80
void
smith_0_5_0();
//z->v2()=>in.at(1)
81
void
offset_smith_1_5();
82
void
smith_1_5_0();
//z->f1()=>in.at(2)
83
void
smith_2_37();
//z->t1(),z->v2()=>in.at(2)
84
void
smith_1_5();
//z->t2(),in.at(2)=>in.at(1)
85
void
offset_smith_1_8();
86
void
smith_1_8_0();
//z->v2()=>in.at(2)
87
void
offset_smith_2_15();
88
void
smith_2_15_0();
//z->v2()=>in.at(3)
89
void
smith_3_29();
//z->t1(),z->v2()=>in.at(3)
90
void
smith_2_15();
//z->t1(),in.at(3)=>in.at(2)
91
void
smith_2_40();
//z->t2(),z->v2()=>in.at(2)
92
void
smith_1_8();
//z->t1(),in.at(2)=>in.at(1)
93
void
offset_smith_1_9();
94
void
smith_1_9_0();
//z->v2()=>in.at(2)
95
void
smith_2_16();
//z->t1(),z->v2()=>in.at(2)
96
void
smith_1_9();
//z->t1(),in.at(2)=>in.at(1)
97
void
offset_smith_1_26();
98
void
smith_1_26_0();
//z->v2()=>in.at(2)
99
void
smith_2_39();
//z->t1(),z->v2()=>in.at(2)
100
void
smith_1_26();
//z->t2(),in.at(2)=>in.at(1)
101
void
smith_1_28();
//z->t2(),z->v2()=>in.at(1)
102
void
smith_1_47();
//z->t3(),z->v2()=>in.at(1)
103
void
smith_0_5(
Ref<Tensor>
&);
//z->t2(),in.at(1)=>out
104
void
offset_smith_0_7();
105
void
smith_0_7_0();
//z->v2()=>in.at(1)
106
void
smith_1_11();
//z->t1(),z->v2()=>in.at(1)
107
void
offset_smith_1_25();
108
void
smith_1_25_0();
//z->v2()=>in.at(2)
109
void
smith_2_36();
//z->t1(),z->v2()=>in.at(2)
110
void
smith_1_25();
//z->t2(),in.at(2)=>in.at(1)
111
void
smith_1_27();
//z->t2(),z->v2()=>in.at(1)
112
void
smith_1_45();
//z->t3(),z->v2()=>in.at(1)
113
void
smith_0_7(
Ref<Tensor>
&);
//z->t2(),in.at(1)=>out
114
void
offset_smith_0_12();
115
void
smith_0_12_0();
//z->v2()=>in.at(1)
116
void
offset_smith_1_20();
117
void
smith_1_20_0();
//z->v2()=>in.at(2)
118
void
smith_2_32();
//z->t1(),z->v2()=>in.at(2)
119
void
smith_1_20();
//z->t1(),in.at(2)=>in.at(1)
120
void
smith_1_42();
//z->t2(),z->v2()=>in.at(1)
121
void
smith_0_12(
Ref<Tensor>
&);
//z->t3(),in.at(1)=>out
122
void
offset_smith_0_13();
123
void
smith_0_13_0();
//z->v2()=>in.at(1)
124
void
smith_1_23();
//z->t1(),z->v2()=>in.at(1)
125
void
smith_1_44();
//z->t2(),z->v2()=>in.at(1)
126
void
smith_0_13(
Ref<Tensor>
&);
//z->t3(),in.at(1)=>out
127
void
smith_0_14(
Ref<Tensor>
&);
//z->t3(),z->v2()=>out
128
void
offset_smith_0_46();
129
void
smith_1_46();
//z->t3(),z->v2()=>in.at(1)
130
void
smith_0_46(
Ref<Tensor>
&);
//z->t2(),in.at(1)=>out
131
132
public
:
133
CCSDT_T3
(
CCR12_Info
* info);
134
135
~
CCSDT_T3
();
136
void
compute_amp(
Ref<Tensor>
& out);
137
138
};
139
140
141
142
}
143
144
#endif
145
146
sc::Ref
A template class that maintains references counts.
Definition:
ref.h:361
sc::CCSDT_T3
Definition:
ccsdt_t3.h:35
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.