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

ABMM2PV5.m

Go to the documentation of this file.
  1. ABMM2PV5 ;IHS/SD/SDR - MU Patient Volume EP Report ;
  1. ;;2.6;IHS 3P BILLING SYSTEM;**11,12,15**;NOV 12, 2009;Build 251
  1. ;IHS/SD/SDR - 2.6*12 - Updated FQHC/RHC/Tribal to include Urban
  1. ;IHS/SD/SDR - 2.6*12 - Made changes for uncompensated care; uncompensated should be a separate detail line
  1. ; and should be included in the patient volume total, not as a separate line. Also initialized ABMFQHC variable.
  1. ;IHS/SD/SDR - 2.6*15 - HEAT183289 - Tribal self-insured added to not-met report
  1. ;
  1. NOTMET ;EP
  1. S ABMCNT=0
  1. K ABMLN
  1. S ABMSDT=$P($G(^XTMP("ABM-PVP2",$J,"PRV TOP",ABMPRV)),U,2)
  1. ;
  1. I +$G(ABMY("TVDTS"))'=0 D
  1. .S ABMCNT=0
  1. .S ABMDT=0
  1. .F S ABMDT=$O(^XTMP("ABM-PVP2",$J,"PRV PERCENT",ABMDT)) Q:'ABMDT D
  1. ..S ABMP("PRV")=0
  1. ..F S ABMP("PRV")=$O(^XTMP("ABM-PVP2",$J,"PRV PERCENT",ABMDT,ABMP("PRV"))) Q:'ABMP("PRV") D
  1. ...I ABMP("PRV")'=ABMPRV Q
  1. ...S ABMCNT=ABMCNT+1
  1. ...;S ABMPRC($G(^XTMP("ABM-PVP2",$J,"PRV PERCENT",ABMDT,ABMPRV)),ABMCNT)=ABMDT ;abm*2.6*12 HEAT136326
  1. ...S ABMPRC(+$G(^XTMP("ABM-PVP2",$J,"PRV PERCENT",ABMDT,ABMPRV)),ABMCNT)=ABMDT ;abm*2.6*12 HEAT136326
  1. .S ABMP=""
  1. .S ABMSAV=ABMCNT-ABMY("TVDTS")
  1. .F S ABMP=$O(ABMPRC(ABMP)) Q:ABMP="" D
  1. ..S ABMCNT=0,ABMC=0
  1. ..F S ABMCNT=$O(ABMPRC(ABMP,ABMCNT)) Q:'ABMCNT D Q:(ABMC=ABMSAV)
  1. ...K ^XTMP("ABM-PVP2",$J,"PRV PERCENT",$G(ABMPRC(ABMP,ABMCNT))),ABMP("PRV")
  1. ...S ABMC=ABMC+1
  1. ;
  1. S ABM("PG")=1
  1. S ABMSDT=$P($G(^XTMP("ABM-PVP2",$J,"PRV TOP",ABMPRV)),U,2)
  1. I +ABMSDT=0 S ABMSDT=ABMY("SDT")
  1. D HDR
  1. W !,"The Patient Volume Threshold (30% for EPs, or 20% for Pediatricians) was not"
  1. W !,"met for the "_$S(("^A^B^C^"[("^"_ABMY("90")_"^")):"timeframe entered",1:"MU Qualification year")_"."
  1. W !,"Details for the volumes that were achieved are provided for your information.",!
  1. W !,"Highest Patient Volume Met: ",+$P($G(^XTMP("ABM-PVP2",$J,"PRV TOP",ABMPRV)),U)_"%"
  1. W !,"First Day Highest Patient Volume Achieved: ",$$SDT^ABMDUTL(ABMSDT)
  1. ;
  1. I $Y+5>IOSL D HD^ABMM2PV3 Q:(IOST["C")&((+$G(Y)=0)!($D(DIRUT)!$D(DIROUT)!$D(DTOUT)!$D(DUOUT)))
  1. S ABMTHPV=0
  1. S:ABMSDT ABMTHPV=+$G(^XTMP("ABM-PVP2",$J,"PRV-DENOM",ABMSDT,ABMPRV))
  1. S ABMMHPV=0
  1. S:ABMSDT ABMMHPV=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM",ABMSDT,ABMPRV))
  1. W !!,"Total Patient Encounters of First Highest Patient Volume Period: ",ABMTHPV,!
  1. S ABMU("TXT")="Total Medicaid"_$S(+$G(ABMFQHC)=1:"/Needy Individual",1:"")
  1. S ABMU("TXT")=ABMU("TXT")_" Encounters of First Highest Patient Volume Period: "_ABMMHPV
  1. S ABMU("LM")=0,ABMU("RM")=80,ABMU("LNG")=80
  1. D ^ABMDWRAP
  1. D NMHDR
  1. ;
  1. S ABMSDT=0,ABMCNT=0
  1. S ABMDTCNT=0
  1. F S ABMSDT=$O(^XTMP("ABM-PVP2",$J,"PRV-DENOM",ABMSDT)) Q:'ABMSDT D
  1. .;I ABMY("90")'="A"&(ABMY("SDT")'=ABMSDT) Q ;only calculate whole year for automated ;abm*2.6*12 uncomp care
  1. .I "^A^D^"'[("^"_ABMY("90")_"^")&(ABMY("SDT")'=ABMSDT) Q ;only whole year for automated ;abm*2.6*12 uncomp care
  1. .;start new code abm*2.6*12 HEAT134048
  1. .S X1=ABMY("SDT")
  1. .S X2=275
  1. .D C^%DTC
  1. .I "^A^D^"[("^"_ABMY("90")_"^")&(ABMSDT>X) Q ;275 days after start won't contain 90 days anymore
  1. .;end new code HEAT134048
  1. .S ABMDTCNT=+$G(ABMDTCNT)+1
  1. .;
  1. .I $Y+5>IOSL D HD^ABMM2PV3,NMHDR Q:(IOST["C")&((+$G(Y)=0)!($D(DIRUT)!$D(DIROUT)!$D(DTOUT)!$D(DUOUT)))
  1. .S ABMP("PRV")=0
  1. .F S ABMP("PRV")=$O(^XTMP("ABM-PVP2",$J,"PRV-DENOM",ABMSDT,ABMP("PRV"))) Q:'ABMP("PRV") D
  1. ..I $Y+5>IOSL D HD^ABMM2PV3,NMHDR Q:(IOST["C")&((+$G(Y)=0)!($D(DIRUT)!$D(DIROUT)!$D(DTOUT)!$D(DUOUT)))
  1. ..I ABMP("PRV")'=ABMPRV Q
  1. ..;I +$G(ABMY("EDT"))=0 D
  1. ..;.S X1=ABMSDT
  1. ..;.S X2=89
  1. ..;.D C^%DTC
  1. ..;.S ABMEDT=X
  1. ..;I +$G(ABMY("EDT"))'=0 S ABMEDT=ABMY("EDT")
  1. ..S X1=ABMSDT
  1. ..S X2=89
  1. ..D C^%DTC
  1. ..S ABMEDT=X
  1. ..S ABMPD=$TR($P($$MDT^ABMDUTL(ABMSDT),"-",1,2),"-"," ")_"-"_$TR($P($$MDT^ABMDUTL(ABMEDT),"-",1,2),"-"," ") ;report period
  1. ..S ABMRT=$J($G(^XTMP("ABM-PVP2",$J,"PRV PERCENT",ABMSDT,ABMPRV)),5)_"%" ;rate
  1. ..S ABMDEN=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-DENOM",ABMSDT,ABMPRV)),6) ;denominator
  1. ..S ABMNUM=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM",ABMSDT,ABMPRV)),6) ;numerator
  1. ..S ABMMCDPD=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM PD",ABMSDT,ABMPRV,"MCD")),6)
  1. ..S ABMSCHPD=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM PD",ABMSDT,ABMPRV,"CHIP")),5)
  1. ..S ABMMCDZP=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ZEROPD",ABMSDT,ABMPRV,"MCD")),6)
  1. ..S ABMMCDEN=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ENR",ABMSDT,ABMPRV,"MCD")),6)
  1. ..S ABMSCHZP=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ZEROPD",ABMSDT,ABMPRV,"CHIP")),5)
  1. ..S ABMSCHEN=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ENR",ABMSDT,ABMPRV,"CHIP")),5)
  1. ..;S ABMUNCOM=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM UNCOMP",ABMSDT,ABMPRV,"UNCOMP")),6) ;abm*2.6*12 ;abm*2.6*15 HEAT183289
  1. ..S ABMUNCOM=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM UNCOMP",ABMSDT,ABMPRV,"UNCOMP")),4) ;abm*2.6*15 HEAT183289 shortened to make room for tribal self-insured
  1. ..S ABMTSI=$J(+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM TRIBSI",ABMSDT,ABMPRV,"TRIBSI")),2) ;abm*2.6*15 HEAT183289 tribal self-insured not met
  1. ..;W !,ABMPD,?15,ABMRT,?20,ABMDEN,?28,ABMNUM,?35,ABMMCDPD,?41,ABMMCDZP,?50,ABMMCDEN,?57,ABMSCHPD,?63,ABMSCHZP,?73,ABMSCHEN ;abm*2.6*12
  1. ..W !,ABMPD,?13,ABMRT,?20,ABMDEN,?27,ABMNUM,?34,ABMMCDPD,?41,ABMMCDZP,?48,ABMMCDEN,?55,ABMSCHPD,?62,ABMSCHZP,?67,ABMSCHEN ;abm*2.6*12
  1. ..;I ABMFQHC=1 W ?74,ABMUNCOM ;abm*2.6*12 ;abm*2.6*15 HEAT183289
  1. ..I ABMFQHC=1 W ?74,ABMUNCOM,?78,ABMTSI ;abm*2.6*15 HEAT183289
  1. I ABMDTCNT=0 D
  1. .W !!, "<< NO DATA FOUND FOR SELECTION >>"
  1. Q
  1. NMHDR ;EP
  1. W !
  1. F ABM=1:1:80 W "="
  1. W !,"MEDICAID"_$S($G(ABMFQHC)=1:"/NEEDY INDIVIDUAL",1:"")_" PATIENT VOLUME"_$S($G(ABMY("ADT"))="":" - QUALIFICATION YEAR "_ABMY("QYR"),1:"")
  1. ;start old code abm*2.6*12 uncomp care
  1. ;W !,"Report Period",?15,"Rate",?21,"Denom-",?30,"Numer-",?38,"Mcd",?44,"Mcd",?52,"Mcd",?58,"Schip",?64,"Schip",?73,"Schip"
  1. ;W !?21,"inator",?30,"ator",?37,"Paid",?42,"ZeroPd",?49,"Enrolled",?59,"Paid",?64,"ZeroPd",?71,"Enrolled"
  1. ;end old start new uncomp care
  1. W !?20,"Denom-",?28,"Numer-",?34,"| --Medicaid-- | --- Schip --- |"
  1. ;I ABMFQHC=1 W ?73,"Uncomp-" ;abm*2.6*15 HEAT183289 tribal self-insured
  1. I ABMFQHC=1 W ?73,"Un- |T" ;abm*2.6*15 HEAT183289 tribal self-insured
  1. W !,"Report Period",?15,"Rate",?20,"inator",?28,"ator",?34,"|",?38,"Pd",?44,"ZP",?51,"En",?55,"|",?57,"Pd",?63,"ZP",?69,"En|"
  1. ;I ABMFQHC=1 W ?73,"ensated" ;abm*2.6*15 HEAT183289 tribal self-insured
  1. I ABMFQHC=1 W ?73,"Comp|SI" ;abm*2.6*15 HEAT183289 tribal self-insured
  1. ;end new uncomp care
  1. W !
  1. F ABM=1:1:80 W "="
  1. Q
  1. HDR ;EP
  1. S:ABMSDT="" ABMSDT=ABMY("SDT")
  1. I ABMY(90)="A"!(ABMY(90)="B") D
  1. .S X1=ABMSDT
  1. .S X2=89
  1. .D C^%DTC
  1. .S ABMEDT=X
  1. I ABMY(90)="C" S ABMEDT=ABMY("EDT")
  1. D EN^ABMVDF("IOF")
  1. W !
  1. I ABMY("RFMT")="P" D CENTER^ABMUCUTL("CONFIDENTIAL PATIENT INFORMATIONCOVERED BY THE PRIVACY ACT") W !
  1. I ABMY("RTYP")="SEL" D CENTER^ABMUCUTL("IHS Meaningful Use Patient Volume Report - Eligible Professional Page "_ABM("PG"))
  1. I ABMY("RTYP")="GRP" D CENTER^ABMUCUTL("IHS Meaningful Use Patient Volume Report - Group Practice Page "_ABM("PG"))
  1. I ABMY("RTYP")="HOS" D CENTER^ABMUCUTL(" IHS Meaningful Use Patient Volume Report - Hospital Page "_ABM("PG"))
  1. I ABMY("RFMT")'="P",+$G(ABMPMET)=0 W ! D CENTER^ABMUCUTL("Minimum Patient Volume NOT Achieved")
  1. I ABMY("RFMT")="P" W ! D CENTER^ABMUCUTL("PATIENT LIST")
  1. W !
  1. D NOW^%DTC
  1. D CENTER^ABMUCUTL("Report Run Date: "_$$CDT^ABMDUTL(%))
  1. W !
  1. D CENTER^ABMUCUTL("Report Generated by: "_$$GET1^DIQ(200,DUZ,.01,"E"))
  1. I ABM("PG")=1 D
  1. .S ABMFQHC=0 ;abm*2.6*12
  1. .I ABMY("RTYP")'="HOS" D
  1. ..W !!,"Participation Year: ",ABMY("PYR")
  1. ..W:("^A^B^C^"[("^"_ABMY("90")_"^")) !,"Qualification Year: ",ABMY("QYR")
  1. ..W:$G(ABMY("ADT")) !,"Attestation Date: ",$$SDT^ABMDUTL(ABMY("ADT"))
  1. .I ABMY("RTYP")="HOS" D
  1. ..W !!,"Participation Federal fiscal year: ",ABMY("PYR")
  1. ..W:("^A^B^C^"[("^"_ABMY("90")_"^")) !,"Qualification Year: ",ABMY("QYR")
  1. ..W:$G(ABMY("AYR")) !,"Attestation Federal fiscal year: ",ABMY("AYR")
  1. .I ("^F^H^"[("^"_$G(ABMY("A90"))_"^")) D
  1. ..W !,$S($G(ABMY("A90"))="F":"First",1:"Highest")_" Reporting Period Identified: "
  1. ..W $S(ABMSDT:$$SDT^ABMDUTL(ABMSDT),1:"")
  1. ..;start new abm*2.6*12
  1. ..S X1=$P(ABMSDT,".")
  1. ..S X2=+89
  1. ..D C^%DTC
  1. ..W " thru "_$$SDT^ABMDUTL(X)
  1. ..;end new abm*2.6*12
  1. .I ("^D^E^"[("^"_ABMY("90")_"^")) W !,$S($G(ABMY("90"))="D":"Automated",1:"Specified")_" 90-Day Period in last 12 months "
  1. .;I ("^A^D^E^"'[("^"_ABMY("90")_"^")) W !,"Reporting Period Identified: ",$S(ABMSDT:$$SDT^ABMDUTL(ABMSDT)_" thru "_$$SDT^ABMDUTL(ABMEDT),ABMY("SDT"):$$SDT^ABMDUTL(ABMY("SDT"))_" thru "_$$SDT^ABMDUTL(ABMEDT),1:"NONE FOUND") ;abm*2.6*12 HEAT134048
  1. .;below line new abm*2.6*12 HEAT134048
  1. .I ("^F^H^"'[("^"_$G(ABMY("A90"))_"^")) W !,"Reporting Period Identified: ",$S(ABMSDT:$$SDT^ABMDUTL(ABMSDT)_" thru "_$$SDT^ABMDUTL(ABMEDT),ABMY("SDT"):$$SDT^ABMDUTL(ABMY("SDT"))_" thru "_$$SDT^ABMDUTL(ABMEDT),1:"NONE FOUND")
  1. .I ABMY("RTYP")'="HOS" D
  1. ..W !,"Facility(s): ",!
  1. ..S ABML=0
  1. ..;F S ABML=$O(ABMF(ABML)) Q:'ABML W ?10,$$GET1^DIQ(9999999.06,ABML,.01,"E"),$S($D(^ABMMUPRM(1,1,"B",ABML)):" (FQHC/RHC/Tribal)",1:""),! I $D(^ABMMUPRM(1,1,"B",ABML)) S ABMFQHC=1 ;abm*2.6*12 include Urban
  1. ..F S ABML=$O(ABMF(ABML)) Q:'ABML W ?10,$$GET1^DIQ(9999999.06,ABML,.01,"E"),$S($D(^ABMMUPRM(1,1,"B",ABML)):" (FQHC/RHC/Tribal/Urban)",1:""),! I $D(^ABMMUPRM(1,1,"B",ABML)) S ABMFQHC=1 ;abm*2.6*12 include Urban
  1. .;
  1. .;start old code abm*2.6*12 uncomp care
  1. .;I $G(ABMFQHC)=1 D
  1. .;.S ABMMPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM PD",ABMSDT,ABMPRV,"MCD"))
  1. .;.S ABMMZPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ZEROPD",ABMSDT,ABMPRV,"MCD"))
  1. .;.S ABMMENR=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ENR",ABMSDT,ABMPRV,"MCD"))
  1. .;.S ABMCPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM PD",ABMSDT,ABMPRV,"CHIP"))
  1. .;.S ABMCZPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ZEROPD",ABMSDT,ABMPRV,"CHIP"))
  1. .;.S ABMCENR=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ENR",ABMSDT,ABMPRV,"CHIP"))
  1. .;.S ABMOTHPD=+$G(^XTMP("ABM-PVP2",$J,"PRV ENC CNT",ABMSDT,ABMPRV,"OTHR"))
  1. .;.S (ABMTENC,ABMDENOM)=+$G(^XTMP("ABM-PVP2",$J,"PRV-DENOM",ABMSDT,ABMPRV))
  1. .;.I ABMY("RTYP")="GRP" D
  1. .;..S ABMMPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM PD",ABMSDT,"MCD"))
  1. .;..S ABMMZPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ZEROPD",ABMSDT,"MCD"))
  1. .;..S ABMMENR=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ENR",ABMSDT,"MCD"))
  1. .;..S ABMCPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM PD",ABMSDT,"CHIP"))
  1. .;..S ABMCZPD=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ZEROPD",ABMSDT,"CHIP"))
  1. .;..S ABMCENR=+$G(^XTMP("ABM-PVP2",$J,"PRV-NUM ENR",ABMSDT,"CHIP"))
  1. .;..S ABMOTHPD=+$G(^XTMP("ABM-PVP2",$J,"PRV ENC CNT",ABMSDT,"OTHR"))
  1. .;..S (ABMTENC,ABMDENOM)=+$G(^XTMP("ABM-PVP2",$J,"PRV-DENOM",ABMSDT))
  1. .;.S ABMUNCOM=ABMTENC-ABMMPD-ABMMZPD-ABMMENR-ABMCPD-ABMCZPD-ABMCENR-ABMOTHPD
  1. .;.S ABMNUMER=ABMMPD+ABMMZPD+ABMMENR+ABMCPD+ABMCZPD+ABMCENR+ABMUNCOM
  1. .;.S ABMTUNCR=$S(+$G(ABMDENOM)>0:(ABMNUMER/ABMDENOM),1:0)
  1. .;.W !,"Uncompensated Care: ",$J(ABMTUNCR*100,0,1)_"%"
  1. .;end old code uncomp care
  1. .;
  1. .W !!,"SCHIP insurers included:"
  1. .I '$D(ABMI) W !?3,"<NONE>"
  1. .S ABMINS=0
  1. .F S ABMINS=$O(ABMI("INS",ABMINS)) Q:'ABMINS D
  1. ..W !?5,$$GET1^DIQ(9999999.18,ABMINS,".01","E")
  1. ;
  1. I +$G(ABMY("TVDTS"))'=0 W !!,"Number of top volume dates to display if minimum thresholds are not met: ",$J(ABMY("TVDTS"),3),!
  1. I ABMY("RFMT")="P",ABM("PG")'=1 W !
  1. I ABMY("RTYP")="SEL" W !,"Eligible Professional: ",$$GET1^DIQ(200,ABMPRV,".01")_" ("_$$GET1^DIQ(7,$$DOCLASS^ABMDVST2(ABMPRV),.01,"E")_")"
  1. I ABMY("RTYP")="GRP" D
  1. .Q:ABM("PG")'=1 ;only print on first page
  1. .W !!,"Eligible Professionals: "
  1. .I '$D(ABMPRV("E")) W !?3,"<NONE>"
  1. .S ABMPRV=0
  1. .F S ABMPRV=$O(ABMPRV("E",ABMPRV)) Q:'ABMPRV D
  1. ..I $Y+5>IOSL,IOST["C" D HD^ABMM2PV3 Q:(IOST["C")&((+$G(Y)=0)!($D(DIRUT)!$D(DIROUT)!$D(DTOUT)!$D(DUOUT)))
  1. ..W !?3,$$GET1^DIQ(200,ABMPRV,".01")_" ("_$$GET1^DIQ(7,$$DOCLASS^ABMDVST2(ABMPRV),.01,"E")_")"
  1. .W !!,"Other Professionals: "
  1. .I '$D(ABMPRV("O")) W !?3,"<NONE>"
  1. .S ABMPRV=0
  1. .F S ABMPRV=$O(ABMPRV("O",ABMPRV)) Q:'ABMPRV D
  1. ..I $Y+5>IOSL,IOST["C" D HD^ABMM2PV3 Q:(IOST["C")&((+$G(Y)=0)!($D(DIRUT)!$D(DIROUT)!$D(DTOUT)!$D(DUOUT)))
  1. ..W !?3,$$GET1^DIQ(200,ABMPRV,".01")_" ("_$$GET1^DIQ(7,$$DOCLASS^ABMDVST2(ABMPRV),.01,"E")_")"
  1. .I IOST["C" D HD^ABMM2PV3 Q:(IOST["C")&((+$G(Y)=0)!($D(DIRUT)!$D(DIROUT)!$D(DTOUT)!$D(DUOUT)))
  1. ;
  1. W !
  1. I ABMY("RFMT")="P" D
  1. .W !
  1. .Q:ABM("PG")'=1
  1. .S ABMU("TXT")="This Patient List is provided for Eligible "_$S(ABMY("RTYP")="HOS":"Hospitals",1:"Professionals")_" to evaluate their "
  1. .S ABMU("TXT")=ABMU("TXT")_"Medicaid"_$S($G(ABMFQHC)=1:"/Needy Individual",1:"")_" Patient Volume Encounters during the Report Period"
  1. .S ABMU("TXT")=ABMU("TXT")_" for participation in the Medicaid EHR Incentive program."
  1. .S ABMU("LM")=0,ABMU("RM")=80,ABMU("LNG")=80
  1. .D ^ABMDWRAP
  1. .W !
  1. I $Y+5>IOSL,IOST["C" D HD^ABMM2PV3 Q:(IOST["C")&((+$G(Y)=0)!($D(DIRUT)!$D(DIROUT)!$D(DTOUT)!$D(DUOUT)))
  1. ;
  1. Q