| 1 | RORX013 ;HOIFO/SG - DIAGNOSIS CODES REPORT ; 6/21/06 3:05pm
 | 
|---|
| 2 |  ;;1.5;CLINICAL CASE REGISTRIES;**1**;Feb 17, 2006;Build 24
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  Q
 | 
|---|
| 5 |  ;
 | 
|---|
| 6 |  ;***** OUTPUTS THE REPORT HEADER
 | 
|---|
| 7 |  ;
 | 
|---|
| 8 |  ; PARTAG        Reference (IEN) to the parent tag
 | 
|---|
| 9 |  ;
 | 
|---|
| 10 |  ; Return Values:
 | 
|---|
| 11 |  ;       <0  Error code
 | 
|---|
| 12 |  ;       >0  IEN of the HEADER element
 | 
|---|
| 13 |  ;
 | 
|---|
| 14 | HEADER(PARTAG) ;
 | 
|---|
| 15 |  ;;ICD9LST(#,CODE,DIAG,NP,NC)
 | 
|---|
| 16 |  ;;PATIENTS(#,NAME,LAST4,DOD,PTICDL(CODE,DIAG,DATE,SOURCE))
 | 
|---|
| 17 |  ;
 | 
|---|
| 18 |  N HEADER,RC
 | 
|---|
| 19 |  S HEADER=$$HEADER^RORXU002(.RORTSK,PARTAG)
 | 
|---|
| 20 |  Q:HEADER<0 HEADER
 | 
|---|
| 21 |  S RC=$$TBLDEF^RORXU002("HEADER^RORX013",HEADER)
 | 
|---|
| 22 |  Q $S(RC<0:RC,1:HEADER)
 | 
|---|
| 23 |  ;
 | 
|---|
| 24 |  ;
 | 
|---|
| 25 |  ;***** COMPILES THE "DIAGNOSIS CODE" REPORT
 | 
|---|
| 26 |  ; REPORT CODE: 013
 | 
|---|
| 27 |  ;
 | 
|---|
| 28 |  ; .RORTSK       Task number and task parameters
 | 
|---|
| 29 |  ;
 | 
|---|
| 30 |  ; The ^TMP("VSIT",$J) global node is used by this function.
 | 
|---|
| 31 |  ;
 | 
|---|
| 32 |  ; @RORTMP@(
 | 
|---|
| 33 |  ;
 | 
|---|
| 34 |  ;   "PAT",              Number of patients
 | 
|---|
| 35 |  ;     DFN,              Descriptor
 | 
|---|
| 36 |  ;                         ^01: Las 4 digits of SSN
 | 
|---|
| 37 |  ;                         ^02: Name
 | 
|---|
| 38 |  ;                         ^03: Date of Death
 | 
|---|
| 39 |  ;       ICD9IEN,        Earliest Code Descriptor
 | 
|---|
| 40 |  ;                         ^01: Date
 | 
|---|
| 41 |  ;                         ^02: Source ("I", "O", or "PB")
 | 
|---|
| 42 |  ;         "C")          Quantity
 | 
|---|
| 43 |  ;         "I")          Inpatient quantity
 | 
|---|
| 44 |  ;         "O")          Outpatient quantity
 | 
|---|
| 45 |  ;         "PB")         Problem List quantity
 | 
|---|
| 46 |  ;
 | 
|---|
| 47 |  ;   "ICD",              Totals
 | 
|---|
| 48 |  ;                         ^01: Number of ICD-9 codes
 | 
|---|
| 49 |  ;                         ^02: Number of different codes
 | 
|---|
| 50 |  ;     ICD9IEN,          ICD-9 Descriptor
 | 
|---|
| 51 |  ;                         ^01: Code
 | 
|---|
| 52 |  ;                         ^02: Diagnosis (current version)
 | 
|---|
| 53 |  ;       "C")            Quantity
 | 
|---|
| 54 |  ;       "P")            Number of unique patients
 | 
|---|
| 55 |  ;
 | 
|---|
| 56 |  ; Return Values:
 | 
|---|
| 57 |  ;       <0  Error code
 | 
|---|
| 58 |  ;        0  Ok
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 | ICD9LST(RORTSK) ;
 | 
|---|
| 61 |  N ROREDT        ; End date
 | 
|---|
| 62 |  N RORICDL       ; Prepared list of ICD-9 codes
 | 
|---|
| 63 |  N RORIGRP       ; List of ICD-9 groups
 | 
|---|
| 64 |  N RORREG        ; Registry IEN
 | 
|---|
| 65 |  N RORSDT        ; Start date
 | 
|---|
| 66 |  N RORTMP        ; Closed root of the temporary buffer
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 |  N ECNT,RC,REPORT,SFLAGS,TMP
 | 
|---|
| 69 |  S RORICDL="",(ECNT,RC)=0
 | 
|---|
| 70 |  ;--- Root node of the report
 | 
|---|
| 71 |  S REPORT=$$ADDVAL^RORTSK11(RORTSK,"REPORT")
 | 
|---|
| 72 |  Q:REPORT<0 REPORT
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 |  ;--- Get and prepare the report parameters
 | 
|---|
| 75 |  S RORREG=$$PARAM^RORTSK01("REGIEN")
 | 
|---|
| 76 |  S RC=$$PARAMS(REPORT,.RORSDT,.ROREDT,.SFLAGS)  Q:RC<0 RC
 | 
|---|
| 77 |  ;
 | 
|---|
| 78 |  ;--- Report header
 | 
|---|
| 79 |  S RC=$$HEADER(REPORT)  Q:RC<0 RC
 | 
|---|
| 80 |  S RORTMP=$$ALLOC^RORTMP()
 | 
|---|
| 81 |  D
 | 
|---|
| 82 |  . ;--- Query the registry
 | 
|---|
| 83 |  . D TPPSETUP^RORTSK01(70)
 | 
|---|
| 84 |  . S RC=$$QUERY^RORX013A(SFLAGS)
 | 
|---|
| 85 |  . I RC  Q:RC<0  S ECNT=ECNT+RC
 | 
|---|
| 86 |  . ;--- Sort the data
 | 
|---|
| 87 |  . D TPPSETUP^RORTSK01(10)
 | 
|---|
| 88 |  . S RC=$$SORT^RORX013A()
 | 
|---|
| 89 |  . I RC  Q:RC<0  S ECNT=ECNT+RC
 | 
|---|
| 90 |  . ;--- Store the results
 | 
|---|
| 91 |  . D TPPSETUP^RORTSK01(20)
 | 
|---|
| 92 |  . S RC=$$STORE^RORX013C(REPORT)
 | 
|---|
| 93 |  . I RC  Q:RC<0  S ECNT=ECNT+RC
 | 
|---|
| 94 |  ;
 | 
|---|
| 95 |  ;--- Cleanup
 | 
|---|
| 96 |  D FREE^RORTMP(RORTMP),FREE^RORTMP(RORICDL)
 | 
|---|
| 97 |  K ^TMP("VSIT",$J)
 | 
|---|
| 98 |  Q $S(RC<0:RC,ECNT>0:-43,1:0)
 | 
|---|
| 99 |  ;
 | 
|---|
| 100 |  ;***** OUTPUTS THE PARAMETERS TO THE REPORT
 | 
|---|
| 101 |  ;
 | 
|---|
| 102 |  ; PARTAG        Reference (IEN) to the parent tag
 | 
|---|
| 103 |  ;
 | 
|---|
| 104 |  ; [.STDT]       Start and end dates of the report
 | 
|---|
| 105 |  ; [.ENDT]       are returned via these parameters
 | 
|---|
| 106 |  ;
 | 
|---|
| 107 |  ; [.FLAGS]      Flags for the $$SKIP^RORXU005 are
 | 
|---|
| 108 |  ;               returned via this parameter
 | 
|---|
| 109 |  ;
 | 
|---|
| 110 |  ; Return Values:
 | 
|---|
| 111 |  ;       <0  Error code
 | 
|---|
| 112 |  ;       >0  IEN of the PARAMETERS element
 | 
|---|
| 113 |  ;
 | 
|---|
| 114 | PARAMS(PARTAG,STDT,ENDT,FLAGS) ;
 | 
|---|
| 115 |  N PARAMS,TMP
 | 
|---|
| 116 |  S PARAMS=$$PARAMS^RORXU002(.RORTSK,PARTAG,.STDT,.ENDT,.FLAGS)
 | 
|---|
| 117 |  Q:PARAMS<0 PARAMS
 | 
|---|
| 118 |  ;--- Process the list of ICD9 codes
 | 
|---|
| 119 |  S TMP=$$ICD9LST^RORXU008(.RORTSK,PARAMS,.RORICDL,.RORIGRP)
 | 
|---|
| 120 |  Q:TMP<0 TMP
 | 
|---|
| 121 |  ;---
 | 
|---|
| 122 |  Q PARAMS
 | 
|---|