24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1134  |  回复: 9
当前主题已经存档。

sgyin

铁杆木虫 (正式写手)

[交流] matlab编程问题

A是m*3的矩阵,是m个原子的坐标值,请问如何求的所有两两原子之间的距离R?(R应该有m*(m-1)/2个分量。)
我试着用for

for ii=1:m,
    r(ii)=sqrt((A(1,:)-A(ii,:)).^2);
end
这样只得到m个值。
该如何把这个程序完成啊?
谢谢

[ Last edited by csfn on 2008-12-29 at 20:20 ]
回复此楼

» 猜你喜欢

<ahref="http://www.TickerFactory.com/"><imgborder="0"src=&am
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

y1ding

铁杆木虫 (著名写手)

★ ★ ★ ★ ★
spur(金币+2,VIP+0):感谢帮助!
csfn(金币+3,VIP+0):thanks~
for ii=1:m-1
   for jj=ii:m
    r(ii_ii)=sqrt((A(jj,:)-A(ii,:)).^2);
end
2楼2008-01-02 09:02:28
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

y1ding

铁杆木虫 (著名写手)

for ii=1:m-1
   for jj=ii:m
    r(ii_ii)=sqrt((A(jj,:)-A(ii,:)).^2);
end
end
3楼2008-01-02 09:02:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

y1ding

铁杆木虫 (著名写手)

for ii=1:m
   for jj=ii:m
    r(ii_ii)=sqrt((A(jj,:)-A(ii,:)).^2);
end
4楼2008-01-02 09:02:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

y1ding

铁杆木虫 (著名写手)

for ii=1:m
   for jj=ii:m
    r(ii_ii)=sqrt((A(jj,:)-A(ii,:)).^2);
   end
end
5楼2008-01-02 09:03:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sgyin

铁杆木虫 (正式写手)

谢谢y1ding,没看懂r(ii_ii)=sqrt((A(jj,:)-A(ii,:)).^2);里面r(ii_ii)是什么意思啊?运行也有错误:
??? Undefined function or variable 'ii_ii'.

Error in ==> D:\Program Files\MATLAB6.5\bin\win32\temp.m
On line 23  ==>     r(ii_ii)=sqrt((A(jj,:)-A(ii,:)).^2);

今天我也试了一下,
for iii=1:m,
    for ii=1+iii:m,   
        rr((iii-1)*m-iii*(iii-1)/2+ii-iii,:)=(A(iii,:)-A(ii,:)).^2;
        r((iii-1)*m-iii*(iii-1)/2+ii-iii)=(rr((iii-1)*m-iii*(iii-1)/2+ii-iii,1)^2+rr((iii-1)*m-iii*(iii-1)/2+ii-iii,2)^2+rr((iii-1)*m-iii*(iii-1)/2+ii-iii,3)^2)^(.5);
       end
end
这样是可以的,可是rr这个矩阵比较大,浪费内存啊

[ Last edited by sgyin on 2008-1-2 at 10:39 ]
<ahref="http://www.TickerFactory.com/"><imgborder="0"src=&am
6楼2008-01-02 10:30:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dnp

荣誉版主 (知名作家)

小木虫浪子

优秀版主

★ ★ ★ ★
spur(金币+2,VIP+0):感谢帮助!欢迎常来!
csfn(金币+2,VIP+0):thanks~
我想你的矩阵A中的坐标值有三个吧?分别代表三维的坐标,你可以这样算:
R=[];
for i=1:m
for j=i:m
R(i,j)=sqrt((A(i,: )-A(j,: )).^2);
R(j,i)=R(i,j);
end
end
这样应该得到的是一个m*m的对称矩阵,对角线上的元素为0。
如果m<1000的话,这样算很快,而且matlab占的内存也不大。
What would Jesus do?
7楼2008-01-02 11:58:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

y1ding

铁杆木虫 (著名写手)

for ii=1:m
   for jj=ii:m
    r(ii,jj)=sqrt((A(jj,:)-A(ii,:)).^2);
   end
end
这样才对,ii_jj打错了
8楼2008-01-02 18:40:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dnp

荣誉版主 (知名作家)

小木虫浪子

优秀版主

呵呵,对于平方项来讲,在前在后都是一样的,这样只不过是将行的那个放在前面,好明白一点而已,每一行代表一个原子,每一列也代表一个原子。
如果你那样写的话,那应该只是一个对角阵了。
What would Jesus do?
9楼2008-01-02 18:58:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sgyin

铁杆木虫 (正式写手)

引用回帖:
Originally posted by dnp at 2008-1-2 18:58:
呵呵,对于平方项来讲,在前在后都是一样的,这样只不过是将行的那个放在前面,好明白一点而已,每一行代表一个原子,每一列也代表一个原子。
如果你那样写的话,那应该只是一个对角阵了。

dnp,你说的有道理,但是得到两两原子之间的距离是为了后面程序调用,不是为了好看,最希望的是占内存少,算法省时,以及容易调用。我选择的是列矩阵保存r值(r=0不要)。
&amp;amp;lt;ahref=&amp;amp;quot;http://www.TickerFactory.com/&amp;amp;quot;&amp;amp;gt;&amp;amp;lt;imgborder=&amp;amp;quot;0&amp;amp;quot;src=&amp;am
10楼2008-01-02 21:07:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 sgyin 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿北京2,材料与化工308求调剂 +9 熊二想上岸 2026-04-04 9/450 2026-04-04 23:40 by lqwchd
[考研] 070300化学学硕311分求调剂 +5 梁富贵险中求 2026-04-04 5/250 2026-04-04 22:51 by 无际的草原
[考研] 086000生物与医药298调剂求助 +6 元元青青 2026-03-31 8/400 2026-04-04 22:15 by lys0704
[考研] 294求调剂 +6 Grey_Ey 2026-04-02 9/450 2026-04-04 22:07 by hemengdong
[考研] 332求调剂 +10 Lyy930824@ 2026-03-29 10/500 2026-04-04 18:41 by macy2011
[考研] 291求调剂 +4 迷蒙木木 2026-04-01 5/250 2026-04-04 15:59 by sihailian3
[考研] 0710生物学336分求调剂 +6 kiyy 2026-04-01 8/400 2026-04-04 10:10 by kiyy
[考研] 一志愿上海海洋大学083200食品学硕,求调剂,接受其他专业083200 +3 what张 2026-04-04 4/200 2026-04-04 09:50 by rzh123456
[考研] 387求调剂 +4 爱吃片豆土 2026-04-03 5/250 2026-04-04 08:10 by 岸上的一条鱼
[考研] 295求调剂 +3 尚偌呀 2026-04-03 4/200 2026-04-03 21:23 by zhq0425
[考研] 085501一志愿天工大,机械专硕求调剂,跨材料 +3 33上 2026-04-03 3/150 2026-04-03 14:08 by 1753564080
[考研] 081200-11408-276学硕求调剂 +6 崔wj 2026-04-02 6/300 2026-04-03 10:19 by 蓝云思雨
[考研] 调剂 +3 好好读书。 2026-04-01 6/300 2026-04-02 15:49 by liumengping
[考研] 生物与医药考研调剂 +5 铁憨憨123425 2026-03-31 5/250 2026-04-01 18:01 by syh9288
[考研] 环境工程 085701,267求调剂 +15 minht 2026-03-29 16/800 2026-04-01 10:13 by li_sujuan99
[考研] 358求调剂 +3 王向阳花 2026-03-31 3/150 2026-04-01 09:56 by zzchen2000
[考研] 一志愿北京科技大学085601材料工程英一数二初试总分335求调剂 +5 双马尾痞老板2 2026-03-31 5/250 2026-04-01 09:04 by oooqiao
[考研] 085601英二数二求调剂 总分325 +4 余航航 2026-03-31 4/200 2026-03-31 17:38 by 唐沐儿
[考研] 江苏苏北高校诚邀调剂同学 +3 zzll406 2026-03-31 3/150 2026-03-31 16:54 by 及时行乐fan
[考研] 抱歉 +3 田洪有 2026-03-30 3/150 2026-03-30 19:11 by 迷糊CCPs
信息提示
请填处理意见