- /
-
Glowing Eigenwalkers
on 22 Nov 2023
- 10
- 40
- 1
- 2
- 1555
drawframe(1)
function drawframe(f)
% EIGENWALKER Human gait
% Cleve's Corner, http://blogs.mathworks.com/cleve/2016/04/11.
fps = 48;
scale = 0.1;
ot = (f-1)*2*pi/fps;
s = sin(ot);
c = cos(ot);
C = scale*[1,s,c,2*s*c,c*c-s*s]';
V = coefficients;
X = reshape(V*C,15,3);
L = {[1 5],[5 12],[2 3 4 5 6 7 8],[9 10 11 12 13 14 15]};
M = {};
F = {};
cla
axis([-750 750 -750 750 0 1500])
daspect([1,1,1])
set(gcf,'Color','k');
hspec=@(cc){'color',cc, 'marker','o',...
'markersize',12, 'markerfacecolor', cc...
'linestyle','-','linewidth',3};
specs=@(cc){'color',cc, 'marker','o',...
'markersize',8, ...
'linestyle','-','linewidth',3};
view(-160,10)
xf=X(L{3},1);
rs = specs('r');
gs = specs('g');
rh = hspec('r');
gh = hspec('g');
for k=1:4
x=X(L{k},1);
y=X(L{k},2);
z=X(L{k},3);
if(k==1)
line(2*xf(1)-x,y,z,gh{:});
line(x,y,z,rh{:});
else
line(2*xf(1)-x,y,z,gs{:});
line(x,y,z,rs{:});
end
end
axis off
function V = coefficients
V = [ 5 -43 -182 0 1
2064 14 -131 11 39
2092 -215 -192 28 15
1660 -72 -173 -1 3
-7 -78 -173 2 1
-1664 -79 -178 4 -3
-2097 -246 -200 -28 -20
-2016 -36 -168 -19 -49
536 53 127 0 15
794 11 83 -3 47
931 -73 -145 1 -2
20 -63 -113 1 0
-883 -74 -146 1 -1
-831 17 74 2 -47
-567 61 125 0 -20
205 -11 -4 -37 27
500 -1010 -256 37 9
-686 -606 -174 -11 17
-59 -153 -52 -57 32
-114 -7 -4 -62 35
-177 139 44 -61 34
-717 691 170 -12 16
414 1174 254 36 0
-544 2214 -576 327 -259
859 1247 170 51 264
-42 -10 -29 -115 80
78 -10 0 -115 67
-58 -10 33 -116 79
832 -1240 -175 56 266
-557 -2227 586 349 -271
13837 1 0 70 86
7695 -189 -11 124 6
9721 61 44 82 59
12251 -20 22 76 85
12058 1 0 74 85
12320 21 -23 78 82
9774 -65 -39 83 49
7766 224 17 119 -23
984 -120 548 -105 266
4122 250 49 123 30
7897 -12 -31 70 84
8766 1 1 70 87
7889 13 32 70 86
4157 -249 -52 124 35
985 127 -548 -116 269];
end
end