SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 645|回复: 2
打印 上一主题 下一主题

如何计算多个点间的距离

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2008-12-10 13:56:25 | 只看该作者

如何计算多个点间的距离

现有一批数据,分为两群,
第一群有一些点,(x1,y1),(x2,y2),(x3,y3),(x4,y4).....
第二群也有一些点,(m1,n1),(m2,n2),(m3,n3),(m4,n4).....
需要求出第一群中每两个点之间的距离,然后计算均值;第一群与第二群之间每两个点间距离,计算均值;
请问如何计算相关距离,距离是欧氏距离
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2008-12-10 18:08:16 | 只看该作者

Re: 如何计算多个点间的距离

[code:7011qbd8]data a;
        do id=1 to 100;
                x=ceil(ranuni(0)*100);
                y=ceil(ranuni(1)*100);
                output;
        end;
run;

data b;
        do id=1 to 1000;
                m=ceil(ranuni(3)*100);
                n=ceil(ranuni(4)*100);
                output;
        end;
run;
proc sql noprint;
        create table result1 as
                select avg(sqrt((a.x-b.x)**2+(a.y-b.y)**2)) as mean from a as a,a as b;
quit;

proc sql noprint;
        create table result2 as
                select avg(sqrt((a.x-b.m)**2+(a.y-b.n)**2)) as mean from a,b;
quit;        [/code:7011qbd8]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2008-12-11 09:13:28 | 只看该作者

Re: 如何计算多个点间的距离

再次感谢byes!呵呵
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-2-5 05:22 , Processed in 0.067508 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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