[613] | 1 | KMPDUG1 ;OAK/RAK - CM Tools Graph Utility ;2/17/04 09:58
|
---|
| 2 | ;;2.0;CAPACITY MANAGEMENT TOOLS;;Mar 22, 2002
|
---|
| 3 | ;
|
---|
| 4 | DRAW ;-- draw graph
|
---|
| 5 | W @IOF,!,IOG1 S DY=2
|
---|
| 6 | ; draw top line
|
---|
| 7 | F I=1:1:27 S DX=41+I X IOXY W IOHL S DX=43-I X IOXY W IOHL
|
---|
| 8 | ; draw top left and right corners
|
---|
| 9 | S DX=15 X IOXY W IOTLC S DX=68 X IOXY W IOTRC,!
|
---|
| 10 | ; draw sides
|
---|
| 11 | F DY=(DY+1):1:BOTTOM F DX=15,68 X IOXY W IOVL,!
|
---|
| 12 | ; draw bottom left and right corners
|
---|
| 13 | S DY=BOTTOM,DX=15 X IOXY W IOBLC S DX=68 X IOXY W IOBRC,!
|
---|
| 14 | ; draw bottom line
|
---|
| 15 | F I=1:1:27 S DX=15+I X IOXY W IOHL S DX=68-I X IOXY W IOHL
|
---|
| 16 | ; draw 'hash marks' on bottom line for relative values
|
---|
| 17 | S DX=15 X IOXY W IOLT,!
|
---|
| 18 | F DX=20:5:65 X IOXY W IOMT,!
|
---|
| 19 | ; print grid
|
---|
| 20 | I KMPUOPT["G" D
|
---|
| 21 | .S DY=2 F DX=20:5:65 X IOXY W IOTT,!
|
---|
| 22 | . F DX=20:5:65 F DY=3:1:(BOTTOM-1) X IOXY W IOVL,!
|
---|
| 23 | W IOG0
|
---|
| 24 | Q
|
---|
| 25 | INIT ;-- initialize required variables.
|
---|
| 26 | D GSET^%ZISS S X="IOECH;IORVOFF;IORVON;IOUOFF;IOUON" D ENDR^%ZISS
|
---|
| 27 | ; actual bars representing data
|
---|
| 28 | S BAR(0)="IORVON,"" "",IORVOFF"
|
---|
| 29 | S BAR(1)="IOG1,""a"",IOG0"
|
---|
| 30 | S (DEC,DNUM,MAX,MIN,SCALE,YNUM)=0,GWIDTH=$S(KMPUOPT["V":10,1:50)
|
---|
| 31 | S TITLE=$P($G(KMPUTI),U,1,2)
|
---|
| 32 | S XTITLE=$P($G(KMPUTI),U,3)
|
---|
| 33 | S YTITLE=$P($G(KMPUTI),U,4)
|
---|
| 34 | ; determine maximum and minimum number and decimals (if any).
|
---|
| 35 | S (I,MAX,MIN)=""
|
---|
| 36 | F S I=$O(@KMPUAR@(I)) Q:I="" I $D(@KMPUAR@(I,0)) S YNUM=YNUM+1 D
|
---|
| 37 | .I $P(@KMPUAR@(I,0),U,2)>MAX S MAX=$P(@KMPUAR@(I,0),U,2)
|
---|
| 38 | .I $P(@KMPUAR@(I,0),U,2)<MIN S MIN=$P(@KMPUAR@(I,0),U,2)
|
---|
| 39 | .; determine number of decimal places (if any).
|
---|
| 40 | .S DNUM=$P($P(@KMPUAR@(I,0),U,2),".",2) Q:'DNUM
|
---|
| 41 | .I $L(DNUM)>DEC S DEC=$L(DNUM)
|
---|
| 42 | Q:MAX'>0
|
---|
| 43 | ; get maximum number for graph.
|
---|
| 44 | D MAX
|
---|
| 45 | ; determine if there are decimal places when printed at end of graph
|
---|
| 46 | S I="" F S I=$O(@KMPUAR@(I)) Q:I="" I $D(@KMPUAR@(I,0)) D
|
---|
| 47 | .S Z=$L($P($P(@KMPUAR@(I,0),U,2)/DIV,".",2)) Q:'Z
|
---|
| 48 | .I Z>DEC S DEC=$S(Z>2:2,1:1)
|
---|
| 49 | S BOTTOM=$S(KMPUOPT["D":(YNUM*2+2),1:(YNUM+3))
|
---|
| 50 | S SCALE=((MAX-KMPUSTRT)/10),STEP=((MAX-KMPUSTRT)/GWIDTH)
|
---|
| 51 | S NUM=(SCALE+KMPUSTRT)
|
---|
| 52 | ; determine if relative values have decimal
|
---|
| 53 | S DEC1=0 F I=20:5:65 I $L($P((NUM/DIV),".",2)) D
|
---|
| 54 | .S DEC1=$S($L($P((NUM/DIV),".",2))>2:2,1:1)
|
---|
| 55 | Q
|
---|
| 56 | ;
|
---|
| 57 | MAX ;-- determine 'max' or largest number for graph.
|
---|
| 58 | ;
|
---|
| 59 | S:$G(KMPUMAX) MAX=KMPUMAX
|
---|
| 60 | S DIV=1,MAX=$FN(MAX,"",0)
|
---|
| 61 | I MAX<2 S MAX=1 Q
|
---|
| 62 | S X=1 F I=1:1:$L(MAX)-1 S X=X*10 I MAX=X S X=X/10
|
---|
| 63 | S MAX=$E(MAX-1)+1*X
|
---|
| 64 | I $L(MAX)>4 D
|
---|
| 65 | .F I=1:1:($L(MAX)-1) S DIV=DIV_"0"
|
---|
| 66 | .I $L(DIV)<7 S DIVT=$S(KMPUOPT["S":"10^"_I,1:(DIV/1000)_"k") Q
|
---|
| 67 | .S DIVT=$S(KMPUOPT["S":"10^"_I,1:(DIV/1000000)_"m")
|
---|
| 68 | Q
|
---|
| 69 | ;
|
---|
| 70 | TITLES ;-- print graph titles.
|
---|
| 71 | W IOG0
|
---|
| 72 | ; print first and second line of title
|
---|
| 73 | S DX=(IOM-$L($P(TITLE,U))\2+1),DY=0 X IOXY W $P(TITLE,U),!
|
---|
| 74 | S DX=(IOM-$L($P(TITLE,U,2))\2+1),DY=1 X IOXY W $P(TITLE,U,2),!
|
---|
| 75 | ; print y title
|
---|
| 76 | S DX=(14-$L(YTITLE)) X IOXY W IOUON,YTITLE,IOUOFF,!
|
---|
| 77 | ; print relative values under hash marks
|
---|
| 78 | S NUM=(SCALE+KMPUSTRT)
|
---|
| 79 | S DY=BOTTOM+1,DX=15-$S($L($FN((KMPUSTRT/DIV),"",DEC1))=1:0,1:$L($FN((KMPUSTRT/DIV),"",DEC1))-2) X IOXY W $FN((KMPUSTRT/DIV),"",DEC1),!
|
---|
| 80 | F I=20:5:65 D
|
---|
| 81 | .I $L($FN((NUM/DIV),"",DEC1))=1 S DX=(I-$L($FN((NUM/DIV),"",DEC1))+1)
|
---|
| 82 | .E S DX=(I-($L($FN((NUM/DIV),"",DEC1))-2))
|
---|
| 83 | .X IOXY W $FN((NUM/DIV),"",DEC1),! S NUM=NUM+SCALE
|
---|
| 84 | ; if div>1 write (x div)
|
---|
| 85 | I DIV>1 S DX=69 X IOXY W "<x",DIVT,">",!
|
---|
| 86 | ; print x title at bottom
|
---|
| 87 | S DX=(IOM-$L(XTITLE)\2+1),DY=BOTTOM+2 X IOXY W IOUON,XTITLE,IOUOFF,!
|
---|
| 88 | ; print data titles
|
---|
| 89 | S DY=3,I=0 F S I=$O(@KMPUAR@(I)) Q:'I I $D(@KMPUAR@(I,0)) D
|
---|
| 90 | .S YTITLE=$E($P(@KMPUAR@(I,0),U),1,14)
|
---|
| 91 | .S DX=(14-$L(YTITLE)) X IOXY W YTITLE,!
|
---|
| 92 | .S DY=DY+$S(KMPUOPT["D":2,1:1)
|
---|
| 93 | Q
|
---|