| 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
 | 
|---|