-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgetTotalK.m
106 lines (92 loc) · 3 KB
/
getTotalK.m
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
K = zeros(85*2, 85*2);
% Calculate the system stiffness K_sys
for index=1:2:128
% Get the diagonal for node_i in the element
n1 = nodes(elements(index).node_i);
K_sum = getDiagonalKSum(n1, elements);
i = n1.index*2 - 1;
K(i:i+1,i:i+1) = K_sum;
% If the element touches the top we need to
% do an extra computation
if mod(elements(index).node_m,5) == 0
n1 = nodes(elements(index).node_m);
K_sum = getDiagonalKSum(n1, elements);
i = n1.index*2 - 1;
K(i:i+1,i:i+1) = K_sum;
end
% Special case of the last column where we need to
% count node_j for each element
if index > 120
n1 = nodes(elements(index).node_j);
K_sum = getDiagonalKSum(n1, elements);
i = n1.index*2 - 1;
K(i:i+1,i:i+1) = K_sum;
end
% Very special case of the last odd element 127
% We need to include the very last node 85
if index == 127
n1 = nodes(elements(index+1).node_m);
K_sum = getDiagonalKSum(n1, elements);
i = n1.index*2 - 1;
K(i:i+1,i:i+1) = K_sum;
end
% Horizontal lines
% nodes i-j
n1 = nodes(elements(index).node_i);
n2 = nodes(elements(index).node_j);
[e1,e2] = getTouchingElements(n1,n2);
K_sum = getNonDiagonalKSum(n1,n2,e1,e2,elements);
i = n1.index*2 - 1;
j = n2.index*2 - 1;
K(i:i+1, j:j+1) = K_sum;
% Symmetric matrix
K(j:j+1, i:i+1) = K_sum;
% Special case of top nodes
if mod(elements(index).node_m,5) == 0
n1 = nodes(elements(index).node_m);
n2 = nodes(elements(index+1).node_m);
% There is only one element that touches this line
e1 = index+1;
e2 = -1;
K_sum = getNonDiagonalKSum(n1,n2,e1,e2,elements);
i = n1.index*2 - 1;
j = n2.index*2 - 1;
K(i:i+1, j:j+1) = K_sum;
K(j:j+1, i:i+1) = K_sum;
end
% Vertical lines
n1 = nodes(elements(index).node_i);
n2 = nodes(elements(index).node_m);
[e1, e2] = getTouchingElements(n1,n2);
K_sum = getNonDiagonalKSum(n1,n2,e1,e2,elements);
i = n1.index*2 - 1;
j = n2.index*2 - 1;
K(i:i+1, j:j+1) = K_sum;
% Symmetric matrix
K(j:j+1, i:i+1) = K_sum;
% Special case of last column
if index > 120
n1 = nodes(elements(index+1).node_j);
n2 = nodes(elements(index+1).node_m);
[e1, e2] = getTouchingElements(n1,n2);
K_sum = getNonDiagonalKSum(n1,n2,e1,e2,elements);
i = n1.index*2 - 1;
j = n2.index*2 - 1;
K(i:i+1, j:j+1) = K_sum;
% Symmetric matrix
K(j:j+1, i:i+1) = K_sum;
end
% Diagonal lines
% No special cases.
n1 = nodes(elements(index).node_j);
n2 = nodes(elements(index).node_m);
e1 = index;
e2 = index+1;
K_sum = getNonDiagonalKSum(n1,n2,e1,e2,elements);
i = n1.index*2 - 1;
j = n2.index*2 - 1;
K(i:i+1, j:j+1) = K_sum;
% Symmetric matrix
K(j:j+1, i:i+1) = K_sum;
end
clear index i j e e1 e2 n1 n2 K_sum n1 length