| 1 | RORX016B ;HCIOFO/BH,SG - OUTPATIENT UTILIZATION (SORT) ; 9/14/05 10:08am | 
|---|
| 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 | 
|---|
| 3 | ; | 
|---|
| 4 | Q | 
|---|
| 5 | ; | 
|---|
| 6 | ;***** SORTS THE RESULTS AND COMPILES THE TOTALS | 
|---|
| 7 | ; | 
|---|
| 8 | ; Return Values: | 
|---|
| 9 | ;       <0  Error code | 
|---|
| 10 | ;        0  Ok | 
|---|
| 11 | ; | 
|---|
| 12 | SORT() ; | 
|---|
| 13 | N I,NDSC,NAME,NODE,NSC,NV,RC,RORBUF,RORMSG,STOP,TMP | 
|---|
| 14 | S NODE=$NA(^TMP("RORX016",$J))  Q:$D(@NODE)<10 0 | 
|---|
| 15 | ;--- Outpatient stop codes | 
|---|
| 16 | S RC=$$LOOP^RORTSK01(0)  Q:RC<0 RC | 
|---|
| 17 | S STOP="",(NDSC,NSC)=0 | 
|---|
| 18 | F  S STOP=$O(@NODE@("OPS",STOP))  Q:STOP=""  D | 
|---|
| 19 | . S NSC=NSC+$G(@NODE@("OPS",STOP,"S")),NDSC=NDSC+1 | 
|---|
| 20 | . D FIND^DIC(40.7,,"@;.01","UX",STOP,1,"C",,,"RORBUF","RORMSG") | 
|---|
| 21 | . D:$G(DIERR) DBS^RORERR("RORMSG",-9,,,40.7) | 
|---|
| 22 | . S NAME=$G(RORBUF("DILIST","ID",1,.01))  K RORBUF | 
|---|
| 23 | . S @NODE@("OPS",STOP)=$S(NAME'="":NAME,1:"Unknown") | 
|---|
| 24 | S @NODE@("OPS")=NSC_U_NDSC | 
|---|
| 25 | ;--- | 
|---|
| 26 | Q 0 | 
|---|
| 27 | ; | 
|---|
| 28 | ;***** CALCULATES THE INTERMEDIATE TOTALS | 
|---|
| 29 | ; | 
|---|
| 30 | ; PATIEN        Patient IEN (DFN) | 
|---|
| 31 | ; CATSUB        Category subscript in the temporary global | 
|---|
| 32 | ; | 
|---|
| 33 | ; Return Values: | 
|---|
| 34 | ;       <0  Error code | 
|---|
| 35 | ;        0  Ok | 
|---|
| 36 | ; | 
|---|
| 37 | TOTALS(PATIEN) ; | 
|---|
| 38 | N NODE,TMP | 
|---|
| 39 | S NODE=$NA(^TMP("RORX016",$J)) | 
|---|
| 40 | ; | 
|---|
| 41 | ;=== Outpatient data | 
|---|
| 42 | D:$D(@NODE@("OP",PATIEN))>1 | 
|---|
| 43 | . N DATE,NDSC,NPSC,NSC,NV,NVSC,SCLST,STOP | 
|---|
| 44 | . S @NODE@("OP")=$G(@NODE@("OP"))+1 | 
|---|
| 45 | . ;--- | 
|---|
| 46 | . S (DATE,NPSC,NV)=0 | 
|---|
| 47 | . F  S DATE=$O(@NODE@("OP",PATIEN,DATE))  Q:DATE'>0  D | 
|---|
| 48 | . . S NV=NV+1                              ; Number of visits | 
|---|
| 49 | . . S NVSC=@NODE@("OP",PATIEN,DATE)        ; Number of visist's stops | 
|---|
| 50 | . . ;--- Count the patient's stops | 
|---|
| 51 | . . S STOP="" | 
|---|
| 52 | . . F  S STOP=$O(@NODE@("OP",PATIEN,DATE,STOP))  Q:STOP=""  D | 
|---|
| 53 | . . . S NSC=@NODE@("OP",PATIEN,DATE,STOP)  ; Number of stops | 
|---|
| 54 | . . . S @NODE@("OPS",STOP,"S")=$G(@NODE@("OPS",STOP,"S"))+NSC | 
|---|
| 55 | . . . S @NODE@("OPS",STOP,"V")=$G(@NODE@("OPS",STOP,"V"))+(NSC/NVSC) | 
|---|
| 56 | . . . S SCLST(STOP)="" | 
|---|
| 57 | . . S NPSC=NPSC+NVSC                       ; Total number of stops | 
|---|
| 58 | . K @NODE@("OP",PATIEN) | 
|---|
| 59 | . ;--- Count the different stops and patients | 
|---|
| 60 | . S STOP="",NDSC=0 | 
|---|
| 61 | . F  S STOP=$O(SCLST(STOP))  Q:STOP=""  D | 
|---|
| 62 | . . S @NODE@("OPS",STOP,"P")=$G(@NODE@("OPS",STOP,"P"))+1 | 
|---|
| 63 | . . S NDSC=NDSC+1                          ; Number of diff. stops | 
|---|
| 64 | . ;--- Count the visits | 
|---|
| 65 | . S:NV>0 @NODE@("OPV")=$G(@NODE@("OPV"))+NV | 
|---|
| 66 | . ;--- Count the stop codes | 
|---|
| 67 | . D:NPSC>0 | 
|---|
| 68 | . . S @NODE@("OP",PATIEN)=NPSC_U_NDSC_U_$G(VA("BID"))_U_NV | 
|---|
| 69 | . . S @NODE@("OPS1",NPSC)=$G(@NODE@("OPS1",NPSC))+1 | 
|---|
| 70 | . . S @NODE@("OPS1",NPSC,RORPNAME,PATIEN)="" | 
|---|
| 71 | Q 0 | 
|---|