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

ORY22107.m

Go to the documentation of this file.
  1. ORY22107 ;SLC/RJS,CLA - OCX PACKAGE RULE TRANSPORT ROUTINE (Delete after Install of OR*3*221) ;AUG 30,2005 at 11:41
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**221**;Dec 17,1997
  1. ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
  1. ;
  1. S ;
  1. ;
  1. D DOT^ORY221ES
  1. ;
  1. ;
  1. K REMOTE,LOCAL,OPCODE,REF
  1. F LINE=1:1:500 S TEXT=$P($T(DATA+LINE),";",2,999) Q:TEXT I $L(TEXT) D Q:QUIT
  1. .S ^TMP("OCXRULE",$J,$O(^TMP("OCXRULE",$J,"A"),-1)+1)=TEXT
  1. ;
  1. G ^ORY22108
  1. ;
  1. Q
  1. ;
  1. DATA ;
  1. ;
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ; date into an Externl Format (Human Readable) date. 'OCXF=SHORT FORMAT OCXF=LONG FORMAT
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; Q:'$L($G(OCXDT)) "" S OCXF=+$G(OCXF)
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; N OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXCYR
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; S (OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXAP)=""
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; S OCXSEC=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; S OCXMIN=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; S OCXHR=$E(OCXDT#24+100,2,3),OCXDT=OCXDT\24
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; S OCXCYR=($H\1461)*4+1841+(($H#1461)\365)
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; S OCXYR=(OCXDT\1461)*4+1841,OCXDT=OCXDT#1461
  1. ;;R^"860.8:",100,12
  1. ;;D^ ; S OCXLPYR=(OCXDT\365),OCXDT=OCXDT-(OCXLPYR*365),OCXYR=OCXYR+OCXLPYR
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; S OCXCNT="031^059^090^120^151^181^212^243^273^304^334^365"
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; S:(OCXLPYR=3) OCXCNT="031^060^091^121^152^182^213^244^274^305^335^366"
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; F OCXMON=1:1:12 Q:(OCXDT<$P(OCXCNT,U,OCXMON))
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; S OCXDAY=OCXDT-$P(OCXCNT,U,OCXMON-1)+1
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; I OCXF S OCXMON=$P("January^February^March^April^May^June^July^August^September^October^November^December",U,OCXMON)
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; E S OCXMON=$E(OCXMON+100,2,3)
  1. ;;R^"860.8:",100,19
  1. ;;D^ ; S OCXAP=$S('OCXHR:"Midnight",(OCXHR=12):"Noon",(OCXHR<12):"AM",1:"PM")
  1. ;;R^"860.8:",100,20
  1. ;;D^ ; I OCXF S OCXHR=OCXHR#12 S:'OCXHR OCXHR=12
  1. ;;R^"860.8:",100,21
  1. ;;D^ ; Q:'OCXF $E(OCXMON+100,2,3)_"/"_$E(OCXDAY+100,2,3)_$S((OCXCYR=OCXYR):" "_OCXHR_":"_OCXMIN,1:"/"_$E(OCXYR,3,4))
  1. ;;R^"860.8:",100,22
  1. ;;D^ ; Q:(OCXHR+OCXMIN+OCXSEC) OCXMON_" "_OCXDAY_","_OCXYR_" at "_OCXHR_":"_OCXMIN_"."_OCXSEC_" "_OCXAP
  1. ;;R^"860.8:",100,23
  1. ;;D^ ; Q OCXMON_" "_OCXDAY_","_OCXYR
  1. ;;R^"860.8:",100,24
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^CREATININE CLEARANCE (ESTIMATED/CALCULATED)
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^CREATININE CLEARANCE (ESTIMATED/CALCULATED)
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^CRCL
  1. ;;R^"860.8:",1,1
  1. ;;D^The CrCl algorithm uses adjusted body weight if patient height is > 60
  1. ;;R^"860.8:",1,2
  1. ;;D^inches. Approved by the CPRS Clinical Workgroup 8/11/04, it is based on a
  1. ;;R^"860.8:",1,3
  1. ;;D^modified Cockcroft-Gault formula and was installed with patch OR*3*221.
  1. ;;R^"860.8:",1,4
  1. ;;D^For more information:
  1. ;;R^"860.8:",1,5
  1. ;;D^ http://www.ascp.com/public/pubs/tcp/1999/jan/cockcroft.shtml
  1. ;;R^"860.8:",1,6
  1. ;;D^
  1. ;;R^"860.8:",1,7
  1. ;;D^ CrCl (male) = (140 - age) x (adj body weight* in kg)
  1. ;;R^"860.8:",1,8
  1. ;;D^ --------------------------------------
  1. ;;R^"860.8:",1,9
  1. ;;D^ (serum creatinine) x 72
  1. ;;R^"860.8:",1,10
  1. ;;D^ * If patient height is not greater than 60 inches, actual body weight
  1. ;;R^"860.8:",1,11
  1. ;;D^ is used.
  1. ;;R^"860.8:",1,12
  1. ;;D^ CrCl (female) = 0.85 x CrCl (male)
  1. ;;R^"860.8:",1,13
  1. ;;D^
  1. ;;R^"860.8:",1,14
  1. ;;D^To calculate adjusted body weight, the following equations are used:
  1. ;;R^"860.8:",1,15
  1. ;;D^Ideal body weight (IBW) = 50 kg x (for men) or 45 kg x (for women) +
  1. ;;R^"860.8:",1,16
  1. ;;D^ 2.3 x (height in inches - 60)
  1. ;;R^"860.8:",1,17
  1. ;;D^Adjusted body weight (Adj. BW) if the ratio of actual BW/IBW > 1.3 =
  1. ;;R^"860.8:",1,18
  1. ;;D^ (0.3 x (Actual BW - IBW)) + IBW
  1. ;;R^"860.8:",1,19
  1. ;;D^Adjusted body weight if the ratio of actual BW/IBW is not > 1.3 =
  1. ;;R^"860.8:",1,20
  1. ;;D^ IBW or Actual BW (whichever is less)
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;CRCL(DFN) ;
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; N HT,AGE,SEX,SCR,SCRD,CRCL,LRWKLD,RSLT,ORW,ORH,PSCR
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; N HTGT60,ABW,IBW,BWRATIO,BWDIFF,LOWBW,ADJBW
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; S RSLT="0^<Unavailable>"
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; S PSCR="^^^^^^0"
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; D VITAL^ORQQVI("WEIGHT","WT",DFN,.ORW,0,"",$$NOW^XLFDT)
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; Q:'$D(ORW) RSLT
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; S ABW=$P(ORW(1),U,3) Q:+$G(ABW)<1 RSLT
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; S ABW=ABW/2.2 ;ABW (actual body weight) in kg
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; D VITAL^ORQQVI("HEIGHT","HT",DFN,.ORH,0,"",$$NOW^XLFDT)
  1. ;;R^"860.8:",100,12
  1. ;;D^ ; Q:'$D(ORH) RSLT
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; S HT=$P(ORH(1),U,3) Q:+$G(HT)<1 RSLT
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; S AGE=$$AGE^ORQPTQ4(DFN) Q:'AGE RSLT
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; S SEX=$P($$SEX^ORQPTQ4(DFN),U,1) Q:'$L(SEX) RSLT
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; S OCXTL="" Q:'$$TERMLKUP^ORB31(.OCXTL,"SERUM CREATININE") RSLT
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; S OCXTLS="" Q:'$$TERMLKUP^ORB31(.OCXTLS,"SERUM SPECIMEN") RSLT
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; S SCR="",OCXT=0 F S OCXT=$O(OCXTL(OCXT)) Q:'OCXT D
  1. ;;R^"860.8:",100,19
  1. ;;D^ ; .S OCXTS=0 F S OCXTS=$O(OCXTLS(OCXTS)) Q:'OCXTS D
  1. ;;R^"860.8:",100,20
  1. ;;D^ ; ..S SCR=$$LOCL^ORQQLR1(DFN,$P(OCXTL(OCXT),U),$P(OCXTLS(OCXTS),U))
  1. ;;R^"860.8:",100,21
  1. ;;D^ ; ..I $P(SCR,U,7)>$P(PSCR,U,7) S PSCR=SCR
  1. ;;R^"860.8:",100,22
  1. ;;D^ ; S SCR=PSCR,SCRV=$P(SCR,U,3) Q:+$G(SCRV)<.01 RSLT
  1. ;;R^"860.8:",100,23
  1. ;;D^ ; S SCRD=$P(SCR,U,7) Q:'$L(SCRD) RSLT
  1. ;;R^"860.8:",100,24
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,25
  1. ;;D^ ; S HTGT60=$S(HT>60:(HT-60)*2.3,1:0) ;if ht > 60 inches
  1. ;;R^"860.8:",100,26
  1. ;;D^ ; I HTGT60>0 D
  1. ;;R^"860.8:",100,27
  1. ;;D^ ; .S IBW=$S(SEX="M":50+HTGT60,1:45.5+HTGT60) ;Ideal Body Weight
  1. ;;R^"860.8:",100,28
  1. ;;D^ ; .S BWRATIO=(ABW/IBW) ;body weight ratio
  1. ;;R^"860.8:",100,29
  1. ;;D^ ; .S BWDIFF=$S(ABW>IBW:ABW-IBW,1:0)
  1. ;;R^"860.8:",100,30
  1. ;;D^ ; .S LOWBW=$S(IBW<ABW:IBW,1:ABW)
  1. ;;R^"860.8:",100,31
  1. ;;D^ ; .I BWRATIO>1.3,(BWDIFF>0) S ADJBW=((0.3*BWDIFF)+IBW)
  1. ;;R^"860.8:",100,32
  1. ;;D^ ; .E S ADJBW=LOWBW
  1. ;;R^"860.8:",100,33
  1. ;;D^ ; I +$G(ADJBW)<1 D
  1. ;;R^"860.8:",100,34
  1. ;;D^ ; .S ADJBW=ABW
  1. ;;R^"860.8:",100,35
  1. ;;D^ ; S CRCL=(((140-AGE)*ADJBW)/(SCRV*72))
  1. ;;R^"860.8:",100,36
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,37
  1. ;;D^ ; S:SEX="M" RSLT=SCRD_U_$J(CRCL,1,1)
  1. ;;R^"860.8:",100,38
  1. ;;D^ ; S:SEX="F" RSLT=SCRD_U_$J((CRCL*.85),1,1)
  1. ;;R^"860.8:",100,39
  1. ;;D^ ; Q RSLT
  1. ;;R^"860.8:",100,40
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^ELAPSED ORDER CHECK TIME LOGGER
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^ELAPSED ORDER CHECK TIME LOGGER
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^TIMELOG
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;TIMELOG(OCXMODE,OCXCALL) ; Log an entry in the Elapsed time log.
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; Q 0
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^EQUALS TERM OPERATOR
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^EQUALS TERM OPERATOR
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^EQTERM
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;EQTERM(DATA,TERM) ;
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,3
  1. ;;D^T+; I $G(OCXTRACE) W !,"%%%%",?20," Execution trace DATA: ",$G(DATA)," TERM: ",$G(TERM)
  1. ;1;
  1. ;