All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hl7.fhir.r4.model.Encounter Maven / Gradle / Ivy

Go to download

Builds the hapi fhir r4. Requires hapi-fhir-base and hapi-fhir-utilities be built first and be excluded from any other poms requiring it.

The newest version!
package org.hl7.fhir.r4.model;

/*
  Copyright (c) 2011+, HL7, Inc.
  All rights reserved.
  
  Redistribution and use in source and binary forms, with or without modification, 
  are permitted provided that the following conditions are met:
  
   * Redistributions of source code must retain the above copyright notice, this 
     list of conditions and the following disclaimer.
   * Redistributions in binary form must reproduce the above copyright notice, 
     this list of conditions and the following disclaimer in the documentation 
     and/or other materials provided with the distribution.
   * Neither the name of HL7 nor the names of its contributors may be used to 
     endorse or promote products derived from this software without specific 
     prior written permission.
  
  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
  POSSIBILITY OF SUCH DAMAGE.
  
*/

// Generated on Tue, May 12, 2020 07:26+1000 for FHIR v4.0.1
import java.util.ArrayList;
import java.util.List;

import org.hl7.fhir.exceptions.FHIRException;
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;

import ca.uhn.fhir.model.api.annotation.Block;
import ca.uhn.fhir.model.api.annotation.Child;
import ca.uhn.fhir.model.api.annotation.Description;
import ca.uhn.fhir.model.api.annotation.ResourceDef;
import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;

/**
 * An interaction between a patient and healthcare provider(s) for the purpose
 * of providing healthcare service(s) or assessing the health status of a
 * patient.
 */
@ResourceDef(name = "Encounter", profile = "http://hl7.org/fhir/StructureDefinition/Encounter")
public class Encounter extends DomainResource {

  public enum EncounterStatus {
    /**
     * The Encounter has not yet started.
     */
    PLANNED,
    /**
     * The Patient is present for the encounter, however is not currently meeting
     * with a practitioner.
     */
    ARRIVED,
    /**
     * The patient has been assessed for the priority of their treatment based on
     * the severity of their condition.
     */
    TRIAGED,
    /**
     * The Encounter has begun and the patient is present / the practitioner and the
     * patient are meeting.
     */
    INPROGRESS,
    /**
     * The Encounter has begun, but the patient is temporarily on leave.
     */
    ONLEAVE,
    /**
     * The Encounter has ended.
     */
    FINISHED,
    /**
     * The Encounter has ended before it has begun.
     */
    CANCELLED,
    /**
     * This instance should not have been part of this patient's medical record.
     */
    ENTEREDINERROR,
    /**
     * The encounter status is unknown. Note that "unknown" is a value of last
     * resort and every attempt should be made to provide a meaningful value other
     * than "unknown".
     */
    UNKNOWN,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static EncounterStatus fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("planned".equals(codeString))
        return PLANNED;
      if ("arrived".equals(codeString))
        return ARRIVED;
      if ("triaged".equals(codeString))
        return TRIAGED;
      if ("in-progress".equals(codeString))
        return INPROGRESS;
      if ("onleave".equals(codeString))
        return ONLEAVE;
      if ("finished".equals(codeString))
        return FINISHED;
      if ("cancelled".equals(codeString))
        return CANCELLED;
      if ("entered-in-error".equals(codeString))
        return ENTEREDINERROR;
      if ("unknown".equals(codeString))
        return UNKNOWN;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown EncounterStatus code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case PLANNED:
        return "planned";
      case ARRIVED:
        return "arrived";
      case TRIAGED:
        return "triaged";
      case INPROGRESS:
        return "in-progress";
      case ONLEAVE:
        return "onleave";
      case FINISHED:
        return "finished";
      case CANCELLED:
        return "cancelled";
      case ENTEREDINERROR:
        return "entered-in-error";
      case UNKNOWN:
        return "unknown";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case PLANNED:
        return "http://hl7.org/fhir/encounter-status";
      case ARRIVED:
        return "http://hl7.org/fhir/encounter-status";
      case TRIAGED:
        return "http://hl7.org/fhir/encounter-status";
      case INPROGRESS:
        return "http://hl7.org/fhir/encounter-status";
      case ONLEAVE:
        return "http://hl7.org/fhir/encounter-status";
      case FINISHED:
        return "http://hl7.org/fhir/encounter-status";
      case CANCELLED:
        return "http://hl7.org/fhir/encounter-status";
      case ENTEREDINERROR:
        return "http://hl7.org/fhir/encounter-status";
      case UNKNOWN:
        return "http://hl7.org/fhir/encounter-status";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case PLANNED:
        return "The Encounter has not yet started.";
      case ARRIVED:
        return "The Patient is present for the encounter, however is not currently meeting with a practitioner.";
      case TRIAGED:
        return "The patient has been assessed for the priority of their treatment based on the severity of their condition.";
      case INPROGRESS:
        return "The Encounter has begun and the patient is present / the practitioner and the patient are meeting.";
      case ONLEAVE:
        return "The Encounter has begun, but the patient is temporarily on leave.";
      case FINISHED:
        return "The Encounter has ended.";
      case CANCELLED:
        return "The Encounter has ended before it has begun.";
      case ENTEREDINERROR:
        return "This instance should not have been part of this patient's medical record.";
      case UNKNOWN:
        return "The encounter status is unknown. Note that \"unknown\" is a value of last resort and every attempt should be made to provide a meaningful value other than \"unknown\".";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case PLANNED:
        return "Planned";
      case ARRIVED:
        return "Arrived";
      case TRIAGED:
        return "Triaged";
      case INPROGRESS:
        return "In Progress";
      case ONLEAVE:
        return "On Leave";
      case FINISHED:
        return "Finished";
      case CANCELLED:
        return "Cancelled";
      case ENTEREDINERROR:
        return "Entered in Error";
      case UNKNOWN:
        return "Unknown";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class EncounterStatusEnumFactory implements EnumFactory {
    public EncounterStatus fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("planned".equals(codeString))
        return EncounterStatus.PLANNED;
      if ("arrived".equals(codeString))
        return EncounterStatus.ARRIVED;
      if ("triaged".equals(codeString))
        return EncounterStatus.TRIAGED;
      if ("in-progress".equals(codeString))
        return EncounterStatus.INPROGRESS;
      if ("onleave".equals(codeString))
        return EncounterStatus.ONLEAVE;
      if ("finished".equals(codeString))
        return EncounterStatus.FINISHED;
      if ("cancelled".equals(codeString))
        return EncounterStatus.CANCELLED;
      if ("entered-in-error".equals(codeString))
        return EncounterStatus.ENTEREDINERROR;
      if ("unknown".equals(codeString))
        return EncounterStatus.UNKNOWN;
      throw new IllegalArgumentException("Unknown EncounterStatus code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, EncounterStatus.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, EncounterStatus.NULL, code);
      if ("planned".equals(codeString))
        return new Enumeration(this, EncounterStatus.PLANNED, code);
      if ("arrived".equals(codeString))
        return new Enumeration(this, EncounterStatus.ARRIVED, code);
      if ("triaged".equals(codeString))
        return new Enumeration(this, EncounterStatus.TRIAGED, code);
      if ("in-progress".equals(codeString))
        return new Enumeration(this, EncounterStatus.INPROGRESS, code);
      if ("onleave".equals(codeString))
        return new Enumeration(this, EncounterStatus.ONLEAVE, code);
      if ("finished".equals(codeString))
        return new Enumeration(this, EncounterStatus.FINISHED, code);
      if ("cancelled".equals(codeString))
        return new Enumeration(this, EncounterStatus.CANCELLED, code);
      if ("entered-in-error".equals(codeString))
        return new Enumeration(this, EncounterStatus.ENTEREDINERROR, code);
      if ("unknown".equals(codeString))
        return new Enumeration(this, EncounterStatus.UNKNOWN, code);
      throw new FHIRException("Unknown EncounterStatus code '" + codeString + "'");
    }

    public String toCode(EncounterStatus code) {
      if (code == EncounterStatus.PLANNED)
        return "planned";
      if (code == EncounterStatus.ARRIVED)
        return "arrived";
      if (code == EncounterStatus.TRIAGED)
        return "triaged";
      if (code == EncounterStatus.INPROGRESS)
        return "in-progress";
      if (code == EncounterStatus.ONLEAVE)
        return "onleave";
      if (code == EncounterStatus.FINISHED)
        return "finished";
      if (code == EncounterStatus.CANCELLED)
        return "cancelled";
      if (code == EncounterStatus.ENTEREDINERROR)
        return "entered-in-error";
      if (code == EncounterStatus.UNKNOWN)
        return "unknown";
      return "?";
    }

    public String toSystem(EncounterStatus code) {
      return code.getSystem();
    }
  }

  public enum EncounterLocationStatus {
    /**
     * The patient is planned to be moved to this location at some point in the
     * future.
     */
    PLANNED,
    /**
     * The patient is currently at this location, or was between the period
     * specified.
     * 
     * A system may update these records when the patient leaves the location to
     * either reserved, or completed.
     */
    ACTIVE,
    /**
     * This location is held empty for this patient.
     */
    RESERVED,
    /**
     * The patient was at this location during the period specified.
     * 
     * Not to be used when the patient is currently at the location.
     */
    COMPLETED,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static EncounterLocationStatus fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("planned".equals(codeString))
        return PLANNED;
      if ("active".equals(codeString))
        return ACTIVE;
      if ("reserved".equals(codeString))
        return RESERVED;
      if ("completed".equals(codeString))
        return COMPLETED;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown EncounterLocationStatus code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case PLANNED:
        return "planned";
      case ACTIVE:
        return "active";
      case RESERVED:
        return "reserved";
      case COMPLETED:
        return "completed";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case PLANNED:
        return "http://hl7.org/fhir/encounter-location-status";
      case ACTIVE:
        return "http://hl7.org/fhir/encounter-location-status";
      case RESERVED:
        return "http://hl7.org/fhir/encounter-location-status";
      case COMPLETED:
        return "http://hl7.org/fhir/encounter-location-status";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case PLANNED:
        return "The patient is planned to be moved to this location at some point in the future.";
      case ACTIVE:
        return "The patient is currently at this location, or was between the period specified.\r\rA system may update these records when the patient leaves the location to either reserved, or completed.";
      case RESERVED:
        return "This location is held empty for this patient.";
      case COMPLETED:
        return "The patient was at this location during the period specified.\r\rNot to be used when the patient is currently at the location.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case PLANNED:
        return "Planned";
      case ACTIVE:
        return "Active";
      case RESERVED:
        return "Reserved";
      case COMPLETED:
        return "Completed";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class EncounterLocationStatusEnumFactory implements EnumFactory {
    public EncounterLocationStatus fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("planned".equals(codeString))
        return EncounterLocationStatus.PLANNED;
      if ("active".equals(codeString))
        return EncounterLocationStatus.ACTIVE;
      if ("reserved".equals(codeString))
        return EncounterLocationStatus.RESERVED;
      if ("completed".equals(codeString))
        return EncounterLocationStatus.COMPLETED;
      throw new IllegalArgumentException("Unknown EncounterLocationStatus code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, EncounterLocationStatus.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, EncounterLocationStatus.NULL, code);
      if ("planned".equals(codeString))
        return new Enumeration(this, EncounterLocationStatus.PLANNED, code);
      if ("active".equals(codeString))
        return new Enumeration(this, EncounterLocationStatus.ACTIVE, code);
      if ("reserved".equals(codeString))
        return new Enumeration(this, EncounterLocationStatus.RESERVED, code);
      if ("completed".equals(codeString))
        return new Enumeration(this, EncounterLocationStatus.COMPLETED, code);
      throw new FHIRException("Unknown EncounterLocationStatus code '" + codeString + "'");
    }

    public String toCode(EncounterLocationStatus code) {
      if (code == EncounterLocationStatus.PLANNED)
        return "planned";
      if (code == EncounterLocationStatus.ACTIVE)
        return "active";
      if (code == EncounterLocationStatus.RESERVED)
        return "reserved";
      if (code == EncounterLocationStatus.COMPLETED)
        return "completed";
      return "?";
    }

    public String toSystem(EncounterLocationStatus code) {
      return code.getSystem();
    }
  }

  @Block()
  public static class StatusHistoryComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * planned | arrived | triaged | in-progress | onleave | finished | cancelled +.
     */
    @Child(name = "status", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "planned | arrived | triaged | in-progress | onleave | finished | cancelled +", formalDefinition = "planned | arrived | triaged | in-progress | onleave | finished | cancelled +.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-status")
    protected Enumeration status;

    /**
     * The time that the episode was in the specified status.
     */
    @Child(name = "period", type = { Period.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The time that the episode was in the specified status", formalDefinition = "The time that the episode was in the specified status.")
    protected Period period;

    private static final long serialVersionUID = -1893906736L;

    /**
     * Constructor
     */
    public StatusHistoryComponent() {
      super();
    }

    /**
     * Constructor
     */
    public StatusHistoryComponent(Enumeration status, Period period) {
      super();
      this.status = status;
      this.period = period;
    }

    /**
     * @return {@link #status} (planned | arrived | triaged | in-progress | onleave
     *         | finished | cancelled +.). This is the underlying object with id,
     *         value and extensions. The accessor "getStatus" gives direct access to
     *         the value
     */
    public Enumeration getStatusElement() {
      if (this.status == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create StatusHistoryComponent.status");
        else if (Configuration.doAutoCreate())
          this.status = new Enumeration(new EncounterStatusEnumFactory()); // bb
      return this.status;
    }

    public boolean hasStatusElement() {
      return this.status != null && !this.status.isEmpty();
    }

    public boolean hasStatus() {
      return this.status != null && !this.status.isEmpty();
    }

    /**
     * @param value {@link #status} (planned | arrived | triaged | in-progress |
     *              onleave | finished | cancelled +.). This is the underlying
     *              object with id, value and extensions. The accessor "getStatus"
     *              gives direct access to the value
     */
    public StatusHistoryComponent setStatusElement(Enumeration value) {
      this.status = value;
      return this;
    }

    /**
     * @return planned | arrived | triaged | in-progress | onleave | finished |
     *         cancelled +.
     */
    public EncounterStatus getStatus() {
      return this.status == null ? null : this.status.getValue();
    }

    /**
     * @param value planned | arrived | triaged | in-progress | onleave | finished |
     *              cancelled +.
     */
    public StatusHistoryComponent setStatus(EncounterStatus value) {
      if (this.status == null)
        this.status = new Enumeration(new EncounterStatusEnumFactory());
      this.status.setValue(value);
      return this;
    }

    /**
     * @return {@link #period} (The time that the episode was in the specified
     *         status.)
     */
    public Period getPeriod() {
      if (this.period == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create StatusHistoryComponent.period");
        else if (Configuration.doAutoCreate())
          this.period = new Period(); // cc
      return this.period;
    }

    public boolean hasPeriod() {
      return this.period != null && !this.period.isEmpty();
    }

    /**
     * @param value {@link #period} (The time that the episode was in the specified
     *              status.)
     */
    public StatusHistoryComponent setPeriod(Period value) {
      this.period = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("status", "code",
          "planned | arrived | triaged | in-progress | onleave | finished | cancelled +.", 0, 1, status));
      children.add(
          new Property("period", "Period", "The time that the episode was in the specified status.", 0, 1, period));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case -892481550:
        /* status */ return new Property("status", "code",
            "planned | arrived | triaged | in-progress | onleave | finished | cancelled +.", 0, 1, status);
      case -991726143:
        /* period */ return new Property("period", "Period", "The time that the episode was in the specified status.",
            0, 1, period);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case -892481550:
        /* status */ return this.status == null ? new Base[0] : new Base[] { this.status }; // Enumeration
      case -991726143:
        /* period */ return this.period == null ? new Base[0] : new Base[] { this.period }; // Period
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case -892481550: // status
        value = new EncounterStatusEnumFactory().fromType(castToCode(value));
        this.status = (Enumeration) value; // Enumeration
        return value;
      case -991726143: // period
        this.period = castToPeriod(value); // Period
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("status")) {
        value = new EncounterStatusEnumFactory().fromType(castToCode(value));
        this.status = (Enumeration) value; // Enumeration
      } else if (name.equals("period")) {
        this.period = castToPeriod(value); // Period
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("status")) {
        this.status = null;
      } else if (name.equals("period")) {
        this.period = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -892481550:
        return getStatusElement();
      case -991726143:
        return getPeriod();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -892481550:
        /* status */ return new String[] { "code" };
      case -991726143:
        /* period */ return new String[] { "Period" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("status")) {
        throw new FHIRException("Cannot call addChild on a singleton property Encounter.status");
      } else if (name.equals("period")) {
        this.period = new Period();
        return this.period;
      } else
        return super.addChild(name);
    }

    public StatusHistoryComponent copy() {
      StatusHistoryComponent dst = new StatusHistoryComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(StatusHistoryComponent dst) {
      super.copyValues(dst);
      dst.status = status == null ? null : status.copy();
      dst.period = period == null ? null : period.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof StatusHistoryComponent))
        return false;
      StatusHistoryComponent o = (StatusHistoryComponent) other_;
      return compareDeep(status, o.status, true) && compareDeep(period, o.period, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof StatusHistoryComponent))
        return false;
      StatusHistoryComponent o = (StatusHistoryComponent) other_;
      return compareValues(status, o.status, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(status, period);
    }

    public String fhirType() {
      return "Encounter.statusHistory";

    }

  }

  @Block()
  public static class ClassHistoryComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * inpatient | outpatient | ambulatory | emergency +.
     */
    @Child(name = "class", type = { Coding.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "inpatient | outpatient | ambulatory | emergency +", formalDefinition = "inpatient | outpatient | ambulatory | emergency +.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v3-ActEncounterCode")
    protected Coding class_;

    /**
     * The time that the episode was in the specified class.
     */
    @Child(name = "period", type = { Period.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The time that the episode was in the specified class", formalDefinition = "The time that the episode was in the specified class.")
    protected Period period;

    private static final long serialVersionUID = 1331020311L;

    /**
     * Constructor
     */
    public ClassHistoryComponent() {
      super();
    }

    /**
     * Constructor
     */
    public ClassHistoryComponent(Coding class_, Period period) {
      super();
      this.class_ = class_;
      this.period = period;
    }

    /**
     * @return {@link #class_} (inpatient | outpatient | ambulatory | emergency +.)
     */
    public Coding getClass_() {
      if (this.class_ == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create ClassHistoryComponent.class_");
        else if (Configuration.doAutoCreate())
          this.class_ = new Coding(); // cc
      return this.class_;
    }

    public boolean hasClass_() {
      return this.class_ != null && !this.class_.isEmpty();
    }

    /**
     * @param value {@link #class_} (inpatient | outpatient | ambulatory | emergency
     *              +.)
     */
    public ClassHistoryComponent setClass_(Coding value) {
      this.class_ = value;
      return this;
    }

    /**
     * @return {@link #period} (The time that the episode was in the specified
     *         class.)
     */
    public Period getPeriod() {
      if (this.period == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create ClassHistoryComponent.period");
        else if (Configuration.doAutoCreate())
          this.period = new Period(); // cc
      return this.period;
    }

    public boolean hasPeriod() {
      return this.period != null && !this.period.isEmpty();
    }

    /**
     * @param value {@link #period} (The time that the episode was in the specified
     *              class.)
     */
    public ClassHistoryComponent setPeriod(Period value) {
      this.period = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("class", "Coding", "inpatient | outpatient | ambulatory | emergency +.", 0, 1, class_));
      children
          .add(new Property("period", "Period", "The time that the episode was in the specified class.", 0, 1, period));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 94742904:
        /* class */ return new Property("class", "Coding", "inpatient | outpatient | ambulatory | emergency +.", 0, 1,
            class_);
      case -991726143:
        /* period */ return new Property("period", "Period", "The time that the episode was in the specified class.", 0,
            1, period);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 94742904:
        /* class */ return this.class_ == null ? new Base[0] : new Base[] { this.class_ }; // Coding
      case -991726143:
        /* period */ return this.period == null ? new Base[0] : new Base[] { this.period }; // Period
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 94742904: // class
        this.class_ = castToCoding(value); // Coding
        return value;
      case -991726143: // period
        this.period = castToPeriod(value); // Period
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("class")) {
        this.class_ = castToCoding(value); // Coding
      } else if (name.equals("period")) {
        this.period = castToPeriod(value); // Period
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("class")) {
        this.class_ = null;
      } else if (name.equals("period")) {
        this.period = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 94742904:
        return getClass_();
      case -991726143:
        return getPeriod();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 94742904:
        /* class */ return new String[] { "Coding" };
      case -991726143:
        /* period */ return new String[] { "Period" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("class")) {
        this.class_ = new Coding();
        return this.class_;
      } else if (name.equals("period")) {
        this.period = new Period();
        return this.period;
      } else
        return super.addChild(name);
    }

    public ClassHistoryComponent copy() {
      ClassHistoryComponent dst = new ClassHistoryComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(ClassHistoryComponent dst) {
      super.copyValues(dst);
      dst.class_ = class_ == null ? null : class_.copy();
      dst.period = period == null ? null : period.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof ClassHistoryComponent))
        return false;
      ClassHistoryComponent o = (ClassHistoryComponent) other_;
      return compareDeep(class_, o.class_, true) && compareDeep(period, o.period, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof ClassHistoryComponent))
        return false;
      ClassHistoryComponent o = (ClassHistoryComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(class_, period);
    }

    public String fhirType() {
      return "Encounter.classHistory";

    }

  }

  @Block()
  public static class EncounterParticipantComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * Role of participant in encounter.
     */
    @Child(name = "type", type = {
        CodeableConcept.class }, order = 1, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
    @Description(shortDefinition = "Role of participant in encounter", formalDefinition = "Role of participant in encounter.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-participant-type")
    protected List type;

    /**
     * The period of time that the specified participant participated in the
     * encounter. These can overlap or be sub-sets of the overall encounter's
     * period.
     */
    @Child(name = "period", type = { Period.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Period of time during the encounter that the participant participated", formalDefinition = "The period of time that the specified participant participated in the encounter. These can overlap or be sub-sets of the overall encounter's period.")
    protected Period period;

    /**
     * Persons involved in the encounter other than the patient.
     */
    @Child(name = "individual", type = { Practitioner.class, PractitionerRole.class,
        RelatedPerson.class }, order = 3, min = 0, max = 1, modifier = false, summary = true)
    @Description(shortDefinition = "Persons involved in the encounter other than the patient", formalDefinition = "Persons involved in the encounter other than the patient.")
    protected Reference individual;

    /**
     * The actual object that is the target of the reference (Persons involved in
     * the encounter other than the patient.)
     */
    protected Resource individualTarget;

    private static final long serialVersionUID = 317095765L;

    /**
     * Constructor
     */
    public EncounterParticipantComponent() {
      super();
    }

    /**
     * @return {@link #type} (Role of participant in encounter.)
     */
    public List getType() {
      if (this.type == null)
        this.type = new ArrayList();
      return this.type;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public EncounterParticipantComponent setType(List theType) {
      this.type = theType;
      return this;
    }

    public boolean hasType() {
      if (this.type == null)
        return false;
      for (CodeableConcept item : this.type)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public CodeableConcept addType() { // 3
      CodeableConcept t = new CodeableConcept();
      if (this.type == null)
        this.type = new ArrayList();
      this.type.add(t);
      return t;
    }

    public EncounterParticipantComponent addType(CodeableConcept t) { // 3
      if (t == null)
        return this;
      if (this.type == null)
        this.type = new ArrayList();
      this.type.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #type}, creating it if
     *         it does not already exist
     */
    public CodeableConcept getTypeFirstRep() {
      if (getType().isEmpty()) {
        addType();
      }
      return getType().get(0);
    }

    /**
     * @return {@link #period} (The period of time that the specified participant
     *         participated in the encounter. These can overlap or be sub-sets of
     *         the overall encounter's period.)
     */
    public Period getPeriod() {
      if (this.period == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterParticipantComponent.period");
        else if (Configuration.doAutoCreate())
          this.period = new Period(); // cc
      return this.period;
    }

    public boolean hasPeriod() {
      return this.period != null && !this.period.isEmpty();
    }

    /**
     * @param value {@link #period} (The period of time that the specified
     *              participant participated in the encounter. These can overlap or
     *              be sub-sets of the overall encounter's period.)
     */
    public EncounterParticipantComponent setPeriod(Period value) {
      this.period = value;
      return this;
    }

    /**
     * @return {@link #individual} (Persons involved in the encounter other than the
     *         patient.)
     */
    public Reference getIndividual() {
      if (this.individual == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterParticipantComponent.individual");
        else if (Configuration.doAutoCreate())
          this.individual = new Reference(); // cc
      return this.individual;
    }

    public boolean hasIndividual() {
      return this.individual != null && !this.individual.isEmpty();
    }

    /**
     * @param value {@link #individual} (Persons involved in the encounter other
     *              than the patient.)
     */
    public EncounterParticipantComponent setIndividual(Reference value) {
      this.individual = value;
      return this;
    }

    /**
     * @return {@link #individual} The actual object that is the target of the
     *         reference. The reference library doesn't populate this, but you can
     *         use it to hold the resource if you resolve it. (Persons involved in
     *         the encounter other than the patient.)
     */
    public Resource getIndividualTarget() {
      return this.individualTarget;
    }

    /**
     * @param value {@link #individual} The actual object that is the target of the
     *              reference. The reference library doesn't use these, but you can
     *              use it to hold the resource if you resolve it. (Persons involved
     *              in the encounter other than the patient.)
     */
    public EncounterParticipantComponent setIndividualTarget(Resource value) {
      this.individualTarget = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("type", "CodeableConcept", "Role of participant in encounter.", 0,
          java.lang.Integer.MAX_VALUE, type));
      children.add(new Property("period", "Period",
          "The period of time that the specified participant participated in the encounter. These can overlap or be sub-sets of the overall encounter's period.",
          0, 1, period));
      children.add(new Property("individual", "Reference(Practitioner|PractitionerRole|RelatedPerson)",
          "Persons involved in the encounter other than the patient.", 0, 1, individual));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 3575610:
        /* type */ return new Property("type", "CodeableConcept", "Role of participant in encounter.", 0,
            java.lang.Integer.MAX_VALUE, type);
      case -991726143:
        /* period */ return new Property("period", "Period",
            "The period of time that the specified participant participated in the encounter. These can overlap or be sub-sets of the overall encounter's period.",
            0, 1, period);
      case -46292327:
        /* individual */ return new Property("individual", "Reference(Practitioner|PractitionerRole|RelatedPerson)",
            "Persons involved in the encounter other than the patient.", 0, 1, individual);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 3575610:
        /* type */ return this.type == null ? new Base[0] : this.type.toArray(new Base[this.type.size()]); // CodeableConcept
      case -991726143:
        /* period */ return this.period == null ? new Base[0] : new Base[] { this.period }; // Period
      case -46292327:
        /* individual */ return this.individual == null ? new Base[0] : new Base[] { this.individual }; // Reference
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 3575610: // type
        this.getType().add(castToCodeableConcept(value)); // CodeableConcept
        return value;
      case -991726143: // period
        this.period = castToPeriod(value); // Period
        return value;
      case -46292327: // individual
        this.individual = castToReference(value); // Reference
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("type")) {
        this.getType().add(castToCodeableConcept(value));
      } else if (name.equals("period")) {
        this.period = castToPeriod(value); // Period
      } else if (name.equals("individual")) {
        this.individual = castToReference(value); // Reference
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("type")) {
        this.getType().remove(castToCodeableConcept(value));
      } else if (name.equals("period")) {
        this.period = null;
      } else if (name.equals("individual")) {
        this.individual = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3575610:
        return addType();
      case -991726143:
        return getPeriod();
      case -46292327:
        return getIndividual();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3575610:
        /* type */ return new String[] { "CodeableConcept" };
      case -991726143:
        /* period */ return new String[] { "Period" };
      case -46292327:
        /* individual */ return new String[] { "Reference" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("type")) {
        return addType();
      } else if (name.equals("period")) {
        this.period = new Period();
        return this.period;
      } else if (name.equals("individual")) {
        this.individual = new Reference();
        return this.individual;
      } else
        return super.addChild(name);
    }

    public EncounterParticipantComponent copy() {
      EncounterParticipantComponent dst = new EncounterParticipantComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(EncounterParticipantComponent dst) {
      super.copyValues(dst);
      if (type != null) {
        dst.type = new ArrayList();
        for (CodeableConcept i : type)
          dst.type.add(i.copy());
      }
      ;
      dst.period = period == null ? null : period.copy();
      dst.individual = individual == null ? null : individual.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof EncounterParticipantComponent))
        return false;
      EncounterParticipantComponent o = (EncounterParticipantComponent) other_;
      return compareDeep(type, o.type, true) && compareDeep(period, o.period, true)
          && compareDeep(individual, o.individual, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof EncounterParticipantComponent))
        return false;
      EncounterParticipantComponent o = (EncounterParticipantComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(type, period, individual);
    }

    public String fhirType() {
      return "Encounter.participant";

    }

  }

  @Block()
  public static class DiagnosisComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * Reason the encounter takes place, as specified using information from another
     * resource. For admissions, this is the admission diagnosis. The indication
     * will typically be a Condition (with other resources referenced in the
     * evidence.detail), or a Procedure.
     */
    @Child(name = "condition", type = { Condition.class,
        Procedure.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
    @Description(shortDefinition = "The diagnosis or procedure relevant to the encounter", formalDefinition = "Reason the encounter takes place, as specified using information from another resource. For admissions, this is the admission diagnosis. The indication will typically be a Condition (with other resources referenced in the evidence.detail), or a Procedure.")
    protected Reference condition;

    /**
     * The actual object that is the target of the reference (Reason the encounter
     * takes place, as specified using information from another resource. For
     * admissions, this is the admission diagnosis. The indication will typically be
     * a Condition (with other resources referenced in the evidence.detail), or a
     * Procedure.)
     */
    protected Resource conditionTarget;

    /**
     * Role that this diagnosis has within the encounter (e.g. admission, billing,
     * discharge …).
     */
    @Child(name = "use", type = {
        CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Role that this diagnosis has within the encounter (e.g. admission, billing, discharge …)", formalDefinition = "Role that this diagnosis has within the encounter (e.g. admission, billing, discharge …).")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/diagnosis-role")
    protected CodeableConcept use;

    /**
     * Ranking of the diagnosis (for each role type).
     */
    @Child(name = "rank", type = {
        PositiveIntType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Ranking of the diagnosis (for each role type)", formalDefinition = "Ranking of the diagnosis (for each role type).")
    protected PositiveIntType rank;

    private static final long serialVersionUID = 128213376L;

    /**
     * Constructor
     */
    public DiagnosisComponent() {
      super();
    }

    /**
     * Constructor
     */
    public DiagnosisComponent(Reference condition) {
      super();
      this.condition = condition;
    }

    /**
     * @return {@link #condition} (Reason the encounter takes place, as specified
     *         using information from another resource. For admissions, this is the
     *         admission diagnosis. The indication will typically be a Condition
     *         (with other resources referenced in the evidence.detail), or a
     *         Procedure.)
     */
    public Reference getCondition() {
      if (this.condition == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create DiagnosisComponent.condition");
        else if (Configuration.doAutoCreate())
          this.condition = new Reference(); // cc
      return this.condition;
    }

    public boolean hasCondition() {
      return this.condition != null && !this.condition.isEmpty();
    }

    /**
     * @param value {@link #condition} (Reason the encounter takes place, as
     *              specified using information from another resource. For
     *              admissions, this is the admission diagnosis. The indication will
     *              typically be a Condition (with other resources referenced in the
     *              evidence.detail), or a Procedure.)
     */
    public DiagnosisComponent setCondition(Reference value) {
      this.condition = value;
      return this;
    }

    /**
     * @return {@link #condition} The actual object that is the target of the
     *         reference. The reference library doesn't populate this, but you can
     *         use it to hold the resource if you resolve it. (Reason the encounter
     *         takes place, as specified using information from another resource.
     *         For admissions, this is the admission diagnosis. The indication will
     *         typically be a Condition (with other resources referenced in the
     *         evidence.detail), or a Procedure.)
     */
    public Resource getConditionTarget() {
      return this.conditionTarget;
    }

    /**
     * @param value {@link #condition} The actual object that is the target of the
     *              reference. The reference library doesn't use these, but you can
     *              use it to hold the resource if you resolve it. (Reason the
     *              encounter takes place, as specified using information from
     *              another resource. For admissions, this is the admission
     *              diagnosis. The indication will typically be a Condition (with
     *              other resources referenced in the evidence.detail), or a
     *              Procedure.)
     */
    public DiagnosisComponent setConditionTarget(Resource value) {
      this.conditionTarget = value;
      return this;
    }

    /**
     * @return {@link #use} (Role that this diagnosis has within the encounter (e.g.
     *         admission, billing, discharge …).)
     */
    public CodeableConcept getUse() {
      if (this.use == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create DiagnosisComponent.use");
        else if (Configuration.doAutoCreate())
          this.use = new CodeableConcept(); // cc
      return this.use;
    }

    public boolean hasUse() {
      return this.use != null && !this.use.isEmpty();
    }

    /**
     * @param value {@link #use} (Role that this diagnosis has within the encounter
     *              (e.g. admission, billing, discharge …).)
     */
    public DiagnosisComponent setUse(CodeableConcept value) {
      this.use = value;
      return this;
    }

    /**
     * @return {@link #rank} (Ranking of the diagnosis (for each role type).). This
     *         is the underlying object with id, value and extensions. The accessor
     *         "getRank" gives direct access to the value
     */
    public PositiveIntType getRankElement() {
      if (this.rank == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create DiagnosisComponent.rank");
        else if (Configuration.doAutoCreate())
          this.rank = new PositiveIntType(); // bb
      return this.rank;
    }

    public boolean hasRankElement() {
      return this.rank != null && !this.rank.isEmpty();
    }

    public boolean hasRank() {
      return this.rank != null && !this.rank.isEmpty();
    }

    /**
     * @param value {@link #rank} (Ranking of the diagnosis (for each role type).).
     *              This is the underlying object with id, value and extensions. The
     *              accessor "getRank" gives direct access to the value
     */
    public DiagnosisComponent setRankElement(PositiveIntType value) {
      this.rank = value;
      return this;
    }

    /**
     * @return Ranking of the diagnosis (for each role type).
     */
    public int getRank() {
      return this.rank == null || this.rank.isEmpty() ? 0 : this.rank.getValue();
    }

    /**
     * @param value Ranking of the diagnosis (for each role type).
     */
    public DiagnosisComponent setRank(int value) {
      if (this.rank == null)
        this.rank = new PositiveIntType();
      this.rank.setValue(value);
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("condition", "Reference(Condition|Procedure)",
          "Reason the encounter takes place, as specified using information from another resource. For admissions, this is the admission diagnosis. The indication will typically be a Condition (with other resources referenced in the evidence.detail), or a Procedure.",
          0, 1, condition));
      children.add(new Property("use", "CodeableConcept",
          "Role that this diagnosis has within the encounter (e.g. admission, billing, discharge …).", 0, 1, use));
      children.add(new Property("rank", "positiveInt", "Ranking of the diagnosis (for each role type).", 0, 1, rank));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case -861311717:
        /* condition */ return new Property("condition", "Reference(Condition|Procedure)",
            "Reason the encounter takes place, as specified using information from another resource. For admissions, this is the admission diagnosis. The indication will typically be a Condition (with other resources referenced in the evidence.detail), or a Procedure.",
            0, 1, condition);
      case 116103:
        /* use */ return new Property("use", "CodeableConcept",
            "Role that this diagnosis has within the encounter (e.g. admission, billing, discharge …).", 0, 1, use);
      case 3492908:
        /* rank */ return new Property("rank", "positiveInt", "Ranking of the diagnosis (for each role type).", 0, 1,
            rank);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case -861311717:
        /* condition */ return this.condition == null ? new Base[0] : new Base[] { this.condition }; // Reference
      case 116103:
        /* use */ return this.use == null ? new Base[0] : new Base[] { this.use }; // CodeableConcept
      case 3492908:
        /* rank */ return this.rank == null ? new Base[0] : new Base[] { this.rank }; // PositiveIntType
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case -861311717: // condition
        this.condition = castToReference(value); // Reference
        return value;
      case 116103: // use
        this.use = castToCodeableConcept(value); // CodeableConcept
        return value;
      case 3492908: // rank
        this.rank = castToPositiveInt(value); // PositiveIntType
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("condition")) {
        this.condition = castToReference(value); // Reference
      } else if (name.equals("use")) {
        this.use = castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("rank")) {
        this.rank = castToPositiveInt(value); // PositiveIntType
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("condition")) {
        this.condition = null;
      } else if (name.equals("use")) {
        this.use = null;
      } else if (name.equals("rank")) {
        this.rank = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -861311717:
        return getCondition();
      case 116103:
        return getUse();
      case 3492908:
        return getRankElement();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -861311717:
        /* condition */ return new String[] { "Reference" };
      case 116103:
        /* use */ return new String[] { "CodeableConcept" };
      case 3492908:
        /* rank */ return new String[] { "positiveInt" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("condition")) {
        this.condition = new Reference();
        return this.condition;
      } else if (name.equals("use")) {
        this.use = new CodeableConcept();
        return this.use;
      } else if (name.equals("rank")) {
        throw new FHIRException("Cannot call addChild on a singleton property Encounter.rank");
      } else
        return super.addChild(name);
    }

    public DiagnosisComponent copy() {
      DiagnosisComponent dst = new DiagnosisComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(DiagnosisComponent dst) {
      super.copyValues(dst);
      dst.condition = condition == null ? null : condition.copy();
      dst.use = use == null ? null : use.copy();
      dst.rank = rank == null ? null : rank.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof DiagnosisComponent))
        return false;
      DiagnosisComponent o = (DiagnosisComponent) other_;
      return compareDeep(condition, o.condition, true) && compareDeep(use, o.use, true)
          && compareDeep(rank, o.rank, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof DiagnosisComponent))
        return false;
      DiagnosisComponent o = (DiagnosisComponent) other_;
      return compareValues(rank, o.rank, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(condition, use, rank);
    }

    public String fhirType() {
      return "Encounter.diagnosis";

    }

  }

  @Block()
  public static class EncounterHospitalizationComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * Pre-admission identifier.
     */
    @Child(name = "preAdmissionIdentifier", type = {
        Identifier.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Pre-admission identifier", formalDefinition = "Pre-admission identifier.")
    protected Identifier preAdmissionIdentifier;

    /**
     * The location/organization from which the patient came before admission.
     */
    @Child(name = "origin", type = { Location.class,
        Organization.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The location/organization from which the patient came before admission", formalDefinition = "The location/organization from which the patient came before admission.")
    protected Reference origin;

    /**
     * The actual object that is the target of the reference (The
     * location/organization from which the patient came before admission.)
     */
    protected Resource originTarget;

    /**
     * From where patient was admitted (physician referral, transfer).
     */
    @Child(name = "admitSource", type = {
        CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "From where patient was admitted (physician referral, transfer)", formalDefinition = "From where patient was admitted (physician referral, transfer).")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-admit-source")
    protected CodeableConcept admitSource;

    /**
     * Whether this hospitalization is a readmission and why if known.
     */
    @Child(name = "reAdmission", type = {
        CodeableConcept.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The type of hospital re-admission that has occurred (if any). If the value is absent, then this is not identified as a readmission", formalDefinition = "Whether this hospitalization is a readmission and why if known.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v2-0092")
    protected CodeableConcept reAdmission;

    /**
     * Diet preferences reported by the patient.
     */
    @Child(name = "dietPreference", type = {
        CodeableConcept.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Diet preferences reported by the patient", formalDefinition = "Diet preferences reported by the patient.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-diet")
    protected List dietPreference;

    /**
     * Special courtesies (VIP, board member).
     */
    @Child(name = "specialCourtesy", type = {
        CodeableConcept.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Special courtesies (VIP, board member)", formalDefinition = "Special courtesies (VIP, board member).")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-special-courtesy")
    protected List specialCourtesy;

    /**
     * Any special requests that have been made for this hospitalization encounter,
     * such as the provision of specific equipment or other things.
     */
    @Child(name = "specialArrangement", type = {
        CodeableConcept.class }, order = 7, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Wheelchair, translator, stretcher, etc.", formalDefinition = "Any special requests that have been made for this hospitalization encounter, such as the provision of specific equipment or other things.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-special-arrangements")
    protected List specialArrangement;

    /**
     * Location/organization to which the patient is discharged.
     */
    @Child(name = "destination", type = { Location.class,
        Organization.class }, order = 8, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Location/organization to which the patient is discharged", formalDefinition = "Location/organization to which the patient is discharged.")
    protected Reference destination;

    /**
     * The actual object that is the target of the reference (Location/organization
     * to which the patient is discharged.)
     */
    protected Resource destinationTarget;

    /**
     * Category or kind of location after discharge.
     */
    @Child(name = "dischargeDisposition", type = {
        CodeableConcept.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Category or kind of location after discharge", formalDefinition = "Category or kind of location after discharge.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-discharge-disposition")
    protected CodeableConcept dischargeDisposition;

    private static final long serialVersionUID = 1350555270L;

    /**
     * Constructor
     */
    public EncounterHospitalizationComponent() {
      super();
    }

    /**
     * @return {@link #preAdmissionIdentifier} (Pre-admission identifier.)
     */
    public Identifier getPreAdmissionIdentifier() {
      if (this.preAdmissionIdentifier == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterHospitalizationComponent.preAdmissionIdentifier");
        else if (Configuration.doAutoCreate())
          this.preAdmissionIdentifier = new Identifier(); // cc
      return this.preAdmissionIdentifier;
    }

    public boolean hasPreAdmissionIdentifier() {
      return this.preAdmissionIdentifier != null && !this.preAdmissionIdentifier.isEmpty();
    }

    /**
     * @param value {@link #preAdmissionIdentifier} (Pre-admission identifier.)
     */
    public EncounterHospitalizationComponent setPreAdmissionIdentifier(Identifier value) {
      this.preAdmissionIdentifier = value;
      return this;
    }

    /**
     * @return {@link #origin} (The location/organization from which the patient
     *         came before admission.)
     */
    public Reference getOrigin() {
      if (this.origin == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterHospitalizationComponent.origin");
        else if (Configuration.doAutoCreate())
          this.origin = new Reference(); // cc
      return this.origin;
    }

    public boolean hasOrigin() {
      return this.origin != null && !this.origin.isEmpty();
    }

    /**
     * @param value {@link #origin} (The location/organization from which the
     *              patient came before admission.)
     */
    public EncounterHospitalizationComponent setOrigin(Reference value) {
      this.origin = value;
      return this;
    }

    /**
     * @return {@link #origin} The actual object that is the target of the
     *         reference. The reference library doesn't populate this, but you can
     *         use it to hold the resource if you resolve it. (The
     *         location/organization from which the patient came before admission.)
     */
    public Resource getOriginTarget() {
      return this.originTarget;
    }

    /**
     * @param value {@link #origin} The actual object that is the target of the
     *              reference. The reference library doesn't use these, but you can
     *              use it to hold the resource if you resolve it. (The
     *              location/organization from which the patient came before
     *              admission.)
     */
    public EncounterHospitalizationComponent setOriginTarget(Resource value) {
      this.originTarget = value;
      return this;
    }

    /**
     * @return {@link #admitSource} (From where patient was admitted (physician
     *         referral, transfer).)
     */
    public CodeableConcept getAdmitSource() {
      if (this.admitSource == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterHospitalizationComponent.admitSource");
        else if (Configuration.doAutoCreate())
          this.admitSource = new CodeableConcept(); // cc
      return this.admitSource;
    }

    public boolean hasAdmitSource() {
      return this.admitSource != null && !this.admitSource.isEmpty();
    }

    /**
     * @param value {@link #admitSource} (From where patient was admitted (physician
     *              referral, transfer).)
     */
    public EncounterHospitalizationComponent setAdmitSource(CodeableConcept value) {
      this.admitSource = value;
      return this;
    }

    /**
     * @return {@link #reAdmission} (Whether this hospitalization is a readmission
     *         and why if known.)
     */
    public CodeableConcept getReAdmission() {
      if (this.reAdmission == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterHospitalizationComponent.reAdmission");
        else if (Configuration.doAutoCreate())
          this.reAdmission = new CodeableConcept(); // cc
      return this.reAdmission;
    }

    public boolean hasReAdmission() {
      return this.reAdmission != null && !this.reAdmission.isEmpty();
    }

    /**
     * @param value {@link #reAdmission} (Whether this hospitalization is a
     *              readmission and why if known.)
     */
    public EncounterHospitalizationComponent setReAdmission(CodeableConcept value) {
      this.reAdmission = value;
      return this;
    }

    /**
     * @return {@link #dietPreference} (Diet preferences reported by the patient.)
     */
    public List getDietPreference() {
      if (this.dietPreference == null)
        this.dietPreference = new ArrayList();
      return this.dietPreference;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public EncounterHospitalizationComponent setDietPreference(List theDietPreference) {
      this.dietPreference = theDietPreference;
      return this;
    }

    public boolean hasDietPreference() {
      if (this.dietPreference == null)
        return false;
      for (CodeableConcept item : this.dietPreference)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public CodeableConcept addDietPreference() { // 3
      CodeableConcept t = new CodeableConcept();
      if (this.dietPreference == null)
        this.dietPreference = new ArrayList();
      this.dietPreference.add(t);
      return t;
    }

    public EncounterHospitalizationComponent addDietPreference(CodeableConcept t) { // 3
      if (t == null)
        return this;
      if (this.dietPreference == null)
        this.dietPreference = new ArrayList();
      this.dietPreference.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #dietPreference},
     *         creating it if it does not already exist
     */
    public CodeableConcept getDietPreferenceFirstRep() {
      if (getDietPreference().isEmpty()) {
        addDietPreference();
      }
      return getDietPreference().get(0);
    }

    /**
     * @return {@link #specialCourtesy} (Special courtesies (VIP, board member).)
     */
    public List getSpecialCourtesy() {
      if (this.specialCourtesy == null)
        this.specialCourtesy = new ArrayList();
      return this.specialCourtesy;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public EncounterHospitalizationComponent setSpecialCourtesy(List theSpecialCourtesy) {
      this.specialCourtesy = theSpecialCourtesy;
      return this;
    }

    public boolean hasSpecialCourtesy() {
      if (this.specialCourtesy == null)
        return false;
      for (CodeableConcept item : this.specialCourtesy)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public CodeableConcept addSpecialCourtesy() { // 3
      CodeableConcept t = new CodeableConcept();
      if (this.specialCourtesy == null)
        this.specialCourtesy = new ArrayList();
      this.specialCourtesy.add(t);
      return t;
    }

    public EncounterHospitalizationComponent addSpecialCourtesy(CodeableConcept t) { // 3
      if (t == null)
        return this;
      if (this.specialCourtesy == null)
        this.specialCourtesy = new ArrayList();
      this.specialCourtesy.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #specialCourtesy},
     *         creating it if it does not already exist
     */
    public CodeableConcept getSpecialCourtesyFirstRep() {
      if (getSpecialCourtesy().isEmpty()) {
        addSpecialCourtesy();
      }
      return getSpecialCourtesy().get(0);
    }

    /**
     * @return {@link #specialArrangement} (Any special requests that have been made
     *         for this hospitalization encounter, such as the provision of specific
     *         equipment or other things.)
     */
    public List getSpecialArrangement() {
      if (this.specialArrangement == null)
        this.specialArrangement = new ArrayList();
      return this.specialArrangement;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public EncounterHospitalizationComponent setSpecialArrangement(List theSpecialArrangement) {
      this.specialArrangement = theSpecialArrangement;
      return this;
    }

    public boolean hasSpecialArrangement() {
      if (this.specialArrangement == null)
        return false;
      for (CodeableConcept item : this.specialArrangement)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public CodeableConcept addSpecialArrangement() { // 3
      CodeableConcept t = new CodeableConcept();
      if (this.specialArrangement == null)
        this.specialArrangement = new ArrayList();
      this.specialArrangement.add(t);
      return t;
    }

    public EncounterHospitalizationComponent addSpecialArrangement(CodeableConcept t) { // 3
      if (t == null)
        return this;
      if (this.specialArrangement == null)
        this.specialArrangement = new ArrayList();
      this.specialArrangement.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #specialArrangement},
     *         creating it if it does not already exist
     */
    public CodeableConcept getSpecialArrangementFirstRep() {
      if (getSpecialArrangement().isEmpty()) {
        addSpecialArrangement();
      }
      return getSpecialArrangement().get(0);
    }

    /**
     * @return {@link #destination} (Location/organization to which the patient is
     *         discharged.)
     */
    public Reference getDestination() {
      if (this.destination == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterHospitalizationComponent.destination");
        else if (Configuration.doAutoCreate())
          this.destination = new Reference(); // cc
      return this.destination;
    }

    public boolean hasDestination() {
      return this.destination != null && !this.destination.isEmpty();
    }

    /**
     * @param value {@link #destination} (Location/organization to which the patient
     *              is discharged.)
     */
    public EncounterHospitalizationComponent setDestination(Reference value) {
      this.destination = value;
      return this;
    }

    /**
     * @return {@link #destination} The actual object that is the target of the
     *         reference. The reference library doesn't populate this, but you can
     *         use it to hold the resource if you resolve it. (Location/organization
     *         to which the patient is discharged.)
     */
    public Resource getDestinationTarget() {
      return this.destinationTarget;
    }

    /**
     * @param value {@link #destination} The actual object that is the target of the
     *              reference. The reference library doesn't use these, but you can
     *              use it to hold the resource if you resolve it.
     *              (Location/organization to which the patient is discharged.)
     */
    public EncounterHospitalizationComponent setDestinationTarget(Resource value) {
      this.destinationTarget = value;
      return this;
    }

    /**
     * @return {@link #dischargeDisposition} (Category or kind of location after
     *         discharge.)
     */
    public CodeableConcept getDischargeDisposition() {
      if (this.dischargeDisposition == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterHospitalizationComponent.dischargeDisposition");
        else if (Configuration.doAutoCreate())
          this.dischargeDisposition = new CodeableConcept(); // cc
      return this.dischargeDisposition;
    }

    public boolean hasDischargeDisposition() {
      return this.dischargeDisposition != null && !this.dischargeDisposition.isEmpty();
    }

    /**
     * @param value {@link #dischargeDisposition} (Category or kind of location
     *              after discharge.)
     */
    public EncounterHospitalizationComponent setDischargeDisposition(CodeableConcept value) {
      this.dischargeDisposition = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("preAdmissionIdentifier", "Identifier", "Pre-admission identifier.", 0, 1,
          preAdmissionIdentifier));
      children.add(new Property("origin", "Reference(Location|Organization)",
          "The location/organization from which the patient came before admission.", 0, 1, origin));
      children.add(new Property("admitSource", "CodeableConcept",
          "From where patient was admitted (physician referral, transfer).", 0, 1, admitSource));
      children.add(new Property("reAdmission", "CodeableConcept",
          "Whether this hospitalization is a readmission and why if known.", 0, 1, reAdmission));
      children.add(new Property("dietPreference", "CodeableConcept", "Diet preferences reported by the patient.", 0,
          java.lang.Integer.MAX_VALUE, dietPreference));
      children.add(new Property("specialCourtesy", "CodeableConcept", "Special courtesies (VIP, board member).", 0,
          java.lang.Integer.MAX_VALUE, specialCourtesy));
      children.add(new Property("specialArrangement", "CodeableConcept",
          "Any special requests that have been made for this hospitalization encounter, such as the provision of specific equipment or other things.",
          0, java.lang.Integer.MAX_VALUE, specialArrangement));
      children.add(new Property("destination", "Reference(Location|Organization)",
          "Location/organization to which the patient is discharged.", 0, 1, destination));
      children.add(new Property("dischargeDisposition", "CodeableConcept",
          "Category or kind of location after discharge.", 0, 1, dischargeDisposition));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case -965394961:
        /* preAdmissionIdentifier */ return new Property("preAdmissionIdentifier", "Identifier",
            "Pre-admission identifier.", 0, 1, preAdmissionIdentifier);
      case -1008619738:
        /* origin */ return new Property("origin", "Reference(Location|Organization)",
            "The location/organization from which the patient came before admission.", 0, 1, origin);
      case 538887120:
        /* admitSource */ return new Property("admitSource", "CodeableConcept",
            "From where patient was admitted (physician referral, transfer).", 0, 1, admitSource);
      case 669348630:
        /* reAdmission */ return new Property("reAdmission", "CodeableConcept",
            "Whether this hospitalization is a readmission and why if known.", 0, 1, reAdmission);
      case -1360641041:
        /* dietPreference */ return new Property("dietPreference", "CodeableConcept",
            "Diet preferences reported by the patient.", 0, java.lang.Integer.MAX_VALUE, dietPreference);
      case 1583588345:
        /* specialCourtesy */ return new Property("specialCourtesy", "CodeableConcept",
            "Special courtesies (VIP, board member).", 0, java.lang.Integer.MAX_VALUE, specialCourtesy);
      case 47410321:
        /* specialArrangement */ return new Property("specialArrangement", "CodeableConcept",
            "Any special requests that have been made for this hospitalization encounter, such as the provision of specific equipment or other things.",
            0, java.lang.Integer.MAX_VALUE, specialArrangement);
      case -1429847026:
        /* destination */ return new Property("destination", "Reference(Location|Organization)",
            "Location/organization to which the patient is discharged.", 0, 1, destination);
      case 528065941:
        /* dischargeDisposition */ return new Property("dischargeDisposition", "CodeableConcept",
            "Category or kind of location after discharge.", 0, 1, dischargeDisposition);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case -965394961:
        /* preAdmissionIdentifier */ return this.preAdmissionIdentifier == null ? new Base[0]
            : new Base[] { this.preAdmissionIdentifier }; // Identifier
      case -1008619738:
        /* origin */ return this.origin == null ? new Base[0] : new Base[] { this.origin }; // Reference
      case 538887120:
        /* admitSource */ return this.admitSource == null ? new Base[0] : new Base[] { this.admitSource }; // CodeableConcept
      case 669348630:
        /* reAdmission */ return this.reAdmission == null ? new Base[0] : new Base[] { this.reAdmission }; // CodeableConcept
      case -1360641041:
        /* dietPreference */ return this.dietPreference == null ? new Base[0]
            : this.dietPreference.toArray(new Base[this.dietPreference.size()]); // CodeableConcept
      case 1583588345:
        /* specialCourtesy */ return this.specialCourtesy == null ? new Base[0]
            : this.specialCourtesy.toArray(new Base[this.specialCourtesy.size()]); // CodeableConcept
      case 47410321:
        /* specialArrangement */ return this.specialArrangement == null ? new Base[0]
            : this.specialArrangement.toArray(new Base[this.specialArrangement.size()]); // CodeableConcept
      case -1429847026:
        /* destination */ return this.destination == null ? new Base[0] : new Base[] { this.destination }; // Reference
      case 528065941:
        /* dischargeDisposition */ return this.dischargeDisposition == null ? new Base[0]
            : new Base[] { this.dischargeDisposition }; // CodeableConcept
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case -965394961: // preAdmissionIdentifier
        this.preAdmissionIdentifier = castToIdentifier(value); // Identifier
        return value;
      case -1008619738: // origin
        this.origin = castToReference(value); // Reference
        return value;
      case 538887120: // admitSource
        this.admitSource = castToCodeableConcept(value); // CodeableConcept
        return value;
      case 669348630: // reAdmission
        this.reAdmission = castToCodeableConcept(value); // CodeableConcept
        return value;
      case -1360641041: // dietPreference
        this.getDietPreference().add(castToCodeableConcept(value)); // CodeableConcept
        return value;
      case 1583588345: // specialCourtesy
        this.getSpecialCourtesy().add(castToCodeableConcept(value)); // CodeableConcept
        return value;
      case 47410321: // specialArrangement
        this.getSpecialArrangement().add(castToCodeableConcept(value)); // CodeableConcept
        return value;
      case -1429847026: // destination
        this.destination = castToReference(value); // Reference
        return value;
      case 528065941: // dischargeDisposition
        this.dischargeDisposition = castToCodeableConcept(value); // CodeableConcept
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("preAdmissionIdentifier")) {
        this.preAdmissionIdentifier = castToIdentifier(value); // Identifier
      } else if (name.equals("origin")) {
        this.origin = castToReference(value); // Reference
      } else if (name.equals("admitSource")) {
        this.admitSource = castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("reAdmission")) {
        this.reAdmission = castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("dietPreference")) {
        this.getDietPreference().add(castToCodeableConcept(value));
      } else if (name.equals("specialCourtesy")) {
        this.getSpecialCourtesy().add(castToCodeableConcept(value));
      } else if (name.equals("specialArrangement")) {
        this.getSpecialArrangement().add(castToCodeableConcept(value));
      } else if (name.equals("destination")) {
        this.destination = castToReference(value); // Reference
      } else if (name.equals("dischargeDisposition")) {
        this.dischargeDisposition = castToCodeableConcept(value); // CodeableConcept
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("preAdmissionIdentifier")) {
        this.preAdmissionIdentifier = null;
      } else if (name.equals("origin")) {
        this.origin = null;
      } else if (name.equals("admitSource")) {
        this.admitSource = null;
      } else if (name.equals("reAdmission")) {
        this.reAdmission = null;
      } else if (name.equals("dietPreference")) {
        this.getDietPreference().remove(castToCodeableConcept(value));
      } else if (name.equals("specialCourtesy")) {
        this.getSpecialCourtesy().remove(castToCodeableConcept(value));
      } else if (name.equals("specialArrangement")) {
        this.getSpecialArrangement().remove(castToCodeableConcept(value));
      } else if (name.equals("destination")) {
        this.destination = null;
      } else if (name.equals("dischargeDisposition")) {
        this.dischargeDisposition = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -965394961:
        return getPreAdmissionIdentifier();
      case -1008619738:
        return getOrigin();
      case 538887120:
        return getAdmitSource();
      case 669348630:
        return getReAdmission();
      case -1360641041:
        return addDietPreference();
      case 1583588345:
        return addSpecialCourtesy();
      case 47410321:
        return addSpecialArrangement();
      case -1429847026:
        return getDestination();
      case 528065941:
        return getDischargeDisposition();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -965394961:
        /* preAdmissionIdentifier */ return new String[] { "Identifier" };
      case -1008619738:
        /* origin */ return new String[] { "Reference" };
      case 538887120:
        /* admitSource */ return new String[] { "CodeableConcept" };
      case 669348630:
        /* reAdmission */ return new String[] { "CodeableConcept" };
      case -1360641041:
        /* dietPreference */ return new String[] { "CodeableConcept" };
      case 1583588345:
        /* specialCourtesy */ return new String[] { "CodeableConcept" };
      case 47410321:
        /* specialArrangement */ return new String[] { "CodeableConcept" };
      case -1429847026:
        /* destination */ return new String[] { "Reference" };
      case 528065941:
        /* dischargeDisposition */ return new String[] { "CodeableConcept" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("preAdmissionIdentifier")) {
        this.preAdmissionIdentifier = new Identifier();
        return this.preAdmissionIdentifier;
      } else if (name.equals("origin")) {
        this.origin = new Reference();
        return this.origin;
      } else if (name.equals("admitSource")) {
        this.admitSource = new CodeableConcept();
        return this.admitSource;
      } else if (name.equals("reAdmission")) {
        this.reAdmission = new CodeableConcept();
        return this.reAdmission;
      } else if (name.equals("dietPreference")) {
        return addDietPreference();
      } else if (name.equals("specialCourtesy")) {
        return addSpecialCourtesy();
      } else if (name.equals("specialArrangement")) {
        return addSpecialArrangement();
      } else if (name.equals("destination")) {
        this.destination = new Reference();
        return this.destination;
      } else if (name.equals("dischargeDisposition")) {
        this.dischargeDisposition = new CodeableConcept();
        return this.dischargeDisposition;
      } else
        return super.addChild(name);
    }

    public EncounterHospitalizationComponent copy() {
      EncounterHospitalizationComponent dst = new EncounterHospitalizationComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(EncounterHospitalizationComponent dst) {
      super.copyValues(dst);
      dst.preAdmissionIdentifier = preAdmissionIdentifier == null ? null : preAdmissionIdentifier.copy();
      dst.origin = origin == null ? null : origin.copy();
      dst.admitSource = admitSource == null ? null : admitSource.copy();
      dst.reAdmission = reAdmission == null ? null : reAdmission.copy();
      if (dietPreference != null) {
        dst.dietPreference = new ArrayList();
        for (CodeableConcept i : dietPreference)
          dst.dietPreference.add(i.copy());
      }
      ;
      if (specialCourtesy != null) {
        dst.specialCourtesy = new ArrayList();
        for (CodeableConcept i : specialCourtesy)
          dst.specialCourtesy.add(i.copy());
      }
      ;
      if (specialArrangement != null) {
        dst.specialArrangement = new ArrayList();
        for (CodeableConcept i : specialArrangement)
          dst.specialArrangement.add(i.copy());
      }
      ;
      dst.destination = destination == null ? null : destination.copy();
      dst.dischargeDisposition = dischargeDisposition == null ? null : dischargeDisposition.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof EncounterHospitalizationComponent))
        return false;
      EncounterHospitalizationComponent o = (EncounterHospitalizationComponent) other_;
      return compareDeep(preAdmissionIdentifier, o.preAdmissionIdentifier, true) && compareDeep(origin, o.origin, true)
          && compareDeep(admitSource, o.admitSource, true) && compareDeep(reAdmission, o.reAdmission, true)
          && compareDeep(dietPreference, o.dietPreference, true)
          && compareDeep(specialCourtesy, o.specialCourtesy, true)
          && compareDeep(specialArrangement, o.specialArrangement, true)
          && compareDeep(destination, o.destination, true)
          && compareDeep(dischargeDisposition, o.dischargeDisposition, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof EncounterHospitalizationComponent))
        return false;
      EncounterHospitalizationComponent o = (EncounterHospitalizationComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(preAdmissionIdentifier, origin, admitSource,
          reAdmission, dietPreference, specialCourtesy, specialArrangement, destination, dischargeDisposition);
    }

    public String fhirType() {
      return "Encounter.hospitalization";

    }

  }

  @Block()
  public static class EncounterLocationComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The location where the encounter takes place.
     */
    @Child(name = "location", type = { Location.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Location the encounter takes place", formalDefinition = "The location where the encounter takes place.")
    protected Reference location;

    /**
     * The actual object that is the target of the reference (The location where the
     * encounter takes place.)
     */
    protected Location locationTarget;

    /**
     * The status of the participants' presence at the specified location during the
     * period specified. If the participant is no longer at the location, then the
     * period will have an end date/time.
     */
    @Child(name = "status", type = { CodeType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "planned | active | reserved | completed", formalDefinition = "The status of the participants' presence at the specified location during the period specified. If the participant is no longer at the location, then the period will have an end date/time.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-location-status")
    protected Enumeration status;

    /**
     * This will be used to specify the required levels (bed/ward/room/etc.) desired
     * to be recorded to simplify either messaging or query.
     */
    @Child(name = "physicalType", type = {
        CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The physical type of the location (usually the level in the location hierachy - bed room ward etc.)", formalDefinition = "This will be used to specify the required levels (bed/ward/room/etc.) desired to be recorded to simplify either messaging or query.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/location-physical-type")
    protected CodeableConcept physicalType;

    /**
     * Time period during which the patient was present at the location.
     */
    @Child(name = "period", type = { Period.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Time period during which the patient was present at the location", formalDefinition = "Time period during which the patient was present at the location.")
    protected Period period;

    private static final long serialVersionUID = -755081862L;

    /**
     * Constructor
     */
    public EncounterLocationComponent() {
      super();
    }

    /**
     * Constructor
     */
    public EncounterLocationComponent(Reference location) {
      super();
      this.location = location;
    }

    /**
     * @return {@link #location} (The location where the encounter takes place.)
     */
    public Reference getLocation() {
      if (this.location == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterLocationComponent.location");
        else if (Configuration.doAutoCreate())
          this.location = new Reference(); // cc
      return this.location;
    }

    public boolean hasLocation() {
      return this.location != null && !this.location.isEmpty();
    }

    /**
     * @param value {@link #location} (The location where the encounter takes
     *              place.)
     */
    public EncounterLocationComponent setLocation(Reference value) {
      this.location = value;
      return this;
    }

    /**
     * @return {@link #location} The actual object that is the target of the
     *         reference. The reference library doesn't populate this, but you can
     *         use it to hold the resource if you resolve it. (The location where
     *         the encounter takes place.)
     */
    public Location getLocationTarget() {
      if (this.locationTarget == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterLocationComponent.location");
        else if (Configuration.doAutoCreate())
          this.locationTarget = new Location(); // aa
      return this.locationTarget;
    }

    /**
     * @param value {@link #location} The actual object that is the target of the
     *              reference. The reference library doesn't use these, but you can
     *              use it to hold the resource if you resolve it. (The location
     *              where the encounter takes place.)
     */
    public EncounterLocationComponent setLocationTarget(Location value) {
      this.locationTarget = value;
      return this;
    }

    /**
     * @return {@link #status} (The status of the participants' presence at the
     *         specified location during the period specified. If the participant is
     *         no longer at the location, then the period will have an end
     *         date/time.). This is the underlying object with id, value and
     *         extensions. The accessor "getStatus" gives direct access to the value
     */
    public Enumeration getStatusElement() {
      if (this.status == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterLocationComponent.status");
        else if (Configuration.doAutoCreate())
          this.status = new Enumeration(new EncounterLocationStatusEnumFactory()); // bb
      return this.status;
    }

    public boolean hasStatusElement() {
      return this.status != null && !this.status.isEmpty();
    }

    public boolean hasStatus() {
      return this.status != null && !this.status.isEmpty();
    }

    /**
     * @param value {@link #status} (The status of the participants' presence at the
     *              specified location during the period specified. If the
     *              participant is no longer at the location, then the period will
     *              have an end date/time.). This is the underlying object with id,
     *              value and extensions. The accessor "getStatus" gives direct
     *              access to the value
     */
    public EncounterLocationComponent setStatusElement(Enumeration value) {
      this.status = value;
      return this;
    }

    /**
     * @return The status of the participants' presence at the specified location
     *         during the period specified. If the participant is no longer at the
     *         location, then the period will have an end date/time.
     */
    public EncounterLocationStatus getStatus() {
      return this.status == null ? null : this.status.getValue();
    }

    /**
     * @param value The status of the participants' presence at the specified
     *              location during the period specified. If the participant is no
     *              longer at the location, then the period will have an end
     *              date/time.
     */
    public EncounterLocationComponent setStatus(EncounterLocationStatus value) {
      if (value == null)
        this.status = null;
      else {
        if (this.status == null)
          this.status = new Enumeration(new EncounterLocationStatusEnumFactory());
        this.status.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #physicalType} (This will be used to specify the required
     *         levels (bed/ward/room/etc.) desired to be recorded to simplify either
     *         messaging or query.)
     */
    public CodeableConcept getPhysicalType() {
      if (this.physicalType == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterLocationComponent.physicalType");
        else if (Configuration.doAutoCreate())
          this.physicalType = new CodeableConcept(); // cc
      return this.physicalType;
    }

    public boolean hasPhysicalType() {
      return this.physicalType != null && !this.physicalType.isEmpty();
    }

    /**
     * @param value {@link #physicalType} (This will be used to specify the required
     *              levels (bed/ward/room/etc.) desired to be recorded to simplify
     *              either messaging or query.)
     */
    public EncounterLocationComponent setPhysicalType(CodeableConcept value) {
      this.physicalType = value;
      return this;
    }

    /**
     * @return {@link #period} (Time period during which the patient was present at
     *         the location.)
     */
    public Period getPeriod() {
      if (this.period == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EncounterLocationComponent.period");
        else if (Configuration.doAutoCreate())
          this.period = new Period(); // cc
      return this.period;
    }

    public boolean hasPeriod() {
      return this.period != null && !this.period.isEmpty();
    }

    /**
     * @param value {@link #period} (Time period during which the patient was
     *              present at the location.)
     */
    public EncounterLocationComponent setPeriod(Period value) {
      this.period = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("location", "Reference(Location)", "The location where the encounter takes place.", 0,
          1, location));
      children.add(new Property("status", "code",
          "The status of the participants' presence at the specified location during the period specified. If the participant is no longer at the location, then the period will have an end date/time.",
          0, 1, status));
      children.add(new Property("physicalType", "CodeableConcept",
          "This will be used to specify the required levels (bed/ward/room/etc.) desired to be recorded to simplify either messaging or query.",
          0, 1, physicalType));
      children.add(new Property("period", "Period", "Time period during which the patient was present at the location.",
          0, 1, period));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 1901043637:
        /* location */ return new Property("location", "Reference(Location)",
            "The location where the encounter takes place.", 0, 1, location);
      case -892481550:
        /* status */ return new Property("status", "code",
            "The status of the participants' presence at the specified location during the period specified. If the participant is no longer at the location, then the period will have an end date/time.",
            0, 1, status);
      case -1474715471:
        /* physicalType */ return new Property("physicalType", "CodeableConcept",
            "This will be used to specify the required levels (bed/ward/room/etc.) desired to be recorded to simplify either messaging or query.",
            0, 1, physicalType);
      case -991726143:
        /* period */ return new Property("period", "Period",
            "Time period during which the patient was present at the location.", 0, 1, period);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 1901043637:
        /* location */ return this.location == null ? new Base[0] : new Base[] { this.location }; // Reference
      case -892481550:
        /* status */ return this.status == null ? new Base[0] : new Base[] { this.status }; // Enumeration
      case -1474715471:
        /* physicalType */ return this.physicalType == null ? new Base[0] : new Base[] { this.physicalType }; // CodeableConcept
      case -991726143:
        /* period */ return this.period == null ? new Base[0] : new Base[] { this.period }; // Period
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 1901043637: // location
        this.location = castToReference(value); // Reference
        return value;
      case -892481550: // status
        value = new EncounterLocationStatusEnumFactory().fromType(castToCode(value));
        this.status = (Enumeration) value; // Enumeration
        return value;
      case -1474715471: // physicalType
        this.physicalType = castToCodeableConcept(value); // CodeableConcept
        return value;
      case -991726143: // period
        this.period = castToPeriod(value); // Period
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("location")) {
        this.location = castToReference(value); // Reference
      } else if (name.equals("status")) {
        value = new EncounterLocationStatusEnumFactory().fromType(castToCode(value));
        this.status = (Enumeration) value; // Enumeration
      } else if (name.equals("physicalType")) {
        this.physicalType = castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("period")) {
        this.period = castToPeriod(value); // Period
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("location")) {
        this.location = null;
      } else if (name.equals("status")) {
        this.status = null;
      } else if (name.equals("physicalType")) {
        this.physicalType = null;
      } else if (name.equals("period")) {
        this.period = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1901043637:
        return getLocation();
      case -892481550:
        return getStatusElement();
      case -1474715471:
        return getPhysicalType();
      case -991726143:
        return getPeriod();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1901043637:
        /* location */ return new String[] { "Reference" };
      case -892481550:
        /* status */ return new String[] { "code" };
      case -1474715471:
        /* physicalType */ return new String[] { "CodeableConcept" };
      case -991726143:
        /* period */ return new String[] { "Period" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("location")) {
        this.location = new Reference();
        return this.location;
      } else if (name.equals("status")) {
        throw new FHIRException("Cannot call addChild on a singleton property Encounter.status");
      } else if (name.equals("physicalType")) {
        this.physicalType = new CodeableConcept();
        return this.physicalType;
      } else if (name.equals("period")) {
        this.period = new Period();
        return this.period;
      } else
        return super.addChild(name);
    }

    public EncounterLocationComponent copy() {
      EncounterLocationComponent dst = new EncounterLocationComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(EncounterLocationComponent dst) {
      super.copyValues(dst);
      dst.location = location == null ? null : location.copy();
      dst.status = status == null ? null : status.copy();
      dst.physicalType = physicalType == null ? null : physicalType.copy();
      dst.period = period == null ? null : period.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof EncounterLocationComponent))
        return false;
      EncounterLocationComponent o = (EncounterLocationComponent) other_;
      return compareDeep(location, o.location, true) && compareDeep(status, o.status, true)
          && compareDeep(physicalType, o.physicalType, true) && compareDeep(period, o.period, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof EncounterLocationComponent))
        return false;
      EncounterLocationComponent o = (EncounterLocationComponent) other_;
      return compareValues(status, o.status, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(location, status, physicalType, period);
    }

    public String fhirType() {
      return "Encounter.location";

    }

  }

  /**
   * Identifier(s) by which this encounter is known.
   */
  @Child(name = "identifier", type = {
      Identifier.class }, order = 0, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Identifier(s) by which this encounter is known", formalDefinition = "Identifier(s) by which this encounter is known.")
  protected List identifier;

  /**
   * planned | arrived | triaged | in-progress | onleave | finished | cancelled +.
   */
  @Child(name = "status", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = true, summary = true)
  @Description(shortDefinition = "planned | arrived | triaged | in-progress | onleave | finished | cancelled +", formalDefinition = "planned | arrived | triaged | in-progress | onleave | finished | cancelled +.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-status")
  protected Enumeration status;

  /**
   * The status history permits the encounter resource to contain the status
   * history without needing to read through the historical versions of the
   * resource, or even have the server store them.
   */
  @Child(name = "statusHistory", type = {}, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "List of past encounter statuses", formalDefinition = "The status history permits the encounter resource to contain the status history without needing to read through the historical versions of the resource, or even have the server store them.")
  protected List statusHistory;

  /**
   * Concepts representing classification of patient encounter such as ambulatory
   * (outpatient), inpatient, emergency, home health or others due to local
   * variations.
   */
  @Child(name = "class", type = { Coding.class }, order = 3, min = 1, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Classification of patient encounter", formalDefinition = "Concepts representing classification of patient encounter such as ambulatory (outpatient), inpatient, emergency, home health or others due to local variations.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v3-ActEncounterCode")
  protected Coding class_;

  /**
   * The class history permits the tracking of the encounters transitions without
   * needing to go through the resource history. This would be used for a case
   * where an admission starts of as an emergency encounter, then transitions into
   * an inpatient scenario. Doing this and not restarting a new encounter ensures
   * that any lab/diagnostic results can more easily follow the patient and not
   * require re-processing and not get lost or cancelled during a kind of
   * discharge from emergency to inpatient.
   */
  @Child(name = "classHistory", type = {}, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "List of past encounter classes", formalDefinition = "The class history permits the tracking of the encounters transitions without needing to go  through the resource history.  This would be used for a case where an admission starts of as an emergency encounter, then transitions into an inpatient scenario. Doing this and not restarting a new encounter ensures that any lab/diagnostic results can more easily follow the patient and not require re-processing and not get lost or cancelled during a kind of discharge from emergency to inpatient.")
  protected List classHistory;

  /**
   * Specific type of encounter (e.g. e-mail consultation, surgical day-care,
   * skilled nursing, rehabilitation).
   */
  @Child(name = "type", type = {
      CodeableConcept.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Specific type of encounter", formalDefinition = "Specific type of encounter (e.g. e-mail consultation, surgical day-care, skilled nursing, rehabilitation).")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-type")
  protected List type;

  /**
   * Broad categorization of the service that is to be provided (e.g. cardiology).
   */
  @Child(name = "serviceType", type = {
      CodeableConcept.class }, order = 6, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Specific type of service", formalDefinition = "Broad categorization of the service that is to be provided (e.g. cardiology).")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-type")
  protected CodeableConcept serviceType;

  /**
   * Indicates the urgency of the encounter.
   */
  @Child(name = "priority", type = {
      CodeableConcept.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Indicates the urgency of the encounter", formalDefinition = "Indicates the urgency of the encounter.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v3-ActPriority")
  protected CodeableConcept priority;

  /**
   * The patient or group present at the encounter.
   */
  @Child(name = "subject", type = { Patient.class,
      Group.class }, order = 8, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "The patient or group present at the encounter", formalDefinition = "The patient or group present at the encounter.")
  protected Reference subject;

  /**
   * The actual object that is the target of the reference (The patient or group
   * present at the encounter.)
   */
  protected Resource subjectTarget;

  /**
   * Where a specific encounter should be classified as a part of a specific
   * episode(s) of care this field should be used. This association can facilitate
   * grouping of related encounters together for a specific purpose, such as
   * government reporting, issue tracking, association via a common problem. The
   * association is recorded on the encounter as these are typically created after
   * the episode of care and grouped on entry rather than editing the episode of
   * care to append another encounter to it (the episode of care could span
   * years).
   */
  @Child(name = "episodeOfCare", type = {
      EpisodeOfCare.class }, order = 9, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Episode(s) of care that this encounter should be recorded against", formalDefinition = "Where a specific encounter should be classified as a part of a specific episode(s) of care this field should be used. This association can facilitate grouping of related encounters together for a specific purpose, such as government reporting, issue tracking, association via a common problem.  The association is recorded on the encounter as these are typically created after the episode of care and grouped on entry rather than editing the episode of care to append another encounter to it (the episode of care could span years).")
  protected List episodeOfCare;
  /**
   * The actual objects that are the target of the reference (Where a specific
   * encounter should be classified as a part of a specific episode(s) of care
   * this field should be used. This association can facilitate grouping of
   * related encounters together for a specific purpose, such as government
   * reporting, issue tracking, association via a common problem. The association
   * is recorded on the encounter as these are typically created after the episode
   * of care and grouped on entry rather than editing the episode of care to
   * append another encounter to it (the episode of care could span years).)
   */
  protected List episodeOfCareTarget;

  /**
   * The request this encounter satisfies (e.g. incoming referral or procedure
   * request).
   */
  @Child(name = "basedOn", type = {
      ServiceRequest.class }, order = 10, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "The ServiceRequest that initiated this encounter", formalDefinition = "The request this encounter satisfies (e.g. incoming referral or procedure request).")
  protected List basedOn;
  /**
   * The actual objects that are the target of the reference (The request this
   * encounter satisfies (e.g. incoming referral or procedure request).)
   */
  protected List basedOnTarget;

  /**
   * The list of people responsible for providing the service.
   */
  @Child(name = "participant", type = {}, order = 11, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "List of participants involved in the encounter", formalDefinition = "The list of people responsible for providing the service.")
  protected List participant;

  /**
   * The appointment that scheduled this encounter.
   */
  @Child(name = "appointment", type = {
      Appointment.class }, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "The appointment that scheduled this encounter", formalDefinition = "The appointment that scheduled this encounter.")
  protected List appointment;
  /**
   * The actual objects that are the target of the reference (The appointment that
   * scheduled this encounter.)
   */
  protected List appointmentTarget;

  /**
   * The start and end time of the encounter.
   */
  @Child(name = "period", type = { Period.class }, order = 13, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "The start and end time of the encounter", formalDefinition = "The start and end time of the encounter.")
  protected Period period;

  /**
   * Quantity of time the encounter lasted. This excludes the time during leaves
   * of absence.
   */
  @Child(name = "length", type = { Duration.class }, order = 14, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Quantity of time the encounter lasted (less time absent)", formalDefinition = "Quantity of time the encounter lasted. This excludes the time during leaves of absence.")
  protected Duration length;

  /**
   * Reason the encounter takes place, expressed as a code. For admissions, this
   * can be used for a coded admission diagnosis.
   */
  @Child(name = "reasonCode", type = {
      CodeableConcept.class }, order = 15, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Coded reason the encounter takes place", formalDefinition = "Reason the encounter takes place, expressed as a code. For admissions, this can be used for a coded admission diagnosis.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/encounter-reason")
  protected List reasonCode;

  /**
   * Reason the encounter takes place, expressed as a code. For admissions, this
   * can be used for a coded admission diagnosis.
   */
  @Child(name = "reasonReference", type = { Condition.class, Procedure.class, Observation.class,
      ImmunizationRecommendation.class }, order = 16, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Reason the encounter takes place (reference)", formalDefinition = "Reason the encounter takes place, expressed as a code. For admissions, this can be used for a coded admission diagnosis.")
  protected List reasonReference;
  /**
   * The actual objects that are the target of the reference (Reason the encounter
   * takes place, expressed as a code. For admissions, this can be used for a
   * coded admission diagnosis.)
   */
  protected List reasonReferenceTarget;

  /**
   * The list of diagnosis relevant to this encounter.
   */
  @Child(name = "diagnosis", type = {}, order = 17, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "The list of diagnosis relevant to this encounter", formalDefinition = "The list of diagnosis relevant to this encounter.")
  protected List diagnosis;

  /**
   * The set of accounts that may be used for billing for this Encounter.
   */
  @Child(name = "account", type = {
      Account.class }, order = 18, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "The set of accounts that may be used for billing for this Encounter", formalDefinition = "The set of accounts that may be used for billing for this Encounter.")
  protected List account;
  /**
   * The actual objects that are the target of the reference (The set of accounts
   * that may be used for billing for this Encounter.)
   */
  protected List accountTarget;

  /**
   * Details about the admission to a healthcare service.
   */
  @Child(name = "hospitalization", type = {}, order = 19, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Details about the admission to a healthcare service", formalDefinition = "Details about the admission to a healthcare service.")
  protected EncounterHospitalizationComponent hospitalization;

  /**
   * List of locations where the patient has been during this encounter.
   */
  @Child(name = "location", type = {}, order = 20, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "List of locations where the patient has been", formalDefinition = "List of locations where  the patient has been during this encounter.")
  protected List location;

  /**
   * The organization that is primarily responsible for this Encounter's services.
   * This MAY be the same as the organization on the Patient record, however it
   * could be different, such as if the actor performing the services was from an
   * external organization (which may be billed seperately) for an external
   * consultation. Refer to the example bundle showing an abbreviated set of
   * Encounters for a colonoscopy.
   */
  @Child(name = "serviceProvider", type = {
      Organization.class }, order = 21, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "The organization (facility) responsible for this encounter", formalDefinition = "The organization that is primarily responsible for this Encounter's services. This MAY be the same as the organization on the Patient record, however it could be different, such as if the actor performing the services was from an external organization (which may be billed seperately) for an external consultation.  Refer to the example bundle showing an abbreviated set of Encounters for a colonoscopy.")
  protected Reference serviceProvider;

  /**
   * The actual object that is the target of the reference (The organization that
   * is primarily responsible for this Encounter's services. This MAY be the same
   * as the organization on the Patient record, however it could be different,
   * such as if the actor performing the services was from an external
   * organization (which may be billed seperately) for an external consultation.
   * Refer to the example bundle showing an abbreviated set of Encounters for a
   * colonoscopy.)
   */
  protected Organization serviceProviderTarget;

  /**
   * Another Encounter of which this encounter is a part of (administratively or
   * in time).
   */
  @Child(name = "partOf", type = { Encounter.class }, order = 22, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Another Encounter this encounter is part of", formalDefinition = "Another Encounter of which this encounter is a part of (administratively or in time).")
  protected Reference partOf;

  /**
   * The actual object that is the target of the reference (Another Encounter of
   * which this encounter is a part of (administratively or in time).)
   */
  protected Encounter partOfTarget;

  private static final long serialVersionUID = 1358318037L;

  /**
   * Constructor
   */
  public Encounter() {
    super();
  }

  /**
   * Constructor
   */
  public Encounter(Enumeration status, Coding class_) {
    super();
    this.status = status;
    this.class_ = class_;
  }

  /**
   * @return {@link #identifier} (Identifier(s) by which this encounter is known.)
   */
  public List getIdentifier() {
    if (this.identifier == null)
      this.identifier = new ArrayList();
    return this.identifier;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setIdentifier(List theIdentifier) {
    this.identifier = theIdentifier;
    return this;
  }

  public boolean hasIdentifier() {
    if (this.identifier == null)
      return false;
    for (Identifier item : this.identifier)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Identifier addIdentifier() { // 3
    Identifier t = new Identifier();
    if (this.identifier == null)
      this.identifier = new ArrayList();
    this.identifier.add(t);
    return t;
  }

  public Encounter addIdentifier(Identifier t) { // 3
    if (t == null)
      return this;
    if (this.identifier == null)
      this.identifier = new ArrayList();
    this.identifier.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #identifier}, creating
   *         it if it does not already exist
   */
  public Identifier getIdentifierFirstRep() {
    if (getIdentifier().isEmpty()) {
      addIdentifier();
    }
    return getIdentifier().get(0);
  }

  /**
   * @return {@link #status} (planned | arrived | triaged | in-progress | onleave
   *         | finished | cancelled +.). This is the underlying object with id,
   *         value and extensions. The accessor "getStatus" gives direct access to
   *         the value
   */
  public Enumeration getStatusElement() {
    if (this.status == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.status");
      else if (Configuration.doAutoCreate())
        this.status = new Enumeration(new EncounterStatusEnumFactory()); // bb
    return this.status;
  }

  public boolean hasStatusElement() {
    return this.status != null && !this.status.isEmpty();
  }

  public boolean hasStatus() {
    return this.status != null && !this.status.isEmpty();
  }

  /**
   * @param value {@link #status} (planned | arrived | triaged | in-progress |
   *              onleave | finished | cancelled +.). This is the underlying
   *              object with id, value and extensions. The accessor "getStatus"
   *              gives direct access to the value
   */
  public Encounter setStatusElement(Enumeration value) {
    this.status = value;
    return this;
  }

  /**
   * @return planned | arrived | triaged | in-progress | onleave | finished |
   *         cancelled +.
   */
  public EncounterStatus getStatus() {
    return this.status == null ? null : this.status.getValue();
  }

  /**
   * @param value planned | arrived | triaged | in-progress | onleave | finished |
   *              cancelled +.
   */
  public Encounter setStatus(EncounterStatus value) {
    if (this.status == null)
      this.status = new Enumeration(new EncounterStatusEnumFactory());
    this.status.setValue(value);
    return this;
  }

  /**
   * @return {@link #statusHistory} (The status history permits the encounter
   *         resource to contain the status history without needing to read
   *         through the historical versions of the resource, or even have the
   *         server store them.)
   */
  public List getStatusHistory() {
    if (this.statusHistory == null)
      this.statusHistory = new ArrayList();
    return this.statusHistory;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setStatusHistory(List theStatusHistory) {
    this.statusHistory = theStatusHistory;
    return this;
  }

  public boolean hasStatusHistory() {
    if (this.statusHistory == null)
      return false;
    for (StatusHistoryComponent item : this.statusHistory)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public StatusHistoryComponent addStatusHistory() { // 3
    StatusHistoryComponent t = new StatusHistoryComponent();
    if (this.statusHistory == null)
      this.statusHistory = new ArrayList();
    this.statusHistory.add(t);
    return t;
  }

  public Encounter addStatusHistory(StatusHistoryComponent t) { // 3
    if (t == null)
      return this;
    if (this.statusHistory == null)
      this.statusHistory = new ArrayList();
    this.statusHistory.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #statusHistory},
   *         creating it if it does not already exist
   */
  public StatusHistoryComponent getStatusHistoryFirstRep() {
    if (getStatusHistory().isEmpty()) {
      addStatusHistory();
    }
    return getStatusHistory().get(0);
  }

  /**
   * @return {@link #class_} (Concepts representing classification of patient
   *         encounter such as ambulatory (outpatient), inpatient, emergency, home
   *         health or others due to local variations.)
   */
  public Coding getClass_() {
    if (this.class_ == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.class_");
      else if (Configuration.doAutoCreate())
        this.class_ = new Coding(); // cc
    return this.class_;
  }

  public boolean hasClass_() {
    return this.class_ != null && !this.class_.isEmpty();
  }

  /**
   * @param value {@link #class_} (Concepts representing classification of patient
   *              encounter such as ambulatory (outpatient), inpatient, emergency,
   *              home health or others due to local variations.)
   */
  public Encounter setClass_(Coding value) {
    this.class_ = value;
    return this;
  }

  /**
   * @return {@link #classHistory} (The class history permits the tracking of the
   *         encounters transitions without needing to go through the resource
   *         history. This would be used for a case where an admission starts of
   *         as an emergency encounter, then transitions into an inpatient
   *         scenario. Doing this and not restarting a new encounter ensures that
   *         any lab/diagnostic results can more easily follow the patient and not
   *         require re-processing and not get lost or cancelled during a kind of
   *         discharge from emergency to inpatient.)
   */
  public List getClassHistory() {
    if (this.classHistory == null)
      this.classHistory = new ArrayList();
    return this.classHistory;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setClassHistory(List theClassHistory) {
    this.classHistory = theClassHistory;
    return this;
  }

  public boolean hasClassHistory() {
    if (this.classHistory == null)
      return false;
    for (ClassHistoryComponent item : this.classHistory)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public ClassHistoryComponent addClassHistory() { // 3
    ClassHistoryComponent t = new ClassHistoryComponent();
    if (this.classHistory == null)
      this.classHistory = new ArrayList();
    this.classHistory.add(t);
    return t;
  }

  public Encounter addClassHistory(ClassHistoryComponent t) { // 3
    if (t == null)
      return this;
    if (this.classHistory == null)
      this.classHistory = new ArrayList();
    this.classHistory.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #classHistory},
   *         creating it if it does not already exist
   */
  public ClassHistoryComponent getClassHistoryFirstRep() {
    if (getClassHistory().isEmpty()) {
      addClassHistory();
    }
    return getClassHistory().get(0);
  }

  /**
   * @return {@link #type} (Specific type of encounter (e.g. e-mail consultation,
   *         surgical day-care, skilled nursing, rehabilitation).)
   */
  public List getType() {
    if (this.type == null)
      this.type = new ArrayList();
    return this.type;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setType(List theType) {
    this.type = theType;
    return this;
  }

  public boolean hasType() {
    if (this.type == null)
      return false;
    for (CodeableConcept item : this.type)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public CodeableConcept addType() { // 3
    CodeableConcept t = new CodeableConcept();
    if (this.type == null)
      this.type = new ArrayList();
    this.type.add(t);
    return t;
  }

  public Encounter addType(CodeableConcept t) { // 3
    if (t == null)
      return this;
    if (this.type == null)
      this.type = new ArrayList();
    this.type.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #type}, creating it if
   *         it does not already exist
   */
  public CodeableConcept getTypeFirstRep() {
    if (getType().isEmpty()) {
      addType();
    }
    return getType().get(0);
  }

  /**
   * @return {@link #serviceType} (Broad categorization of the service that is to
   *         be provided (e.g. cardiology).)
   */
  public CodeableConcept getServiceType() {
    if (this.serviceType == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.serviceType");
      else if (Configuration.doAutoCreate())
        this.serviceType = new CodeableConcept(); // cc
    return this.serviceType;
  }

  public boolean hasServiceType() {
    return this.serviceType != null && !this.serviceType.isEmpty();
  }

  /**
   * @param value {@link #serviceType} (Broad categorization of the service that
   *              is to be provided (e.g. cardiology).)
   */
  public Encounter setServiceType(CodeableConcept value) {
    this.serviceType = value;
    return this;
  }

  /**
   * @return {@link #priority} (Indicates the urgency of the encounter.)
   */
  public CodeableConcept getPriority() {
    if (this.priority == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.priority");
      else if (Configuration.doAutoCreate())
        this.priority = new CodeableConcept(); // cc
    return this.priority;
  }

  public boolean hasPriority() {
    return this.priority != null && !this.priority.isEmpty();
  }

  /**
   * @param value {@link #priority} (Indicates the urgency of the encounter.)
   */
  public Encounter setPriority(CodeableConcept value) {
    this.priority = value;
    return this;
  }

  /**
   * @return {@link #subject} (The patient or group present at the encounter.)
   */
  public Reference getSubject() {
    if (this.subject == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.subject");
      else if (Configuration.doAutoCreate())
        this.subject = new Reference(); // cc
    return this.subject;
  }

  public boolean hasSubject() {
    return this.subject != null && !this.subject.isEmpty();
  }

  /**
   * @param value {@link #subject} (The patient or group present at the
   *              encounter.)
   */
  public Encounter setSubject(Reference value) {
    this.subject = value;
    return this;
  }

  /**
   * @return {@link #subject} The actual object that is the target of the
   *         reference. The reference library doesn't populate this, but you can
   *         use it to hold the resource if you resolve it. (The patient or group
   *         present at the encounter.)
   */
  public Resource getSubjectTarget() {
    return this.subjectTarget;
  }

  /**
   * @param value {@link #subject} The actual object that is the target of the
   *              reference. The reference library doesn't use these, but you can
   *              use it to hold the resource if you resolve it. (The patient or
   *              group present at the encounter.)
   */
  public Encounter setSubjectTarget(Resource value) {
    this.subjectTarget = value;
    return this;
  }

  /**
   * @return {@link #episodeOfCare} (Where a specific encounter should be
   *         classified as a part of a specific episode(s) of care this field
   *         should be used. This association can facilitate grouping of related
   *         encounters together for a specific purpose, such as government
   *         reporting, issue tracking, association via a common problem. The
   *         association is recorded on the encounter as these are typically
   *         created after the episode of care and grouped on entry rather than
   *         editing the episode of care to append another encounter to it (the
   *         episode of care could span years).)
   */
  public List getEpisodeOfCare() {
    if (this.episodeOfCare == null)
      this.episodeOfCare = new ArrayList();
    return this.episodeOfCare;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setEpisodeOfCare(List theEpisodeOfCare) {
    this.episodeOfCare = theEpisodeOfCare;
    return this;
  }

  public boolean hasEpisodeOfCare() {
    if (this.episodeOfCare == null)
      return false;
    for (Reference item : this.episodeOfCare)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Reference addEpisodeOfCare() { // 3
    Reference t = new Reference();
    if (this.episodeOfCare == null)
      this.episodeOfCare = new ArrayList();
    this.episodeOfCare.add(t);
    return t;
  }

  public Encounter addEpisodeOfCare(Reference t) { // 3
    if (t == null)
      return this;
    if (this.episodeOfCare == null)
      this.episodeOfCare = new ArrayList();
    this.episodeOfCare.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #episodeOfCare},
   *         creating it if it does not already exist
   */
  public Reference getEpisodeOfCareFirstRep() {
    if (getEpisodeOfCare().isEmpty()) {
      addEpisodeOfCare();
    }
    return getEpisodeOfCare().get(0);
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public List getEpisodeOfCareTarget() {
    if (this.episodeOfCareTarget == null)
      this.episodeOfCareTarget = new ArrayList();
    return this.episodeOfCareTarget;
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public EpisodeOfCare addEpisodeOfCareTarget() {
    EpisodeOfCare r = new EpisodeOfCare();
    if (this.episodeOfCareTarget == null)
      this.episodeOfCareTarget = new ArrayList();
    this.episodeOfCareTarget.add(r);
    return r;
  }

  /**
   * @return {@link #basedOn} (The request this encounter satisfies (e.g. incoming
   *         referral or procedure request).)
   */
  public List getBasedOn() {
    if (this.basedOn == null)
      this.basedOn = new ArrayList();
    return this.basedOn;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setBasedOn(List theBasedOn) {
    this.basedOn = theBasedOn;
    return this;
  }

  public boolean hasBasedOn() {
    if (this.basedOn == null)
      return false;
    for (Reference item : this.basedOn)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Reference addBasedOn() { // 3
    Reference t = new Reference();
    if (this.basedOn == null)
      this.basedOn = new ArrayList();
    this.basedOn.add(t);
    return t;
  }

  public Encounter addBasedOn(Reference t) { // 3
    if (t == null)
      return this;
    if (this.basedOn == null)
      this.basedOn = new ArrayList();
    this.basedOn.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #basedOn}, creating it
   *         if it does not already exist
   */
  public Reference getBasedOnFirstRep() {
    if (getBasedOn().isEmpty()) {
      addBasedOn();
    }
    return getBasedOn().get(0);
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public List getBasedOnTarget() {
    if (this.basedOnTarget == null)
      this.basedOnTarget = new ArrayList();
    return this.basedOnTarget;
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public ServiceRequest addBasedOnTarget() {
    ServiceRequest r = new ServiceRequest();
    if (this.basedOnTarget == null)
      this.basedOnTarget = new ArrayList();
    this.basedOnTarget.add(r);
    return r;
  }

  /**
   * @return {@link #participant} (The list of people responsible for providing
   *         the service.)
   */
  public List getParticipant() {
    if (this.participant == null)
      this.participant = new ArrayList();
    return this.participant;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setParticipant(List theParticipant) {
    this.participant = theParticipant;
    return this;
  }

  public boolean hasParticipant() {
    if (this.participant == null)
      return false;
    for (EncounterParticipantComponent item : this.participant)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public EncounterParticipantComponent addParticipant() { // 3
    EncounterParticipantComponent t = new EncounterParticipantComponent();
    if (this.participant == null)
      this.participant = new ArrayList();
    this.participant.add(t);
    return t;
  }

  public Encounter addParticipant(EncounterParticipantComponent t) { // 3
    if (t == null)
      return this;
    if (this.participant == null)
      this.participant = new ArrayList();
    this.participant.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #participant},
   *         creating it if it does not already exist
   */
  public EncounterParticipantComponent getParticipantFirstRep() {
    if (getParticipant().isEmpty()) {
      addParticipant();
    }
    return getParticipant().get(0);
  }

  /**
   * @return {@link #appointment} (The appointment that scheduled this encounter.)
   */
  public List getAppointment() {
    if (this.appointment == null)
      this.appointment = new ArrayList();
    return this.appointment;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setAppointment(List theAppointment) {
    this.appointment = theAppointment;
    return this;
  }

  public boolean hasAppointment() {
    if (this.appointment == null)
      return false;
    for (Reference item : this.appointment)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Reference addAppointment() { // 3
    Reference t = new Reference();
    if (this.appointment == null)
      this.appointment = new ArrayList();
    this.appointment.add(t);
    return t;
  }

  public Encounter addAppointment(Reference t) { // 3
    if (t == null)
      return this;
    if (this.appointment == null)
      this.appointment = new ArrayList();
    this.appointment.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #appointment},
   *         creating it if it does not already exist
   */
  public Reference getAppointmentFirstRep() {
    if (getAppointment().isEmpty()) {
      addAppointment();
    }
    return getAppointment().get(0);
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public List getAppointmentTarget() {
    if (this.appointmentTarget == null)
      this.appointmentTarget = new ArrayList();
    return this.appointmentTarget;
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public Appointment addAppointmentTarget() {
    Appointment r = new Appointment();
    if (this.appointmentTarget == null)
      this.appointmentTarget = new ArrayList();
    this.appointmentTarget.add(r);
    return r;
  }

  /**
   * @return {@link #period} (The start and end time of the encounter.)
   */
  public Period getPeriod() {
    if (this.period == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.period");
      else if (Configuration.doAutoCreate())
        this.period = new Period(); // cc
    return this.period;
  }

  public boolean hasPeriod() {
    return this.period != null && !this.period.isEmpty();
  }

  /**
   * @param value {@link #period} (The start and end time of the encounter.)
   */
  public Encounter setPeriod(Period value) {
    this.period = value;
    return this;
  }

  /**
   * @return {@link #length} (Quantity of time the encounter lasted. This excludes
   *         the time during leaves of absence.)
   */
  public Duration getLength() {
    if (this.length == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.length");
      else if (Configuration.doAutoCreate())
        this.length = new Duration(); // cc
    return this.length;
  }

  public boolean hasLength() {
    return this.length != null && !this.length.isEmpty();
  }

  /**
   * @param value {@link #length} (Quantity of time the encounter lasted. This
   *              excludes the time during leaves of absence.)
   */
  public Encounter setLength(Duration value) {
    this.length = value;
    return this;
  }

  /**
   * @return {@link #reasonCode} (Reason the encounter takes place, expressed as a
   *         code. For admissions, this can be used for a coded admission
   *         diagnosis.)
   */
  public List getReasonCode() {
    if (this.reasonCode == null)
      this.reasonCode = new ArrayList();
    return this.reasonCode;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setReasonCode(List theReasonCode) {
    this.reasonCode = theReasonCode;
    return this;
  }

  public boolean hasReasonCode() {
    if (this.reasonCode == null)
      return false;
    for (CodeableConcept item : this.reasonCode)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public CodeableConcept addReasonCode() { // 3
    CodeableConcept t = new CodeableConcept();
    if (this.reasonCode == null)
      this.reasonCode = new ArrayList();
    this.reasonCode.add(t);
    return t;
  }

  public Encounter addReasonCode(CodeableConcept t) { // 3
    if (t == null)
      return this;
    if (this.reasonCode == null)
      this.reasonCode = new ArrayList();
    this.reasonCode.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #reasonCode}, creating
   *         it if it does not already exist
   */
  public CodeableConcept getReasonCodeFirstRep() {
    if (getReasonCode().isEmpty()) {
      addReasonCode();
    }
    return getReasonCode().get(0);
  }

  /**
   * @return {@link #reasonReference} (Reason the encounter takes place, expressed
   *         as a code. For admissions, this can be used for a coded admission
   *         diagnosis.)
   */
  public List getReasonReference() {
    if (this.reasonReference == null)
      this.reasonReference = new ArrayList();
    return this.reasonReference;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setReasonReference(List theReasonReference) {
    this.reasonReference = theReasonReference;
    return this;
  }

  public boolean hasReasonReference() {
    if (this.reasonReference == null)
      return false;
    for (Reference item : this.reasonReference)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Reference addReasonReference() { // 3
    Reference t = new Reference();
    if (this.reasonReference == null)
      this.reasonReference = new ArrayList();
    this.reasonReference.add(t);
    return t;
  }

  public Encounter addReasonReference(Reference t) { // 3
    if (t == null)
      return this;
    if (this.reasonReference == null)
      this.reasonReference = new ArrayList();
    this.reasonReference.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #reasonReference},
   *         creating it if it does not already exist
   */
  public Reference getReasonReferenceFirstRep() {
    if (getReasonReference().isEmpty()) {
      addReasonReference();
    }
    return getReasonReference().get(0);
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public List getReasonReferenceTarget() {
    if (this.reasonReferenceTarget == null)
      this.reasonReferenceTarget = new ArrayList();
    return this.reasonReferenceTarget;
  }

  /**
   * @return {@link #diagnosis} (The list of diagnosis relevant to this
   *         encounter.)
   */
  public List getDiagnosis() {
    if (this.diagnosis == null)
      this.diagnosis = new ArrayList();
    return this.diagnosis;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setDiagnosis(List theDiagnosis) {
    this.diagnosis = theDiagnosis;
    return this;
  }

  public boolean hasDiagnosis() {
    if (this.diagnosis == null)
      return false;
    for (DiagnosisComponent item : this.diagnosis)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public DiagnosisComponent addDiagnosis() { // 3
    DiagnosisComponent t = new DiagnosisComponent();
    if (this.diagnosis == null)
      this.diagnosis = new ArrayList();
    this.diagnosis.add(t);
    return t;
  }

  public Encounter addDiagnosis(DiagnosisComponent t) { // 3
    if (t == null)
      return this;
    if (this.diagnosis == null)
      this.diagnosis = new ArrayList();
    this.diagnosis.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #diagnosis}, creating
   *         it if it does not already exist
   */
  public DiagnosisComponent getDiagnosisFirstRep() {
    if (getDiagnosis().isEmpty()) {
      addDiagnosis();
    }
    return getDiagnosis().get(0);
  }

  /**
   * @return {@link #account} (The set of accounts that may be used for billing
   *         for this Encounter.)
   */
  public List getAccount() {
    if (this.account == null)
      this.account = new ArrayList();
    return this.account;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setAccount(List theAccount) {
    this.account = theAccount;
    return this;
  }

  public boolean hasAccount() {
    if (this.account == null)
      return false;
    for (Reference item : this.account)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Reference addAccount() { // 3
    Reference t = new Reference();
    if (this.account == null)
      this.account = new ArrayList();
    this.account.add(t);
    return t;
  }

  public Encounter addAccount(Reference t) { // 3
    if (t == null)
      return this;
    if (this.account == null)
      this.account = new ArrayList();
    this.account.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #account}, creating it
   *         if it does not already exist
   */
  public Reference getAccountFirstRep() {
    if (getAccount().isEmpty()) {
      addAccount();
    }
    return getAccount().get(0);
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public List getAccountTarget() {
    if (this.accountTarget == null)
      this.accountTarget = new ArrayList();
    return this.accountTarget;
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public Account addAccountTarget() {
    Account r = new Account();
    if (this.accountTarget == null)
      this.accountTarget = new ArrayList();
    this.accountTarget.add(r);
    return r;
  }

  /**
   * @return {@link #hospitalization} (Details about the admission to a healthcare
   *         service.)
   */
  public EncounterHospitalizationComponent getHospitalization() {
    if (this.hospitalization == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.hospitalization");
      else if (Configuration.doAutoCreate())
        this.hospitalization = new EncounterHospitalizationComponent(); // cc
    return this.hospitalization;
  }

  public boolean hasHospitalization() {
    return this.hospitalization != null && !this.hospitalization.isEmpty();
  }

  /**
   * @param value {@link #hospitalization} (Details about the admission to a
   *              healthcare service.)
   */
  public Encounter setHospitalization(EncounterHospitalizationComponent value) {
    this.hospitalization = value;
    return this;
  }

  /**
   * @return {@link #location} (List of locations where the patient has been
   *         during this encounter.)
   */
  public List getLocation() {
    if (this.location == null)
      this.location = new ArrayList();
    return this.location;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Encounter setLocation(List theLocation) {
    this.location = theLocation;
    return this;
  }

  public boolean hasLocation() {
    if (this.location == null)
      return false;
    for (EncounterLocationComponent item : this.location)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public EncounterLocationComponent addLocation() { // 3
    EncounterLocationComponent t = new EncounterLocationComponent();
    if (this.location == null)
      this.location = new ArrayList();
    this.location.add(t);
    return t;
  }

  public Encounter addLocation(EncounterLocationComponent t) { // 3
    if (t == null)
      return this;
    if (this.location == null)
      this.location = new ArrayList();
    this.location.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #location}, creating
   *         it if it does not already exist
   */
  public EncounterLocationComponent getLocationFirstRep() {
    if (getLocation().isEmpty()) {
      addLocation();
    }
    return getLocation().get(0);
  }

  /**
   * @return {@link #serviceProvider} (The organization that is primarily
   *         responsible for this Encounter's services. This MAY be the same as
   *         the organization on the Patient record, however it could be
   *         different, such as if the actor performing the services was from an
   *         external organization (which may be billed seperately) for an
   *         external consultation. Refer to the example bundle showing an
   *         abbreviated set of Encounters for a colonoscopy.)
   */
  public Reference getServiceProvider() {
    if (this.serviceProvider == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.serviceProvider");
      else if (Configuration.doAutoCreate())
        this.serviceProvider = new Reference(); // cc
    return this.serviceProvider;
  }

  public boolean hasServiceProvider() {
    return this.serviceProvider != null && !this.serviceProvider.isEmpty();
  }

  /**
   * @param value {@link #serviceProvider} (The organization that is primarily
   *              responsible for this Encounter's services. This MAY be the same
   *              as the organization on the Patient record, however it could be
   *              different, such as if the actor performing the services was from
   *              an external organization (which may be billed seperately) for an
   *              external consultation. Refer to the example bundle showing an
   *              abbreviated set of Encounters for a colonoscopy.)
   */
  public Encounter setServiceProvider(Reference value) {
    this.serviceProvider = value;
    return this;
  }

  /**
   * @return {@link #serviceProvider} The actual object that is the target of the
   *         reference. The reference library doesn't populate this, but you can
   *         use it to hold the resource if you resolve it. (The organization that
   *         is primarily responsible for this Encounter's services. This MAY be
   *         the same as the organization on the Patient record, however it could
   *         be different, such as if the actor performing the services was from
   *         an external organization (which may be billed seperately) for an
   *         external consultation. Refer to the example bundle showing an
   *         abbreviated set of Encounters for a colonoscopy.)
   */
  public Organization getServiceProviderTarget() {
    if (this.serviceProviderTarget == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.serviceProvider");
      else if (Configuration.doAutoCreate())
        this.serviceProviderTarget = new Organization(); // aa
    return this.serviceProviderTarget;
  }

  /**
   * @param value {@link #serviceProvider} The actual object that is the target of
   *              the reference. The reference library doesn't use these, but you
   *              can use it to hold the resource if you resolve it. (The
   *              organization that is primarily responsible for this Encounter's
   *              services. This MAY be the same as the organization on the
   *              Patient record, however it could be different, such as if the
   *              actor performing the services was from an external organization
   *              (which may be billed seperately) for an external consultation.
   *              Refer to the example bundle showing an abbreviated set of
   *              Encounters for a colonoscopy.)
   */
  public Encounter setServiceProviderTarget(Organization value) {
    this.serviceProviderTarget = value;
    return this;
  }

  /**
   * @return {@link #partOf} (Another Encounter of which this encounter is a part
   *         of (administratively or in time).)
   */
  public Reference getPartOf() {
    if (this.partOf == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.partOf");
      else if (Configuration.doAutoCreate())
        this.partOf = new Reference(); // cc
    return this.partOf;
  }

  public boolean hasPartOf() {
    return this.partOf != null && !this.partOf.isEmpty();
  }

  /**
   * @param value {@link #partOf} (Another Encounter of which this encounter is a
   *              part of (administratively or in time).)
   */
  public Encounter setPartOf(Reference value) {
    this.partOf = value;
    return this;
  }

  /**
   * @return {@link #partOf} The actual object that is the target of the
   *         reference. The reference library doesn't populate this, but you can
   *         use it to hold the resource if you resolve it. (Another Encounter of
   *         which this encounter is a part of (administratively or in time).)
   */
  public Encounter getPartOfTarget() {
    if (this.partOfTarget == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Encounter.partOf");
      else if (Configuration.doAutoCreate())
        this.partOfTarget = new Encounter(); // aa
    return this.partOfTarget;
  }

  /**
   * @param value {@link #partOf} The actual object that is the target of the
   *              reference. The reference library doesn't use these, but you can
   *              use it to hold the resource if you resolve it. (Another
   *              Encounter of which this encounter is a part of (administratively
   *              or in time).)
   */
  public Encounter setPartOfTarget(Encounter value) {
    this.partOfTarget = value;
    return this;
  }

  protected void listChildren(List children) {
    super.listChildren(children);
    children.add(new Property("identifier", "Identifier", "Identifier(s) by which this encounter is known.", 0,
        java.lang.Integer.MAX_VALUE, identifier));
    children.add(new Property("status", "code",
        "planned | arrived | triaged | in-progress | onleave | finished | cancelled +.", 0, 1, status));
    children.add(new Property("statusHistory", "",
        "The status history permits the encounter resource to contain the status history without needing to read through the historical versions of the resource, or even have the server store them.",
        0, java.lang.Integer.MAX_VALUE, statusHistory));
    children.add(new Property("class", "Coding",
        "Concepts representing classification of patient encounter such as ambulatory (outpatient), inpatient, emergency, home health or others due to local variations.",
        0, 1, class_));
    children.add(new Property("classHistory", "",
        "The class history permits the tracking of the encounters transitions without needing to go  through the resource history.  This would be used for a case where an admission starts of as an emergency encounter, then transitions into an inpatient scenario. Doing this and not restarting a new encounter ensures that any lab/diagnostic results can more easily follow the patient and not require re-processing and not get lost or cancelled during a kind of discharge from emergency to inpatient.",
        0, java.lang.Integer.MAX_VALUE, classHistory));
    children.add(new Property("type", "CodeableConcept",
        "Specific type of encounter (e.g. e-mail consultation, surgical day-care, skilled nursing, rehabilitation).", 0,
        java.lang.Integer.MAX_VALUE, type));
    children.add(new Property("serviceType", "CodeableConcept",
        "Broad categorization of the service that is to be provided (e.g. cardiology).", 0, 1, serviceType));
    children
        .add(new Property("priority", "CodeableConcept", "Indicates the urgency of the encounter.", 0, 1, priority));
    children.add(new Property("subject", "Reference(Patient|Group)", "The patient or group present at the encounter.",
        0, 1, subject));
    children.add(new Property("episodeOfCare", "Reference(EpisodeOfCare)",
        "Where a specific encounter should be classified as a part of a specific episode(s) of care this field should be used. This association can facilitate grouping of related encounters together for a specific purpose, such as government reporting, issue tracking, association via a common problem.  The association is recorded on the encounter as these are typically created after the episode of care and grouped on entry rather than editing the episode of care to append another encounter to it (the episode of care could span years).",
        0, java.lang.Integer.MAX_VALUE, episodeOfCare));
    children.add(new Property("basedOn", "Reference(ServiceRequest)",
        "The request this encounter satisfies (e.g. incoming referral or procedure request).", 0,
        java.lang.Integer.MAX_VALUE, basedOn));
    children.add(new Property("participant", "", "The list of people responsible for providing the service.", 0,
        java.lang.Integer.MAX_VALUE, participant));
    children.add(new Property("appointment", "Reference(Appointment)", "The appointment that scheduled this encounter.",
        0, java.lang.Integer.MAX_VALUE, appointment));
    children.add(new Property("period", "Period", "The start and end time of the encounter.", 0, 1, period));
    children.add(new Property("length", "Duration",
        "Quantity of time the encounter lasted. This excludes the time during leaves of absence.", 0, 1, length));
    children.add(new Property("reasonCode", "CodeableConcept",
        "Reason the encounter takes place, expressed as a code. For admissions, this can be used for a coded admission diagnosis.",
        0, java.lang.Integer.MAX_VALUE, reasonCode));
    children.add(new Property("reasonReference",
        "Reference(Condition|Procedure|Observation|ImmunizationRecommendation)",
        "Reason the encounter takes place, expressed as a code. For admissions, this can be used for a coded admission diagnosis.",
        0, java.lang.Integer.MAX_VALUE, reasonReference));
    children.add(new Property("diagnosis", "", "The list of diagnosis relevant to this encounter.", 0,
        java.lang.Integer.MAX_VALUE, diagnosis));
    children.add(new Property("account", "Reference(Account)",
        "The set of accounts that may be used for billing for this Encounter.", 0, java.lang.Integer.MAX_VALUE,
        account));
    children.add(new Property("hospitalization", "", "Details about the admission to a healthcare service.", 0, 1,
        hospitalization));
    children.add(new Property("location", "", "List of locations where  the patient has been during this encounter.", 0,
        java.lang.Integer.MAX_VALUE, location));
    children.add(new Property("serviceProvider", "Reference(Organization)",
        "The organization that is primarily responsible for this Encounter's services. This MAY be the same as the organization on the Patient record, however it could be different, such as if the actor performing the services was from an external organization (which may be billed seperately) for an external consultation.  Refer to the example bundle showing an abbreviated set of Encounters for a colonoscopy.",
        0, 1, serviceProvider));
    children.add(new Property("partOf", "Reference(Encounter)",
        "Another Encounter of which this encounter is a part of (administratively or in time).", 0, 1, partOf));
  }

  @Override
  public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
    switch (_hash) {
    case -1618432855:
      /* identifier */ return new Property("identifier", "Identifier",
          "Identifier(s) by which this encounter is known.", 0, java.lang.Integer.MAX_VALUE, identifier);
    case -892481550:
      /* status */ return new Property("status", "code",
          "planned | arrived | triaged | in-progress | onleave | finished | cancelled +.", 0, 1, status);
    case -986695614:
      /* statusHistory */ return new Property("statusHistory", "",
          "The status history permits the encounter resource to contain the status history without needing to read through the historical versions of the resource, or even have the server store them.",
          0, java.lang.Integer.MAX_VALUE, statusHistory);
    case 94742904:
      /* class */ return new Property("class", "Coding",
          "Concepts representing classification of patient encounter such as ambulatory (outpatient), inpatient, emergency, home health or others due to local variations.",
          0, 1, class_);
    case 962575356:
      /* classHistory */ return new Property("classHistory", "",
          "The class history permits the tracking of the encounters transitions without needing to go  through the resource history.  This would be used for a case where an admission starts of as an emergency encounter, then transitions into an inpatient scenario. Doing this and not restarting a new encounter ensures that any lab/diagnostic results can more easily follow the patient and not require re-processing and not get lost or cancelled during a kind of discharge from emergency to inpatient.",
          0, java.lang.Integer.MAX_VALUE, classHistory);
    case 3575610:
      /* type */ return new Property("type", "CodeableConcept",
          "Specific type of encounter (e.g. e-mail consultation, surgical day-care, skilled nursing, rehabilitation).",
          0, java.lang.Integer.MAX_VALUE, type);
    case -1928370289:
      /* serviceType */ return new Property("serviceType", "CodeableConcept",
          "Broad categorization of the service that is to be provided (e.g. cardiology).", 0, 1, serviceType);
    case -1165461084:
      /* priority */ return new Property("priority", "CodeableConcept", "Indicates the urgency of the encounter.", 0, 1,
          priority);
    case -1867885268:
      /* subject */ return new Property("subject", "Reference(Patient|Group)",
          "The patient or group present at the encounter.", 0, 1, subject);
    case -1892140189:
      /* episodeOfCare */ return new Property("episodeOfCare", "Reference(EpisodeOfCare)",
          "Where a specific encounter should be classified as a part of a specific episode(s) of care this field should be used. This association can facilitate grouping of related encounters together for a specific purpose, such as government reporting, issue tracking, association via a common problem.  The association is recorded on the encounter as these are typically created after the episode of care and grouped on entry rather than editing the episode of care to append another encounter to it (the episode of care could span years).",
          0, java.lang.Integer.MAX_VALUE, episodeOfCare);
    case -332612366:
      /* basedOn */ return new Property("basedOn", "Reference(ServiceRequest)",
          "The request this encounter satisfies (e.g. incoming referral or procedure request).", 0,
          java.lang.Integer.MAX_VALUE, basedOn);
    case 767422259:
      /* participant */ return new Property("participant", "",
          "The list of people responsible for providing the service.", 0, java.lang.Integer.MAX_VALUE, participant);
    case -1474995297:
      /* appointment */ return new Property("appointment", "Reference(Appointment)",
          "The appointment that scheduled this encounter.", 0, java.lang.Integer.MAX_VALUE, appointment);
    case -991726143:
      /* period */ return new Property("period", "Period", "The start and end time of the encounter.", 0, 1, period);
    case -1106363674:
      /* length */ return new Property("length", "Duration",
          "Quantity of time the encounter lasted. This excludes the time during leaves of absence.", 0, 1, length);
    case 722137681:
      /* reasonCode */ return new Property("reasonCode", "CodeableConcept",
          "Reason the encounter takes place, expressed as a code. For admissions, this can be used for a coded admission diagnosis.",
          0, java.lang.Integer.MAX_VALUE, reasonCode);
    case -1146218137:
      /* reasonReference */ return new Property("reasonReference",
          "Reference(Condition|Procedure|Observation|ImmunizationRecommendation)",
          "Reason the encounter takes place, expressed as a code. For admissions, this can be used for a coded admission diagnosis.",
          0, java.lang.Integer.MAX_VALUE, reasonReference);
    case 1196993265:
      /* diagnosis */ return new Property("diagnosis", "", "The list of diagnosis relevant to this encounter.", 0,
          java.lang.Integer.MAX_VALUE, diagnosis);
    case -1177318867:
      /* account */ return new Property("account", "Reference(Account)",
          "The set of accounts that may be used for billing for this Encounter.", 0, java.lang.Integer.MAX_VALUE,
          account);
    case 1057894634:
      /* hospitalization */ return new Property("hospitalization", "",
          "Details about the admission to a healthcare service.", 0, 1, hospitalization);
    case 1901043637:
      /* location */ return new Property("location", "",
          "List of locations where  the patient has been during this encounter.", 0, java.lang.Integer.MAX_VALUE,
          location);
    case 243182534:
      /* serviceProvider */ return new Property("serviceProvider", "Reference(Organization)",
          "The organization that is primarily responsible for this Encounter's services. This MAY be the same as the organization on the Patient record, however it could be different, such as if the actor performing the services was from an external organization (which may be billed seperately) for an external consultation.  Refer to the example bundle showing an abbreviated set of Encounters for a colonoscopy.",
          0, 1, serviceProvider);
    case -995410646:
      /* partOf */ return new Property("partOf", "Reference(Encounter)",
          "Another Encounter of which this encounter is a part of (administratively or in time).", 0, 1, partOf);
    default:
      return super.getNamedProperty(_hash, _name, _checkValid);
    }

  }

  @Override
  public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
    switch (hash) {
    case -1618432855:
      /* identifier */ return this.identifier == null ? new Base[0]
          : this.identifier.toArray(new Base[this.identifier.size()]); // Identifier
    case -892481550:
      /* status */ return this.status == null ? new Base[0] : new Base[] { this.status }; // Enumeration
    case -986695614:
      /* statusHistory */ return this.statusHistory == null ? new Base[0]
          : this.statusHistory.toArray(new Base[this.statusHistory.size()]); // StatusHistoryComponent
    case 94742904:
      /* class */ return this.class_ == null ? new Base[0] : new Base[] { this.class_ }; // Coding
    case 962575356:
      /* classHistory */ return this.classHistory == null ? new Base[0]
          : this.classHistory.toArray(new Base[this.classHistory.size()]); // ClassHistoryComponent
    case 3575610:
      /* type */ return this.type == null ? new Base[0] : this.type.toArray(new Base[this.type.size()]); // CodeableConcept
    case -1928370289:
      /* serviceType */ return this.serviceType == null ? new Base[0] : new Base[] { this.serviceType }; // CodeableConcept
    case -1165461084:
      /* priority */ return this.priority == null ? new Base[0] : new Base[] { this.priority }; // CodeableConcept
    case -1867885268:
      /* subject */ return this.subject == null ? new Base[0] : new Base[] { this.subject }; // Reference
    case -1892140189:
      /* episodeOfCare */ return this.episodeOfCare == null ? new Base[0]
          : this.episodeOfCare.toArray(new Base[this.episodeOfCare.size()]); // Reference
    case -332612366:
      /* basedOn */ return this.basedOn == null ? new Base[0] : this.basedOn.toArray(new Base[this.basedOn.size()]); // Reference
    case 767422259:
      /* participant */ return this.participant == null ? new Base[0]
          : this.participant.toArray(new Base[this.participant.size()]); // EncounterParticipantComponent
    case -1474995297:
      /* appointment */ return this.appointment == null ? new Base[0]
          : this.appointment.toArray(new Base[this.appointment.size()]); // Reference
    case -991726143:
      /* period */ return this.period == null ? new Base[0] : new Base[] { this.period }; // Period
    case -1106363674:
      /* length */ return this.length == null ? new Base[0] : new Base[] { this.length }; // Duration
    case 722137681:
      /* reasonCode */ return this.reasonCode == null ? new Base[0]
          : this.reasonCode.toArray(new Base[this.reasonCode.size()]); // CodeableConcept
    case -1146218137:
      /* reasonReference */ return this.reasonReference == null ? new Base[0]
          : this.reasonReference.toArray(new Base[this.reasonReference.size()]); // Reference
    case 1196993265:
      /* diagnosis */ return this.diagnosis == null ? new Base[0]
          : this.diagnosis.toArray(new Base[this.diagnosis.size()]); // DiagnosisComponent
    case -1177318867:
      /* account */ return this.account == null ? new Base[0] : this.account.toArray(new Base[this.account.size()]); // Reference
    case 1057894634:
      /* hospitalization */ return this.hospitalization == null ? new Base[0] : new Base[] { this.hospitalization }; // EncounterHospitalizationComponent
    case 1901043637:
      /* location */ return this.location == null ? new Base[0] : this.location.toArray(new Base[this.location.size()]); // EncounterLocationComponent
    case 243182534:
      /* serviceProvider */ return this.serviceProvider == null ? new Base[0] : new Base[] { this.serviceProvider }; // Reference
    case -995410646:
      /* partOf */ return this.partOf == null ? new Base[0] : new Base[] { this.partOf }; // Reference
    default:
      return super.getProperty(hash, name, checkValid);
    }

  }

  @Override
  public Base setProperty(int hash, String name, Base value) throws FHIRException {
    switch (hash) {
    case -1618432855: // identifier
      this.getIdentifier().add(castToIdentifier(value)); // Identifier
      return value;
    case -892481550: // status
      value = new EncounterStatusEnumFactory().fromType(castToCode(value));
      this.status = (Enumeration) value; // Enumeration
      return value;
    case -986695614: // statusHistory
      this.getStatusHistory().add((StatusHistoryComponent) value); // StatusHistoryComponent
      return value;
    case 94742904: // class
      this.class_ = castToCoding(value); // Coding
      return value;
    case 962575356: // classHistory
      this.getClassHistory().add((ClassHistoryComponent) value); // ClassHistoryComponent
      return value;
    case 3575610: // type
      this.getType().add(castToCodeableConcept(value)); // CodeableConcept
      return value;
    case -1928370289: // serviceType
      this.serviceType = castToCodeableConcept(value); // CodeableConcept
      return value;
    case -1165461084: // priority
      this.priority = castToCodeableConcept(value); // CodeableConcept
      return value;
    case -1867885268: // subject
      this.subject = castToReference(value); // Reference
      return value;
    case -1892140189: // episodeOfCare
      this.getEpisodeOfCare().add(castToReference(value)); // Reference
      return value;
    case -332612366: // basedOn
      this.getBasedOn().add(castToReference(value)); // Reference
      return value;
    case 767422259: // participant
      this.getParticipant().add((EncounterParticipantComponent) value); // EncounterParticipantComponent
      return value;
    case -1474995297: // appointment
      this.getAppointment().add(castToReference(value)); // Reference
      return value;
    case -991726143: // period
      this.period = castToPeriod(value); // Period
      return value;
    case -1106363674: // length
      this.length = castToDuration(value); // Duration
      return value;
    case 722137681: // reasonCode
      this.getReasonCode().add(castToCodeableConcept(value)); // CodeableConcept
      return value;
    case -1146218137: // reasonReference
      this.getReasonReference().add(castToReference(value)); // Reference
      return value;
    case 1196993265: // diagnosis
      this.getDiagnosis().add((DiagnosisComponent) value); // DiagnosisComponent
      return value;
    case -1177318867: // account
      this.getAccount().add(castToReference(value)); // Reference
      return value;
    case 1057894634: // hospitalization
      this.hospitalization = (EncounterHospitalizationComponent) value; // EncounterHospitalizationComponent
      return value;
    case 1901043637: // location
      this.getLocation().add((EncounterLocationComponent) value); // EncounterLocationComponent
      return value;
    case 243182534: // serviceProvider
      this.serviceProvider = castToReference(value); // Reference
      return value;
    case -995410646: // partOf
      this.partOf = castToReference(value); // Reference
      return value;
    default:
      return super.setProperty(hash, name, value);
    }

  }

  @Override
  public Base setProperty(String name, Base value) throws FHIRException {
    if (name.equals("identifier")) {
      this.getIdentifier().add(castToIdentifier(value));
    } else if (name.equals("status")) {
      value = new EncounterStatusEnumFactory().fromType(castToCode(value));
      this.status = (Enumeration) value; // Enumeration
    } else if (name.equals("statusHistory")) {
      this.getStatusHistory().add((StatusHistoryComponent) value);
    } else if (name.equals("class")) {
      this.class_ = castToCoding(value); // Coding
    } else if (name.equals("classHistory")) {
      this.getClassHistory().add((ClassHistoryComponent) value);
    } else if (name.equals("type")) {
      this.getType().add(castToCodeableConcept(value));
    } else if (name.equals("serviceType")) {
      this.serviceType = castToCodeableConcept(value); // CodeableConcept
    } else if (name.equals("priority")) {
      this.priority = castToCodeableConcept(value); // CodeableConcept
    } else if (name.equals("subject")) {
      this.subject = castToReference(value); // Reference
    } else if (name.equals("episodeOfCare")) {
      this.getEpisodeOfCare().add(castToReference(value));
    } else if (name.equals("basedOn")) {
      this.getBasedOn().add(castToReference(value));
    } else if (name.equals("participant")) {
      this.getParticipant().add((EncounterParticipantComponent) value);
    } else if (name.equals("appointment")) {
      this.getAppointment().add(castToReference(value));
    } else if (name.equals("period")) {
      this.period = castToPeriod(value); // Period
    } else if (name.equals("length")) {
      this.length = castToDuration(value); // Duration
    } else if (name.equals("reasonCode")) {
      this.getReasonCode().add(castToCodeableConcept(value));
    } else if (name.equals("reasonReference")) {
      this.getReasonReference().add(castToReference(value));
    } else if (name.equals("diagnosis")) {
      this.getDiagnosis().add((DiagnosisComponent) value);
    } else if (name.equals("account")) {
      this.getAccount().add(castToReference(value));
    } else if (name.equals("hospitalization")) {
      this.hospitalization = (EncounterHospitalizationComponent) value; // EncounterHospitalizationComponent
    } else if (name.equals("location")) {
      this.getLocation().add((EncounterLocationComponent) value);
    } else if (name.equals("serviceProvider")) {
      this.serviceProvider = castToReference(value); // Reference
    } else if (name.equals("partOf")) {
      this.partOf = castToReference(value); // Reference
    } else
      return super.setProperty(name, value);
    return value;
  }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
    if (name.equals("identifier")) {
      this.getIdentifier().remove(castToIdentifier(value));
    } else if (name.equals("status")) {
      this.status = null;
    } else if (name.equals("statusHistory")) {
      this.getStatusHistory().remove((StatusHistoryComponent) value);
    } else if (name.equals("class")) {
      this.class_ = null;
    } else if (name.equals("classHistory")) {
      this.getClassHistory().remove((ClassHistoryComponent) value);
    } else if (name.equals("type")) {
      this.getType().remove(castToCodeableConcept(value));
    } else if (name.equals("serviceType")) {
      this.serviceType = null;
    } else if (name.equals("priority")) {
      this.priority = null;
    } else if (name.equals("subject")) {
      this.subject = null;
    } else if (name.equals("episodeOfCare")) {
      this.getEpisodeOfCare().remove(castToReference(value));
    } else if (name.equals("basedOn")) {
      this.getBasedOn().remove(castToReference(value));
    } else if (name.equals("participant")) {
      this.getParticipant().remove((EncounterParticipantComponent) value);
    } else if (name.equals("appointment")) {
      this.getAppointment().remove(castToReference(value));
    } else if (name.equals("period")) {
      this.period = null;
    } else if (name.equals("length")) {
      this.length = null;
    } else if (name.equals("reasonCode")) {
      this.getReasonCode().remove(castToCodeableConcept(value));
    } else if (name.equals("reasonReference")) {
      this.getReasonReference().remove(castToReference(value));
    } else if (name.equals("diagnosis")) {
      this.getDiagnosis().remove((DiagnosisComponent) value);
    } else if (name.equals("account")) {
      this.getAccount().remove(castToReference(value));
    } else if (name.equals("hospitalization")) {
      this.hospitalization = (EncounterHospitalizationComponent) value; // EncounterHospitalizationComponent
    } else if (name.equals("location")) {
      this.getLocation().remove((EncounterLocationComponent) value);
    } else if (name.equals("serviceProvider")) {
      this.serviceProvider = null;
    } else if (name.equals("partOf")) {
      this.partOf = null;
    } else
      super.removeChild(name, value);
    
  }

  @Override
  public Base makeProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case -1618432855:
      return addIdentifier();
    case -892481550:
      return getStatusElement();
    case -986695614:
      return addStatusHistory();
    case 94742904:
      return getClass_();
    case 962575356:
      return addClassHistory();
    case 3575610:
      return addType();
    case -1928370289:
      return getServiceType();
    case -1165461084:
      return getPriority();
    case -1867885268:
      return getSubject();
    case -1892140189:
      return addEpisodeOfCare();
    case -332612366:
      return addBasedOn();
    case 767422259:
      return addParticipant();
    case -1474995297:
      return addAppointment();
    case -991726143:
      return getPeriod();
    case -1106363674:
      return getLength();
    case 722137681:
      return addReasonCode();
    case -1146218137:
      return addReasonReference();
    case 1196993265:
      return addDiagnosis();
    case -1177318867:
      return addAccount();
    case 1057894634:
      return getHospitalization();
    case 1901043637:
      return addLocation();
    case 243182534:
      return getServiceProvider();
    case -995410646:
      return getPartOf();
    default:
      return super.makeProperty(hash, name);
    }

  }

  @Override
  public String[] getTypesForProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case -1618432855:
      /* identifier */ return new String[] { "Identifier" };
    case -892481550:
      /* status */ return new String[] { "code" };
    case -986695614:
      /* statusHistory */ return new String[] {};
    case 94742904:
      /* class */ return new String[] { "Coding" };
    case 962575356:
      /* classHistory */ return new String[] {};
    case 3575610:
      /* type */ return new String[] { "CodeableConcept" };
    case -1928370289:
      /* serviceType */ return new String[] { "CodeableConcept" };
    case -1165461084:
      /* priority */ return new String[] { "CodeableConcept" };
    case -1867885268:
      /* subject */ return new String[] { "Reference" };
    case -1892140189:
      /* episodeOfCare */ return new String[] { "Reference" };
    case -332612366:
      /* basedOn */ return new String[] { "Reference" };
    case 767422259:
      /* participant */ return new String[] {};
    case -1474995297:
      /* appointment */ return new String[] { "Reference" };
    case -991726143:
      /* period */ return new String[] { "Period" };
    case -1106363674:
      /* length */ return new String[] { "Duration" };
    case 722137681:
      /* reasonCode */ return new String[] { "CodeableConcept" };
    case -1146218137:
      /* reasonReference */ return new String[] { "Reference" };
    case 1196993265:
      /* diagnosis */ return new String[] {};
    case -1177318867:
      /* account */ return new String[] { "Reference" };
    case 1057894634:
      /* hospitalization */ return new String[] {};
    case 1901043637:
      /* location */ return new String[] {};
    case 243182534:
      /* serviceProvider */ return new String[] { "Reference" };
    case -995410646:
      /* partOf */ return new String[] { "Reference" };
    default:
      return super.getTypesForProperty(hash, name);
    }

  }

  @Override
  public Base addChild(String name) throws FHIRException {
    if (name.equals("identifier")) {
      return addIdentifier();
    } else if (name.equals("status")) {
      throw new FHIRException("Cannot call addChild on a singleton property Encounter.status");
    } else if (name.equals("statusHistory")) {
      return addStatusHistory();
    } else if (name.equals("class")) {
      this.class_ = new Coding();
      return this.class_;
    } else if (name.equals("classHistory")) {
      return addClassHistory();
    } else if (name.equals("type")) {
      return addType();
    } else if (name.equals("serviceType")) {
      this.serviceType = new CodeableConcept();
      return this.serviceType;
    } else if (name.equals("priority")) {
      this.priority = new CodeableConcept();
      return this.priority;
    } else if (name.equals("subject")) {
      this.subject = new Reference();
      return this.subject;
    } else if (name.equals("episodeOfCare")) {
      return addEpisodeOfCare();
    } else if (name.equals("basedOn")) {
      return addBasedOn();
    } else if (name.equals("participant")) {
      return addParticipant();
    } else if (name.equals("appointment")) {
      return addAppointment();
    } else if (name.equals("period")) {
      this.period = new Period();
      return this.period;
    } else if (name.equals("length")) {
      this.length = new Duration();
      return this.length;
    } else if (name.equals("reasonCode")) {
      return addReasonCode();
    } else if (name.equals("reasonReference")) {
      return addReasonReference();
    } else if (name.equals("diagnosis")) {
      return addDiagnosis();
    } else if (name.equals("account")) {
      return addAccount();
    } else if (name.equals("hospitalization")) {
      this.hospitalization = new EncounterHospitalizationComponent();
      return this.hospitalization;
    } else if (name.equals("location")) {
      return addLocation();
    } else if (name.equals("serviceProvider")) {
      this.serviceProvider = new Reference();
      return this.serviceProvider;
    } else if (name.equals("partOf")) {
      this.partOf = new Reference();
      return this.partOf;
    } else
      return super.addChild(name);
  }

  public String fhirType() {
    return "Encounter";

  }

  public Encounter copy() {
    Encounter dst = new Encounter();
    copyValues(dst);
    return dst;
  }

  public void copyValues(Encounter dst) {
    super.copyValues(dst);
    if (identifier != null) {
      dst.identifier = new ArrayList();
      for (Identifier i : identifier)
        dst.identifier.add(i.copy());
    }
    ;
    dst.status = status == null ? null : status.copy();
    if (statusHistory != null) {
      dst.statusHistory = new ArrayList();
      for (StatusHistoryComponent i : statusHistory)
        dst.statusHistory.add(i.copy());
    }
    ;
    dst.class_ = class_ == null ? null : class_.copy();
    if (classHistory != null) {
      dst.classHistory = new ArrayList();
      for (ClassHistoryComponent i : classHistory)
        dst.classHistory.add(i.copy());
    }
    ;
    if (type != null) {
      dst.type = new ArrayList();
      for (CodeableConcept i : type)
        dst.type.add(i.copy());
    }
    ;
    dst.serviceType = serviceType == null ? null : serviceType.copy();
    dst.priority = priority == null ? null : priority.copy();
    dst.subject = subject == null ? null : subject.copy();
    if (episodeOfCare != null) {
      dst.episodeOfCare = new ArrayList();
      for (Reference i : episodeOfCare)
        dst.episodeOfCare.add(i.copy());
    }
    ;
    if (basedOn != null) {
      dst.basedOn = new ArrayList();
      for (Reference i : basedOn)
        dst.basedOn.add(i.copy());
    }
    ;
    if (participant != null) {
      dst.participant = new ArrayList();
      for (EncounterParticipantComponent i : participant)
        dst.participant.add(i.copy());
    }
    ;
    if (appointment != null) {
      dst.appointment = new ArrayList();
      for (Reference i : appointment)
        dst.appointment.add(i.copy());
    }
    ;
    dst.period = period == null ? null : period.copy();
    dst.length = length == null ? null : length.copy();
    if (reasonCode != null) {
      dst.reasonCode = new ArrayList();
      for (CodeableConcept i : reasonCode)
        dst.reasonCode.add(i.copy());
    }
    ;
    if (reasonReference != null) {
      dst.reasonReference = new ArrayList();
      for (Reference i : reasonReference)
        dst.reasonReference.add(i.copy());
    }
    ;
    if (diagnosis != null) {
      dst.diagnosis = new ArrayList();
      for (DiagnosisComponent i : diagnosis)
        dst.diagnosis.add(i.copy());
    }
    ;
    if (account != null) {
      dst.account = new ArrayList();
      for (Reference i : account)
        dst.account.add(i.copy());
    }
    ;
    dst.hospitalization = hospitalization == null ? null : hospitalization.copy();
    if (location != null) {
      dst.location = new ArrayList();
      for (EncounterLocationComponent i : location)
        dst.location.add(i.copy());
    }
    ;
    dst.serviceProvider = serviceProvider == null ? null : serviceProvider.copy();
    dst.partOf = partOf == null ? null : partOf.copy();
  }

  protected Encounter typedCopy() {
    return copy();
  }

  @Override
  public boolean equalsDeep(Base other_) {
    if (!super.equalsDeep(other_))
      return false;
    if (!(other_ instanceof Encounter))
      return false;
    Encounter o = (Encounter) other_;
    return compareDeep(identifier, o.identifier, true) && compareDeep(status, o.status, true)
        && compareDeep(statusHistory, o.statusHistory, true) && compareDeep(class_, o.class_, true)
        && compareDeep(classHistory, o.classHistory, true) && compareDeep(type, o.type, true)
        && compareDeep(serviceType, o.serviceType, true) && compareDeep(priority, o.priority, true)
        && compareDeep(subject, o.subject, true) && compareDeep(episodeOfCare, o.episodeOfCare, true)
        && compareDeep(basedOn, o.basedOn, true) && compareDeep(participant, o.participant, true)
        && compareDeep(appointment, o.appointment, true) && compareDeep(period, o.period, true)
        && compareDeep(length, o.length, true) && compareDeep(reasonCode, o.reasonCode, true)
        && compareDeep(reasonReference, o.reasonReference, true) && compareDeep(diagnosis, o.diagnosis, true)
        && compareDeep(account, o.account, true) && compareDeep(hospitalization, o.hospitalization, true)
        && compareDeep(location, o.location, true) && compareDeep(serviceProvider, o.serviceProvider, true)
        && compareDeep(partOf, o.partOf, true);
  }

  @Override
  public boolean equalsShallow(Base other_) {
    if (!super.equalsShallow(other_))
      return false;
    if (!(other_ instanceof Encounter))
      return false;
    Encounter o = (Encounter) other_;
    return compareValues(status, o.status, true);
  }

  public boolean isEmpty() {
    return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(identifier, status, statusHistory, class_,
        classHistory, type, serviceType, priority, subject, episodeOfCare, basedOn, participant, appointment, period,
        length, reasonCode, reasonReference, diagnosis, account, hospitalization, location, serviceProvider, partOf);
  }

  @Override
  public ResourceType getResourceType() {
    return ResourceType.Encounter;
  }

  /**
   * Search parameter: date
   * 

* Description: A date within the period the Encounter lasted
* Type: date
* Path: Encounter.period
*

*/ @SearchParamDefinition(name = "date", path = "Encounter.period", description = "A date within the period the Encounter lasted", type = "date") public static final String SP_DATE = "date"; /** * Fluent Client search parameter constant for date *

* Description: A date within the period the Encounter lasted
* Type: date
* Path: Encounter.period
*

*/ public static final ca.uhn.fhir.rest.gclient.DateClientParam DATE = new ca.uhn.fhir.rest.gclient.DateClientParam( SP_DATE); /** * Search parameter: identifier *

* Description: Identifier(s) by which this encounter is known
* Type: token
* Path: Encounter.identifier
*

*/ @SearchParamDefinition(name = "identifier", path = "Encounter.identifier", description = "Identifier(s) by which this encounter is known", type = "token") public static final String SP_IDENTIFIER = "identifier"; /** * Fluent Client search parameter constant for identifier *

* Description: Identifier(s) by which this encounter is known
* Type: token
* Path: Encounter.identifier
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam IDENTIFIER = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_IDENTIFIER); /** * Search parameter: participant-type *

* Description: Role of participant in encounter
* Type: token
* Path: Encounter.participant.type
*

*/ @SearchParamDefinition(name = "participant-type", path = "Encounter.participant.type", description = "Role of participant in encounter", type = "token") public static final String SP_PARTICIPANT_TYPE = "participant-type"; /** * Fluent Client search parameter constant for participant-type *

* Description: Role of participant in encounter
* Type: token
* Path: Encounter.participant.type
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam PARTICIPANT_TYPE = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_PARTICIPANT_TYPE); /** * Search parameter: practitioner *

* Description: Persons involved in the encounter other than the * patient
* Type: reference
* Path: Encounter.participant.individual
*

*/ @SearchParamDefinition(name = "practitioner", path = "Encounter.participant.individual.where(resolve() is Practitioner)", description = "Persons involved in the encounter other than the patient", type = "reference", providesMembershipIn = { @ca.uhn.fhir.model.api.annotation.Compartment(name = "Practitioner") }, target = { Practitioner.class }) public static final String SP_PRACTITIONER = "practitioner"; /** * Fluent Client search parameter constant for practitioner *

* Description: Persons involved in the encounter other than the * patient
* Type: reference
* Path: Encounter.participant.individual
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam PRACTITIONER = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_PRACTITIONER); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:practitioner". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_PRACTITIONER = new ca.uhn.fhir.model.api.Include( "Encounter:practitioner").toLocked(); /** * Search parameter: subject *

* Description: The patient or group present at the encounter
* Type: reference
* Path: Encounter.subject
*

*/ @SearchParamDefinition(name = "subject", path = "Encounter.subject", description = "The patient or group present at the encounter", type = "reference", target = { Group.class, Patient.class }) public static final String SP_SUBJECT = "subject"; /** * Fluent Client search parameter constant for subject *

* Description: The patient or group present at the encounter
* Type: reference
* Path: Encounter.subject
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam SUBJECT = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_SUBJECT); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:subject". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_SUBJECT = new ca.uhn.fhir.model.api.Include( "Encounter:subject").toLocked(); /** * Search parameter: length *

* Description: Length of encounter in days
* Type: quantity
* Path: Encounter.length
*

*/ @SearchParamDefinition(name = "length", path = "Encounter.length", description = "Length of encounter in days", type = "quantity") public static final String SP_LENGTH = "length"; /** * Fluent Client search parameter constant for length *

* Description: Length of encounter in days
* Type: quantity
* Path: Encounter.length
*

*/ public static final ca.uhn.fhir.rest.gclient.QuantityClientParam LENGTH = new ca.uhn.fhir.rest.gclient.QuantityClientParam( SP_LENGTH); /** * Search parameter: episode-of-care *

* Description: Episode(s) of care that this encounter should be recorded * against
* Type: reference
* Path: Encounter.episodeOfCare
*

*/ @SearchParamDefinition(name = "episode-of-care", path = "Encounter.episodeOfCare", description = "Episode(s) of care that this encounter should be recorded against", type = "reference", target = { EpisodeOfCare.class }) public static final String SP_EPISODE_OF_CARE = "episode-of-care"; /** * Fluent Client search parameter constant for episode-of-care *

* Description: Episode(s) of care that this encounter should be recorded * against
* Type: reference
* Path: Encounter.episodeOfCare
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam EPISODE_OF_CARE = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_EPISODE_OF_CARE); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:episode-of-care". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_EPISODE_OF_CARE = new ca.uhn.fhir.model.api.Include( "Encounter:episode-of-care").toLocked(); /** * Search parameter: diagnosis *

* Description: The diagnosis or procedure relevant to the encounter
* Type: reference
* Path: Encounter.diagnosis.condition
*

*/ @SearchParamDefinition(name = "diagnosis", path = "Encounter.diagnosis.condition", description = "The diagnosis or procedure relevant to the encounter", type = "reference", target = { Condition.class, Procedure.class }) public static final String SP_DIAGNOSIS = "diagnosis"; /** * Fluent Client search parameter constant for diagnosis *

* Description: The diagnosis or procedure relevant to the encounter
* Type: reference
* Path: Encounter.diagnosis.condition
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam DIAGNOSIS = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_DIAGNOSIS); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:diagnosis". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_DIAGNOSIS = new ca.uhn.fhir.model.api.Include( "Encounter:diagnosis").toLocked(); /** * Search parameter: appointment *

* Description: The appointment that scheduled this encounter
* Type: reference
* Path: Encounter.appointment
*

*/ @SearchParamDefinition(name = "appointment", path = "Encounter.appointment", description = "The appointment that scheduled this encounter", type = "reference", target = { Appointment.class }) public static final String SP_APPOINTMENT = "appointment"; /** * Fluent Client search parameter constant for appointment *

* Description: The appointment that scheduled this encounter
* Type: reference
* Path: Encounter.appointment
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam APPOINTMENT = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_APPOINTMENT); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:appointment". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_APPOINTMENT = new ca.uhn.fhir.model.api.Include( "Encounter:appointment").toLocked(); /** * Search parameter: part-of *

* Description: Another Encounter this encounter is part of
* Type: reference
* Path: Encounter.partOf
*

*/ @SearchParamDefinition(name = "part-of", path = "Encounter.partOf", description = "Another Encounter this encounter is part of", type = "reference", target = { Encounter.class }) public static final String SP_PART_OF = "part-of"; /** * Fluent Client search parameter constant for part-of *

* Description: Another Encounter this encounter is part of
* Type: reference
* Path: Encounter.partOf
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam PART_OF = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_PART_OF); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:part-of". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_PART_OF = new ca.uhn.fhir.model.api.Include( "Encounter:part-of").toLocked(); /** * Search parameter: type *

* Description: Specific type of encounter
* Type: token
* Path: Encounter.type
*

*/ @SearchParamDefinition(name = "type", path = "Encounter.type", description = "Specific type of encounter", type = "token") public static final String SP_TYPE = "type"; /** * Fluent Client search parameter constant for type *

* Description: Specific type of encounter
* Type: token
* Path: Encounter.type
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam TYPE = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_TYPE); /** * Search parameter: reason-code *

* Description: Coded reason the encounter takes place
* Type: token
* Path: Encounter.reasonCode
*

*/ @SearchParamDefinition(name = "reason-code", path = "Encounter.reasonCode", description = "Coded reason the encounter takes place", type = "token") public static final String SP_REASON_CODE = "reason-code"; /** * Fluent Client search parameter constant for reason-code *

* Description: Coded reason the encounter takes place
* Type: token
* Path: Encounter.reasonCode
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam REASON_CODE = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_REASON_CODE); /** * Search parameter: participant *

* Description: Persons involved in the encounter other than the * patient
* Type: reference
* Path: Encounter.participant.individual
*

*/ @SearchParamDefinition(name = "participant", path = "Encounter.participant.individual", description = "Persons involved in the encounter other than the patient", type = "reference", providesMembershipIn = { @ca.uhn.fhir.model.api.annotation.Compartment(name = "Practitioner"), @ca.uhn.fhir.model.api.annotation.Compartment(name = "RelatedPerson") }, target = { Practitioner.class, PractitionerRole.class, RelatedPerson.class }) public static final String SP_PARTICIPANT = "participant"; /** * Fluent Client search parameter constant for participant *

* Description: Persons involved in the encounter other than the * patient
* Type: reference
* Path: Encounter.participant.individual
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam PARTICIPANT = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_PARTICIPANT); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:participant". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_PARTICIPANT = new ca.uhn.fhir.model.api.Include( "Encounter:participant").toLocked(); /** * Search parameter: based-on *

* Description: The ServiceRequest that initiated this encounter
* Type: reference
* Path: Encounter.basedOn
*

*/ @SearchParamDefinition(name = "based-on", path = "Encounter.basedOn", description = "The ServiceRequest that initiated this encounter", type = "reference", target = { ServiceRequest.class }) public static final String SP_BASED_ON = "based-on"; /** * Fluent Client search parameter constant for based-on *

* Description: The ServiceRequest that initiated this encounter
* Type: reference
* Path: Encounter.basedOn
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam BASED_ON = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_BASED_ON); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:based-on". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_BASED_ON = new ca.uhn.fhir.model.api.Include( "Encounter:based-on").toLocked(); /** * Search parameter: patient *

* Description: The patient or group present at the encounter
* Type: reference
* Path: Encounter.subject
*

*/ @SearchParamDefinition(name = "patient", path = "Encounter.subject.where(resolve() is Patient)", description = "The patient or group present at the encounter", type = "reference", providesMembershipIn = { @ca.uhn.fhir.model.api.annotation.Compartment(name = "Patient") }, target = { Patient.class }) public static final String SP_PATIENT = "patient"; /** * Fluent Client search parameter constant for patient *

* Description: The patient or group present at the encounter
* Type: reference
* Path: Encounter.subject
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam PATIENT = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_PATIENT); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:patient". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_PATIENT = new ca.uhn.fhir.model.api.Include( "Encounter:patient").toLocked(); /** * Search parameter: reason-reference *

* Description: Reason the encounter takes place (reference)
* Type: reference
* Path: Encounter.reasonReference
*

*/ @SearchParamDefinition(name = "reason-reference", path = "Encounter.reasonReference", description = "Reason the encounter takes place (reference)", type = "reference", target = { Condition.class, ImmunizationRecommendation.class, Observation.class, Procedure.class }) public static final String SP_REASON_REFERENCE = "reason-reference"; /** * Fluent Client search parameter constant for reason-reference *

* Description: Reason the encounter takes place (reference)
* Type: reference
* Path: Encounter.reasonReference
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam REASON_REFERENCE = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_REASON_REFERENCE); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:reason-reference". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_REASON_REFERENCE = new ca.uhn.fhir.model.api.Include( "Encounter:reason-reference").toLocked(); /** * Search parameter: location-period *

* Description: Time period during which the patient was present at the * location
* Type: date
* Path: Encounter.location.period
*

*/ @SearchParamDefinition(name = "location-period", path = "Encounter.location.period", description = "Time period during which the patient was present at the location", type = "date") public static final String SP_LOCATION_PERIOD = "location-period"; /** * Fluent Client search parameter constant for location-period *

* Description: Time period during which the patient was present at the * location
* Type: date
* Path: Encounter.location.period
*

*/ public static final ca.uhn.fhir.rest.gclient.DateClientParam LOCATION_PERIOD = new ca.uhn.fhir.rest.gclient.DateClientParam( SP_LOCATION_PERIOD); /** * Search parameter: location *

* Description: Location the encounter takes place
* Type: reference
* Path: Encounter.location.location
*

*/ @SearchParamDefinition(name = "location", path = "Encounter.location.location", description = "Location the encounter takes place", type = "reference", target = { Location.class }) public static final String SP_LOCATION = "location"; /** * Fluent Client search parameter constant for location *

* Description: Location the encounter takes place
* Type: reference
* Path: Encounter.location.location
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam LOCATION = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_LOCATION); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:location". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_LOCATION = new ca.uhn.fhir.model.api.Include( "Encounter:location").toLocked(); /** * Search parameter: service-provider *

* Description: The organization (facility) responsible for this * encounter
* Type: reference
* Path: Encounter.serviceProvider
*

*/ @SearchParamDefinition(name = "service-provider", path = "Encounter.serviceProvider", description = "The organization (facility) responsible for this encounter", type = "reference", target = { Organization.class }) public static final String SP_SERVICE_PROVIDER = "service-provider"; /** * Fluent Client search parameter constant for service-provider *

* Description: The organization (facility) responsible for this * encounter
* Type: reference
* Path: Encounter.serviceProvider
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam SERVICE_PROVIDER = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_SERVICE_PROVIDER); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:service-provider". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_SERVICE_PROVIDER = new ca.uhn.fhir.model.api.Include( "Encounter:service-provider").toLocked(); /** * Search parameter: special-arrangement *

* Description: Wheelchair, translator, stretcher, etc.
* Type: token
* Path: Encounter.hospitalization.specialArrangement
*

*/ @SearchParamDefinition(name = "special-arrangement", path = "Encounter.hospitalization.specialArrangement", description = "Wheelchair, translator, stretcher, etc.", type = "token") public static final String SP_SPECIAL_ARRANGEMENT = "special-arrangement"; /** * Fluent Client search parameter constant for special-arrangement *

* Description: Wheelchair, translator, stretcher, etc.
* Type: token
* Path: Encounter.hospitalization.specialArrangement
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam SPECIAL_ARRANGEMENT = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_SPECIAL_ARRANGEMENT); /** * Search parameter: class *

* Description: Classification of patient encounter
* Type: token
* Path: Encounter.class
*

*/ @SearchParamDefinition(name = "class", path = "Encounter.class", description = "Classification of patient encounter", type = "token") public static final String SP_CLASS = "class"; /** * Fluent Client search parameter constant for class *

* Description: Classification of patient encounter
* Type: token
* Path: Encounter.class
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam CLASS = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_CLASS); /** * Search parameter: account *

* Description: The set of accounts that may be used for billing for this * Encounter
* Type: reference
* Path: Encounter.account
*

*/ @SearchParamDefinition(name = "account", path = "Encounter.account", description = "The set of accounts that may be used for billing for this Encounter", type = "reference", target = { Account.class }) public static final String SP_ACCOUNT = "account"; /** * Fluent Client search parameter constant for account *

* Description: The set of accounts that may be used for billing for this * Encounter
* Type: reference
* Path: Encounter.account
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam ACCOUNT = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_ACCOUNT); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Encounter:account". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_ACCOUNT = new ca.uhn.fhir.model.api.Include( "Encounter:account").toLocked(); /** * Search parameter: status *

* Description: planned | arrived | triaged | in-progress | onleave | * finished | cancelled +
* Type: token
* Path: Encounter.status
*

*/ @SearchParamDefinition(name = "status", path = "Encounter.status", description = "planned | arrived | triaged | in-progress | onleave | finished | cancelled +", type = "token") public static final String SP_STATUS = "status"; /** * Fluent Client search parameter constant for status *

* Description: planned | arrived | triaged | in-progress | onleave | * finished | cancelled +
* Type: token
* Path: Encounter.status
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam STATUS = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_STATUS); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy