楼主: quintinyang
1035 3

[原创博文] 如何計算以下的狀況 [推广有奖]

  • 0关注
  • 0粉丝

小学生

57%

还不是VIP/贵宾

-

威望
0
论坛币
0 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
43 点
帖子
3
精华
0
在线时间
9 小时
注册时间
2010-11-19
最后登录
2016-6-18

楼主
quintinyang 发表于 2011-4-17 16:26:12 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
dear all,


ID_i: i=1, 2, 3---n
X_i: response variable
Data structure is following:
ID   X
1     4
2     6
3     2
4     5
5     2
.      .
.      .


n    4
如果我想要計算新variable "R" ( see attachment), pro.jpg ,    I為indicatior function

該如何使用SAS code來運算呢?想破頭了~~
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:Attachment following Structure Variable function following structure function 如何

沙发
morfecourier 发表于 2011-4-17 17:50:56
用IML过程最为快捷。这是我的程序段,用了你从1到5的观测,在程序里运行成功。将我的程序段稍加改动,就能得到你想要的结果,相信下面的步骤你能解决了。

data test;
input ID X;
cards;
1 4
2 6
3 2
4 5
5 2
;
run;

proc print data=test;
run;

proc IML;
use test;
read all var {ID X} into matrix;
print matrix;

n=nrow(matrix);
Pool=j(n,1,0);
R=j(n,1,0);

do i=1 to n;
Pool[i]=Matrix[i,2];
t=0;
      do j=1 to n;
      if Matrix[j,2] >= Pool[i] then t=t+1;
      end;
R[i]=t;
end;

print Matrix R;

newone=matrix||R;
create newone var {ID X R};
append from newone;
quit;

proc print data=newone;
run;
已有 1 人评分学术水平 热心指数 收起 理由
peijiamei + 1 + 1 好的意见建议

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

藤椅
quintinyang 发表于 2011-4-17 21:54:26
Thanks a lot!雖然我看不懂IML....不過這的確解決了我的問題~~

萬分感謝~~

板凳
ntsean 发表于 2011-4-17 23:32:55
用sql比较方便

data test;
input ID   X;
datalines;
1     4
2     6
3     2
4     5
5     2
;
run;

proc sql;
create table new as
select *, (select count(ID) from test where X>=a.X) as count
from test as a
;
quit;

proc print data=new;run;
已有 1 人评分学术水平 热心指数 收起 理由
peijiamei + 1 + 1 好的意见建议

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-27 10:31