全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1783 2
2017-09-16
在SAS EG里跑回归 跑2-6个自变量还正常 但是跑2-8个自变量就提示内存不足了
但是把2-6和7-8分两段跑也提示内存不足
代码如下,请教一下大家如何修改代码才能避免该问题
在SAS EG里不知道怎么调内存memsize

%let para=&para2;
%let num=&num_para2;
%let ecodata=sas66.eco_his_season;

%macro paracorr(name,ecodata,para,num,corr);
proc corr
data=&ecodata
out=work.corr;
var ¶
run;
data work.corr1;
set work.corr;
if _TYPE_ ne 'CORR' then delete;
%do i=1 %to #
         %let p=%scan(&para,&i);
         if &p>&corr and &p<1 then &p=0;
         else &p=1;
%end;
run;
%mend;

%paracorr(M1,sas66.eco_his_season,&para,&num,0.85);

%macro mreg(name,para,num,min_num,max_num);
%local x;
%let x1=%scan(&para,1);
%let x=x1;
%do i=2 %to &num;
         %let x&i=%scan(&para,&i);
         %let x=&x,x&i;
%end;
/*%put x=&x;*/
proc reg data=work.&name outest=work.&name.test;
%do j=&min_num %to &max_num;
         %let ncomb=%sysfunc(comb(&num,&j));
         %do k=1 %to &ncomb;
                 %syscall allcomb(k, j, &x);
                 %let regpara= ;
                 %do m=1 %to &j;
                         %let regpara=%str(&regpara &&x&m);
                 %end;
                 reg1:model logit&name=&regpara
                 ;
                /*
                 %put regpara &j &k: &regpara sysinfo=&sysinfo syserr=&syserr;
                 */         
         %end;
%end;
run;
quit;
%mend mreg;

%macro mreg_33(name,para,num,min_num,max_num);
%local x y;
%let x1=%scan(&para,1);
%let y1=0;
%let x=x1;
%let y=y1;
%let y_num=1;
%do i=2 %to &num;
         %let x&i=%scan(&para,&i);
         %let x=&x,x&i;
%end;
proc reg data=work.&name outest=work.&name.test;
%do j=&min_num %to &max_num;
         %do %while( &y_num<&j);
                 %let y_num=%eval(&y_num+1);
                 /*%put y_num=&y_num j=&j;*/
                 %let y&y_num=0;
                 %let y=&y,y&y_num;
         %end;
         %let ncomb=%sysfunc(comb(&num,&j));
         %let y1=0;
         %do k=1 %to &ncomb;
                 %syscall allcombi(num, j, &y);
                 /*%put y=&y;*/
                 %let regpara= ;
                 %do m=1 %to &j;
                         %let ym=&&y&m;
                         %let regpara=%str(&regpara &&x&ym);
                 %end;
                 reg1:model logit&name=&regpara
                 ;
                 /*%put regpara &j &k: &regpara sysinfo=&sysinfo syserr=&syserr;
                 */         
         %end;
%end;
run;
quit;
%mend mreg_33;



*%mreg_33(lgdcorp,&newpara,&num_newpara,1,5);
%mreg(M1,&para,&num,2,7);
二维码

扫码加我 拉你入群

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

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

全部回复
2017-9-17 13:53:34
upupup
二维码

扫码加我 拉你入群

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

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

2017-9-18 00:40:10
upupup
二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群