source: FOIAVistA/tag/r/MENTAL_HEALTH-YS-RUCL-YI-YT/YTSF36.m@ 636

Last change on this file since 636 was 628, checked in by George Lilly, 14 years ago

initial load of FOIAVistA 6/30/08 version

File size: 3.3 KB
Line 
1YTSF36 ;ALBANY/ASF SF-36 HEALTH SURVEY ;1/12/96 10:33
2 ;;5.01;MENTAL HEALTH;**10,19**;Dec 30, 1994
3SCOR ;GET RESPONSES
4 S X=^YTD(601.2,YSDFN,1,YSET,1,YSED,1)
5 ;ARRAY SET
6 F I=1:1:36 S YSX(I)=$E(X,I)
7RV ;REVERSE SCORE 10 ITEMS
8 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)
9 ;RECODE 3 ITEMS
10 S YSX(1)=YSX(1)+$S($E(X,1)=2:.4,$E(X,1)=3:.4,1:0)
11 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)
12 I ($E(X,22)=1)&($E(X,21)=1) S YSX(22)=6
13 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)
14RAWER ;RAW CALCULATIONS
15 K S S R="" F J=1:1:9 S YSN=0,YSXN=0 D RAW1 D:YSXN>0 MISS
16 G STND Q
17RAW1 S YSKK=^YTT(601,YSTEST,"S",J,"K",1,0)
18 F I=1:2 S A=$P(YSKK,U,I) Q:A="" D RAW2
19 Q
20RAW2 S $P(R,U,J)=$P(R,U,J)+YSX(A)
21 I YSX(A)="X" S YSXN=YSXN+1
22 S YSN=YSN+1
23 Q
24MISS ;MISSING ITEM RECODE BY MEANS
25 S B=$P("10^4^2^5^4^2^3^5^1",U,J)
26 I YSXN/B>.5 S $P(R,U,J)="*" Q
27 S Y=$P(R,U,J)/(YSN-YSXN)
28 S $P(R,U,J)=$P(R,U,J)+(Y*YSXN)
29 Q
30STND ;
31 S S="",J=1,P="M"
32ST ;
33 S A=$P(R,U,J) G:A=""!(J=9) REPT
34 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
35REPT ;
36 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
37 D DTA^YTREPT W !!?(72-$L(X)\2),X,!!!?(A-9\2+L1),"S C A L E",?(L2+1),"RAW 0-100",!
38 F J=1:1 S YSRS=$P(R,U,J) Q:YSRS="" D
39 . D:IOST?1"C-".E&($Y>21) SCR Q:YSTOUT!YSUOUT
40 . W !?L1,$P(^YTT(601,YSTEST,"S",J,0),U,2)
41 . W ?L2,$S(YSRS="*":" *",1:$J(YSRS,6,2))
42 . I YSRS="*" W ?(L2+10)," *"
43 . I $P(^YTT(601,YSTEST,"S",J,0),U,2)="Reported Health Transition" D LS Q
44 . W ?(L2+10),$J($P(S,U,J),6,2)
45 W !! F YSZZ=0:1 S YSTXT=$T(TEXT+YSZZ) Q:YSTXT="" W ?7,$P(YSTXT,";;",2),!
46 S YSNOITEM="ITMS^YTSF36"
47 Q
48 ;
49LS ;
50 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:" ")
51 Q
52 ;
53ITMS ;ITEM OUTPUT
54 W:$Y>5 @IOF D DTA^YTREPT S (YSOUT,YSUOUT)=0,A=^YTD(601.2,YSDFN,1,YSET,1,YSED,1)
55 W !!?15,"Item Responses",!
56 S K=0 F I=1:1 S K=$O(^YTT(601,YSTEST,"G",K)) Q:K'>0 D ITMS1
57 Q
58ITMS1 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
59 Q
60ITMS2 I YSX?1N.E S YSN=+YSX W !,YSX Q
61 I (J=1)&(YSX?1U.E) W !!?15,"<<<",YSX,">>>" Q
62 I YSX?1"^".E W !?5,"Answer= ",$P(YSX,"^",$E(A,YSN)+1) Q
63 W !,YSX
64 Q
65DONE ;
66 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
67 Q
68 ;
69SCR ;
70 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
71 N N1,N2,N3,N4,P,P0,P1,P3,R,R1,S,S1,T,T1,T2,TT,V,V1,V2,V3
72 N V4,V5,V6,W,X,X0,X1,X2,X3,X4,X7,X8,X9,Y,Y1,Y2,Z,Z1,Z3
73 ;
74 F I0=1:1:(IOSL-$Y-2) W !
75 N DTOUT,DUOUT,DIRUT,X
76 S DIR(0)="E" D ^DIR K DIR S YSTOUT=$D(DTOUT),YSUOUT=$D(DUOUT),YSLFT=$D(DIRUT)
77 W @IOF Q
78 ;
79TEXT ;
80 ;;The numbers for all but the last scale reflect the degree to
81 ;;which the individual has given answers in the direction of
82 ;;good health. The 0-100 column will contain a zero if none
83 ;;of the answers are in the direction of good health, and 100
84 ;;if all the answers are in the direction of good health.
85 ;;The last scale reflects how individuals rate the change in
86 ;;their health over the prior year and ranges from 1 (Much Better)
87 ;;to 5 (Much Worse).
88 ;;
89 ;
90EOR ;YTSF36
Note: See TracBrowser for help on using the repository browser.