Skip to content

Latest commit

 

History

History
91 lines (58 loc) · 5.3 KB

README.md

File metadata and controls

91 lines (58 loc) · 5.3 KB

HAPI-FHIR Let's Build

Precursors

  • Check this project out to your local hard drive.
  • Open it in an IDE
  • Have the following tools installed:

Day 1 - Build a FHIR Data Mapper

Rationale: When adopting FHIR, a common scenario is needing to convert your existing data into the FHIR model. This can be a challenging first step, but if you approach it systematically it can be easy.

Exercise: For this exercise, we will be building a mapper that converts existing data a CSV file into FHIR Patient and Observation resources.

We'll be using a sample data file from the CDC NHANES (National Health and Nutrition Examination Study) publicly available sample data set. The format of the data set is described at this link but we have reworked the format a bit to add fake patient identities and timestamps to the data.

The input CSV file can be found here: https://github.com/hapifhir/lets-build/blob/main/src/main/resources/sample-data.csv

Approach

The input data looks like the following:

SEQN   , TIMESTAMP               , PATIENT_ID, PATIENT_FAMILYNAME, PATIENT_GIVENNAME, PATIENT_GENDER, WBC, RBC, HB
93704.0, 2020-11-13T07:47:35.964Z, PT00002   , Simpson           , Marge            , F             , 7.4, 0.1, 13.1

Note the columns:

  • SEQN: This is a unique identifier for the test
  • TIMESTAMP: This is the timestamp for the test
  • Patient detail columns (note that the patients repeat so you will want to ):
    • PATIENT_ID: This is the ID of the patient
    • PATIENT_FAMILYNAME: This is the family (last) name of the patient
    • PATIENT_GIVENNAME: This is the given (first) name of the patient
    • PATIENT_GENDER: This is the gender of the patient
  • Test result columns (each of these will be a separate Observation resource):
    • WBC: "White Blood Cell Count": This is a count of the number of white blood cells in your blood (These cells deliver oxygen)
    • RBC: "Red Blood Cell Count": This is a count of the number of red blood cells in your blood (These cells are an important part of the immune system)
    • HB: "Hemoglobin": This a measurement of the amount of hemoglobin protein in your blood (this iron-rich protein carries oxygen, among other things)

Writing a Mapper

Hints:

  • Don't optimize at first! There are lots of ways this code can be made efficient, but it's better to start by getting it working, then worry about performance later.

  • You can use the PATIENT_ID column as the resource ID for the Patient resource. Using a client-assigned ID for your resources makes the outcome predictable, and means that you can re-run your uploader as many times as you like without constantly creating new datasets.

  • You can use the SEQN column as the resource ID for the Observation resources, but you will need to append something to it since there are 3 Observations per row.

Hour 2 - Upload the Resources to a FHIR Server

Testing Your Solution

The class ca.uhn.fhir.letsbuild.server.RunServer can be used to execute a local in-memory server for testing. In this server, nothing is stored to disk so data will not survive restarts!

To execute this server, execute the command below. If you get an error of java.io.IOException: Failed to bind to 0.0.0.0/0.0.0.0:8000 this means that port 8000 is already taken on your machine. If you can free up this port, that is great but you can also just look for 8000 in the source code here and replace it with another port.

mvn exec:java -Dexec.mainClass="ca.uhn.fhir.letsbuild.server.RunServer"

This server does not implement the complete FHIR specification, just a very small subset needed for this exercize.

The following things will work: