Information model: diagram

Uit Zorginformatiebouwstenen
Naar navigatie springen Naar zoeken springen

Auteursnaam instellen

Versie beheer

Classes toevoegen

Als een klasse met stereotype 'Rootconcept' wordt toegevoegd wordt de lijndikte van de box op 3 gezet.

Welke items/class vullen

Codering van de concepten

De DCM standaard eist dat voor ieder concept een definition code gedefinieerd wordt. Zonder codering is alles betekenisloos. Daarin kan alleen een Snomed CT code staan als je zeker weet dat het de juiste is, anders moet je een eigen code opvoeren en deze goed definieren. Die “eigen” code kan ook een Snomed CT extensie zijn. Foute SNOEMD codes zouden juist misverstanden kunnen introduceren doordat je toch 'misbruik' maakt van een concept uit bv SNOMED, wat eigenlijk een semantische fout introduceert. Ook zijn er vaak geen definition codes voor ons type containers.
In de implementatie handleiding zullen we wel verwijzingen moeten opnemen. Daarvoor hebben we de definition codes ook nodig.

Daarom is besloten om een eigen lijst met concept definitie codes te maken. Hiervoor is een projectOID aangevraagd en toegekend. Idem voor een eigen lijst met ValueSets en klinische bouwstenen. Deze OID komt onder de Nictiz root.

De project OID heeft de waarde 2.16.480.-.-.-.-. (komt nog)
In de DCM nemen we per concept een DCM::DefinitionCode op in de vorm:
DCM::DefinitionCode = NL-CM: <sectienummer>.<DCMvolgnummer>.<elementnummer>
NL-CM staat voor : "Netherlands Content Models Elements".

We gebruiken in de DCM::DefinitionCodes de volgende aliases, zodat we niet steeds het hele lange OID hoeven in te tikken:

  • Project OID.1 = Content Models Elementen (alias 'NL-CM')
  • Project OID.2 = Content Modules ValueSets (alias 'NL-CM-VS' )
  • Project OID.3 = DCM bouwstenen (Geen alias. Wordt alleen in de metagegevens gebruikt. Daar schrijven we de OID voluit).


In het geval van Content Models Elements wordt de notatie ‘root:extensie’ gebruikt. De root is NL-CM (=ProjectOID.1) en de extensie heeft de vorm x.y.z waarin:

  • X = sectienummer
  • Y = DCM volgnummer (1 sectie kan meerdere DCM’s omvatten)
  • Z = elementvolgnummer

Bij de elementnummering wordt begonnen bij het rootconcept. Dit krijgt elementnummer 1. Voor de overige elementen wordt geen vaste volgorde voorgeschreven.
Voorbeeld: NL-CM:5.1.1 voor het rootconcept van DCM#1 van sectie 5, Problems

Voor valuesets wordt gebruikelijk geen notatie in de vorm van een root en een extensie gebruikt, maar wordt achter de root OID doorgenummerd, met punten als scheidingsteken. Een alias is hierbij niet gebruikelijk. In ieder geval tot er een projectOID is kunnen we de alias wel gebruiken. De notatie voor de valuesets wordt dan: NL-CM-VS.x.y.z, echter Z is hier het volgnummer van de valueset binnen de DCM en niet het volgnummer van het element waar de valueset bij hoort. (let op het verschil in notatie, een ‘.’ ipv ‘:)


Voor DCM’s is de nummering in de vorm:
Project OID.3.x.y waarin:

  • X = sectienummer
  • Y = DCM volgnummer

Als er slechts één (1) DCM in de sectie voorkomt, dan heeft Y de waarde ‘1’ (en mag dan dus niet weggelaten worden).

Samenvattend zijn de afspraken voor het coderen van de element van de bouwstenen:

  • Ieder element krijgt een code uit het NL-CM systeem, zoals hierboven beschreven.
  • Het rootconcept krijgt binnen de bouwsteen elementnummer 1
  • Het rootconcept krijgt nooit een andere(bv SNOMED-CT) code.
  • Andere elementen inclusief containers kunnen wel codes uit andere codesystemen, zoals SNOMED-CT krijgen, uitsluitend als het element overeenkomt met het concept van de code.

Generalisatie of aggregatie

We gebruiken zo min mogelijk specialisaties in het model. Maar als iets echt een generalisatie/specialisatie ism mag die ook zo gemodelleerd worden.
Indien er in geval van een aggregatie slechts één element mag voorkomen, ga dan in het model als volgt te werk:

  • Voeg een Boundary toe (uit de common elements van de toolbox)
  • Voeg een Constraint toe met de tekst: 'Precies één concept in deze choice box moet gekozen worden' en verbindt deze constraint via een NoteLink met de Boundary.

Aggregatie.png

Relaties maken

Notes

Constraints

Subdiagrammen

Als een diagram te groot of te complex wordt, kan het diagram opgeknipt worden in een hoofddiagram en subdiagrammen.
De verbinding tussen hoofd- en subdiagrammen verloopt via een gemeenschappelijke container. Als dit op de juiste manier gedaan wordt, kan met een dubbelclick op deze container in het hoofddiagram automatisch naar het subdiagram gesprongen worden.
De werkwijze daarvoor is als volgt. Uitgangssituatie is dat er een hoofdiagram is en dat de gemeenschappelijke container daar nog niet instaat.

  • Voeg aan het Information Model een nieuw package toe.
  • Indien dit niet automatisch gebeurt, voeg aan dit package een class diagram toe.

AddPackage.png

NewDiagram2.png


NewDiagram.png

  • Vul het diagram met de gewenste concepten incl. de gemeenschappelijke container.
  • Verplaats in de Project Browser het diagram naar de gemeenschappelijke container.



NewDiagram3.png
NewDiagram4.png



  • Selecteer in het subdiagram de container en kies via de rechtermuisknop 'Advanced > Composite'.
  • Sleep het diagram in de Project Browser terug naar de oorspronkelijke plaats.
  • Ga naar het hoofddiagram en sleep de gemeenschappelijke container vanuit de Project Browser naar het diagram als 'Simple Link'.



Hoofddiagram
Submenu



Verwijzingen naar andere bouwstenen

Algemeen

Als in een bouwsteen verwezen wordt naar een andere bouwsteen of een concept in een andere bouwsteen wordt een generieke klasse aangemaakt met stereotype <<context>> en <<reference>>. N.B. Stereotype ‘context’ moet evt aangemaakt worden.
De naam van de klasse wordt Conceptnaam::GerefereerdeConceptnaam. De eerste conceptnaam is de naam in de verwijzende bouwsteen, de tweede is de naam in de de bouwsteen waarna verwezen wordt. Beide conceptnamen benoemen is niet verplicht. Dit wordt alleen gebruikt als het nodig en zinvol is. In de minimale vorm is de naam van de klasse GerefereerdeConceptnaam. De hele tekst van de klasse heeft 40% grijs als kleur (dit wordt een eigenschap van het stereotype, actie Michael).
De verwijzing wordt gecomplementeerd door bij het verwijzende concept de tag DCM::DCMIdentifier te vullen met de GUID van het concept waarnaar verwezen wordt. (Hoe? zo!) Bouwsteenverwijzing.png

Zorgverleners

Zorgverleners komen in vrijwel alle secties voor.
Indien in deze secties het vermelden van deze betrokkenen klinisch relevant is, wordt dit gedaan door een verwijzing naar zorgverlener.
De modellering van zorgverlener verbeurt eenmalig in sectie 0.

Valuesets en codes

Valueset vermelding

Bij een concept van het type CD wordt het waardebereik vastgelegd in de enumeratie attributen of in een losse value set.
Bij een losse valueset wordt de naam van deze set vermeld in een tagged value van het concept:

DCM::Valueset Naam van de valueset

Voor het documenteren van de koppeling van de naam van de valueset aan de OID van de valueset zijn twee plaatsen genoemd:

  • sectie References van de DCM
  • note van de beteffende tag value

Voor het project Generieke overdrachtsgegevens is voor de tweede mogelijkheid gekozen.

Naamgeving en nummering

Alle valueset hebben een naam en een nummer in de vorm van een OID. Soms kunnen voor de bouwsteen betaande valuesets gebruikt worden. Als zo'n valueset in zijn geheel overgenomen wordt, dus zonder uitbreidingen of inperkingen, wordt de oorspronkelijke naam en OID gebruikt. In alle andere gevallen wordt zelf een naam en een OID toegekend.Hierbij is de afspraak, dat

  • de naam wordt <Conceptnaam>Codelijst , waarbij <Conceptnaam> vervangen wordt door de naam van het concept waar de valueset aan gekoppeld is.
  • de OID wordt toegekend zoals in Onderwerp is beschreven.

Opstellen valueset

Indien het waardebereik niet wordt vastgelegd in een losse valueset maar als enumeratie, is er voor gekozen dit niet te doen als enumeratie attributen bij het concept maar de waardenlijst aan aan het concept te koppelen middels een ‘document artifact’ (uit de Common elements). Dit doen we in alle gevallen voor enumeratie, dus niet alleen voor lange waardelijsten, maar ook voor korte.

Werkwijze:

  • In de toolkit op ProjectPlace vind je een Word-template waarin je de waardelijst kunt intikken (template voor valuesets.docx).
  • Sleep een "Document" component uit de "Common" sectie van de toolbox naar het diagram.
  • DoubleClick op het 'artifact'
  • De document editor gaat dan open. Plak via copy/paste de waardelijst (tabel) uit het Word-document in de document editor.

CreateArtifact.PNG

  • Sluit de document editor.
  • Het document wordt vervolgens met het concept verbonden met een ‘Dependency Link’. Vervolgens wordt de pijlkop van de link verwijderd door met de rechtermuisknop te kiezen: Advanced->Change Directions->Unspecified (br>

Note: Doe dit eenmalig en edit daarna eventuele wijzigingen direct in de document editor van EA. Dit om te voorkomen dat je de waardelijst op twee plaatsen (in het Word-bestand en in EA) actueel moet houden.

Omdat niet alle Value sets even goed beschikbaar zijn, zou ik willen voorstellen in dit document artifact een kopie van de set op te nemen met de naam van de beherende instantie erbij. Anders blijven die in spreadsheets staan.

Valueset.png

Waarden buiten Valueset

Elk concept van het type CD heeft naast de value set een ‘overige’ mogelijkheid om te voorkomen dat bij gebrek aan een juiste waarde een foute waarde geselecteerd wordt (zeker bij verplichte items). Afspraak is dat deze overige waarden niet gecodeerde vrije tekst is. (in HL7 zal dit nullflavour OTH zijn met de tekst in originalText)

Bovenstaande geldt ook voor datatype CO