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

DGPTDRG.m

Go to the documentation of this file.
  1. DGPTDRG ;ALB/ABS - DRG Information Report User Prompts ; 11/15/06 8:31am
  1. ;;5.3;Registration;**60,441,510,559,599,606,669,729,1015**;Aug 13, 1993;Build 21
  1. ;;ADL;Update for CSV Project;;Mar 28, 2003
  1. S U="^" D Q,DT^DICRW
  1. PAT D EFFDATE G Q:$D(DUOUT),Q:$D(DTOUT)
  1. W !!,"Choose Patient from PATIENT file" S %=1 D YN^DICN G Q:%=-1
  1. I %Y["?"!('%) W !?3,"Enter <RET> for YES if you want DRGs for a patient from your PATIENT File",!?3,"Answer 'N' for NO if you want DRGs for a hypothetical patient" G PAT
  1. S DGPTHOW=% I %=2 S NAME="" G AGE
  1. N DOB S DIC="^DPT(",DIC(0)="AEQMZ" W ! D ^DIC G Q:Y'>0 S DFN=+Y,NAME=$P(Y(0),"^"),(DOB,AGE)=$P(Y(0),U,3),SEX=$P(Y(0),U,2),X1=DT,X2=AGE D ^%DTC S AGE=X\365.25 W " AGE:",AGE
  1. ;I AGE<0!(AGE>124) W !,"Unacceptable AGE",!,"Grouper accepts age values from 0-124 years.",!,"Verify patient's age in PATIENT File before continuing." G Q
  1. S DGEXP=$S($D(^DPT(DFN,.35))#2:1,1:0) I DGEXP,'$P(^(.35),"^") S DGEXP=0
  1. G EXP:DGEXP,TRS
  1. AGE R !!,"Patient's AGE: ",AGE:DTIME G Q:AGE["^"!('$T) S:AGE<0!(AGE="")!(AGE>124)!(AGE'?.N) AGE="?" I AGE["?" W !,"Enter a number for patient's age in years (0-124)" G AGE
  1. SEX R !!,"Patient's SEX: MALE// ",X:DTIME G Q:X["^"!('$T) S Z="^MALE^FEMALE" I X="" S X="M" W X
  1. D IN^DGHELP I %=-1 W !?3,"Enter <RET> for MALE if hypothetical patient is male",!?3,"Enter 'F' for Female" G SEX
  1. S SEX=$E(X)
  1. EXP W !!,"Did patient die during this episode" S %=2 D YN^DICN G Q:%=-1 I %Y["?"!('%) W !?3,"Enter <RET> for NO if patient did not die during the hospital",!?15,"stay for which this DRG is to be calculated",!?3,"Enter 'Y' for YES" G EXP
  1. S DGEXP=$S(%=1:1,1:0) I DGEXP S (DGTRS,DGDMS)=0 G DX
  1. TRS W !!,"Transfer to an acute care facility" S %=2 D YN^DICN G Q:%=-1 I %Y["?"!('%) W !?3,"Enter <RET> for NO if patient not transfered to an acute care facility",!?3,"Enter 'Y' for YES if patient was transfered to acute care facility" G TRS
  1. S DGTRS=$S(%=1:1,1:0)
  1. DMS W !!,"Discharged against medical advice" S %=2 D YN^DICN G Q:%=-1 I %Y["?"!('%) W !?3,"Enter <RET> for NO if patient did not leave against medical advice",!?3,"Enter 'Y' for YES if patient did leave against medical advice",!,*7 G DMS
  1. S DGDMS=$S(%=1:1,1:0)
  1. DX N DXINF,ICDVDT S ICDVDT=DGDAT
  1. S (DGDX,DGSURG)="" S PROMPT="Enter PRINCIPAL diagnosis: "
  1. D ICDEN1^DGPTF5
  1. Q:X["^"!(X="")
  1. S Y=+$$CODEN^ICDCODE(X,80)
  1. I $P($$ICDDX^ICDCODE(Y,DGDAT),U,5) D G DX
  1. . W !,*7,">>>You have selected diagnosis code that is not considered"
  1. . W !,"a primary diagnosis code. Please enter a PRIMARY code."
  1. S DGPTTMP=$$ICDDX^ICDCODE(+Y,DGDAT) S:$P(DGPTTMP,U,10) DGDX=+Y,DXINF=$$ICDDX^ICDCODE(+Y,DGDAT),DGDX(1)=$P(DXINF,"^",2)_"^"_$P(DXINF,"^",4) I '$$ISVALID^ICDGTDRG(+Y,DGDAT,9) D INAC G DX
  1. S PROMPT="Enter SECONDARY diagnosis: " W !
  1. F DGI=2:1:5 D ICDEN1^DGPTF5 Q:X["^"!(X="") S Y=+$$CODEN^ICDCODE(X,80) I +Y>0 S DGPTTMP=$$ICDDX^ICDCODE(+Y,DGDAT) S:DGPTTMP>0&($P(DGPTTMP,U,10)) DGDX=DGDX_"^"_+Y,DXINF=$$ICDDX^ICDCODE(+Y,DGDAT),DGDX(DGI)=$P(DXINF,"^",2)_"^"_$P(DXINF,"^",4) D
  1. . I '$P(DGPTTMP,U,10) D INAC S DGI=DGI-1
  1. G Q:X["^" S DIC(0)="AEQMZ",DIC("S")="I $$ISVALID^ICDGTDRG(+Y,DGDAT,0)",DIC="^ICD0(",DIC("A")="Enter Operation/Procedure: " W !
  1. F DGI=1:1:4 D ^DIC Q:X["^"!(X="") I +Y>0 S DGSURG=+Y_"^"_DGSURG,DXINF=$$ICDOP^ICDCODE(+Y,DGDAT),DGSURG(DGI)=$P(DXINF,U,2)_U_$P(DXINF,U,5)
  1. ; added next line for DG*5.3*441
  1. S DGSURG=U_DGSURG
  1. G Q:X["^" I $D(DGPTODR) S DGVAR="AGE^NAME^SEX^DGDMS^DGEXP^DGTRS^DGDX#^DGSURG#^DGDAT",DGPGM="^DGPTODR" W ! D ZIS^DGUTQ G:POP Q U IO D ^DGPTODR,CLOSE^DGUTQ,Q S DGPTODR=1 G PAT
  1. S DGDRGPRT=1 D ^DGPTICD,Q G PAT ;return DRG code even if inactive
  1. Q K DFN,DGI,DGPGM,AGE,NAME,DGDMS,DGDX,DGEXP,DGPTHOW,DGSURG,DGTRS,DGVAR,DGDRGPRT,DRG,DIC,SEX,POP,X,Y,Z,X1,X2,%,%Y Q
  1. ;
  1. EFFDATE ;prompts for effective date for DRG grouper?
  1. K DIR S DIR(0)="D^::AEX",DIR("B")="TODAY",DIR("A")="Effective Date"
  1. S DIR("?")="The effective to be used when calculating the DRG code for the patient."
  1. D ^DIR K DIR I $D(DIRUT) S QUIT=1 Q
  1. S DGDAT=Y
  1. Q
  1. INAC ;
  1. W !,*7,">>> You have selected an INACTIVE diagnosis code."
  1. W !," This code is not used by the grouper and may cause"
  1. W !," the case to be grouped into DRG 470 - UNGROUPABLE.",!
  1. W !," Therefore, this diagnosis code will NOT be passed"
  1. W !," to the grouper. Please enter another code."