我认为 SAS 中的绘图引擎并不是很直接。我希望有人可以帮助我:
我想绘制 4 种不同股票订单簿的数量。但它只是画出奇怪的点。我有以下示例数据集:
股票 AskVolume1 AskVolume2 AskVolume3 BidVolume1 BidVolume2 BidVolume3 AskScaledPrice1 AskScaledPrice2 AskScaledPrice3 BidScaledPrice1 BidScaledPrice2 BidScaledPrice3
库存A 1 2 3 1 2 3 -9.7 -9.8 -9.9 9.7 9.8 9.9
库存B 2 4 6 2 4 6 -9.6 -9.7 -9.9 9.5 9.6 9.8
股票C等...
横轴应显示价格,中点为 10。成交量应该在垂直轴上(图表最终应该看起来像一个 V,每只股票一个 V 形图)。
我拥有的代码不起作用是:
goptions reset=all noborder ctext=CX000000 htext=20 pt
colors=(CX0000FF CXFF0000 CX008080 CX00FF00 CXFF00FF CXFFFF00 CX00FFFF CX800000 CX008000
CX800080 CX000080 CX808000 CXFFFFFF CX808080 CXC0C0C0 CX000000);
ods _all_ close; ods listing device=png ;
filename myfile "&DIRECTORY.\output.png";
title1 justify=center color=CX000000 height=14 pt "OrderBook Shapes";
/* set the graphics environment */
goptions reset=global gunit=pct border
ftext=swissb htitle=6 htext=3;
/* set the graphics device */
goptions device=ps300 rotate=landscape ;
/* define titles and footnotes */
title1 'OrderBooks';
/* define symbol characteristics */
symbol1 color=black interpol=join value=dot height=2;
symbol2 color=black interpol=join value=diamond height=3;
/* generate two plots */
proc gplot data=plot2;
plot
BidVolume1*Price1=stock BidVolume2*price2=stock (....etc)
AskVolume1*Price1=stock AskVolume2*price2=stock (....etc)
/ overlay;
run;
感谢您的任何意见!