NCF参数化建筑论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 4823|回复: 12

[工作记录] 原创贝兹曲线程序——继续萌路线

[复制链接]
发表于 2010-6-10 00:22:14 | 显示全部楼层 |阅读模式
这里吧贝兹曲线的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) 这个算法还比较快~
111.jpg
222.jpg
333.jpg

评分

参与人数 2强度 +7 照度 +70 收起 理由
skywoolf + 5 + 50 原创内容
f(x) + 2 + 20

查看全部评分

 楼主| 发表于 2010-6-10 00:24:03 | 显示全部楼层
也就是lagrange程序的升级版 觉得大家对程序视乎不感兴趣 所以嘛~没动力把程序再贴上来~
发表于 2010-6-10 08:42:49 | 显示全部楼层
{:3_57:}支持了~
头像被屏蔽
发表于 2010-6-10 09:43:04 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2010-6-10 10:13:53 | 显示全部楼层
看不懂~~~~
发表于 2010-6-10 10:34:43 | 显示全部楼层
看不懂,,,不过知道你知道的好多。
发表于 2010-6-10 14:01:12 | 显示全部楼层
主要还是会语言同时会建筑的人少。上学时时间多点,学了也就学了;一旦上班,几乎没有时间再系统学这些了(当然,我说的是像我这样的一部分人,我承认有些人很有毅力,任何情况下都能学东西。)
发表于 2010-6-11 16:41:38 | 显示全部楼层
8# architc 严重同意啊。。。。。
发表于 2010-9-19 10:04:40 | 显示全部楼层
hoho ,我也想学但是没时间,郁闷
发表于 2010-9-22 22:40:48 | 显示全部楼层
学习一下~~~~~~
发表于 2011-7-30 17:23:29 | 显示全部楼层
都好厉害啊
发表于 2011-8-14 20:24:55 | 显示全部楼层
各位坛友,我是新手 请大家多多关照小弟我啊
发表于 2013-4-16 21:53:02 | 显示全部楼层
我觉得挺好的,大家的看法呢












                               
登录/注册后可看大图

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

手机版|NCF参数化建筑论坛 ( 辽ICP备12011358号-1 )    辽公网安备 21020302000097号

GMT+8, 2019-9-19 16:52 , Processed in 0.283314 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表