VistA-WorldVistAEHR/r/MENTAL_HEALTH-YS-RUCL-YI-YT/YTSF36.m

91 lines
3.3 KiB
Mathematica

YTSF36 ;ALBANY/ASF SF-36 HEALTH SURVEY ;1/12/96 10:33
;;5.01;MENTAL HEALTH;**10,19**;Dec 30, 1994
SCOR ;GET RESPONSES
S X=^YTD(601.2,YSDFN,1,YSET,1,YSED,1)
;ARRAY SET
F I=1:1:36 S YSX(I)=$E(X,I)
RV ;REVERSE SCORE 10 ITEMS
F I=21,22,1,34,36,23,27,20,26,30 I YSX(I)'="X" S YSMX=$P(^YTT(601,YSTEST,"Q",I,0),U,2),YSMX=$E(YSMX,$L(YSMX)-1)+1,YSX(I)=YSMX-YSX(I)
;RECODE 3 ITEMS
S YSX(1)=YSX(1)+$S($E(X,1)=2:.4,$E(X,1)=3:.4,1:0)
S:YSX(21)'="X" YSX(21)=YSX(21)+$S($E(X,21)=2:.4,$E(X,21)=3:.2,$E(X,21)=4:.1,$E(X,21)=5:.2,1:0)
I ($E(X,22)=1)&($E(X,21)=1) S YSX(22)=6
I $E(X,21)="X"&(YSX(22)'="X") S YSX(22)=YSX(22)+$S($E(X,22)=1:1,$E(X,22)=2:.75,$E(X,22)=3:.5,$E(X,22)=4:.25,1:0)
RAWER ;RAW CALCULATIONS
K S S R="" F J=1:1:9 S YSN=0,YSXN=0 D RAW1 D:YSXN>0 MISS
G STND Q
RAW1 S YSKK=^YTT(601,YSTEST,"S",J,"K",1,0)
F I=1:2 S A=$P(YSKK,U,I) Q:A="" D RAW2
Q
RAW2 S $P(R,U,J)=$P(R,U,J)+YSX(A)
I YSX(A)="X" S YSXN=YSXN+1
S YSN=YSN+1
Q
MISS ;MISSING ITEM RECODE BY MEANS
S B=$P("10^4^2^5^4^2^3^5^1",U,J)
I YSXN/B>.5 S $P(R,U,J)="*" Q
S Y=$P(R,U,J)/(YSN-YSXN)
S $P(R,U,J)=$P(R,U,J)+(Y*YSXN)
Q
STND ;
S S="",J=1,P="M"
ST ;
S A=$P(R,U,J) G:A=""!(J=9) REPT
S X=^YTT(601,YSTEST,"S",J,P),S=S_$J((A-$P(X,U)/$P(X,U,2)*100),0,2)_"^",J=J+1 G ST
REPT ;
S X=$P(^YTT(601,YSTEST,"P"),U),A=$P(^("P"),U,2),L1=58-A\2,L2=L1+A+7 S:A<9 A=9
D DTA^YTREPT W !!?(72-$L(X)\2),X,!!!?(A-9\2+L1),"S C A L E",?(L2+1),"RAW 0-100",!
F J=1:1 S YSRS=$P(R,U,J) Q:YSRS="" D
. D:IOST?1"C-".E&($Y>21) SCR Q:YSTOUT!YSUOUT
. W !?L1,$P(^YTT(601,YSTEST,"S",J,0),U,2)
. W ?L2,$S(YSRS="*":" *",1:$J(YSRS,6,2))
. I YSRS="*" W ?(L2+10)," *"
. I $P(^YTT(601,YSTEST,"S",J,0),U,2)="Reported Health Transition" D LS Q
. W ?(L2+10),$J($P(S,U,J),6,2)
W !! F YSZZ=0:1 S YSTXT=$T(TEXT+YSZZ) Q:YSTXT="" W ?7,$P(YSTXT,";;",2),!
S YSNOITEM="ITMS^YTSF36"
Q
;
LS ;
W ?(L2+10),$S(YSRS=1:"Much Better",YSRS=2:"Somewhat Better",YSRS=3:"About the Same",YSRS=4:"Somewhat Worse",YSRS=5:"Much Worse",1:" ")
Q
;
ITMS ;ITEM OUTPUT
W:$Y>5 @IOF D DTA^YTREPT S (YSOUT,YSUOUT)=0,A=^YTD(601.2,YSDFN,1,YSET,1,YSED,1)
W !!?15,"Item Responses",!
S K=0 F I=1:1 S K=$O(^YTT(601,YSTEST,"G",K)) Q:K'>0 D ITMS1
Q
ITMS1 S J=0 F I=1:1 S J=$O(^YTT(601,YSTEST,"G",K,1,J)) Q:J'>0 S YSX=^(J,0) D:IOST?1"C-".E&($Y>21) SCR Q:YSOUT!YSUOUT D ITMS2
Q
ITMS2 I YSX?1N.E S YSN=+YSX W !,YSX Q
I (J=1)&(YSX?1U.E) W !!?15,"<<<",YSX,">>>" Q
I YSX?1"^".E W !?5,"Answer= ",$P(YSX,"^",$E(A,YSN)+1) Q
W !,YSX
Q
DONE ;
K YSTY,X,Y,A,B,K,YSKK,YSXN,YSN,YSX,L,L1,L2,M,J,YSIT,YSRS,I,P,YSMX,YSTL,YSTTL,YSTXT,YSZZ
Q
;
SCR ;
N A,B,B1,C,D,E,E1,F,F1,G,G1,H,I,J,J1,J2,J3,J4,K,L,L1,L2,M,N
N N1,N2,N3,N4,P,P0,P1,P3,R,R1,S,S1,T,T1,T2,TT,V,V1,V2,V3
N V4,V5,V6,W,X,X0,X1,X2,X3,X4,X7,X8,X9,Y,Y1,Y2,Z,Z1,Z3
;
F I0=1:1:(IOSL-$Y-2) W !
N DTOUT,DUOUT,DIRUT,X
S DIR(0)="E" D ^DIR K DIR S YSTOUT=$D(DTOUT),YSUOUT=$D(DUOUT),YSLFT=$D(DIRUT)
W @IOF Q
;
TEXT ;
;;The numbers for all but the last scale reflect the degree to
;;which the individual has given answers in the direction of
;;good health. The 0-100 column will contain a zero if none
;;of the answers are in the direction of good health, and 100
;;if all the answers are in the direction of good health.
;;The last scale reflects how individuals rate the change in
;;their health over the prior year and ranges from 1 (Much Better)
;;to 5 (Much Worse).
;;
;
EOR ;YTSF36