Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: BGP2UTL1

BGP2UTL1.m

Go to the documentation of this file.
  1. BGP2UTL1 ; IHS/CMI/LAB - NO DESCRIPTION PROVIDED 02 Jul 2010 2:07 PM ;
  1. ;;12.1;IHS CLINICAL REPORTING;;MAY 17, 2012;Build 66
  1. ;
  1. ;
  1. SETPRC(P,BDATE,EDATE,T,BGPG) ;EP
  1. K BGPG
  1. NEW BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5
  1. ;RETURN BGPDX4=1 or 0^dx code^date found^IEN OF ICD CODE^IEN OF V PROC
  1. S (BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5)=""
  1. I $G(BDATE)="" S BDATE=$P(^DPT(P,0),U,3) ;if no date then set to DOB
  1. I $G(EDATE)="" S EDATE=DT ;if no end date then set to today
  1. S BGPTX5=$O(^ATXAX("B",T,0)) ;get taxonomy ien
  1. I BGPTX5="" Q ;not a valid taxonomy
  1. S BGPDX4=0 ;return value
  1. F S BGPDX1=$O(^AUPNVPRC("AC",P,BGPDX1)) Q:BGPDX1="" D
  1. .S BGPDX3=$P($G(^AUPNVPRC(BGPDX1,0)),U)
  1. .Q:BGPDX3="" ;bad
  1. .Q:'$$ICD^ATXCHK(BGPDX3,BGPTX5,0)
  1. .S BGPDX4=BGPDX4+1,BGPG(BGPDX4)=$$VD^APCLV($P(^AUPNVPRC(BGPDX1,0),U,3))_"^"_$P($$ICDOP^ICDCODE(BGPDX3),U,2)_"^"_$P($$ICDOP^ICDCODE(BGPDX3),U,2)_"^"_BGPDX1_";AUPNVPRC"_"^"_$P(^AUPNVPRC(BGPDX1,0),U,3)
  1. .Q
  1. Q
  1. ;
  1. LASTDX(P,T,BDATE,EDATE) ;EP
  1. I '$G(P) Q ""
  1. ;RETURN BGPDX4=1 or 0^dx code^date found^IEN OF ICD CODE^IEN OF V POV
  1. NEW BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5
  1. S (BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5)=""
  1. I $G(BDATE)="" S BDATE=$P(^DPT(P,0),U,3) ;if no date then set to DOB
  1. I $G(EDATE)="" S EDATE=DT ;if no end date then set to today
  1. S BGPTX5=$O(^ATXAX("B",T,0)) ;get taxonomy ien
  1. I BGPTX5="" Q "" ;not a valid taxonomy
  1. S BGPDX4="" ;return value
  1. S BGPDXBD=9999999-BDATE,BGPDXED=9999999-EDATE ;get inverse date and begin at edate-1 and end when greater than begin date
  1. S BGPDX1=BGPDXED-1 F S BGPDX1=$O(^AUPNVPOV("AA",P,BGPDX1)) Q:BGPDX1=""!(BGPDX1>BGPDXBD)!(BGPDX4]"") D
  1. .S BGPDX2=0 F S BGPDX2=$O(^AUPNVPOV("AA",P,BGPDX1,BGPDX2)) Q:BGPDX2'=+BGPDX2!(BGPDX4]"") D
  1. ..S BGPDX3=$P($G(^AUPNVPOV(BGPDX2,0)),U)
  1. ..Q:BGPDX3="" ;bad xref
  1. ..Q:'$D(^ICD9(BGPDX3))
  1. ..Q:'$$ICD^ATXCHK(BGPDX3,BGPTX5,9)
  1. ..S BGPDX4=1_"^"_$P($$ICDDX^ICDCODE(BGPDX3),U,2)_"^"_(9999999-BGPDX1)_"^"_BGPDX3_"^"_BGPDX2
  1. ..Q
  1. .Q
  1. Q BGPDX4
  1. LASTDXI(P,T,BDATE,EDATE,SC) ;EP
  1. I '$G(P) Q ""
  1. S SC=$G(SC)
  1. ;RETURN BGPDX4=1 or 0^dx code^date found^IEN OF ICD CODE^IEN OF V POV
  1. NEW BGPDX1,BGPDX2,BGPDX3,BGPDX5,BGPTX5,BGPDX4,BGPDXV
  1. S (BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5)=""
  1. I $G(BDATE)="" S BDATE=$P(^DPT(P,0),U,3) ;if no date then set to DOB
  1. I $G(EDATE)="" S EDATE=DT ;if no end date then set to today
  1. ;S BGPTX5=$O(^ICD9("AB",T,0)) ;get taxonomy ien
  1. S BGPTX5=+$$CODEN^ICDCODE(T,80)
  1. I BGPTX5'>0 Q "" ;not a valid code
  1. S BGPDX4="" ;return value
  1. S BGPDXBD=9999999-BDATE,BGPDXED=9999999-EDATE ;get inverse date and begin at edate-1 and end when greater than begin date
  1. S BGPDX1=BGPDXED-1 F S BGPDX1=$O(^AUPNVPOV("AA",P,BGPDX1)) Q:BGPDX1=""!(BGPDX1>BGPDXBD)!(BGPDX4]"") D
  1. .S BGPDX2=0 F S BGPDX2=$O(^AUPNVPOV("AA",P,BGPDX1,BGPDX2)) Q:BGPDX2'=+BGPDX2!(BGPDX4]"") D
  1. ..S BGPDX3=$P($G(^AUPNVPOV(BGPDX2,0)),U)
  1. ..Q:BGPDX3="" ;bad xref
  1. ..Q:BGPDX3'=BGPTX5
  1. ..S BGPDXV=$P(^AUPNVPOV(BGPDX2,0),U,3)
  1. ..I '$D(^AUPNVSIT(BGPDXV,0)) Q ;no visit entry
  1. ..I SC]"",SC'[$P(^AUPNVSIT(BGPDXV,0),U,7)
  1. ..S BGPDX4=1_"^"_$P($$ICDDX^ICDCODE(BGPDX3),U,2)_"^"_(9999999-BGPDX1)_"^"_BGPDX3_"^"_BGPDX2
  1. ..Q
  1. .Q
  1. Q BGPDX4
  1. LASTPRC(P,T,BDATE,EDATE) ;EP
  1. I '$G(P) Q ""
  1. ;RETURN BGPDX4=1 or 0^dx code^date found^IEN OF ICD CODE^IEN OF V PROC
  1. S (BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5)=""
  1. I $G(BDATE)="" S BDATE=$P(^DPT(P,0),U,3) ;if no date then set to DOB
  1. I $G(EDATE)="" S EDATE=DT ;if no end date then set to today
  1. S BGPTX5=$O(^ATXAX("B",T,0)) ;get taxonomy ien
  1. I BGPTX5="" Q "" ;not a valid taxonomy
  1. S BGPDX4="" ;return value
  1. S BGPDXBD=9999999-BDATE,BGPDXED=9999999-EDATE ;get inverse date and begin at edate-1 and end when greater than begin date
  1. S BGPDX1=BGPDXED-1 F S BGPDX1=$O(^AUPNVPRC("AA",P,BGPDX1)) Q:BGPDX1=""!(BGPDX1>BGPDXBD)!(BGPDX4]"") D
  1. .S BGPDX2=0 F S BGPDX2=$O(^AUPNVPRC("AA",P,BGPDX1,BGPDX2)) Q:BGPDX2'=+BGPDX2!(BGPDX4]"") D
  1. ..S BGPDX3=$P($G(^AUPNVPRC(BGPDX2,0)),U)
  1. ..Q:BGPDX3="" ;bad xref
  1. ..Q:'$$ICD^ATXCHK(BGPDX3,BGPTX5,0)
  1. ..S BGPDX4=1_"^"_$P($$ICDOP^ICDCODE(BGPDX3),U,2)_"^"_(9999999-BGPDX1)_"^"_BGPDX3_"^"_BGPDX2
  1. ..Q
  1. .Q
  1. Q BGPDX4
  1. ;
  1. LASTPRCI(P,T,BDATE,EDATE) ;EP
  1. I '$G(P) Q ""
  1. ;RETURN BGPDX4=1 or 0^dx code^date found^IEN OF ICD CODE^IEN OF V PROC
  1. S (BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5)=""
  1. I $G(BDATE)="" S BDATE=$P(^DPT(P,0),U,3) ;if no date then set to DOB
  1. I $G(EDATE)="" S EDATE=DT ;if no end date then set to today
  1. ;S BGPTX5=$O(^ICD0("AB",T,0)) ;get ICD PROC ien
  1. S BGPTX5=+$$CODEN^ICDCODE(T,80.1)
  1. I BGPTX5'>0 Q "" ;not a valid PROC
  1. S BGPDX4="" ;return value
  1. S BGPDXBD=9999999-BDATE,BGPDXED=9999999-EDATE ;get inverse date and begin at edate-1 and end when greater than begin date
  1. S BGPDX1=BGPDXED-1 F S BGPDX1=$O(^AUPNVPRC("AA",P,BGPDX1)) Q:BGPDX1=""!(BGPDX1>BGPDXBD)!(BGPDX4]"") D
  1. .S BGPDX2=0 F S BGPDX2=$O(^AUPNVPRC("AA",P,BGPDX1,BGPDX2)) Q:BGPDX2'=+BGPDX2!(BGPDX4]"") D
  1. ..S BGPDX3=$P($G(^AUPNVPRC(BGPDX2,0)),U)
  1. ..Q:BGPDX3="" ;bad xref
  1. ..Q:BGPTX5'=BGPDX3
  1. ..S BGPDX4=1_"^"_$P($$ICDOP^ICDCODE(BGPDX3),U,2)_"^"_(9999999-BGPDX1)_"^"_BGPDX3_"^"_BGPDX2
  1. ..Q
  1. .Q
  1. Q BGPDX4
  1. FIRSTPRC(P,T,BDATE,EDATE) ;EP
  1. I '$G(P) Q ""
  1. ;RETURN BGPDX4=1 or 0^dx code^date found^IEN OF ICD CODE^IEN OF V PROC
  1. S (BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5)=""
  1. I $G(BDATE)="" S BDATE=$P(^DPT(P,0),U,3) ;if no date then set to DOB
  1. I $G(EDATE)="" S EDATE=DT ;if no end date then set to today
  1. S BGPTX5=$O(^ATXAX("B",T,0)) ;get taxonomy ien
  1. I BGPTX5="" Q "" ;not a valid taxonomy
  1. S BGPDX4="" ;return value
  1. S BGPX=0 F S BGPX=$O(^AUPNVPRC("AC",P,BGPX)) Q:BGPX'=+BGPX!(BGPDX4]"") D
  1. .S BGPDX3=$P($G(^AUPNVPRC(BGPX,0)),U)
  1. .Q:BGPDX3="" ;BAD XREF
  1. .Q:'$$ICD^ATXCHK(BGPDX3,BGPTX5,0)
  1. .S D=$P(^AUPNVPRC(BGPX,0),U,3)
  1. .Q:'D
  1. .S D=$P($P($G(^AUPNVSIT(D,0)),U),".")
  1. .Q:D<BDATE
  1. .Q:D>EDATE
  1. .S BGPDX4=1_"^"_$P($$ICDOP^ICDCODE(BGPDX3),U,2)_"^"_D_"^"_BGPDX3_"^"_BGPX
  1. .Q
  1. Q BGPDX4
  1. NMIREF(P,F,I,B,E) ;EP
  1. I '$G(P) Q ""
  1. I '$G(F) Q ""
  1. I '$G(I) Q ""
  1. I $G(B)="" Q ""
  1. I $G(E)="" Q ""
  1. NEW G,X,Y,%DT S X=B,%DT="P" D ^%DT S B=Y
  1. S X=E,%DT="P" D ^%DT S E=Y
  1. S (X,G)=0 F S X=$O(^AUPNPREF("AA",P,F,I,X)) Q:X'=+X!(G) D
  1. .S Y=0 F S Y=$O(^AUPNPREF("AA",P,F,I,X,Y)) Q:Y'=+Y D
  1. ..Q:$P(^AUPNPREF(Y,0),U,7)'="N"
  1. ..S D=$P(^AUPNPREF(Y,0),U,3) I D'<B&(D'>E) S G="1^"_D_"^"_$P(^AUPNPREF(Y,0),U,7)
  1. Q G
  1. REFUSAL(P,F,I,B,E) ;EP
  1. I '$G(P) Q ""
  1. I '$G(F) Q ""
  1. I '$G(I) Q ""
  1. I $G(B)="" Q ""
  1. I $G(E)="" Q ""
  1. NEW G,X,Y,%DT S X=B,%DT="P" D ^%DT S B=Y
  1. S X=E,%DT="P" D ^%DT S E=Y
  1. S (X,G)=0 F S X=$O(^AUPNPREF("AA",P,F,I,X)) Q:X'=+X!(G) S Y=0 F S Y=$O(^AUPNPREF("AA",P,F,I,X,Y)) Q:Y'=+Y S D=$P(^AUPNPREF(Y,0),U,3) I D'<B&(D'>E) S G="1^"_D_"^"_$P(^AUPNPREF(Y,0),U,7)
  1. Q G
  1. RADREF(P,BDATE,EDATE,T) ;EP - return ien of CPT entry if patient had this CPT
  1. I '$G(P) Q ""
  1. I '$G(T) Q ""
  1. I $G(EDATE)="" Q ""
  1. I $G(BDATE)="" S BDATE=$$FMADD^XLFDT(EDATE,-365)
  1. NEW G,X,Y,Z,I
  1. S G=""
  1. S I=0 F S I=$O(^AUPNPREF("AA",P,71,I)) Q:I=""!($P(G,U)) D
  1. .S (X,G)=0 F S X=$O(^AUPNPREF("AA",P,71,I,X)) Q:X'=+X!($P(G,U)) S Y=0 F S Y=$O(^AUPNPREF("AA",P,71,I,X,Y)) Q:Y'=+Y S D=$P(^AUPNPREF(Y,0),U,3) I D'<BDATE&(D'>EDATE) D
  1. ..S C=$P($G(^RAMIS(71,I,0)),U,9) Q:C=""
  1. ..Q:'$$ICD^ATXCHK(C,T,1)
  1. ..S G="1^"_D_"^"_$P(^AUPNPREF(Y,0),U,7)_U_$P(^ICPT(C,0),U)_U_$P(^RAMIS(71,I,0),U,1)
  1. .Q
  1. Q G
  1. I1() ;EP
  1. I BGPVALUE="" Q 0
  1. I BGPINDW="E",BGPVALUE]"",BGPAGEB>64 Q 1
  1. I BGPINDW="E",BGPVALUE]"",BGPAGEB<65 Q 0
  1. I BGPVALUE]"" Q 1
  1. Q 0
  1. I12() ;EP
  1. I BGPINDW="D" Q 1
  1. I BGPINDW="D",'BGPD4 Q 0
  1. I BGPINDW="E",(BGPD3+BGPD7) Q 1
  1. I BGPINDW="E",'(BGPD3+BGPD7) Q 0
  1. I BGPACTUP Q 1
  1. Q 0
  1. I13() ;EP
  1. I BGPINDW="D",BGPD2 Q 1
  1. I BGPINDW="D",'BGPD2 Q 0
  1. I BGPINDW="E",(BGPD3+BGPD1) Q 1
  1. I BGPINDW="E",'(BGPD3+BGPD1) Q 0
  1. I (BGPD1+BGPD2+BGPD3+BGPD4+BGPD5+BGPD6+BGPD7) Q 1
  1. Q 0
  1. IA() ;EP
  1. ;TESTING ONLY
  1. NEW X
  1. S X=BGPN1
  1. I BGPINDW="D",BGPD7,'X Q 1
  1. I BGPINDW="D",BGPD7,X Q 1 ;XXXX CHANGE TO Q 0 AFTER TESTING
  1. I BGPINDW="D",'BGPD7 Q 0
  1. I BGPINDW="C",BGPD8,'X Q 1
  1. I BGPINDW="C",BGPD8,X Q 1 ;XXXX CHANGE TO Q 0
  1. I BGPINDW="C",'BGPD8 Q 0
  1. I BGPINDW="S" I (BGPD1+BGPD2+BGPD3+BGPD4+BGPD5+BGPD6+BGPD7+BGPD8) Q $S(X:1,1:1) ;LORI **** CHANGE x:1 TO x:0 AFTER TESTING
  1. Q 0
  1. I17() ;EP
  1. I 'BGPD1 Q 0
  1. I BGPINDW="W" Q $S(BGPSEX="F":1,1:0)
  1. Q 1
  1. I25() ;EP
  1. I BGPINDW="D" Q BGPDMD2
  1. I 'BGPD1 Q 0
  1. I BGPINDW="W" Q $S(BGPSEX="F":1,1:0)
  1. Q 1
  1. LASTECOD(P,T,BDATE,EDATE) ;EP
  1. I '$G(P) Q ""
  1. ;RETURN BGPDX4=1 or 0^dx code^date found^IEN OF ICD CODE^IEN OF V POV
  1. S (BGPDX1,BGPDX2,BGPDX3,BGPDX4,BGPTX5,BGPDX6,BGPDX7)=""
  1. I $G(BDATE)="" S BDATE=$P(^DPT(P,0),U,3) ;if no date then set to DOB
  1. I $G(EDATE)="" S EDATE=DT ;if no end date then set to today
  1. S BGPTX5=$O(^ATXAX("B",T,0)) ;get taxonomy ien
  1. I BGPTX5="" Q "" ;not a valid taxonomy
  1. S BGPDX4="" ;return value
  1. S BGPDXBD=9999999-BDATE,BGPDXED=9999999-EDATE ;get inverse date and begin at edate-1 and end when greater than begin date
  1. S BGPDX1=BGPDXED-1 F S BGPDX1=$O(^AUPNVPOV("AA",P,BGPDX1)) Q:BGPDX1=""!(BGPDX1>BGPDXBD)!(BGPDX4]"") D
  1. .S BGPDX2=0 F S BGPDX2=$O(^AUPNVPOV("AA",P,BGPDX1,BGPDX2)) Q:BGPDX2'=+BGPDX2!(BGPDX4]"") D
  1. ..F BGPDX6=9,18,19 S BGPDX3=$P($G(^AUPNVPOV(BGPDX2,0)),U,BGPDX6) D
  1. ...Q:BGPDX3="" ;no ecode
  1. ...I $$ICD^ATXCHK(BGPDX3,BGPTX5,9) S BGPDX4=1_"^"_$P($$ICDDX^ICDCODE(BGPDX3),U,2)_"^"_(9999999-BGPDX1)_"^"_BGPDX3_"^"_BGPDX2
  1. ..Q
  1. .Q
  1. Q BGPDX4
  1. REFTAX(P,F,T,B,E) ;EP - refused an item in a taxonomy
  1. I '$G(P) Q ""
  1. I '$G(F) Q ""
  1. I '$G(T) Q ""
  1. I $G(B)="" Q ""
  1. I $G(E)="" Q ""
  1. NEW G,X,Y,%DT,T1 S X=B,%DT="P" D ^%DT S B=Y
  1. S X=E,%DT="P" D ^%DT S E=Y
  1. S T1=0,G="" F S T1=$O(^ATXAX(T,21,"B",T1)) Q:T1=""!(G) D
  1. .S (X,G)=0 F S X=$O(^AUPNPREF("AA",P,F,T1,X)) Q:X'=+X!(G) S Y=0 F S Y=$O(^AUPNPREF("AA",P,F,T1,X,Y)) Q:Y'=+Y S D=$P(^AUPNPREF(Y,0),U,3) I D'<B&(D'>E) S G="1^"_D_"^"_$P(^AUPNPREF(Y,0),U,7)
  1. Q G
  1. CPTREFT(P,BDATE,EDATE,T) ;EP - return ien of CPT entry if patient had this CPT
  1. I '$G(P) Q ""
  1. I '$G(T) Q ""
  1. I $G(EDATE)="" Q ""
  1. I $G(BDATE)="" S BDATE=$$FMADD^XLFDT(EDATE,-365)
  1. NEW G,X,Y,Z,I
  1. S G=""
  1. S I=0 F S I=$O(^AUPNPREF("AA",P,81,I)) Q:I=""!($P(G,U)) D
  1. .S (X,G)=0 F S X=$O(^AUPNPREF("AA",P,81,I,X)) Q:X'=+X!($P(G,U)) S Y=0 F S Y=$O(^AUPNPREF("AA",P,81,I,X,Y)) Q:Y'=+Y S D=$P(^AUPNPREF(Y,0),U,3) I D'<BDATE&(D'>EDATE) D
  1. ..Q:'$$ICD^ATXCHK(I,T,1)
  1. ..S G="1^"_D_"^"_$P(^AUPNPREF(Y,0),U,7)_"^"_$P(^ICPT(I,0),U)
  1. .Q
  1. Q G
  1. PRCREFT(P,BDATE,EDATE,T) ;EP - return ien of proc
  1. I '$G(P) Q ""
  1. I '$G(T) Q ""
  1. I $G(EDATE)="" Q ""
  1. I $G(BDATE)="" S BDATE=$$FMADD^XLFDT(EDATE,-365)
  1. NEW G,X,Y,Z,I
  1. S G=""
  1. S I=0 F S I=$O(^AUPNPREF("AA",P,80.1,I)) Q:I=""!($P(G,U)) D
  1. .S (X,G)=0 F S X=$O(^AUPNPREF("AA",P,80.1,I,X)) Q:X'=+X!($P(G,U)) S Y=0 F S Y=$O(^AUPNPREF("AA",P,80.1,I,X,Y)) Q:Y'=+Y S D=$P(^AUPNPREF(Y,0),U,3) I D'<BDATE&(D'>EDATE) D
  1. ..Q:'$$ICD^ATXCHK(I,T,0)
  1. ..S G="1^"_D_"^"_$P(^AUPNPREF(Y,0),U,7)_"^"_$P($$ICDOP^ICDCODE(I),U,2)
  1. .Q
  1. Q G
  1. STI16A() ;EP
  1. I 'BGPACTCL Q 0
  1. I BGPD4,(BGPD4'=BGPN9) Q 1
  1. I BGPN18 Q 1
  1. Q 0
  1. STI16B() ;EP
  1. I 'BGPACTUP Q 0
  1. I BGPD4,(BGPD4'=BGPN9) Q 1
  1. I BGPN18 Q 1
  1. Q 0