create by dejavu
r = 5 (1 + sin(11 u / 5)) - 4 sin4(17 u / 3) sin8(2 cos(3 u) - 28 u)
. . . where 0 <= u <= 21 pi
x = r cos(u)
y = r sin(u)
-
利用以上公式可绘制二维平面上,如下的图像
z的公式可以自定义
这里为了美观利用如下式子
z = (r/20+.2)*sin(r*2*PI/7);
-
将z带入可以得到如下图像
-
p5js 代码
function setup() {
createCanvas(1024,720,WEBGL);
}
var angle,beta = 0,0;
var rate = 40;
var z_rate=0.01;
function draw() {
rotateY(angle);
rotateZ(angle);
var u = beta*21.0*PI/3000;
var p4 = sin(17*u/3);
var p8 = sin(2*cos(3*u)-28*u);
var r = _rate*(5*(1+sin(11*u/5)) - 4*p4*p4*p4*p4 * p8*p8*p8*p8*p8*p8*p8*p8);
var x = r*cos(u);
var y = r*sin(u);
var z = ((r*z_rate)*20+.2)*sin((r*z_rate)*(2*PI)/7);
beta += 1;
beginShape();
fill(255,0,0);
torus(0,0,0,0);
for(var i=0;i<vec.length;i++) {
vertex(vec[i][0],vec[i][1],vec[i][2]);
}
endShape();
}
原理---- 参考 paulbourke
网友评论