1 | RORX005C ;HCIOFO/BH,SG - INPATIENT UTILIZATION (STORE) ; 9/14/05 9:17am
|
---|
2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006
|
---|
3 | ;
|
---|
4 | Q
|
---|
5 | ;
|
---|
6 | ;***** HIGHEST UTILIZATION
|
---|
7 | ;
|
---|
8 | ; PRNTELMT IEN of the parent element
|
---|
9 | ;
|
---|
10 | ; RORNODE Closed root of the section in the temporary global
|
---|
11 | ;
|
---|
12 | ; Return Values:
|
---|
13 | ; <0 Error code
|
---|
14 | ; 0 Ok
|
---|
15 | ;
|
---|
16 | HIGHUTIL(PRNTELMT,RORNODE) ;
|
---|
17 | N RC,RORMAXUT,RORTCNT,SECTION,TMP
|
---|
18 | S RORMAXUT=$$PARAM^RORTSK01("MAXUTNUM")
|
---|
19 | Q:RORMAXUT'>0 0
|
---|
20 | S SECTION=$$ADDVAL^RORTSK11(RORTSK,"HIGHUTIL",,PRNTELMT)
|
---|
21 | Q:SECTION<0 SECTION
|
---|
22 | S (RC,RORTCNT)=0
|
---|
23 | ;--- Stays
|
---|
24 | S RC=$$HIGHUTSD(SECTION,"IPS","HU_STAYS") Q:RC<0 RC
|
---|
25 | ;--- Days
|
---|
26 | S RC=$$HIGHUTSD(SECTION,"IPD","HU_DAYS") Q:RC<0 RC
|
---|
27 | ;--- Disable the empty section
|
---|
28 | D:RORTCNT'>0 UPDVAL^RORTSK11(RORTSK,SECTION,"",,1)
|
---|
29 | Q 0
|
---|
30 | ;
|
---|
31 | ;*****
|
---|
32 | ;
|
---|
33 | ; SECTION IEN of the parent element
|
---|
34 | ;
|
---|
35 | ; SUBS Utilization subscript in the temporary global
|
---|
36 | ;
|
---|
37 | ; TBLNAME Name of the table element
|
---|
38 | ;
|
---|
39 | ; Return Values:
|
---|
40 | ; <0 Error code
|
---|
41 | ; 0 Ok
|
---|
42 | ;
|
---|
43 | HIGHUTSD(SECTION,SUBS,TBLNAME) ;
|
---|
44 | Q:$D(@RORNODE@(SUBS))<10 0
|
---|
45 | N COUNT,DFN,ITEM,NAME,NUM,RC,TABLE,TMP
|
---|
46 | S TABLE=$$ADDVAL^RORTSK11(RORTSK,TBLNAME,,SECTION)
|
---|
47 | Q:TABLE<0 TABLE
|
---|
48 | D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE",TBLNAME)
|
---|
49 | S RORTCNT=RORTCNT+1
|
---|
50 | ;---
|
---|
51 | S NUM="",(COUNT,RC)=0
|
---|
52 | F S NUM=$O(@RORNODE@(SUBS,NUM),-1) Q:NUM="" D Q:RC
|
---|
53 | . S NAME=""
|
---|
54 | . F S NAME=$O(@RORNODE@(SUBS,NUM,NAME)) Q:NAME="" D Q:RC
|
---|
55 | . . S DFN=""
|
---|
56 | . . F S DFN=$O(@RORNODE@(SUBS,NUM,NAME,DFN)) Q:DFN="" D Q:RC
|
---|
57 | . . . S COUNT=COUNT+1 I COUNT>RORMAXUT S RC=1 Q
|
---|
58 | . . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"PATIENT",,TABLE)
|
---|
59 | . . . D ADDVAL^RORTSK11(RORTSK,"NAME",NAME,ITEM,1)
|
---|
60 | . . . S TMP=$G(@RORNODE@("IP",DFN))
|
---|
61 | . . . D ADDVAL^RORTSK11(RORTSK,"LAST4",$P(TMP,U),ITEM,2)
|
---|
62 | . . . S TMP=+$G(@RORNODE@("IP",DFN,"S"))
|
---|
63 | . . . D ADDVAL^RORTSK11(RORTSK,"NST",TMP,ITEM,3)
|
---|
64 | . . . S TMP=+$G(@RORNODE@("IP",DFN,"D"))
|
---|
65 | . . . D ADDVAL^RORTSK11(RORTSK,"ND",TMP,ITEM,3)
|
---|
66 | . . . S TMP=$G(@RORNODE@("IP",DFN,"V"))
|
---|
67 | . . . D ADDVAL^RORTSK11(RORTSK,"NSS",TMP,ITEM,3)
|
---|
68 | Q 0
|
---|
69 | ;
|
---|
70 | ;***** STORES THE REPORT DATA
|
---|
71 | ;
|
---|
72 | ; REPORT IEN of the REPORT element
|
---|
73 | ;
|
---|
74 | ; Return Values:
|
---|
75 | ; <0 Error code
|
---|
76 | ; 0 Ok
|
---|
77 | ; >0 Number of non-fatal errors
|
---|
78 | ;
|
---|
79 | STORE(REPORT) ;
|
---|
80 | N RORSONLY ; Output summary only
|
---|
81 | ;
|
---|
82 | N ECNT,NODE,RC,TMP
|
---|
83 | S NODE=$NA(^TMP("RORX005",$J))
|
---|
84 | Q:$D(@NODE)<10 0
|
---|
85 | S RORSONLY=$$SMRYONLY^RORXU006(),(ECNT,RC)=0
|
---|
86 | ;--- Inpatients
|
---|
87 | S RC=$$LOOP^RORTSK01(0) Q:RC<0 RC
|
---|
88 | S RC=$$STOREIP(REPORT,NODE)
|
---|
89 | I RC Q:RC<0 RC S ECNT=ECNT+1
|
---|
90 | ;--- Highest utilization
|
---|
91 | S RC=$$LOOP^RORTSK01(0.5) Q:RC<0 RC
|
---|
92 | S RC=$$HIGHUTIL(REPORT,NODE)
|
---|
93 | I RC Q:RC<0 RC S ECNT=ECNT+1
|
---|
94 | ;---
|
---|
95 | Q ECNT
|
---|
96 | ;
|
---|
97 | ;***** INPATIENT DATA
|
---|
98 | ;
|
---|
99 | ; PRNTELMT IEN of the parent element
|
---|
100 | ;
|
---|
101 | ; NODE Closed root of the category section
|
---|
102 | ; in the temporary global
|
---|
103 | ;
|
---|
104 | ; Return Values:
|
---|
105 | ; <0 Error code
|
---|
106 | ; 0 Ok
|
---|
107 | ;
|
---|
108 | STOREIP(PRNTELMT,NODE) ;
|
---|
109 | Q:$D(@NODE@("IP"))<10 0
|
---|
110 | N BSID,DATE,ITEM,NAME,NS,PATIEN,PTF,RC,SECTION,TABLE,TMP
|
---|
111 | S SECTION=$$ADDVAL^RORTSK11(RORTSK,"INPATIENTS",,PRNTELMT)
|
---|
112 | Q:SECTION<0 SECTION
|
---|
113 | S RC=0
|
---|
114 | ;--- Stays
|
---|
115 | I $D(@NODE@("IPS"))>1 D Q:RC<0 RC
|
---|
116 | . S TABLE=$$ADDVAL^RORTSK11(RORTSK,"STAYS",,SECTION)
|
---|
117 | . I TABLE<0 S RC=TABLE Q
|
---|
118 | . D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","STAYS")
|
---|
119 | . S NS=""
|
---|
120 | . F S NS=$O(@NODE@("IPS",NS)) Q:NS="" D
|
---|
121 | . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"ITEM",,TABLE)
|
---|
122 | . . D ADDVAL^RORTSK11(RORTSK,"NP",$P(@NODE@("IPS",NS),U),ITEM,3)
|
---|
123 | . . D ADDVAL^RORTSK11(RORTSK,"NST",NS,ITEM,3)
|
---|
124 | ;--- Bed sections (clinics)
|
---|
125 | I $D(@NODE@("IPB"))>1 D Q:RC<0 RC
|
---|
126 | . S TABLE=$$ADDVAL^RORTSK11(RORTSK,"BEDSECTIONS",,SECTION)
|
---|
127 | . I TABLE<0 S RC=TABLE Q
|
---|
128 | . D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","BEDSECTIONS")
|
---|
129 | . S NAME=""
|
---|
130 | . F S NAME=$O(@NODE@("IPB","B",NAME)) Q:NAME="" D
|
---|
131 | . . S BSID=""
|
---|
132 | . . F S BSID=$O(@NODE@("IPB","B",NAME,BSID)) Q:BSID="" D:BSID>0
|
---|
133 | . . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"BEDSECTION",,TABLE)
|
---|
134 | . . . D ADDVAL^RORTSK11(RORTSK,"NAME",NAME,ITEM,1)
|
---|
135 | . . . S TMP=+$G(@NODE@("IPB",BSID,"P"))
|
---|
136 | . . . D ADDVAL^RORTSK11(RORTSK,"NP",TMP,ITEM,3)
|
---|
137 | . . . S TMP=+$G(@NODE@("IPB",BSID,"S"))
|
---|
138 | . . . D ADDVAL^RORTSK11(RORTSK,"NST",TMP,ITEM,3)
|
---|
139 | . . . S TMP=+$G(@NODE@("IPB",BSID,"D"))
|
---|
140 | . . . D ADDVAL^RORTSK11(RORTSK,"ND",TMP,ITEM,3)
|
---|
141 | . . . S TMP=+$G(@NODE@("IPMLOS",BSID))
|
---|
142 | . . . D ADDVAL^RORTSK11(RORTSK,"MLOS",$J(TMP,0,1),ITEM,3)
|
---|
143 | . . . S TMP=$G(@NODE@("IPB",BSID,"V"))
|
---|
144 | . . . D ADDVAL^RORTSK11(RORTSK,"NSS",TMP,ITEM,3)
|
---|
145 | ;--- No bed section
|
---|
146 | I 'RORSONLY,$D(@NODE@("IPNOBS"))>1 D Q:RC<0 RC
|
---|
147 | . S TABLE=$$ADDVAL^RORTSK11(RORTSK,"NOBS",,SECTION)
|
---|
148 | . I TABLE<0 S RC=TABLE Q
|
---|
149 | . D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","NOBS")
|
---|
150 | . S NAME=""
|
---|
151 | . F S NAME=$O(@NODE@("IPNOBS",NAME)) Q:NAME="" D
|
---|
152 | . . S DATE=""
|
---|
153 | . . F S DATE=$O(@NODE@("IPNOBS",NAME,DATE)) Q:DATE="" D
|
---|
154 | . . . S PTF=""
|
---|
155 | . . . F S PTF=$O(@NODE@("IPNOBS",NAME,DATE,PTF)) Q:PTF="" D
|
---|
156 | . . . . S DFN=""
|
---|
157 | . . . . F S DFN=$O(@NODE@("IPNOBS",NAME,DATE,PTF,DFN)) Q:DFN="" D
|
---|
158 | . . . . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"PATIENT",,TABLE)
|
---|
159 | . . . . . D ADDVAL^RORTSK11(RORTSK,"NAME",NAME,ITEM,1)
|
---|
160 | . . . . . S TMP=$P($G(@NODE@("IP",DFN)),U)
|
---|
161 | . . . . . D ADDVAL^RORTSK11(RORTSK,"LAST4",TMP,ITEM,2)
|
---|
162 | . . . . . D ADDVAL^RORTSK11(RORTSK,"DATE",DATE,ITEM,3)
|
---|
163 | . . . . . D ADDVAL^RORTSK11(RORTSK,"PTF",PTF,ITEM,1)
|
---|
164 | ;--- Summary
|
---|
165 | D ADDVAL^RORTSK11(RORTSK,"NP",+$G(@NODE@("IP")),SECTION)
|
---|
166 | D ADDVAL^RORTSK11(RORTSK,"NST",+$G(@NODE@("IPS")),SECTION)
|
---|
167 | D ADDVAL^RORTSK11(RORTSK,"ND",+$G(@NODE@("IPD")),SECTION)
|
---|
168 | D ADDVAL^RORTSK11(RORTSK,"NSS",+$G(@NODE@("IPV")),SECTION)
|
---|
169 | S TMP=$G(@NODE@("IPMLOS",0))
|
---|
170 | D ADDVAL^RORTSK11(RORTSK,"MLOS",$J(TMP,0,1),SECTION)
|
---|
171 | I $G(@NODE@("IPS"))>0 D
|
---|
172 | . S TMP=$G(@NODE@("IPD"))/@NODE@("IPS")
|
---|
173 | E S TMP=0
|
---|
174 | D ADDVAL^RORTSK11(RORTSK,"ALOS",$J(TMP,0,1),SECTION)
|
---|
175 | Q 0
|
---|