| [1595] | 1 | C0PLKUP ; VEN/SMH - Extrinsics to map med numbers ; 5/8/12 4:09pm | 
|---|
|  | 2 | ;;1.0;C0P;;Apr 25, 2012;Build 103 | 
|---|
|  | 3 | ;Copyright 2009 Sam Habiel.  Licensed under the terms of the GNU | 
|---|
|  | 4 | ;General Public License See attached copy of the License. | 
|---|
|  | 5 | ; | 
|---|
|  | 6 | ;This program is free software; you can redistribute it and/or modify | 
|---|
|  | 7 | ;it under the terms of the GNU General Public License as published by | 
|---|
|  | 8 | ;the Free Software Foundation; either version 2 of the License, or | 
|---|
|  | 9 | ;(at your option) any later version. | 
|---|
|  | 10 | ; | 
|---|
|  | 11 | ;This program is distributed in the hope that it will be useful, | 
|---|
|  | 12 | ;but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
|  | 13 | ;MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
|  | 14 | ;GNU General Public License for more details. | 
|---|
|  | 15 | ; | 
|---|
|  | 16 | ;You should have received a copy of the GNU General Public License along | 
|---|
|  | 17 | ;with this program; if not, write to the Free Software Foundation, Inc., | 
|---|
|  | 18 | ;51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | 
|---|
|  | 19 | Q | 
|---|
|  | 20 | FDBFN() Q 1130590010 ; First Databank Drugs file number | 
|---|
|  | 21 | RXNFN() Q 1130590011.001 ; RxNorm Concepts file number | 
|---|
|  | 22 | FULLNAME(MEDID) ; $$ Public - Get FDB full name for the drug | 
|---|
|  | 23 | ; Used in Bulletin | 
|---|
|  | 24 | ; Input: MEDID By Value | 
|---|
|  | 25 | ; Output: Extrinsic | 
|---|
|  | 26 | N C0PIEN S C0PIEN=$$FIND1^DIC($$FDBFN,"","QX",MEDID,"B") | 
|---|
|  | 27 | Q $$GET1^DIQ($$FDBFN,C0PIEN,"MED MEDID DESC") | 
|---|
|  | 28 | GCN(MEDID)      ; $$ Public - Get GCN given MEDID | 
|---|
|  | 29 | ; Input: MEDID by Value | 
|---|
|  | 30 | ; Output: Extrinsic | 
|---|
|  | 31 | ; MEDID is the .01 field in the First Databank Drug file | 
|---|
|  | 32 | ; GCN is the 1 field = Generic Code Number | 
|---|
|  | 33 | ; WS supplies MEDID in return. Need Generic Code Number to map to RxNorm. | 
|---|
|  | 34 | N X,Y,DTOUT,DUOUT,DLAYGO,DIC | 
|---|
|  | 35 | S DIC=$$FDBFN | 
|---|
|  | 36 | S X=MEDID | 
|---|
|  | 37 | S DIC(0)="OXZ" ; One entry only, Exact match, return zero node | 
|---|
|  | 38 | D ^DIC | 
|---|
|  | 39 | I Y<0 Q "" ; Failed match | 
|---|
|  | 40 | Q $P(Y(0),U,2) ; GCN is 2nd piece of zero node | 
|---|
|  | 41 | ; | 
|---|
|  | 42 | RXNCUI(GCN)     ; $$ Public - Get RxNorm CUI using GCN | 
|---|
|  | 43 | ; Input: GCN by Value | 
|---|
|  | 44 | ; Output: Extrinsic | 
|---|
|  | 45 | ; Seach GCN index for an exact match | 
|---|
|  | 46 | ; One match, quick lookup, Exact matching | 
|---|
|  | 47 | N C0PIEN S C0PIEN=$$FIND1^DIC($$RXNFN,"","QX",GCN,"GCN") | 
|---|
|  | 48 | Q $$GET1^DIQ($$RXNFN,C0PIEN,.01) | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | VUID(RXNCUI)    ; $$ Public - Get VUID(s) for given RXNCUI for Clinical Drug | 
|---|
|  | 51 | ; Input: RXNCUI by Value | 
|---|
|  | 52 | ; Output: Caret delimited extrinsic. Should not be more than 2 entries. | 
|---|
|  | 53 | ; @;4 means return IEN and VUID. | 
|---|
|  | 54 | N C0POUT,C0PVUID | 
|---|
|  | 55 | I '$D(^DIC($$RXNFN,0,"GL")) Q ""  ; RXNORM UMLS NOT INSTALLED | 
|---|
|  | 56 | D FIND^DIC($$RXNFN,"","@;4","PXQ",RXNCUI,"","VUIDCD","","","C0POUT") | 
|---|
|  | 57 | ; Example output: | 
|---|
|  | 58 | ; SAM("DILIST",0)="2^*^0^" | 
|---|
|  | 59 | ; SAM("DILIST",0,"MAP")="IEN^4" | 
|---|
|  | 60 | ; SAM("DILIST",1,0)="112482^4010153" | 
|---|
|  | 61 | ; SAM("DILIST",2,0)="112484^4016607" | 
|---|
|  | 62 | I +$G(C0POUT("DILIST",0))=0 Q ""  ; no matches | 
|---|
|  | 63 | N I S I=0 | 
|---|
|  | 64 | F  S I=$O(C0POUT("DILIST",I)) Q:I=""  S C0PVUID=$G(C0PVUID)_$P(C0POUT("DILIST",I,0),U,2)_"^" | 
|---|
|  | 65 | S C0PVUID=$E(C0PVUID,1,$L(C0PVUID)-1) ; remove trailing ^ | 
|---|
|  | 66 | Q C0PVUID | 
|---|
|  | 67 | VUID2(MEDID)    ; $$ Public - Get VUID(s) for given MEDID | 
|---|
|  | 68 | Q $$VUID($$RXNCUI($$GCN(MEDID))) | 
|---|
|  | 69 | VAPROD(VUID)    ; $$ Public - Get VA Product IEN from VUID | 
|---|
|  | 70 | ; Input VUID by Value | 
|---|
|  | 71 | ; Output: Extrinsic | 
|---|
|  | 72 | Q $$FIND1^DIC(50.68,"","QX",VUID,"AVUID") | 
|---|
|  | 73 | DRUG(VAPROD)    ; $$ Public - Get Drug(s) using VA Product IEN | 
|---|
|  | 74 | ; Input: VA Product IEN By Value | 
|---|
|  | 75 | ; OUtput: Caret delimited extrinsic | 
|---|
|  | 76 | N C0POUT,C0PDRUG | 
|---|
|  | 77 | ;D FIND^DIC(50,"","@;4","PXQ",VAPROD,"","C0PVAPROD","","","C0POUT") | 
|---|
|  | 78 | ;D FIND^DIC(50,"","@;4","PXQ",VAPROD,"","AC0P","","","C0POUT") ;GPL 7/10 | 
|---|
|  | 79 | I +VAPROD=0 Q 0 ; | 
|---|
|  | 80 | I '$D(^PSDRUG("AC0P",VAPROD)) Q 0 ;W "AC0P cross reference error" Q 0 ; | 
|---|
|  | 81 | ;S C0PDRUG=$O(^PSDRUG("AC0P",VAPROD,"")) ;GPL ABOVE FIND DOESN'T WORK | 
|---|
|  | 82 | N I S I="" | 
|---|
|  | 83 | S C0PDRUG="" | 
|---|
|  | 84 | F  S I=$O(^PSDRUG("AC0P",VAPROD,I)) Q:I=""  D  ; | 
|---|
|  | 85 | . S C0PDRUG=C0PDRUG_I_"^" | 
|---|
|  | 86 | S C0PDRUG=$E(C0PDRUG,1,$L(C0PDRUG)-1) ; remove trailing ^ | 
|---|
|  | 87 | Q C0PDRUG | 
|---|
|  | 88 | ; Example output: | 
|---|
|  | 89 | ; C0POUT("DILIST",0)="2^*^0^" | 
|---|
|  | 90 | ; C0POUT("DILIST",0,"MAP")="IEN^4" | 
|---|
|  | 91 | ; C0POUT("DILIST",1,0)="1512^" | 
|---|
|  | 92 | ; C0POUT("DILIST",2,0)="21632^" | 
|---|
|  | 93 | ; or | 
|---|
|  | 94 | ; C0POUT("DILIST",0)="0^*^0^" | 
|---|
|  | 95 | ; C0POUT("DILIST",0,"MAP")="IEN^4" | 
|---|
|  | 96 | I +$G(C0POUT("DILIST",0))=0 Q ""  ; no matches | 
|---|
|  | 97 | N I S I=0 | 
|---|
|  | 98 | F  S I=$O(C0POUT("DILIST",I)) Q:I=""  S C0PDRUG=$G(C0PDRUG)_$P(C0POUT("DILIST",I,0),U)_"^" | 
|---|
|  | 99 | S C0PDRUG=$E(C0PDRUG,1,$L(C0PDRUG)-1) ; remove trailing ^ | 
|---|
|  | 100 | Q C0PDRUG | 
|---|
|  | 101 | DRUG2(MEDID)    ; $$ Public - Get Drugs for a FDB MEDID | 
|---|
|  | 102 | ; Input: MEDID by Value | 
|---|
|  | 103 | ; Output: Caret delimited extrinsic | 
|---|
|  | 104 | N OUT S OUT="" | 
|---|
|  | 105 | N C0PDRUGS  ; tmp holding space for drugs | 
|---|
|  | 106 | N C0PVUIDS S C0PVUIDS=$$VUID2(MEDID) | 
|---|
|  | 107 | N C0PI | 
|---|
|  | 108 | F C0PI=1:1:$L(C0PVUIDS,U) D  ; for each VUID | 
|---|
|  | 109 | . N C0PVUID S C0PVUID=$P(C0PVUIDS,U,C0PI) | 
|---|
|  | 110 | . N C0PVAPROD S C0PVAPROD=$$VAPROD(C0PVUID) ; get VA Product | 
|---|
|  | 111 | . S C0PDRUGS=$$DRUG(C0PVAPROD) | 
|---|
|  | 112 | . S:$L(C0PDRUGS) OUT=OUT_C0PDRUGS_"^" | 
|---|
|  | 113 | S OUT=$E(OUT,1,$L(OUT)-1) ; rm trailing ^ | 
|---|
|  | 114 | Q OUT | 
|---|
|  | 115 | RXNCUI2(BASE)   ; $$ Public - Get RxNorm CUI for FDB Ingredient/Base | 
|---|
|  | 116 | ; Input: BASE By Value | 
|---|
|  | 117 | ; Output: RxNorm CUI | 
|---|
|  | 118 | N C0PIEN S C0PIEN=$$FIND1^DIC($$RXNFN,"","QX",BASE,"NDDFBASE") | 
|---|
|  | 119 | Q $$GET1^DIQ($$RXNFN,C0PIEN,.01) | 
|---|
|  | 120 | VUIDIN(RXNCUI)  ; $$ Public - Get VUID Ingredient for RxNorm CUI | 
|---|
|  | 121 | ; Input: RXNCUI By Value | 
|---|
|  | 122 | ; Output: VUID | 
|---|
|  | 123 | N C0PIEN S C0PIEN=$$FIND1^DIC($$RXNFN,"","QX",RXNCUI,"VUIDIN") | 
|---|
|  | 124 | Q $$GET1^DIQ($$RXNFN,C0PIEN,"CODE") | 
|---|
|  | 125 | VAGEN(VUID)     ; $$ Public - Get VA Generic for VUID Ingredient | 
|---|
|  | 126 | ; Input: VUID By Value | 
|---|
|  | 127 | ; Output: IEN^VA Generic Name (i.e. .01 field value) | 
|---|
|  | 128 | N C0PIEN S C0PIEN=$$FIND1^DIC(50.6,"","QX",VUID,"AVUID") | 
|---|
|  | 129 | N C0P01 S C0P01=$$GET1^DIQ(50.6,C0PIEN,.01) | 
|---|
|  | 130 | Q C0PIEN_"^"_C0P01 | 
|---|
|  | 131 | VAGEN2(BASE)    ; $$ Public - Get VA Generic for FDB Ingredient/Base | 
|---|
|  | 132 | ; Input: BASE By Value | 
|---|
|  | 133 | ; Output: IEN^VA Generic Name (i.e. .01 field value) | 
|---|
|  | 134 | Q $$VAGEN($$VUIDIN($$RXNCUI2(BASE))) | 
|---|
|  | 135 | DRUGING(VUID)   ; $$ Public - Get Drug Ingredient for VUID Ingredient | 
|---|
|  | 136 | ; Input: VUID By Value | 
|---|
|  | 137 | ; Output: IEN^Drug Ingredient Name (i.e. .01 field value) | 
|---|
|  | 138 | N C0PIEN S C0PIEN=$$FIND1^DIC(50.416,"","QX",VUID,"AVUID") | 
|---|
|  | 139 | N C0P01 S C0P01=$$GET1^DIQ(50.416,C0PIEN,.01) | 
|---|
|  | 140 | Q C0PIEN_"^"_C0P01 | 
|---|
|  | 141 | DRUGING2(BASE)  ; $$ Public - Get Drug Ingredient for FDB Ingredient/Base | 
|---|
|  | 142 | ; Input: BASE By Value | 
|---|
|  | 143 | ; Output: IEN^Drug Ingredient Name (i.e. .01 field value) | 
|---|
|  | 144 | Q $$DRUGING($$VUIDIN($$RXNCUI2(BASE))) | 
|---|
|  | 145 | RXNCUI3(VUID)   ; $$ Public - Get RXNCUI for VUID (any VUID) | 
|---|
|  | 146 | ; Input: VUID By Value | 
|---|
|  | 147 | ; Output: RXNCUI | 
|---|
|  | 148 | I $G(VUID)="" Q "" | 
|---|
|  | 149 | N C0PIEN ; S C0PIEN=$$FIND1^DIC($$RXNFN,"","QX",VUID,"VUID") | 
|---|
|  | 150 | S C0PIEN=$O(^C0P("RXN","VUID",VUID,"")) ;GPL FIX FOR MULTIPLES | 
|---|
|  | 151 | Q $$GET1^DIQ($$RXNFN,C0PIEN,.01) | 
|---|
|  | 152 | NDDFBASE(RXNCUI)        ; $$ Public - Get NDDF Ingredient for RXNCUI | 
|---|
|  | 153 | ; Input: RXNCUI By Value | 
|---|
|  | 154 | ; Output: NDDF Base code | 
|---|
|  | 155 | N C0PIEN S C0PIEN=$$FIND1^DIC($$RXNFN,"","QX",RXNCUI,"RNDDFBASE") | 
|---|
|  | 156 | Q +$$GET1^DIQ($$RXNFN,C0PIEN,"CODE") ; strip leading zeros | 
|---|
|  | 157 | NDDFBAS2(VUID)  ; $$ Public - Get NDDF Ingredient for VUID | 
|---|
|  | 158 | ; NB: WILL ONLY WORK IF VUID IS AN INGREDIENT VUID, NOT A CLINICAL DRUG | 
|---|
|  | 159 | ; Input: VUID By Value | 
|---|
|  | 160 | ; Output: NDDF Base code | 
|---|
|  | 161 | Q $$NDDFBASE($$RXNCUI3(VUID)) | 
|---|
|  | 162 | ; | 
|---|
|  | 163 | DRUGNAM(CURRENTMEDS,ZMED)       ; EXTRINSIC WHICH RETURNS THE FULL NAME | 
|---|
|  | 164 | ; OF THE DRUG FROM CURRENTMEDS, PASSED BY REFERENCE | 
|---|
|  | 165 | ; ZMED IS THE NUMBER OF THE MED IN THE ARRAY | 
|---|
|  | 166 | ; IF THERE IS A DRUGID, IT IS USED TO LOOKUP THE NAME | 
|---|
|  | 167 | ; IF THERE IS NO DRUGID, IT IS A FREETEXT MED AND THE NAME IS | 
|---|
|  | 168 | ; PULLED FROM THE SIG, WHERE IS IT STORED WITH A "|" DELIMITER | 
|---|
|  | 169 | N ZD | 
|---|
|  | 170 | I $D(CURRENTMEDS(ZMED,"DRUG")) S ZD=$$FULLNAME(CURRENTMEDS(ZMED,"DRUG")) | 
|---|
|  | 171 | E  D  ; pull the name from the first piece of the sig | 
|---|
|  | 172 | . N ZDSIG | 
|---|
|  | 173 | . S ZDSIG=$G(CURRENTMEDS(ZMED,"SIG",1,0)) | 
|---|
|  | 174 | .  S ZD=$P(ZDSIG,"|",1) | 
|---|
|  | 175 | Q ZD | 
|---|
|  | 176 | ; | 
|---|
|  | 177 | CODES(MEDID)    ; EXTRINSIC WHICH RETURNS A LINE OF CODES FOR THE MED | 
|---|
|  | 178 | ; FORMAT IS MEDID:XXX GCN:XXX RXNORM:XXX VUID:XXX DRUG:XXX | 
|---|
|  | 179 | N ZL | 
|---|
|  | 180 | S ZL="MEDID:"_MEDID_" " | 
|---|
|  | 181 | N ZG S ZG=$$GCN(MEDID) ; GCN (GENERIC CONCEPT NUMBER) | 
|---|
|  | 182 | S ZL=ZL_"GCN:"_ZG_" " | 
|---|
|  | 183 | N ZR S ZR=$$RXNCUI(ZG) ; RXNORM CONCEPT ID | 
|---|
|  | 184 | S ZL=ZL_"RXNORM:"_ZR_" " | 
|---|
|  | 185 | N ZV S ZV=$$VUID(ZR) ; VUID (VA UNIVERSAL ID) | 
|---|
|  | 186 | S ZL=ZL_"VUID:"_ZV_" " | 
|---|
|  | 187 | N ZD S ZD=$$DRUG2(MEDID) ; VISTA DRUG FILE IEN | 
|---|
|  | 188 | I ZD=0 S ZD="" | 
|---|
|  | 189 | S ZL=ZL_"DRUG:"_ZD_" " | 
|---|
|  | 190 | Q ZL | 
|---|
|  | 191 | ; | 
|---|