BGPAP24 ; IHS/CMI/LAB - print ind 24 ;
;;7.0;IHS CLINICAL REPORTING;;JAN 24, 2007
;
;
I24 ;EP ;
;Q:'$D(BGPIND(24))
D HEADER^BGPAPH
W !,"Indicator 24: Adult Immunizations-Pneumovax and Flu Vaccine in Diabetics"
W !!,"Denominator is all patients in the active user population diagnoses with",!,"diabetes (Indicator 1) who are aged 65 or older at the beginning of the ",!,"time period."
W !,"Increase pneumoccal and influenza vaccination levels among adult diabetics",!,"65 years of age and older.",!,"% of patients with pneumoccal Vaccine",!
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,17,1)
.S BGPCYN=$$V(BGPRPT,17,2),BGPCYP=$S(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
.S BGP98D=$$V(BGPRPT,87,1)
.S BGP98N=$$V(BGPRPT,87,2),BGP98P=$S(BGP98D:((BGP98N/BGP98D)*100),1:"")
.S BGPPRD=$$V(BGPRPT,47,1)
.S BGPPRN=$$V(BGPRPT,47,2),BGPPRP=$S(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
.D LOCW Q:BGPQUIT
FLU ;
D HEADER^BGPAPH
W !,"Indicator 24: Adult Immunizations-Pneumovax and Flu Vaccine in Diabetics"
W !!,"Denominator is all patients in the active user population diagnoses with",!,"diabetes (Indicator 1) who are aged 65 or older at the beginning of the ",!,"time period."
W !,"Increase pneumoccal and influenza vaccination levels among adult diabetics",!,"65 years of age and older.",!,"% of patients with influenza vaccination",!
D H
S BGPRPT=0 F S BGPRPT=$O(BGPSUL(BGPRPT)) Q:BGPRPT'=+BGPRPT!(BGPQUIT) D
.S BGPCYD=$$V(BGPRPT,17,1)
.S BGPCYN=$$V(BGPRPT,17,3),BGPCYP=$S(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
.S BGP98D=$$V(BGPRPT,87,1)
.S BGP98N=$$V(BGPRPT,87,3),BGP98P=$S(BGP98D:((BGP98N/BGP98D)*100),1:"")
.S BGPPRD=$$V(BGPRPT,47,1)
.S BGPPRN=$$V(BGPRPT,47,3),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
BGPAP24 ; IHS/CMI/LAB - print ind 24 ;
+1 ;;7.0;IHS CLINICAL REPORTING;;JAN 24, 2007
+2 ;
+3 ;
I24 ;EP ;
+1 ;Q:'$D(BGPIND(24))
+2 DO HEADER^BGPAPH
+3 WRITE !,"Indicator 24: Adult Immunizations-Pneumovax and Flu Vaccine in Diabetics"
+4 WRITE !!,"Denominator is all patients in the active user population diagnoses with",!,"diabetes (Indicator 1) who are aged 65 or older at the beginning of the ",!,"time period."
+5 WRITE !,"Increase pneumoccal and influenza vaccination levels among adult diabetics",!,"65 years of age and older.",!,"% of patients with pneumoccal Vaccine",!
+6 IF $Y>(IOSL-5)
DO HEADER^BGPAPH
IF BGPQUIT
QUIT
+7 DO H
+8 SET BGPRPT=0
FOR
SET BGPRPT=$ORDER(BGPSUL(BGPRPT))
IF BGPRPT'=+BGPRPT!(BGPQUIT)
QUIT
Begin DoDot:1
+9 SET BGPCYD=$$V(BGPRPT,17,1)
+10 SET BGPCYN=$$V(BGPRPT,17,2)
SET BGPCYP=$SELECT(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
+11 SET BGP98D=$$V(BGPRPT,87,1)
+12 SET BGP98N=$$V(BGPRPT,87,2)
SET BGP98P=$SELECT(BGP98D:((BGP98N/BGP98D)*100),1:"")
+13 SET BGPPRD=$$V(BGPRPT,47,1)
+14 SET BGPPRN=$$V(BGPRPT,47,2)
SET BGPPRP=$SELECT(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
+15 DO LOCW
IF BGPQUIT
QUIT
End DoDot:1
FLU ;
+1 DO HEADER^BGPAPH
+2 WRITE !,"Indicator 24: Adult Immunizations-Pneumovax and Flu Vaccine in Diabetics"
+3 WRITE !!,"Denominator is all patients in the active user population diagnoses with",!,"diabetes (Indicator 1) who are aged 65 or older at the beginning of the ",!,"time period."
+4 WRITE !,"Increase pneumoccal and influenza vaccination levels among adult diabetics",!,"65 years of age and older.",!,"% of patients with influenza vaccination",!
+5 DO H
+6 SET BGPRPT=0
FOR
SET BGPRPT=$ORDER(BGPSUL(BGPRPT))
IF BGPRPT'=+BGPRPT!(BGPQUIT)
QUIT
Begin DoDot:1
+7 SET BGPCYD=$$V(BGPRPT,17,1)
+8 SET BGPCYN=$$V(BGPRPT,17,3)
SET BGPCYP=$SELECT(BGPCYD:((BGPCYN/BGPCYD)*100),1:"")
+9 SET BGP98D=$$V(BGPRPT,87,1)
+10 SET BGP98N=$$V(BGPRPT,87,3)
SET BGP98P=$SELECT(BGP98D:((BGP98N/BGP98D)*100),1:"")
+11 SET BGPPRD=$$V(BGPRPT,47,1)
+12 SET BGPPRN=$$V(BGPRPT,47,3)
SET BGPPRP=$SELECT(BGPPRD:((BGPPRN/BGPPRD)*100),1:"")
+13 DO LOCW
IF BGPQUIT
QUIT
End DoDot:1
+14 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