楼主: lqlon
1066 1

[问答] 问下大家这个为啥报错 [推广有奖]

  • 0关注
  • 0粉丝

本科生

53%

还不是VIP/贵宾

-

威望
0
论坛币
147 个
通用积分
1.0500
学术水平
0 点
热心指数
2 点
信用等级
1 点
经验
80 点
帖子
6
精华
0
在线时间
197 小时
注册时间
2016-10-1
最后登录
2024-3-12

相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
这个宏是来算期货momentum策略的收益,四周调仓一次,发现前面几周都没什么问题,到506周的时候报错了一次,后面又不报错了? week数据长这样

屏幕快照 2018-02-27 下午4.02.38.png 屏幕快照 2018-02-27 下午4.02.51.png


ERROR: 数据集 WORK.TEMP 不是以“升序”顺序排序的。当前 BY 组中“weeknum=514”,
        下一个 BY 组中“weeknum=510”。
NOTE: 由于出错,SAS 系统停止处理该步。
WARNING: 数据集 WORK.RETURN_DSCP 可能不完整。该步停止时,共有 2 个观测和 3 个变量。
WARNING: 数据集 WORK.RETURN_DSCP 由于该步已停止,而没有被替换。
NOTE: “PROCEDURE UNIVARIATE”所用时间(总处理时间):
       实际时间          0.00 秒
       CPU 时间          0.01 秒




%macro mom;
%do i = 7 %to 723 %by 4;

data temp1;
set week;
if weeknum=&i;
bgnprice=settle;
drop settle;
run;

data temp2;
set week;
if weeknum=&i+51;
endprice=settle;
drop settle;
run;

data temp3;
set week;
if weeknum=&i+55;
returnprice=settle;
drop settle;
run;

data temp;
merge temp1(in=ik) temp2 temp3;
by namec;
if ik=1;
run;

data temp;
set temp;
return_ratio=(endprice-bgnprice)/bgnprice;
return=(returnprice-endprice)/endprice;
run;

proc sort data =temp;
by return_ratio;
run;

proc univariate data = temp noprint;
var return_ratio;
output out=tempnumcount
n=num;
run;

data tempnumcount;
set tempnumcount;
temp=1;
run;


data temp;
set temp;
temp=1;
run;

data temp;
merge temp tempnumcount;
by temp;
drop temp;
run;

proc sort data=temp;
by return_ratio;
run;

data temp;
set temp;
rank=_n_;
run;

data temp;
set temp;
bound1=int(num/3);
bound2=num-int(num/3);
if rank<=bound1 then group=1;
else if rank>bound2 then group=3;
else group=2;
run;


proc univariate data = temp noprint;
by weeknum group;
var return;
output out = return_dscp
mean=pfrt;
run;

data finalreturntemp;
set return_dscp;
logreturn=log(1+pfrt);
weeknum=&i+55;
run;

proc sort data = finalreturntemp;
by group weeknum;
run;

%if &i=7 %then %do;
data finalreturn;
set finalreturntemp;
run;
%end;

%else %do;
data finalreturn;
set finalreturn finalreturntemp;
run;
%end;
%end;
%mend mom;
%mom;

二维码

扫码加我 拉你入群

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

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

关键词:Univariate Procedure Momentum Variate warning

已有 1 人评分热心指数 信用等级 收起 理由
eijuhz + 1 + 1 精彩帖子

总评分: 热心指数 + 1  信用等级 + 1   查看全部评分

沙发
xiami2000 在职认证  发表于 2018-2-28 02:24:52 |只看作者 |坛友微信交流群
Sort dataset temp before proc univariate.

proc sort data = temp ;
by weeknum group ;
run;

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-19 20:57