forked from rgmelko/Spin-Models-on-GPU
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlattice.cpp
126 lines (95 loc) · 4.08 KB
/
lattice.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*!
\file lattice.cpp
\brief Contains bond array filling functions, describing which sites are linked to which
*/
#include"lattice.h"
void Fill_Bonds_12A(int* Bond){
for(int i = 0; i < 12; i++){
Bond[i] = i;
}
Bond[12] = 5; Bond[13] = 2; Bond[14] = 3; Bond[15] = 4;
Bond[16] = 10; Bond[17] = 6; Bond[18] = 7; Bond[19] = 8;
Bond[20] = 9; Bond[21] = 0; Bond[22] = 11; Bond[23] = 1;
Bond[24] = 3; Bond[25] = 6; Bond[26] = 7; Bond[27] = 8;
Bond[28] = 9; Bond[29] = 4; Bond[30] = 10; Bond[31] = 11;
Bond[32] = 1; Bond[33] = 2; Bond[34] = 0; Bond[35] = 5;
}
void Fill_Bonds_16A(int* Bond){
Bond[0] = 0; Bond[1] = 1; Bond[2] = 2; Bond[3] = 3; Bond[4] = 4;
Bond[5] = 5; Bond[6] = 6; Bond[7] = 7; Bond[8] = 8; Bond[9] = 9;
Bond[10] = 10; Bond[11] = 11; Bond[12] = 12; Bond[13] = 13; Bond[14] = 14;
Bond[15] = 15;
Bond[16] = 12; Bond[17] = 2; Bond[18] = 3; Bond[19] = 15;
Bond[20] = 5; Bond[21] = 6; Bond[22] = 7; Bond[23] = 0; Bond[24] = 9;
Bond[25] = 10; Bond[26] = 11; Bond[27] = 1; Bond[28] = 13; Bond[29] = 14;
Bond[30] = 4; Bond[31] = 8;
Bond[32] = 1; Bond[33] = 4; Bond[34] = 5;
Bond[35] = 6; Bond[36] = 8; Bond[37] = 9; Bond[38] = 10; Bond[39] = 11;
Bond[40] = 0; Bond[41] = 12; Bond[42] = 13; Bond[43] = 14; Bond[44] = 2;
Bond[45] = 3; Bond[46] = 15; Bond[47] = 7;
}
void Fill_Bonds_16B(int* Bond){
//Bond = (int*)malloc(3*16*sizeof(int));
Bond[0] = 0; Bond[1] = 1; Bond[2] = 2; Bond[3] = 3; Bond[4] = 4;
Bond[5] = 5; Bond[6] = 6; Bond[7] = 7; Bond[8] = 8; Bond[9] = 9;
Bond[10] = 10; Bond[11] = 11; Bond[12] = 12; Bond[13] = 13; Bond[14] = 14;
Bond[15] = 15; Bond[16] = 1; Bond[17] = 2; Bond[18] = 3; Bond[19] = 0;
Bond[20] = 5; Bond[21] = 6; Bond[22] = 7; Bond[23] = 4; Bond[24] = 9;
Bond[25] = 10; Bond[26] = 11; Bond[27] = 8; Bond[28] = 13; Bond[29] = 14;
Bond[30] = 15; Bond[31] = 12; Bond[32] = 4; Bond[33] = 5; Bond[34] = 6;
Bond[35] = 7; Bond[36] = 8; Bond[37] = 9; Bond[38] = 10; Bond[39] = 11;
Bond[40] = 12; Bond[41] = 13; Bond[42] = 14; Bond[43] = 15; Bond[44] = 0;
Bond[45] = 1; Bond[46] = 2; Bond[47] = 3;
}
void Fill_Bonds_18A(int* Bond){
for(int i = 0; i < 18; i++){
Bond[i] = i;
}
Bond[18] = 9; Bond[19] = 2; Bond[20] = 3;
Bond[21] = 14; Bond[22] = 5; Bond[23] = 6;
Bond[24] = 7; Bond[25] = 8; Bond[26] = 17;
Bond[27] = 10; Bond[28] = 11; Bond[29] = 12;
Bond[30] = 13; Bond[31] = 0; Bond[32] = 15;
Bond[33] = 16; Bond[34] = 1; Bond[35] = 4;
Bond[36] = 2; Bond[37] = 5; Bond[38] = 6;
Bond[39] = 7; Bond[40] = 9; Bond[41] = 10;
Bond[42] = 11; Bond[43] = 12; Bond[44] = 13;
Bond[45] = 3; Bond[46] = 14; Bond[47] = 15;
Bond[48] = 16; Bond[49] = 1; Bond[50] = 8;
Bond[51] = 17; Bond[52] = 4; Bond[53] = 0;
}
void Fill_Bonds_22A(int* Bond){
//Bond = (int*)malloc(3*22*sizeof(int));
for(int i = 0; i < 22; i++){
Bond[i] = i;
Bond[i + 22] = i + 1;
}
Bond[43] = 0;
Bond[44] = 5; Bond[45] = 6; Bond[46] = 7; Bond[47] = 8; Bond[48] = 9;
Bond[49] = 10; Bond[50] = 11; Bond[51] = 12; Bond[52] = 13; Bond[53] = 14;
Bond[54] = 15; Bond[55] = 16; Bond[56] = 17; Bond[57] = 18; Bond[58] = 19;
Bond[59] = 20; Bond[60] = 21; Bond[61] = 0; Bond[62] = 1; Bond[63] = 2;
Bond[64] = 3; Bond[65] = 4;
}
void Fill_Bonds_20A(int* Bond){
for(int i = 0; i < 20; i++){
Bond[i] = i;
}
Bond[20] = 13; Bond[21] = 2; Bond[22] = 3; Bond[23] = 18;
Bond[24] = 5; Bond[25] = 6; Bond[26] = 7; Bond[27] = 8;
Bond[28] = 0; Bond[29] = 10; Bond[30] = 11; Bond[31] = 12;
Bond[32] = 13; Bond[33] = 1; Bond[34] = 15; Bond[35] = 16;
Bond[36] = 17; Bond[37] = 4; Bond[38] = 19; Bond[39] = 9;
Bond[40] = 1; Bond[41] = 5; Bond[42] = 6; Bond[43] = 7;
Bond[44] = 9; Bond[45] = 10; Bond[46] = 11; Bond[47] = 12;
Bond[48] = 13; Bond[49] = 14; Bond[50] = 15; Bond[51] = 16;
Bond[52] = 17; Bond[53] = 4; Bond[54] = 2; Bond[55] = 3;
Bond[56] = 18; Bond[57] = 19; Bond[58] = 8; Bond[59] = 0;
}
/*void Fill_Bonds_22B(int* Bond){
Bond = (int*)malloc(3*22*sizeof(int));
for(int i = 0; i < 22; i++){
Bond[i] = i;
}
Bond[22] = 15; Bond[23] = 2; Bond[24] = 3; Bond[25] = 20;
Bond[26] = 5; Bond[27] = [*/