YTSFAST ;SLC/PIJ - Score FAST ; 01/08/2016
;;5.01;MENTAL HEALTH;**123,202**;DEC 30,1994;Build 47
;
; Reference to GET1^DIQ in ICR #2056
;
Q
;
DATA1 ;
S YSINSNAM=$P(YSDATA(2),U,3)
I $G(YSINSNAM)="" S YSINSNAM=$G(YS("CODE"),"NO NAME PASSED")
S NODE=2 F S NODE=$O(YSDATA(NODE)) Q:NODE="" D ; Start at YSDATA(3)
.S DATA=YSDATA(NODE)
.S YSQN=$P(DATA,U,1)
.S YSCDA=$P($G(DATA),U,3)
.D DESGNTR^YTSCORE(YSQN,.DES)
.S LEG=$$GET1^DIQ(601.75,YSCDA_",",4,"I")
.I (DES=2),(LEG="Y") S:STAGE<2 STAGE=2
.I (DES=3),(LEG="Y") S:STAGE<3 STAGE=3
.I (DES=4),(LEG="Y") S:STAGE<4 STAGE=4
.I (DES=5),(LEG="Y") S:STAGE<5 STAGE=5
.I ($E(DES)=6),(LEG="Y") S:STAGE<6 STAGE=6
.I ($E(DES)=7),(LEG="Y") S:STAGE<7 STAGE=7
Q
;
; --- BEGIN OLD ALGORITHM ---
; The lines below were the previous algorithm for scoring. They assumed
; that the stages were additive, so scoring stopped at the first negative
; answer, even if later answers were positive
;.I (DES=1),(LEG="Y") S STAGE=1 Q
;.I (DES=2),(LEG="Y") S STAGE=2 Q
;.I (DES=3),(STAGE=2),(LEG="Y") S STAGE=3 Q
;.I (DES=4),(STAGE=3),(LEG="Y") S STAGE=4 Q
;.I (DES=5),(STAGE=4),(LEG="Y") S STAGE=5 Q
;.I (DES="6a"),(STAGE=5),(LEG="Y") S STAGE=6 Q
;.I (DES="6b"),(STAGE=6),(LEG="Y") S STAGE=7 Q
;.I (DES="6c"),(STAGE=7),(LEG="Y") S STAGE=8 Q
;.I (DES="6d"),(STAGE=8),(LEG="Y") S STAGE=9 Q
;.I (DES="6e"),(STAGE=9),(LEG="Y") S STAGE=10 Q
;.I (DES="7a"),(STAGE=10),(LEG="Y") S STAGE=11 Q
;.I (DES="7b"),(STAGE=11),(LEG="Y") S STAGE=12 Q
;.I (DES="7c"),(STAGE=12),(LEG="Y") S STAGE=13 Q
;.I (DES="7d"),(STAGE=13),(LEG="Y") S STAGE=14 Q
;.I (DES="7e"),(STAGE=14),(LEG="Y") S STAGE=15 Q
;.I (DES="7f"),(STAGE=15),(LEG="Y") S STAGE=16 Q
;Q
;
;STRING ;
; I (STAGE>5),(STAGE<11) S STAGE=6,STRING=STAGE Q
; I (STAGE>10),(STAGE<17) S STAGE=7,STRING=STAGE Q
; S STRING=STAGE
; Q
; --- END OLD ALGORITM ---
;
SCORESV ;
I $D(^TMP($J,"YSG",1)),^TMP($J,"YSG",1)="[ERROR]" D Q ;-->out
.K ^TMP($J,"YSCOR")
.S ^TMP($J,"YSCOR",1)="[ERROR]"
.S ^TMP($J,"YSCOR",2)=$G(YSINSNAM)_" Scale not found"
S YSSCNAM=$P($G(^TMP($J,"YSG",3)),U,4) ; Scale Name
;
K ^TMP($J,"YSCOR")
S ^TMP($J,"YSCOR",1)="[DATA]"
S ^TMP($J,"YSCOR",2)=$$GET1^DIQ(601.87,509_",",3,"I")_"="_STAGE
Q
;
DLLSTR(YSDATA,YS,YSTRNG) ;
; YSTRNG = 1 Score Instrument
; YSTRNG = 2 get Report Answers and Text
N DATA,DES,LEG,NODE,STAGE,YSQN
N YSCDA,YSSCNAM,YSINSNAM
;
; FAST returns a scale score which is calculated and stored, no special text in report
I YSTRNG=2 Q
;
S STAGE=1
D DATA1
D SCORESV
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HYTSFAST 2621 printed Mar 10, 2023@00:09:33 Page 2
YTSFAST ;SLC/PIJ - Score FAST ; 01/08/2016
+1 ;;5.01;MENTAL HEALTH;**123,202**;DEC 30,1994;Build 47
+2 ;
+3 ; Reference to GET1^DIQ in ICR #2056
+4 ;
+5 QUIT
+6 ;
DATA1 ;
+1 SET YSINSNAM=$PIECE(YSDATA(2),U,3)
+2 IF $GET(YSINSNAM)=""
SET YSINSNAM=$GET(YS("CODE"),"NO NAME PASSED")
+3 ; Start at YSDATA(3)
SET NODE=2
FOR
SET NODE=$ORDER(YSDATA(NODE))
if NODE=""
QUIT
Begin DoDot:1
+4 SET DATA=YSDATA(NODE)
+5 SET YSQN=$PIECE(DATA,U,1)
+6 SET YSCDA=$PIECE($GET(DATA),U,3)
+7 DO DESGNTR^YTSCORE(YSQN,.DES)
+8 SET LEG=$$GET1^DIQ(601.75,YSCDA_",",4,"I")
+9 IF (DES=2)
IF (LEG="Y")
if STAGE<2
SET STAGE=2
+10 IF (DES=3)
IF (LEG="Y")
if STAGE<3
SET STAGE=3
+11 IF (DES=4)
IF (LEG="Y")
if STAGE<4
SET STAGE=4
+12 IF (DES=5)
IF (LEG="Y")
if STAGE<5
SET STAGE=5
+13 IF ($EXTRACT(DES)=6)
IF (LEG="Y")
if STAGE<6
SET STAGE=6
+14 IF ($EXTRACT(DES)=7)
IF (LEG="Y")
if STAGE<7
SET STAGE=7
End DoDot:1
+15 QUIT
+16 ;
+17 ; --- BEGIN OLD ALGORITHM ---
+18 ; The lines below were the previous algorithm for scoring. They assumed
+19 ; that the stages were additive, so scoring stopped at the first negative
+20 ; answer, even if later answers were positive
+21 ;.I (DES=1),(LEG="Y") S STAGE=1 Q
+22 ;.I (DES=2),(LEG="Y") S STAGE=2 Q
+23 ;.I (DES=3),(STAGE=2),(LEG="Y") S STAGE=3 Q
+24 ;.I (DES=4),(STAGE=3),(LEG="Y") S STAGE=4 Q
+25 ;.I (DES=5),(STAGE=4),(LEG="Y") S STAGE=5 Q
+26 ;.I (DES="6a"),(STAGE=5),(LEG="Y") S STAGE=6 Q
+27 ;.I (DES="6b"),(STAGE=6),(LEG="Y") S STAGE=7 Q
+28 ;.I (DES="6c"),(STAGE=7),(LEG="Y") S STAGE=8 Q
+29 ;.I (DES="6d"),(STAGE=8),(LEG="Y") S STAGE=9 Q
+30 ;.I (DES="6e"),(STAGE=9),(LEG="Y") S STAGE=10 Q
+31 ;.I (DES="7a"),(STAGE=10),(LEG="Y") S STAGE=11 Q
+32 ;.I (DES="7b"),(STAGE=11),(LEG="Y") S STAGE=12 Q
+33 ;.I (DES="7c"),(STAGE=12),(LEG="Y") S STAGE=13 Q
+34 ;.I (DES="7d"),(STAGE=13),(LEG="Y") S STAGE=14 Q
+35 ;.I (DES="7e"),(STAGE=14),(LEG="Y") S STAGE=15 Q
+36 ;.I (DES="7f"),(STAGE=15),(LEG="Y") S STAGE=16 Q
+37 ;Q
+38 ;
+39 ;STRING ;
+40 ; I (STAGE>5),(STAGE<11) S STAGE=6,STRING=STAGE Q
+41 ; I (STAGE>10),(STAGE<17) S STAGE=7,STRING=STAGE Q
+42 ; S STRING=STAGE
+43 ; Q
+44 ; --- END OLD ALGORITM ---
+45 ;
SCORESV ;
+1 ;-->out
IF $DATA(^TMP($JOB,"YSG",1))
IF ^TMP($JOB,"YSG",1)="[ERROR]"
Begin DoDot:1
+2 KILL ^TMP($JOB,"YSCOR")
+3 SET ^TMP($JOB,"YSCOR",1)="[ERROR]"
+4 SET ^TMP($JOB,"YSCOR",2)=$GET(YSINSNAM)_" Scale not found"
End DoDot:1
QUIT
+5 ; Scale Name
SET YSSCNAM=$PIECE($GET(^TMP($JOB,"YSG",3)),U,4)
+6 ;
+7 KILL ^TMP($JOB,"YSCOR")
+8 SET ^TMP($JOB,"YSCOR",1)="[DATA]"
+9 SET ^TMP($JOB,"YSCOR",2)=$$GET1^DIQ(601.87,509_",",3,"I")_"="_STAGE
+10 QUIT
+11 ;
DLLSTR(YSDATA,YS,YSTRNG) ;
+1 ; YSTRNG = 1 Score Instrument
+2 ; YSTRNG = 2 get Report Answers and Text
+3 NEW DATA,DES,LEG,NODE,STAGE,YSQN
+4 NEW YSCDA,YSSCNAM,YSINSNAM
+5 ;
+6 ; FAST returns a scale score which is calculated and stored, no special text in report
+7 IF YSTRNG=2
QUIT
+8 ;
+9 SET STAGE=1
+10 DO DATA1
+11 DO SCORESV
+12 QUIT