SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 676|回复: 6
打印 上一主题 下一主题

求助:请高手帮俺写个循环的语句

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2010-12-7 08:16:05 | 只看该作者

求助:请高手帮俺写个循环的语句

因为要求目标函数y=P(概率)×log(w×Y+(1-w))的最大值,我利用nlp找了一个解决的方法:
proc nlp;
  max y;
PARMS w sigma;
bounds 0<=w<=1, 0<=sigma;
Y1= exp(sigma*0);
Y2= exp(sigma);
Y3= exp(-sigma);
P1= 1/3;
P2= 1/3;
P3= 1/3;
y=P1*log(w1*Y1+(1-w))+P2*log(w*Y2+(1-w))+P3*log(w*Y3+(1-w));
run;
得到的结果
w=0.5, sigma= 709.08955 , max y=235.90


我想在想做一个循环,
首先, w 从 0 逐步增加到 1, 步长为 0.1
然后 在 每一个给定的w,  sigma 从 0 逐步增加到710, 步长为1.
最后, 把每一个 w,sigma 相对应的 y值  导出来, 要求包括 (w, sigma, y)。
因为很久没有用sas了,循环语句很生疏了,请高手帮忙,谢谢在先了。

另外,如果做这个循环,能不能在循环中嵌套proc nlp 得到 每一步的最优解呢?
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2010-12-9 03:29:36 | 只看该作者

Re: 求助:请高手帮俺写个循环的语句

you may like try  Proc IML.
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2010-12-9 05:28:31 | 只看该作者

Re: 求助:请高手帮俺写个循环的语句

[quote:3p1qs3gz]如果做这个循环,能不能在循环中嵌套proc nlp 得到 每一步的最优解呢? [/quote:3p1qs3gz]

给定w 和sigma,最优解是什么意思呢?
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2010-12-9 09:31:22 | 只看该作者

Re: 求助:请高手帮俺写个循环的语句

他的意思是要人帮忙写个宏循环。
回复 支持 反对

使用道具 举报

0

主题

0

帖子

2

积分

新手上路

Rank: 1

积分
2
5#
发表于 2010-12-10 09:27:54 | 只看该作者

Re: 求助:请高手帮俺写个循环的语句

to sxlion
顺便问问宏变量怎么弄出小数啊?
比如
%let a=0.1;
怎么让b=2*a呀?不用data _null_~~
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
6#
 楼主| 发表于 2010-12-10 12:48:30 | 只看该作者

Re: 求助:请高手帮俺写个循环的语句

to edle
for the looping, maybe you want this? [manually compute Y for each given w, sigma]?

data comp_out;
       do w=0 to 1 by 0.1;
             do sigma=0 to 710 by 1;
             Y1= exp(sigma*0);
             Y2= exp(sigma);
             Y3= exp(-sigma);
            /* P1= 1/3; P2= 1/3; P3= 1/3;*/
             y=(log(w1*Y1+(1-w))+log(w*Y2+(1-w))+log(w*Y3+(1-w)))/3;
             output;  keep w sigma Y;
             end;
        end;
run;

don't understand ur second Q. Do u mean initial values?
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
7#
 楼主| 发表于 2010-12-11 05:07:52 | 只看该作者

Re: 求助:请高手帮俺写个循环的语句

非常感谢各位高手:) <!-- s:D --><img src="{SMILIES_PATH}/icon_biggrin.gif" alt=":D" title="Very Happy" /><!-- s:D -->
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-13 19:40 , Processed in 0.531377 second(s), 19 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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