| 1 | ONCOSSA4 ;WASH ISC/SRR,MLH-PLOT SURVIVAL SURVES ;11/1/93  12:33
 | 
|---|
| 2 |  ;;2.11;ONCOLOGY;;Mar 07, 1995
 | 
|---|
| 3 | PLOT ;plot survival curves
 | 
|---|
| 4 |  ;in:  CASES,HEADER,LEN,NGRPS,NMORT,NPG,XCRT,^TMP($J
 | 
|---|
| 5 |  ;use: GRP
 | 
|---|
| 6 |  ;out: NPG
 | 
|---|
| 7 |  ;do:  TOF^ONCOSSA3
 | 
|---|
| 8 |  D TOF^ONCOSSA3 Q:ONCOEX  W $P(HEADER,U,1),"Survival Curve",$S(NGRPS>1:"s",1:"")
 | 
|---|
| 9 |  W ?IOM-30,$P(HEADER,U,2),NPG I NMORT=0 W !!,"NO deaths!",! Q
 | 
|---|
| 10 |  N IX,LMORT,LN,N,NLN,NX,P,XADJ,XSCL,XSIZ,YSIZ
 | 
|---|
| 11 |  I IOM<120 S NLN=20,XSIZ=60
 | 
|---|
| 12 |  E  S NLN=50,XSIZ=120
 | 
|---|
| 13 |  S XSCL=0,YSIZ=100/NLN,LMORT=""
 | 
|---|
| 14 |  F GRP=1:1:NGRPS S N=CASES(GRP) D:N CPLT
 | 
|---|
| 15 |  S X="1;.01^3;.025^6;.05^12;.1^30;.25^60;.5^120;1",XSCL=XSCL/LEN
 | 
|---|
| 16 |  I XSCL>120 S XSCL=XSCL-1/120+1\1
 | 
|---|
| 17 |  E  F GRP=1:1:99 S Y=$P(X,U,GRP) Q:Y=""  I XSCL'>+Y S XSCL=$P(Y,";",2) Q
 | 
|---|
| 18 |  S:XSIZ=60 XSCL=XSCL+XSCL S XADJ=XSCL*LEN
 | 
|---|
| 19 |  F GRP=1:1:NGRPS S:$D(INS(GRP)) INTS(GRP)=INTS(GRP)\XADJ
 | 
|---|
| 20 |  F LN=0:1:NLN-1 D PLIN
 | 
|---|
| 21 |  W !?7,"0 |" F X=1:1:XSIZ W $S(X#10=0:"+",1:"-")
 | 
|---|
| 22 |  W !,"  ",$P(LEN,U,3),":",?8 S Y=$S(XSCL<.1:2,XSCL<.5:1,1:0)
 | 
|---|
| 23 |  F X=0:10:XSIZ W $J(X*XSCL,3,Y),"       "
 | 
|---|
| 24 |  Q
 | 
|---|
| 25 |  ;
 | 
|---|
| 26 | CPLT ;compute plot coordinates
 | 
|---|
| 27 |  S P=100,(IX(GRP),Z)=0
 | 
|---|
| 28 |  F X=-1:0 S X=$O(^TMP($J,"KM",GRP,X)) Q:X=""  D CP1 S Z=X
 | 
|---|
| 29 |  S INTS(GRP)=Z S:Z>XSCL XSCL=Z S LMORT=LMORT_$D(^TMP($J,"KM",GRP,Z,1))
 | 
|---|
| 30 |  Q
 | 
|---|
| 31 | CP1 ;compute Psurv
 | 
|---|
| 32 |  I '$D(^TMP($J,"KM",GRP,X,1)) S N=N-^(0) Q
 | 
|---|
| 33 |  S Y=^TMP($J,"KM",GRP,X,1) F %=1:1:Y S N=N-1,P=P*N/(N+1)
 | 
|---|
| 34 |  S N=N-(+$G(^TMP($J,"KM",GRP,X,0))),Y=100-P\YSIZ S:Y&'$D(^TMP($J,"PLT",GRP,Y)) ^(Y)=X
 | 
|---|
| 35 |  Q
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 | PLIN ;plot a line
 | 
|---|
| 38 |  N C
 | 
|---|
| 39 |  F GRP=1:1:NGRPS D:CASES(GRP) PL1
 | 
|---|
| 40 |  S Y="" F C=0:1:XSIZ S Y=Y_$S($D(C(C)):C(C),1:" ") Q:$O(C(C))=""
 | 
|---|
| 41 |  I LN#4=0 W !?5,$J(NLN-LN/NLN*100,3)," +",Y
 | 
|---|
| 42 |  E  W !?9,"|",Y
 | 
|---|
| 43 |  Q
 | 
|---|
| 44 | PL1 ;setup line in C(
 | 
|---|
| 45 |  S X=$O(^TMP($J,"PLT",GRP,LN)),Z=$S(X="":INTS(GRP),1:^(X)\XADJ),NX(GRP)=Z
 | 
|---|
| 46 |  F C=IX(GRP):1:Z S C(C)=$S($D(C(C)):"*",1:$C(GRP+64))
 | 
|---|
| 47 |  I X=""&'$E(LMORT,GRP) S CASES(GRP)=0
 | 
|---|
| 48 |  E  S IX(GRP)=NX(GRP)
 | 
|---|
| 49 |  Q
 | 
|---|