BGPAP4 ; IHS/CMI/LAB -print ind 4 ;
;;7.0;IHS CLINICAL REPORTING;;JAN 24, 2007
;
;
I4A ;EP ;
;Q:'$D(BGPIND(9))
D HEADER^BGPAPH
W !,"Indicator 4A: Diabetes-Reduce Diabetic Complications-Assessed for Dyslipidemia"
W !,"Denominator is all patients with a DM diagnosis ever."
W !,"Continue the trend of increasing the proportion of I/T/U clients with"
W !,"diagnosed diabetes who have been assessed for dyslipidemia using LDL as",!,"the screening test.",!,"% with LDL done",!
I $Y>(IOSL-5) D HEADER^BGPAPH Q:BGPQUIT
D H
S BGPRPT=0 F S BGPRPT=$O(BGPSUL(BGPRPT)) Q:BGPRPT'=+BGPRPT!(BGPQUIT) D
.S BGPCYD=$P($$V(BGPRPT,10,10),"!",1)+$P($$V(BGPRPT,10,10),"!",2),BGPCYN=$$V(BGPRPT,14,6),BGPCYP=$S(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
.S BGP98D=$P($$V(BGPRPT,80,10),"!",1)+$P($$V(BGPRPT,80,10),"!",2),BGP98N=$$V(BGPRPT,84,6),BGP98P=$S(BGP98D:((BGP98N/BGP98D)*100),1:"")
.S BGPPRD=$P($$V(BGPRPT,40,10),"!",1)+$P($$V(BGPRPT,40,10),"!",2),BGPPRN=$$V(BGPRPT,44,6),BGPPRP=$S(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
.D LOCW Q:BGPQUIT
Q
I4B ;EP ;
;Q:'$D(BGPIND(10))
D HEADER^BGPAPH
W !,"Indicator 4B: Diabetes-Reduce Diabetic Complications-Assessed for Dyslipidemia"
W !,"Denominator is all patients with a DM diagnosis ever, with at least",!,"2 visits in the year prior to the end of the time period and the first",!,"ever recorded diagnosis of Diabetes > 1year prior to the end of the time period."
W !,"Continue the trend of increasing the proportion of I/T/U clients with"
W !,"diagnosed diabetes who have been assessed for dyslipidemia using LDL as",!,"the screening test.",!,"% with LDL done",!
I $Y>(IOSL-5) D HEADER^BGPAPH Q:BGPQUIT
D H
S BGPRPT=0 F S BGPRPT=$O(BGPSUL(BGPRPT)) Q:BGPRPT'=+BGPRPT!(BGPQUIT) D
.S BGPCYD=$$V(BGPRPT,12,5),BGPCYN=$$V(BGPRPT,14,14),BGPCYP=$S(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
.S BGP98D=$$V(BGPRPT,82,5),BGP98N=$$V(BGPRPT,84,14),BGP98P=$S(BGP98D:((BGP98N/BGP98D)*100),1:"")
.S BGPPRD=$$V(BGPRPT,42,5),BGPPRN=$$V(BGPRPT,44,14),BGPPRP=$S(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
.D LOCW Q:BGPQUIT
Q
I4C ;EP ;
;Q:'$D(BGPIND(11))
D HEADER^BGPAPH
W !,"Indicator 4C: Diabetes-Reduce Diabetic Complications-Assessed for Dyslipidemia"
W !,"Denominator is all patients with a DM diagnosis ever, who are 19 or older",!,"who had at least 2 diabetes related encounters ever, at least one",!,"encounter in a primary clinic with a primary provider for diabetes,"
W !,"and an absence of a creatinine value of 5.0 or greater."
W !,"Continue the trend of increasing the proportion of I/T/U clients with"
W !,"diagnosed diabetes who have been assessed for dyslipidemia using LDL as",!,"the screening test.",!,"% with LDL done",!
I $Y>(IOSL-5) D HEADER^BGPAPH Q:BGPQUIT
D H
S BGPRPT=0 F S BGPRPT=$O(BGPSUL(BGPRPT)) Q:BGPRPT'=+BGPRPT!(BGPQUIT) D
.S BGPCYD=$$V(BGPRPT,12,10),BGPCYN=$$V(BGPRPT,14,22),BGPCYP=$S(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
.S BGP98D=$$V(BGPRPT,82,10),BGP98N=$$V(BGPRPT,84,22),BGP98P=$S(BGP98D:((BGP98N/BGP98D)*100),1:"")
.S BGPPRD=$$V(BGPRPT,42,10),BGPPRN=$$V(BGPRPT,44,22),BGPPRP=$S(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
.D LOCW Q:BGPQUIT
Q
CALC(N,O) ;ENTRY POINT
NEW Z
I O=0!(N=0)!(O="")!(N="") Q "**"
NEW X,X2,X3
S X=N,X2=1,X3=0 D COMMA^%DTC S N=X
S X=O,X2=1,X3=0 D COMMA^%DTC S O=X
I +O=0 Q "**"
S Z=(((N-O)/O)*100),Z=$FN(Z,"+,",1)
Q Z
Q
H ;write header
W !?44,"% CHANGE",?62,"% CHANGE",!?44,"FROM BASE YR",?62,"FROM PREV YR"
Q
LOCW ;
I $Y>(IOSL-3) D HEADER^BGPDPH Q:BGPQUIT
W !?3,$P(^BGPD(BGPRPT,0),U,5)
S X=$P(^BGPD(BGPRPT,0),U,5)
I X="" W ?11,"?????" Q
S X=$O(^AUTTLOC("C",X,0))
I X="" W ?11,"?????" Q
W ?11,$E($P(^DIC(4,X,0),U),1,20)
S BGPX=$J($$CALC(BGPCYP,BGP98P),6),$E(BGPX,20)=$J($$CALC(BGPCYP,BGPPRP),6)
W ?46,BGPX
Q
WLOC ;
I $Y>(IOSL-3) D HEADER^BGPDPH Q:BGPQUIT
W !?3,$P(^BGPD(BGPRPT,0),U,5)
S X=$P(^BGPD(BGPRPT,0),U,5)
I X="" W ?11,"?????" Q
S X=$O(^AUTTLOC("C",X,0))
I X="" W ?11,"?????" Q
W ?11,$E($P(^DIC(4,X,0),U),1,20)
Q
V(R,N,P) ;
NEW Y
I $G(BGPAREAA),'$G(BGPSUMR) G VA
Q $P($G(^BGPD(R,N)),U,P)
VA ;
NEW X,C,V,MT,FT,M,F,B S X=0,C="" F S X=$O(BGPSUL(X)) Q:X'=+X D
.S V=$P($G(^BGPD(X,N)),U,P)
.I C="" S C=V Q
.S MT=$P(C,"!"),FT=$P(C,"!",2),M=$P(V,"!"),F=$P(V,"!",2)
.F B=1:1:6 S $P(MT,"~",B)=$P(MT,"~",B)+$P(M,"~",B)
.F B=1:1:6 S $P(FT,"~",B)=$P(FT,"~",B)+$P(F,"~",B)
.S C=MT_"!"_FT
.Q
Q C
C(X,X2,X3) ;
D COMMA^%DTC
Q X
BGPAP4 ; IHS/CMI/LAB -print ind 4 ;
+1 ;;7.0;IHS CLINICAL REPORTING;;JAN 24, 2007
+2 ;
+3 ;
I4A ;EP ;
+1 ;Q:'$D(BGPIND(9))
+2 DO HEADER^BGPAPH
+3 WRITE !,"Indicator 4A: Diabetes-Reduce Diabetic Complications-Assessed for Dyslipidemia"
+4 WRITE !,"Denominator is all patients with a DM diagnosis ever."
+5 WRITE !,"Continue the trend of increasing the proportion of I/T/U clients with"
+6 WRITE !,"diagnosed diabetes who have been assessed for dyslipidemia using LDL as",!,"the screening test.",!,"% with LDL done",!
+7 IF $Y>(IOSL-5)
DO HEADER^BGPAPH
IF BGPQUIT
QUIT
+8 DO H
+9 SET BGPRPT=0
FOR
SET BGPRPT=$ORDER(BGPSUL(BGPRPT))
IF BGPRPT'=+BGPRPT!(BGPQUIT)
QUIT
Begin DoDot:1
+10 SET BGPCYD=$PIECE($$V(BGPRPT,10,10),"!",1)+$PIECE($$V(BGPRPT,10,10),"!",2)
SET BGPCYN=$$V(BGPRPT,14,6)
SET BGPCYP=$SELECT(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
+11 SET BGP98D=$PIECE($$V(BGPRPT,80,10),"!",1)+$PIECE($$V(BGPRPT,80,10),"!",2)
SET BGP98N=$$V(BGPRPT,84,6)
SET BGP98P=$SELECT(BGP98D:((BGP98N/BGP98D)*100),1:"")
+12 SET BGPPRD=$PIECE($$V(BGPRPT,40,10),"!",1)+$PIECE($$V(BGPRPT,40,10),"!",2)
SET BGPPRN=$$V(BGPRPT,44,6)
SET BGPPRP=$SELECT(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
+13 DO LOCW
IF BGPQUIT
QUIT
End DoDot:1
+14 QUIT
I4B ;EP ;
+1 ;Q:'$D(BGPIND(10))
+2 DO HEADER^BGPAPH
+3 WRITE !,"Indicator 4B: Diabetes-Reduce Diabetic Complications-Assessed for Dyslipidemia"
+4 WRITE !,"Denominator is all patients with a DM diagnosis ever, with at least",!,"2 visits in the year prior to the end of the time period and the first",!,"ever recorded diagnosis of Diabetes > 1year prior to the end of the time period."
+5 WRITE !,"Continue the trend of increasing the proportion of I/T/U clients with"
+6 WRITE !,"diagnosed diabetes who have been assessed for dyslipidemia using LDL as",!,"the screening test.",!,"% with LDL done",!
+7 IF $Y>(IOSL-5)
DO HEADER^BGPAPH
IF BGPQUIT
QUIT
+8 DO H
+9 SET BGPRPT=0
FOR
SET BGPRPT=$ORDER(BGPSUL(BGPRPT))
IF BGPRPT'=+BGPRPT!(BGPQUIT)
QUIT
Begin DoDot:1
+10 SET BGPCYD=$$V(BGPRPT,12,5)
SET BGPCYN=$$V(BGPRPT,14,14)
SET BGPCYP=$SELECT(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
+11 SET BGP98D=$$V(BGPRPT,82,5)
SET BGP98N=$$V(BGPRPT,84,14)
SET BGP98P=$SELECT(BGP98D:((BGP98N/BGP98D)*100),1:"")
+12 SET BGPPRD=$$V(BGPRPT,42,5)
SET BGPPRN=$$V(BGPRPT,44,14)
SET BGPPRP=$SELECT(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
+13 DO LOCW
IF BGPQUIT
QUIT
End DoDot:1
+14 QUIT
I4C ;EP ;
+1 ;Q:'$D(BGPIND(11))
+2 DO HEADER^BGPAPH
+3 WRITE !,"Indicator 4C: Diabetes-Reduce Diabetic Complications-Assessed for Dyslipidemia"
+4 WRITE !,"Denominator is all patients with a DM diagnosis ever, who are 19 or older",!,"who had at least 2 diabetes related encounters ever, at least one",!,"encounter in a primary clinic with a primary provider for diabetes,"
+5 WRITE !,"and an absence of a creatinine value of 5.0 or greater."
+6 WRITE !,"Continue the trend of increasing the proportion of I/T/U clients with"
+7 WRITE !,"diagnosed diabetes who have been assessed for dyslipidemia using LDL as",!,"the screening test.",!,"% with LDL done",!
+8 IF $Y>(IOSL-5)
DO HEADER^BGPAPH
IF BGPQUIT
QUIT
+9 DO H
+10 SET BGPRPT=0
FOR
SET BGPRPT=$ORDER(BGPSUL(BGPRPT))
IF BGPRPT'=+BGPRPT!(BGPQUIT)
QUIT
Begin DoDot:1
+11 SET BGPCYD=$$V(BGPRPT,12,10)
SET BGPCYN=$$V(BGPRPT,14,22)
SET BGPCYP=$SELECT(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
+12 SET BGP98D=$$V(BGPRPT,82,10)
SET BGP98N=$$V(BGPRPT,84,22)
SET BGP98P=$SELECT(BGP98D:((BGP98N/BGP98D)*100),1:"")
+13 SET BGPPRD=$$V(BGPRPT,42,10)
SET BGPPRN=$$V(BGPRPT,44,22)
SET BGPPRP=$SELECT(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
+14 DO LOCW
IF BGPQUIT
QUIT
End DoDot:1
+15 QUIT
CALC(N,O) ;ENTRY POINT
+1 NEW Z
+2 IF O=0!(N=0)!(O="")!(N="")
QUIT "**"
+3 NEW X,X2,X3
+4 SET X=N
SET X2=1
SET X3=0
DO COMMA^%DTC
SET N=X
+5 SET X=O
SET X2=1
SET X3=0
DO COMMA^%DTC
SET O=X
+6 IF +O=0
QUIT "**"
+7 SET Z=(((N-O)/O)*100)
SET Z=$FNUMBER(Z,"+,",1)
+8 QUIT Z
+9 QUIT
H ;write header
+1 WRITE !?44,"% CHANGE",?62,"% CHANGE",!?44,"FROM BASE YR",?62,"FROM PREV YR"
+2 QUIT
LOCW ;
+1 IF $Y>(IOSL-3)
DO HEADER^BGPDPH
IF BGPQUIT
QUIT
+2 WRITE !?3,$PIECE(^BGPD(BGPRPT,0),U,5)
+3 SET X=$PIECE(^BGPD(BGPRPT,0),U,5)
+4 IF X=""
WRITE ?11,"?????"
QUIT
+5 SET X=$ORDER(^AUTTLOC("C",X,0))
+6 IF X=""
WRITE ?11,"?????"
QUIT
+7 WRITE ?11,$EXTRACT($PIECE(^DIC(4,X,0),U),1,20)
+8 SET BGPX=$JUSTIFY($$CALC(BGPCYP,BGP98P),6)
SET $EXTRACT(BGPX,20)=$JUSTIFY($$CALC(BGPCYP,BGPPRP),6)
+9 WRITE ?46,BGPX
+10 QUIT
WLOC ;
+1 IF $Y>(IOSL-3)
DO HEADER^BGPDPH
IF BGPQUIT
QUIT
+2 WRITE !?3,$PIECE(^BGPD(BGPRPT,0),U,5)
+3 SET X=$PIECE(^BGPD(BGPRPT,0),U,5)
+4 IF X=""
WRITE ?11,"?????"
QUIT
+5 SET X=$ORDER(^AUTTLOC("C",X,0))
+6 IF X=""
WRITE ?11,"?????"
QUIT
+7 WRITE ?11,$EXTRACT($PIECE(^DIC(4,X,0),U),1,20)
+8 QUIT
V(R,N,P) ;
+1 NEW Y
+2 IF $GET(BGPAREAA)
IF '$GET(BGPSUMR)
GOTO VA
+3 QUIT $PIECE($GET(^BGPD(R,N)),U,P)
VA ;
+1 NEW X,C,V,MT,FT,M,F,B
SET X=0
SET C=""
FOR
SET X=$ORDER(BGPSUL(X))
IF X'=+X
QUIT
Begin DoDot:1
+2 SET V=$PIECE($GET(^BGPD(X,N)),U,P)
+3 IF C=""
SET C=V
QUIT
+4 SET MT=$PIECE(C,"!")
SET FT=$PIECE(C,"!",2)
SET M=$PIECE(V,"!")
SET F=$PIECE(V,"!",2)
+5 FOR B=1:1:6
SET $PIECE(MT,"~",B)=$PIECE(MT,"~",B)+$PIECE(M,"~",B)
+6 FOR B=1:1:6
SET $PIECE(FT,"~",B)=$PIECE(FT,"~",B)+$PIECE(F,"~",B)
+7 SET C=MT_"!"_FT
+8 QUIT
End DoDot:1
+9 QUIT C
C(X,X2,X3) ;
+1 DO COMMA^%DTC
+2 QUIT X