⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 polygon.m

📁 这是几何代数的matlab工具包
💻 M
字号:
function polygon(Poly, BV, O, c)% polygon(Poly,BV,O,c): draw a polygon%  Poly: a polygon struct%  BV: bivector plane in which to draw%  O: an offset from the origin%  c: the color of the polygon%%See also gable.% GABLE, Copyright (c) 1999, University of Amsterdam% Copying, use and development for non-commercial purposes permitted.%          All rights for commercial use reserved; for more information%          contact Leo Dorst (leo@wins.uva.nl).%%          This software is unsupported.N = dual(BV);lA = abs(norm(N));if abs(N.m(4)) < lA*.9   p1 = grade((e3^N)*inverse(N),1);else   p1 = grade((e2^N)*inverse(N),1);endhold onp2 = dual(p1^N);p1 = (sqrt(lA/Poly.A)/sqrt(double(inner(p1,p1))))*p1;p2 = (sqrt(lA/Poly.A)/sqrt(double(inner(p2,p2))))*p2;% Cell array versionfor i=1:length(Poly.X)    pts{i} = (Poly.X(i)-Poly.CX)*p1 + (Poly.Y(i)-Poly.CY)*p2 + O;end% Convert character color to RGB tripleif isa(c,'char')   if strncmp(c,'r',1)      c = [1 0 0];   elseif strncmp(c,'g',1)      c = [0 1 0];   elseif strncmp(c,'b',1)      c = [0 0 1];   elseif strncmp(c,'c',1)      c = [0 1 1];   elseif strncmp(c,'m',1)      c = [1 0 1];   elseif strncmp(c,'y',1)      c = [1 1 0];   elseif strncmp(c,'w',1)      c = [1 1 1];   endendGAPatch(pts,c);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -