Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FHIR format for the API response #16

Open
pacharanero opened this issue Jun 6, 2020 · 12 comments
Open

FHIR format for the API response #16

pacharanero opened this issue Jun 6, 2020 · 12 comments
Labels
design-decision An issue that documents a past, present or future design decision in the project dev Developer task mvp required for MVP launch

Comments

@pacharanero
Copy link
Member

FHIR ('Fast Healthcare Interoperability Resources', pronounced 'Fire') is a standard interchange format for medical data. It has been suggested that the response from the Growth Chart API should be in the form of a FHIR Resource.

More information on FHIR can be found here: https://en.wikipedia.org/wiki/Fast_Healthcare_Interoperability_Resources

The FHIR specifications are here: http://hl7.org/fhir/

At present the data returned by the API is in a structured data format called JSON (JavaScript Object Notation) and this is also the most common way that FHIR resources are transmitted. From initial discussions between myself and @eatyourpeas we think it is likely that we would be able to return a FHIR Resource as the API response.

@pacharanero pacharanero added design-decision An issue that documents a past, present or future design decision in the project dev Developer task mvp required for MVP launch labels Jun 6, 2020
@pacharanero
Copy link
Member Author

pacharanero commented Jun 6, 2020

Looking through the FHIR spec, I think the most appropriate resource for us to use for calculated centile data would be Observation

The CodeableConcept we would use to identify the type of measurement should be expressed in SNOMED-CT (not FHIR's default LOINC - we don't use LOINC in the UK) and there are number of suitable options within the descendants of this concept Body measure (observable entity)

@statist7
Copy link
Contributor

statist7 commented Jun 8, 2020

I strongly endorse the use of the FHIR format. Neil Sebire who leads the electronic patient data initiative at Great Ormond Street requires all APIs to access patient data via FHIR.

@clarotech
Copy link

If you need any help with the FHIR aspects of this - then happy to assist.

@pacharanero
Copy link
Member Author

Thanks @clarotech! Does the approach outlined above seem reasonable?

We're going to have two API endpoints, both will present exactly the same calculations, but the FHIR endpoint will wrap the response in an appropriate FHIR resource. If you have any thoughts regarding this approach, or the choice of resource etc then we'd be pleased to chat

@pacharanero
Copy link
Member Author

pacharanero commented Nov 25, 2020

I had a chat with some UK GP IT experts with a lot of experience in SNOMED terminology, regarding the correct coding entities to use. They agreed that the below are the correct SNOMED concepts.

248356008 |Weight centile (observable entity)|
248338008 |Height centile (observable entity)|
446974000 |Body mass index centile (observable entity)|
248397001 |Head circumference centile (observable entity)|

I'm going to propose the following as a rough idea of the JSON structure to be added to the 'simple' API response.

{
  "suggested_clinical_terminologies": [
    {
      "snomed-ct": {
        "concept_id": "248397001",
        "term_text": "Head circumference centile (observable entity)"
      }
    },
    {
      "readv2": {
        "code": "649Z.",
        "term_text": "Child HC centiles NOS"
      }
    }
  ]
}

We should support SNOMED-CT, which is what is currently used in GP systems in England, and possibly consider other terminologies such as Read Version 2, which is still in active use in Scotland, where EMIS PCS is used.

Using this kind of structure we make the terminology component extensible so that other coding systems (eg international) can be added in the future.

@eatyourpeas
Copy link
Member

eatyourpeas commented Nov 25, 2020 via email

@pacharanero
Copy link
Member Author

pacharanero commented Nov 25, 2020

Another JSON format for this would be to use FHIR's CodeableConcept verbatim (even though the simple API won't return FHIR (there will be another endpoint for FHIR)

"valueCodeableConcept": {
	"coding": [
			{
				"system": "http://snomed.info/sct",
				"code": "248397001",
				"display": "Head circumference centile (observable entity)"
			}, {
				"system": "https://acme.lab/resultcodes",
				"code": "649Z.",
				"display": "Child HC centiles NOS"
			}
		],
		"text": "Head circumference centile"
	}

@pacharanero
Copy link
Member Author

I am pausing work on this until the changes to Term References and Gestation Age Correction are all stable

@KevinMayfield
Copy link

Do you mean putting a FHIR API inside your app?

I'm not sure that has much use. I would see sourcing data from external sources via FHIR as more useful. I.e. you source data from external EPR/EHR (they have FHIR API's) and or get feeds of data from these or PHR apps.
That I feel would be a better use of FHIR.

@KevinMayfield
Copy link

Are you wanting to expose the calculation API for other vendors to use? (Then yes FHIR would be appropriate)

@pacharanero
Copy link
Member Author

Do you mean putting a FHIR API inside your app?

No, we don't need to do that.

Are you wanting to expose the calculation API for other vendors to use? (Then yes FHIR would be appropriate)

Yes, the idea is that vendors can use this API to get clinically validated, warranted growth calculations instead of having to implement the centiles, SDS and other calculations themselves. The implementation is HUGELY complex and not a simple lookup table.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
design-decision An issue that documents a past, present or future design decision in the project dev Developer task mvp required for MVP launch
Projects
None yet
Development

No branches or pull requests

5 participants