24小时热门版块排行榜    

查看: 1060  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

glazio

铁虫 (小有名气)

[求助] 如何计算多粒子聚集体系的最大长度

如果有某团聚体由N个球形粒子(相同尺寸、质量)组成,该使用什么算法找到该团聚体中相聚最远的两个粒子,并由此得到团聚体的最大长度L呢?团聚体的模型请参考这个链接( http://v.youku.com/v_show/id_XNDQyMzYzODEy.html )

我的想法是首先得到该团聚体的重心G,然后以G为起始点寻找距它最远的粒子A,最后再以A为起始点寻找距离最远的点B,这样A和B之间的距离就是L。

[ Last edited by glazio on 2012-8-23 at 12:55 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

glazio

铁虫 (小有名气)

按照luxuia的建议搜了一下,好像这个问题需要用三维凸包的旋转卡壳算法解决。感觉我打开了一个潘多拉盒子,谢谢你的建议!
5楼2012-08-25 22:10:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
jjdg: 金币+2, 感谢应助 2012-08-25 00:24:44
双重循环计算距离,如果比当前最大距离大,更新最大距离(如果需要这2个粒子的信息,将下标也存储),如果将粒子两两距离看做一个矩阵,你只需要计算上三角(或者下三角),内存循环从当前坐标往大取.类似
CODE:
// 初始化,将粒子的中心坐标存入particle.centre[N],下标范围[0,N-1]
maxDist = 0;
ind1 = 0;
ind2 = 0;
for (int i=0;i {
        for (int j=i+1;j         {
                curDist = computeDistance(particle.centre[ind1],particle.centre[ind2]);
                if (curDist>maxDist)
                {
                        maxDist = curDist;
                        ind1 = i;
                        ind2 = j;
                }
        }
}
// 打印输出maxDist和ind1,ind2

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2012-08-23 15:40:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

glazio

铁虫 (小有名气)

可能我没说清楚,我现在只会用python,而在1楼中我提到的那个计算方法自己可以用python实现,但是算法受人质疑不够强壮。所以在这里求助大神
1. 能否给出算法描述、伪代码或python代码?参考链接或文献均可
2. 2楼的算法好象是对所有粒间距里进行循环计算,那么有无比较强壮的算法,而且考虑到需要用python实现,该算法的效率较高?

抱歉没说清楚而让libra大神误会,现在能否针对这两个问题指点一下?
3楼2012-08-23 16:00:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

luxuia

铁虫 (初入文坛)

【答案】应助回帖

★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
jjdg: 金币+1, 感谢应助 2012-08-25 00:24:37
glazio: 金币+5, ★★★很有帮助, 谢谢你的建议 2012-08-25 22:12:41
求凸包,凸包算法详查google。复杂度O(nlogn).
4楼2012-08-24 17:18:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[论文投稿] 申请回稿延期一个月,编辑同意了。但系统上的时间没变,给编辑又写邮件了,没回复 10+3 wangf9518 2026-03-17 4/200 2026-03-19 23:55 by babero
[考研] 0703化学调剂 +10 妮妮ninicgb 2026-03-15 14/700 2026-03-19 22:59 by 学员8dgXkO
[考研] 求调剂 +3 Mqqqqqq 2026-03-19 3/150 2026-03-19 14:11 by peike
[考研] 287求调剂 +3 晨昏线与星海 2026-03-19 4/200 2026-03-19 12:32 by peike
[考研] 一志愿985,本科211,0817化学工程与技术319求调剂 +10 Liwangman 2026-03-15 10/500 2026-03-19 10:25 by 无际的草原
[考研] 332求调剂 +3 ydfyh 2026-03-17 3/150 2026-03-19 10:14 by 功夫疯狂
[考研] 0703化学调剂,求各位老师收留 +10 秋有木北 2026-03-14 10/500 2026-03-19 05:52 by anny19840123
[考研] 328求调剂,英语六级551,有科研经历 +3 生物工程调剂 2026-03-17 7/350 2026-03-18 20:41 by Wangjingyue
[考研] 070300化学319求调剂 +6 锦鲤0909 2026-03-17 6/300 2026-03-18 13:22 by Iveryant
[考研] 265求调剂 +3 梁梁校校 2026-03-17 3/150 2026-03-18 09:12 by zhukairuo
[考研] 293求调剂 +11 zjl的号 2026-03-16 16/800 2026-03-18 08:10 by zhukairuo
[考研] 301求调剂 +4 A_JiXing 2026-03-16 4/200 2026-03-17 17:32 by ruiyingmiao
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
[考研] 277材料科学与工程080500求调剂 +3 自由煎饼果子 2026-03-16 3/150 2026-03-16 14:10 by 运气yunqi
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 288求调剂 +4 奇点0314 2026-03-14 4/200 2026-03-14 23:04 by JourneyLucky
[考研] 中科大材料与化工319求调剂 +3 孟鑫材料 2026-03-14 3/150 2026-03-14 20:10 by ms629
[考研] 中科大材料专硕319求调剂 +3 孟鑫材料 2026-03-13 3/150 2026-03-14 18:10 by houyaoxu
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
[硕博家园] 085600 260分求调剂 +3 天空还下雨么 2026-03-13 5/250 2026-03-13 18:46 by 天空还下雨么
信息提示
请填处理意见