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

RORX005A.m

Go to the documentation of this file.
  1. RORX005A ;HOIFO/BH,SG - INPATIENT UTILIZATION (QUERY) ;4/21/09 2:20pm
  1. ;;1.5;CLINICAL CASE REGISTRIES;**1,8,10,13,19,21,31,39**;Feb 17, 2006;Build 4
  1. ;
  1. ; This routine uses the following IAs:
  1. ;
  1. ; #92 ^DGPT( #45.7 (controlled)
  1. ; #417 .01 field and "C" x-ref of file #40.8 (controlled)
  1. ; #2056 $$GET1^DIQ (supported)
  1. ; #3545 ^DGPT("AAD" (private)
  1. ; #10061 IN5^VADPT (supported)
  1. ; #10103 FMADD^XLFDT, FMDIFF^XLFDT (supported)
  1. ;
  1. ;******************************************************************************
  1. ;******************************************************************************
  1. ; --- ROUTINE MODIFICATION LOG ---
  1. ;
  1. ;PKG/PATCH DATE DEVELOPER MODIFICATION
  1. ;----------- ---------- ----------- ----------------------------------------
  1. ;ROR*1.5*8 MAR 2010 V CARR Modified to handle ICD9 filter for
  1. ; 'include' or 'exclude'.
  1. ;ROR*1.5*13 DEC 2010 A SAUNDERS User can select specific patients.
  1. ;ROR*1.5*19 FEB 2012 K GUPTA Support for ICD-10 Coding System
  1. ;ROR*1.5*31 MAY 2017 M FERRARESE Adding PACT,PCP, and AGE/DOB as additional
  1. ; identifiers.
  1. ;ROR*1.5*39 JUL 2021 M FERRARESE Setting SSN and LAST4 to zeros
  1. ;******************************************************************************
  1. ;******************************************************************************
  1. Q
  1. ;
  1. ;***** ADDS THE INPATIENT STAY
  1. ;
  1. ; DFN Patient IEN (in file #2)
  1. ; PTFIEN IEN of the PTF record
  1. ; LOS Length of stay
  1. ; BSID Bed section ID
  1. ; DATE Movement date/time (FileMan)
  1. ;
  1. ADDSTAY(DFN,PTFIEN,LOS,BSID,DATE) ;
  1. N DST,I,TMP
  1. S:$G(BSID)="" BSID=0
  1. ;--- Number of patients for the bedsection
  1. I 'BSID S DST=$NA(@RORDST@("IP",DFN))
  1. E S DST=$NA(@RORDST@("IPB",BSID)) D:'$D(@DST@("P",DFN))
  1. . S @DST@("P")=$G(@DST@("P"))+1,@DST@("P",DFN)=""
  1. ;--- No bed section ID
  1. S:BSID<0 @RORDST@("IPNOBS",RORPNAME,DATE,PTFIEN,DFN)=""
  1. ;--- Short stays (visits)
  1. I LOS'>0 S @DST@("V")=$G(@DST@("V"))+1 Q
  1. ;--- Days and stays
  1. S @DST@("D")=$G(@DST@("D"))+LOS
  1. S @DST@("S")=$G(@DST@("S"))+1
  1. ;--- Lengths of stay for median value calculations
  1. S I=$O(@RORDST@("IPMLOS",BSID,LOS,""),-1)+1
  1. S @RORDST@("IPMLOS",BSID,LOS,I)=""
  1. Q
  1. ;
  1. ;***** LOADS AND PROCESSES THE INPATIENT DATA
  1. ;
  1. ; DFN Patient IEN (in file #2)
  1. ;
  1. ; Return Values:
  1. ; <0 Error code
  1. ; 0 Ok
  1. ; >0 Number of non-fatal errors
  1. ;
  1. IPDATA(DFN) ;
  1. N RORDST ; Closed reference to the category node in ^TMP
  1. ;
  1. N BSID,DATE,DISDT,ENDT,FACILITY,LOS,PTFIEN,RC,RORMSG,STDT,SUFFIX,TMP,VAHOW,VAIP,VAROOT,XDATE
  1. S RORDST=$NA(^TMP("RORX005",$J))
  1. ;---
  1. S XDATE=RORSDT
  1. F S RC=0 D Q:RC<2 S XDATE=$O(^DGPT("AAD",DFN,XDATE)) Q:XDATE'>0
  1. . I XDATE'<ROREDT1 S RC=1 Q
  1. . K DATE,LOS,VAIP S VAIP(16,1)=XDATE
  1. . F D Q:RC
  1. . . S VAIP("D")=+$G(VAIP(16,1))
  1. . . I VAIP("D")'>0 S RC=2 Q
  1. . . D IN5^VADPT
  1. . . I $G(VAIP(1))'>0 S RC=2 Q
  1. . . S DATE=+VAIP(3)
  1. . . Q:+$G(VAIP(4))=3
  1. . . ;--- Check the movement date
  1. . . I DATE'<ROREDT1 S RC=1 Q
  1. . . S:DATE<RORSDT DATE=RORSDT
  1. . . ;--- Check the PTF record - Task removed April 2009
  1. . . S PTFIEN=+$G(VAIP(12)) Q:PTFIEN'>0
  1. . . I '$D(PTFIEN(PTFIEN)) D Q:RC
  1. . . . S PTFIEN(PTFIEN)=0
  1. . . . Q:$$PTF^RORXU001(PTFIEN,"FP",,,.SUFFIX,,.FACILITY)
  1. . . . ;--- Check the suffix
  1. . . . ;I SUFFIX'="" Q:$$VSUFFIX(SUFFIX) ; ROR 1.5
  1. . . . ;--- Check the division
  1. . . . S TMP=$$PARAM^RORTSK01("DIVISIONS","ALL")
  1. . . . I 'TMP D Q:'$D(RORTSK("PARAMS","DIVISIONS","C",DIVIEN))
  1. . . . . S TMP=FACILITY_SUFFIX
  1. . . . . S DIVIEN=$S(TMP'="":+$O(^DG(40.8,"C",TMP,"")),1:0)
  1. . . . K DIVIEN ;kill statement added
  1. . . . S PTFIEN(PTFIEN)=1
  1. . . ;--- Skip the PTF record if necessary
  1. . . Q:'PTFIEN(PTFIEN)
  1. . . ;--- Process the admission (only once)
  1. . . I '$D(LOS) D Q:RC
  1. . . . S LOS=$$LOS(+$G(VAIP(13,1)),+$G(VAIP(17,1)))
  1. . . . D ADDSTAY(DFN,PTFIEN,LOS)
  1. . . ;--- Process the movement
  1. . . S ENDT=$G(VAIP(16,1))\1
  1. . . S:(ENDT'>0)!(ENDT'<ROREDT1) ENDT=ROREDT,RC=2
  1. . . Q:ENDT<RORSDT
  1. . . S LOS=$$FMDIFF^XLFDT(ENDT,DATE\1,1) S:LOS'>0 LOS=0
  1. . . ;--- Use the IEN in the SPECIALTY file (#42.4) as the Bedsection
  1. . . ; ID if it is available (it should be). Otherwise, use the
  1. . . ;--- IEN in the FACILITY TREATING SPECIALTY file (#45.7).
  1. . . I $G(VAIP(8))>0 D
  1. . . . K RORMSG S TMP=$$GET1^DIQ(45.7,+VAIP(8),1,"I",,"RORMSG")
  1. . . . ;D:$G(DIERR) DBS^RORERR("RORMSG",-9,,DFN,45.7,+VAIP(8))
  1. . . . D:$G(RORMSG("DIERR")) DBS^RORERR("RORMSG",-9,,DFN,45.7,+VAIP(8))
  1. . . . S BSID=$S(TMP>0:TMP_";42.4",1:+VAIP(8)_";45.7")
  1. . . E S BSID=-1
  1. . . D ADDSTAY(DFN,PTFIEN,LOS,BSID,+VAIP(3))
  1. . S:$G(DATE)>XDATE XDATE=DATE
  1. ;---
  1. Q $S(RC<0:RC,1:0)
  1. ;
  1. ;***** CALCULATES THE LENGTH OF STAY
  1. LOS(STDT,ENDT) ;
  1. N DAYS
  1. S:STDT<RORSDT STDT=RORSDT
  1. S:(ENDT'>0)!(ENDT>ROREDT) ENDT=ROREDT
  1. S DAYS=$$FMDIFF^XLFDT(ENDT\1,STDT\1,1)
  1. Q $S(DAYS'<0:DAYS,1:0)
  1. ;
  1. ;***** QUERIES THE REGISTRY
  1. ;
  1. ; FLAGS Flags for the $$SKIP^RORXU005
  1. ;
  1. ; Return Values:
  1. ; <0 Error code
  1. ; 0 Ok
  1. ; >0 Number of non-fatal errors
  1. ;
  1. QUERY(FLAGS) ;
  1. N ROREDT1 ; Day after the end date
  1. N RORLAST4 ; Last 4 digits of the current patient's SSN
  1. N RORPNAME ; Name of the current patient
  1. N RORICN ; National ICN
  1. N RORPACT ; Patient Care team
  1. N RORPCP ; Primary care physician
  1. N RORPTN ; Number of patients in the registry
  1. N AGE,AGETYPE
  1. ;
  1. N CNT,ECNT,IEN,IENS,PATIEN,RC,TMP,VA,VADM,XREFNODE
  1. N RCC,FLAG
  1. S XREFNODE=$NA(^RORDATA(798,"AC",+RORREG))
  1. S RORPTN=$$REGSIZE^RORUTL02(+RORREG) S:RORPTN<0 RORPTN=0
  1. S ROREDT1=$$FMADD^XLFDT(ROREDT,1)
  1. S (CNT,ECNT,RC)=0
  1. ;--- Browse through the registry records
  1. S IEN=0
  1. S FLAG=$G(RORTSK("PARAMS","ICDFILT","A","FILTER"))
  1. F S IEN=$O(@XREFNODE@(IEN)) Q:IEN'>0 D Q:RC<0
  1. . S TMP=$S(RORPTN>0:CNT/RORPTN,1:"")
  1. . S RC=$$LOOP^RORTSK01(TMP) Q:RC<0
  1. . S IENS=IEN_",",CNT=CNT+1
  1. . ;--- Get the patient DFN
  1. . S PATIEN=$$PTIEN^RORUTL01(IEN) Q:PATIEN'>0
  1. . ;check for patient list and quit if not on list
  1. . I $D(RORTSK("PARAMS","PATIENTS","C")),'$D(RORTSK("PARAMS","PATIENTS","C",PATIEN)) Q
  1. . ;--- Check if the patient should be skipped
  1. . Q:$$SKIP^RORXU005(IEN,FLAGS,RORSDT,ROREDT)
  1. . ;--- Filter patient on ICD codes
  1. . S RCC=0
  1. . I FLAG'="ALL" D
  1. . . S RCC=$$ICD^RORXU010(PATIEN)
  1. . I (FLAG="INCLUDE")&(RCC=0) Q
  1. . I (FLAG="EXCLUDE")&(RCC=1) Q
  1. . ;--- End of filter
  1. . ;
  1. . ;--- Get the patient's data
  1. . D VADEM^RORUTL05(PATIEN,1)
  1. . S RORPNAME=VADM(1),RORLAST4="0000"
  1. . S RORICN=$S($$PARAM^RORTSK01("PATIENTS","ICN"):$$ICN^RORUTL02(PATIEN),1:"")
  1. . S RORPACT=$S($$PARAM^RORTSK01("PATIENTS","PACT"):$$PACT^RORUTL02(PATIEN),1:"")
  1. . S RORPCP=$S($$PARAM^RORTSK01("PATIENTS","PCP"):$$PCP^RORUTL02(PATIEN),1:"")
  1. . S AGETYPE=$$PARAM^RORTSK01("AGE_RANGE","TYPE") D
  1. . . S AGE=$S(AGETYPE="AGE":$P(VADM(4),U),AGETYPE="DOB":$$DATE^RORXU002($P(VADM(3),U)\1),1:"")
  1. . ;
  1. . ;--- Get the inpatient data
  1. . S RC=$$IPDATA(PATIEN)
  1. . I RC S ECNT=ECNT+1 Q:RC<0
  1. . ;
  1. . ;--- Calculate intermediate totals
  1. . S RC=$$TOTALS^RORX005B(PATIEN)
  1. . I RC S ECNT=ECNT+1 Q:RC<0
  1. ;---
  1. Q $S(RC<0:RC,1:ECNT)
  1. ;
  1. ;***** CHECKS THE SUFFIX FOR VALIDITY
  1. ;
  1. ; SUFFIX Suffix
  1. ;
  1. ; Return Values:
  1. ; 0 Ok
  1. ; 1 Invalid suffix
  1. VSUFFIX(SUFFIX) ;
  1. Q '("9AA,9AB,9AC,9AD,9AE,9BB,A0,A4,A5,BU,BV,PA"[SUFFIX)