NCF参数化建筑论坛

标题: 原创贝兹曲线程序——继续萌路线 [打印本页]

作者: panhao1    时间: 2010-6-10 00:22
标题: 原创贝兹曲线程序——继续萌路线
这里吧贝兹曲线的ruby代码发下 def BZ__BezierClassic.points(pts, numpts) curvepts = [] dt = 1.0 / numpts # evaluate the points on the curve for i in 0..numpts t = i * dt curvepts[i] = BZ__BezierClassic.evaluate(pts, t) end curvepts end def BZ__BezierClassic.evaluate(pts, t) degree = pts.length - 1 if degree < 1 return nil end t1 = 1.0 - t fact = 1.0 n_choose_i = 1 x = pts[0].x * t1 y = pts[0].y * t1 z = pts[0].z * t1 for i in 1...degree fact = fact*t n_choose_i = n_choose_i*(degree-i+1)/i fn = fact * n_choose_i x = (x + fn*pts[i].x) * t1 y = (y + fn*pts[i].y) * t1 z = (z + fn*pts[i].z) * t1 end x = x + fact*t*pts[degree].x y = y + fact*t*pts[degree].y z = z + fact*t*pts[degree].z Geom::Point3d.new(x, y, z) 这个算法还比较快~
作者: panhao1    时间: 2010-6-10 00:24
也就是lagrange程序的升级版 觉得大家对程序视乎不感兴趣 所以嘛~没动力把程序再贴上来~
作者: skywoolf    时间: 2010-6-10 08:42
{:3_57:}支持了~
作者: musofan    时间: 2010-6-10 09:43
提示: 作者被禁止或删除 内容自动屏蔽
作者: stratagem    时间: 2010-6-10 10:13
看不懂~~~~
作者: 城市边缘工厂    时间: 2010-6-10 10:34
看不懂,,,不过知道你知道的好多。
作者: architc    时间: 2010-6-10 14:01
主要还是会语言同时会建筑的人少。上学时时间多点,学了也就学了;一旦上班,几乎没有时间再系统学这些了(当然,我说的是像我这样的一部分人,我承认有些人很有毅力,任何情况下都能学东西。)
作者: yal7    时间: 2010-6-11 16:41
8# architc 严重同意啊。。。。。
作者: huaishi    时间: 2010-9-19 10:04
hoho ,我也想学但是没时间,郁闷
作者: eco    时间: 2010-9-22 22:40
学习一下~~~~~~
作者: 菡萏521    时间: 2011-7-30 17:23
都好厉害啊
作者: www.zdfjr.com    时间: 2011-8-14 20:24
各位坛友,我是新手 请大家多多关照小弟我啊
作者: smar35358    时间: 2013-4-16 21:53
我觉得挺好的,大家的看法呢












                               
登录/注册后可看大图

了解婴儿游泳,查看婴儿游泳池就上http://www.beiaispa.com




欢迎光临 NCF参数化建筑论坛 (http://www.ncf-china.com/) Powered by Discuz! X3.2