| Package | ihe.pharm.supply | 
| Resource Type | StructureDefinition | 
| Id | ProductModel | 
| FHIR Version | R5 | 
| Source | http://profiles.ihe.net/PHARM/supply/https://build.fhir.org/ig/IHE/pharm-supply/StructureDefinition-ProductModel.html | 
| URL | http://profiles.ihe.net/PHARM/supply/StructureDefinition/ProductModel | 
| Version | 0.3.0 | 
| Status | draft | 
| Date | 2024-06-18T21:00:54+00:00 | 
| Name | ProductModel | 
| Realm | uv | 
| Authority | ihe | 
| Description | This is the logical model for a Product | 
| Copyright | IHE http://www.ihe.net/Governance/#Intellectual_Property | 
| Type | http://profiles.ihe.net/PHARM/supply/StructureDefinition/ProductModel | 
| Kind | logical | 
| StructureDefinition | |
| ItemModel | ItemModel | 
| ProductModel | ProductModel | 
| StructureDefinition | |
| ItemModel | ItemModel | 
| ProductModel | ProductModel | 
| ValueSet | |
| vs-ihe-pharm-product-association-type | Product association type Value Set | 
Note: links and images are rebased to the (stated) source
| Name | Flags | Card. | Type | Description & Constraints | 
|---|---|---|---|---|
|   ProductModel | 0..* | Element | Elements defined in Ancestors:@id, extension A functional description of a product’s functionality, used for counting Instances of this logical model can be the target of a Reference | |
|    identifier | 0..* | Identifier | Business identifier for the product | |
|    baseUnitOfMeasure | 0..1 | CodeableConcept | The base unit of measure - the unit in which the product is used or counted. | |
|    description | 0..* | BackboneElement | The type of counting - whether it is a manual counting, automated data capture, estimate.. | |
|     attributeType | 1..1 | CodeableConcept | The type of operation - add/subtract | |
|     attributeType[x] | 1..1 | The value of the attribute | ||
|      attributeTypeInteger | integer | |||
|      attributeTypeString | string | |||
|      attributeTypeBoolean | boolean | |||
|    association | 0..* | BackboneElement | For example, Product A (powder) should be mixed with product B '(saline)', or 'product A should be applied with device B' , or 'Product X applies to parent device Y | |
|     associationType | 1..1 | CodeableConcept | The type of association | |
|     Slices for associatedProduct[x] | 1..1 | The actual related product Slice: Unordered, Open by type:$this | ||
|      associatedProductCodeableConcept | CodeableConcept | |||
|      associatedProductReference | Reference(ProductModel | ItemModel) | |||
|      associatedProduct[x]:associatedProductCodeableConcept | 0..1 | CodeableConcept | The actual related product Binding: Product association type Value Set (preferred) | |
|     quantity | 1..1 | Ratio | The quantity of the associated product in this product | |
|    classification | 0..* | CodeableConcept | The classification(s) of the product, e.g. ATC code, schedule, device class, ... | |
{
  "resourceType": "StructureDefinition",
  "id": "ProductModel",
  "text": {
    "status": "extensions",
    "div": "<!-- snip (see above) -->"
  },
  "extension": [
    {
      "url": "http://hl7.org/fhir/tools/StructureDefinition/logical-target",
      "valueBoolean": true
    }
  ],
  "url": "http://profiles.ihe.net/PHARM/supply/StructureDefinition/ProductModel",
  "version": "0.3.0",
  "name": "ProductModel",
  "status": "draft",
  "date": "2024-06-18T21:00:54+00:00",
  "publisher": "IHE Pharmacy Technical Committee",
  "contact": [
    {
      "telecom": [
        {
          "system": "url",
          "value": "https://www.ihe.net/ihe_domains/pharmacy/"
        }
      ]
    },
    {
      "telecom": [
        {
          "system": "email",
          "value": "pharmacy@ihe.net"
        }
      ]
    },
    {
      "name": "IHE Pharmacy Technical Committee",
      "telecom": [
        {
          "system": "email",
          "value": "pharmacy@ihe.net"
        }
      ]
    }
  ],
  "description": "This is the logical model for a Product",
  "jurisdiction": [
    {
      "coding": [
        {
          "system": "http://unstats.un.org/unsd/methods/m49/m49.htm",
          "code": "001"
        }
      ]
    }
  ],
  "copyright": "IHE http://www.ihe.net/Governance/#Intellectual_Property",
  "fhirVersion": "5.0.0",
  "mapping": [
    {
      "identity": "rim",
      "uri": "http://hl7.org/v3",
      "name": "RIM Mapping"
    }
  ],
  "kind": "logical",
  "abstract": false,
  "type": "http://profiles.ihe.net/PHARM/supply/StructureDefinition/ProductModel",
  "baseDefinition": "http://hl7.org/fhir/StructureDefinition/Element",
  "derivation": "specialization",
  "snapshot": {
    "element": [
      {
        "id": "ProductModel",
        "path": "ProductModel",
        "short": "A functional description of a product’s functionality, used for counting",
        "definition": "This is the logical model for a Product",
        "min": 0,
        "max": "*",
        "base": {
          "path": "Element",
          "min": 0,
          "max": "*"
        },
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          }
        ],
        "isModifier": false,
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "ProductModel.id",
        "path": "ProductModel.id",
        "representation": [
          "xmlAttr"
        ],
        "short": "Unique id for inter-element referencing",
        "definition": "Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.",
        "min": 0,
        "max": "1",
        "base": {
          "path": "Element.id",
          "min": 0,
          "max": "1"
        },
        "type": [
          {
            "extension": [
              {
                "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-fhir-type",
                "valueUrl": "string"
              }
            ],
            "code": "http://hl7.org/fhirpath/System.String"
          }
        ],
        "condition": [
          "ele-1"
        ],
        "isModifier": false,
        "isSummary": false,
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "ProductModel.extension",
        "path": "ProductModel.extension",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "url"
            }
          ],
          "description": "Extensions are always sliced by (at least) url",
          "rules": "open"
        },
        "short": "Additional content defined by implementations",
        "definition": "May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and managable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.",
        "comment": "There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions.  The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.",
        "alias": [
          "extensions",
          "user content"
        ],
        "min": 0,
        "max": "*",
        "base": {
          "path": "Element.extension",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "Extension"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          },
          {
            "key": "ext-1",
            "severity": "error",
            "human": "Must have either extensions or value[x], not both",
            "expression": "extension.exists() != value.exists()",
            "source": "http://hl7.org/fhir/StructureDefinition/Extension"
          }
        ],
        "isModifier": false,
        "isSummary": false,
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "ProductModel.identifier",
        "path": "ProductModel.identifier",
        "short": "Business identifier for the product",
        "definition": "Business identifier for the product",
        "min": 0,
        "max": "*",
        "base": {
          "path": "ProductModel.identifier",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "Identifier"
          }
        ]
      },
      {
        "id": "ProductModel.baseUnitOfMeasure",
        "path": "ProductModel.baseUnitOfMeasure",
        "short": "The base unit of measure - the unit in which the product is used or counted.",
        "definition": "The base unit of measure - the unit in which the product is used or counted.",
        "min": 0,
        "max": "1",
        "base": {
          "path": "ProductModel.baseUnitOfMeasure",
          "min": 0,
          "max": "1"
        },
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "ProductModel.description",
        "path": "ProductModel.description",
        "short": "The type of counting - whether it is a manual counting, automated data capture, estimate..",
        "definition": "The type of counting - whether it is a manual counting, automated data capture, estimate..",
        "min": 0,
        "max": "*",
        "base": {
          "path": "ProductModel.description",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "BackboneElement"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          }
        ]
      },
      {
        "id": "ProductModel.description.id",
        "path": "ProductModel.description.id",
        "representation": [
          "xmlAttr"
        ],
        "short": "Unique id for inter-element referencing",
        "definition": "Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.",
        "min": 0,
        "max": "1",
        "base": {
          "path": "Element.id",
          "min": 0,
          "max": "1"
        },
        "type": [
          {
            "extension": [
              {
                "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-fhir-type",
                "valueUrl": "id"
              }
            ],
            "code": "http://hl7.org/fhirpath/System.String"
          }
        ],
        "condition": [
          "ele-1"
        ],
        "isModifier": false,
        "isSummary": false,
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "ProductModel.description.extension",
        "path": "ProductModel.description.extension",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "url"
            }
          ],
          "description": "Extensions are always sliced by (at least) url",
          "rules": "open"
        },
        "short": "Additional content defined by implementations",
        "definition": "May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and managable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.",
        "comment": "There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions.  The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.",
        "alias": [
          "extensions",
          "user content"
        ],
        "min": 0,
        "max": "*",
        "base": {
          "path": "Element.extension",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "Extension"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          },
          {
            "key": "ext-1",
            "severity": "error",
            "human": "Must have either extensions or value[x], not both",
            "expression": "extension.exists() != value.exists()",
            "source": "http://hl7.org/fhir/StructureDefinition/Extension"
          }
        ],
        "isModifier": false,
        "isSummary": false,
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "ProductModel.description.modifierExtension",
        "path": "ProductModel.description.modifierExtension",
        "short": "Extensions that cannot be ignored even if unrecognized",
        "definition": "May be used to represent additional information that is not part of the basic definition of the element and that modifies the understanding of the element in which it is contained and/or the understanding of the containing element's descendants. Usually modifier elements provide negation or qualification. To make the use of extensions safe and managable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.\n\nModifier extensions SHALL NOT change the meaning of any elements on Resource or DomainResource (including cannot change the meaning of modifierExtension itself).",
        "comment": "There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions.  The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.",
        "requirements": "Modifier extensions allow for extensions that *cannot* be safely ignored to be clearly distinguished from the vast majority of extensions which can be safely ignored.  This promotes interoperability by eliminating the need for implementers to prohibit the presence of extensions. For further information, see the [definition of modifier extensions](http://hl7.org/fhir/R5/extensibility.html#modifierExtension).",
        "alias": [
          "extensions",
          "user content",
          "modifiers"
        ],
        "min": 0,
        "max": "*",
        "base": {
          "path": "BackboneElement.modifierExtension",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "Extension"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          },
          {
            "key": "ext-1",
            "severity": "error",
            "human": "Must have either extensions or value[x], not both",
            "expression": "extension.exists() != value.exists()",
            "source": "http://hl7.org/fhir/StructureDefinition/Extension"
          }
        ],
        "isModifier": true,
        "isModifierReason": "Modifier extensions are expected to modify the meaning or interpretation of the element that contains them",
        "isSummary": true,
        "mapping": [
          {
            "identity": "rim",
            "map": "N/A"
          }
        ]
      },
      {
        "id": "ProductModel.description.attributeType",
        "path": "ProductModel.description.attributeType",
        "short": "The type of operation - add/subtract",
        "definition": "The type of operation - add/subtract",
        "min": 1,
        "max": "1",
        "base": {
          "path": "ProductModel.description.attributeType",
          "min": 1,
          "max": "1"
        },
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "ProductModel.description.attributeType[x]",
        "path": "ProductModel.description.attributeType[x]",
        "short": "The value of the attribute",
        "definition": "The value of the attribute",
        "min": 1,
        "max": "1",
        "base": {
          "path": "ProductModel.description.attributeType[x]",
          "min": 1,
          "max": "1"
        },
        "type": [
          {
            "code": "integer"
          },
          {
            "code": "string"
          },
          {
            "code": "boolean"
          }
        ]
      },
      {
        "id": "ProductModel.association",
        "path": "ProductModel.association",
        "short": "For example, Product A (powder) should be mixed with product B '(saline)', or 'product A should be applied with device B' , or 'Product X applies to parent device Y",
        "definition": "For example, Product A (powder) should be mixed with product B '(saline)', or 'product A should be applied with device B' , or 'Product X applies to parent device Y",
        "min": 0,
        "max": "*",
        "base": {
          "path": "ProductModel.association",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "BackboneElement"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          }
        ]
      },
      {
        "id": "ProductModel.association.id",
        "path": "ProductModel.association.id",
        "representation": [
          "xmlAttr"
        ],
        "short": "Unique id for inter-element referencing",
        "definition": "Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.",
        "min": 0,
        "max": "1",
        "base": {
          "path": "Element.id",
          "min": 0,
          "max": "1"
        },
        "type": [
          {
            "extension": [
              {
                "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-fhir-type",
                "valueUrl": "id"
              }
            ],
            "code": "http://hl7.org/fhirpath/System.String"
          }
        ],
        "condition": [
          "ele-1"
        ],
        "isModifier": false,
        "isSummary": false,
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "ProductModel.association.extension",
        "path": "ProductModel.association.extension",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "url"
            }
          ],
          "description": "Extensions are always sliced by (at least) url",
          "rules": "open"
        },
        "short": "Additional content defined by implementations",
        "definition": "May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and managable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.",
        "comment": "There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions.  The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.",
        "alias": [
          "extensions",
          "user content"
        ],
        "min": 0,
        "max": "*",
        "base": {
          "path": "Element.extension",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "Extension"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          },
          {
            "key": "ext-1",
            "severity": "error",
            "human": "Must have either extensions or value[x], not both",
            "expression": "extension.exists() != value.exists()",
            "source": "http://hl7.org/fhir/StructureDefinition/Extension"
          }
        ],
        "isModifier": false,
        "isSummary": false,
        "mapping": [
          {
            "identity": "rim",
            "map": "n/a"
          }
        ]
      },
      {
        "id": "ProductModel.association.modifierExtension",
        "path": "ProductModel.association.modifierExtension",
        "short": "Extensions that cannot be ignored even if unrecognized",
        "definition": "May be used to represent additional information that is not part of the basic definition of the element and that modifies the understanding of the element in which it is contained and/or the understanding of the containing element's descendants. Usually modifier elements provide negation or qualification. To make the use of extensions safe and managable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.\n\nModifier extensions SHALL NOT change the meaning of any elements on Resource or DomainResource (including cannot change the meaning of modifierExtension itself).",
        "comment": "There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions.  The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.",
        "requirements": "Modifier extensions allow for extensions that *cannot* be safely ignored to be clearly distinguished from the vast majority of extensions which can be safely ignored.  This promotes interoperability by eliminating the need for implementers to prohibit the presence of extensions. For further information, see the [definition of modifier extensions](http://hl7.org/fhir/R5/extensibility.html#modifierExtension).",
        "alias": [
          "extensions",
          "user content",
          "modifiers"
        ],
        "min": 0,
        "max": "*",
        "base": {
          "path": "BackboneElement.modifierExtension",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "Extension"
          }
        ],
        "constraint": [
          {
            "key": "ele-1",
            "severity": "error",
            "human": "All FHIR elements must have a @value or children",
            "expression": "hasValue() or (children().count() > id.count())",
            "source": "http://hl7.org/fhir/StructureDefinition/Element"
          },
          {
            "key": "ext-1",
            "severity": "error",
            "human": "Must have either extensions or value[x], not both",
            "expression": "extension.exists() != value.exists()",
            "source": "http://hl7.org/fhir/StructureDefinition/Extension"
          }
        ],
        "isModifier": true,
        "isModifierReason": "Modifier extensions are expected to modify the meaning or interpretation of the element that contains them",
        "isSummary": true,
        "mapping": [
          {
            "identity": "rim",
            "map": "N/A"
          }
        ]
      },
      {
        "id": "ProductModel.association.associationType",
        "path": "ProductModel.association.associationType",
        "short": "The type of association",
        "definition": "e.g. 'applied with' or 'used with' or 'to be mixed with",
        "min": 1,
        "max": "1",
        "base": {
          "path": "ProductModel.association.associationType",
          "min": 1,
          "max": "1"
        },
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "ProductModel.association.associatedProduct[x]:associatedProductCodeableConcept",
        "path": "ProductModel.association.associatedProduct[x]",
        "sliceName": "associatedProductCodeableConcept",
        "slicing": {
          "discriminator": [
            {
              "type": "type",
              "path": "$this"
            }
          ],
          "ordered": false,
          "rules": "open"
        },
        "short": "The actual related product",
        "definition": "The actual related product",
        "min": 0,
        "max": "1",
        "base": {
          "path": "ProductModel.association.associatedProduct[x]",
          "min": 0,
          "max": "1"
        },
        "type": [
          {
            "code": "CodeableConcept"
          }
        ],
        "binding": {
          "strength": "preferred",
          "valueSet": "http://profiles.ihe.net/PHARM/supply/ValueSet/vs-ihe-pharm-product-association-type"
        }
      },
      {
        "id": "ProductModel.association.quantity",
        "path": "ProductModel.association.quantity",
        "short": "The quantity of the associated product in this product",
        "definition": "The quantity of the associated product in this product - Numerator is the quantity of the related product. Denominator is the quantity of the present product. for example a value of 20 means that this product contains 20 units of the related product; a value of 1:20 means the inverse - that the contained product contains 20 units of this product.",
        "min": 1,
        "max": "1",
        "base": {
          "path": "ProductModel.association.quantity",
          "min": 1,
          "max": "1"
        },
        "type": [
          {
            "code": "Ratio"
          }
        ]
      },
      {
        "id": "ProductModel.classification",
        "path": "ProductModel.classification",
        "short": "The classification(s) of the product, e.g. ATC code, schedule, device class, ...",
        "definition": "The classification(s) of the product, e.g. ATC code, schedule, device class, ...",
        "min": 0,
        "max": "*",
        "base": {
          "path": "ProductModel.classification",
          "min": 0,
          "max": "*"
        },
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      }
    ]
  },
  "differential": {
    "element": [
      {
        "id": "ProductModel",
        "path": "ProductModel",
        "short": "A functional description of a product’s functionality, used for counting",
        "definition": "This is the logical model for a Product"
      },
      {
        "id": "ProductModel.identifier",
        "path": "ProductModel.identifier",
        "short": "Business identifier for the product",
        "definition": "Business identifier for the product",
        "min": 0,
        "max": "*",
        "type": [
          {
            "code": "Identifier"
          }
        ]
      },
      {
        "id": "ProductModel.baseUnitOfMeasure",
        "path": "ProductModel.baseUnitOfMeasure",
        "short": "The base unit of measure - the unit in which the product is used or counted.",
        "definition": "The base unit of measure - the unit in which the product is used or counted.",
        "min": 0,
        "max": "1",
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "ProductModel.description",
        "path": "ProductModel.description",
        "short": "The type of counting - whether it is a manual counting, automated data capture, estimate..",
        "definition": "The type of counting - whether it is a manual counting, automated data capture, estimate..",
        "min": 0,
        "max": "*",
        "type": [
          {
            "code": "BackboneElement"
          }
        ]
      },
      {
        "id": "ProductModel.description.attributeType",
        "path": "ProductModel.description.attributeType",
        "short": "The type of operation - add/subtract",
        "definition": "The type of operation - add/subtract",
        "min": 1,
        "max": "1",
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "ProductModel.description.attributeType[x]",
        "path": "ProductModel.description.attributeType[x]",
        "short": "The value of the attribute",
        "definition": "The value of the attribute",
        "min": 1,
        "max": "1",
        "type": [
          {
            "code": "integer"
          },
          {
            "code": "string"
          },
          {
            "code": "boolean"
          }
        ]
      },
      {
        "id": "ProductModel.association",
        "path": "ProductModel.association",
        "short": "For example, Product A (powder) should be mixed with product B '(saline)', or 'product A should be applied with device B' , or 'Product X applies to parent device Y",
        "definition": "For example, Product A (powder) should be mixed with product B '(saline)', or 'product A should be applied with device B' , or 'Product X applies to parent device Y",
        "min": 0,
        "max": "*",
        "type": [
          {
            "code": "BackboneElement"
          }
        ]
      },
      {
        "id": "ProductModel.association.associationType",
        "path": "ProductModel.association.associationType",
        "short": "The type of association",
        "definition": "e.g. 'applied with' or 'used with' or 'to be mixed with",
        "min": 1,
        "max": "1",
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "ProductModel.association.associatedProduct[x]",
        "path": "ProductModel.association.associatedProduct[x]",
        "slicing": {
          "discriminator": [
            {
              "type": "type",
              "path": "$this"
            }
          ],
          "ordered": false,
          "rules": "open"
        },
        "short": "The actual related product",
        "definition": "The actual related product",
        "min": 1,
        "max": "1",
        "type": [
          {
            "code": "CodeableConcept"
          },
          {
            "code": "Reference",
            "targetProfile": [
              "http://profiles.ihe.net/PHARM/supply/StructureDefinition/ProductModel",
              "http://profiles.ihe.net/PHARM/supply/StructureDefinition/ItemModel"
            ]
          }
        ]
      },
      {
        "id": "ProductModel.association.associatedProduct[x]:associatedProductCodeableConcept",
        "path": "ProductModel.association.associatedProduct[x]",
        "sliceName": "associatedProductCodeableConcept",
        "min": 0,
        "max": "1",
        "type": [
          {
            "code": "CodeableConcept"
          }
        ],
        "binding": {
          "strength": "preferred",
          "valueSet": "http://profiles.ihe.net/PHARM/supply/ValueSet/vs-ihe-pharm-product-association-type"
        }
      },
      {
        "id": "ProductModel.association.quantity",
        "path": "ProductModel.association.quantity",
        "short": "The quantity of the associated product in this product",
        "definition": "The quantity of the associated product in this product - Numerator is the quantity of the related product. Denominator is the quantity of the present product. for example a value of 20 means that this product contains 20 units of the related product; a value of 1:20 means the inverse - that the contained product contains 20 units of this product.",
        "min": 1,
        "max": "1",
        "type": [
          {
            "code": "Ratio"
          }
        ]
      },
      {
        "id": "ProductModel.classification",
        "path": "ProductModel.classification",
        "short": "The classification(s) of the product, e.g. ATC code, schedule, device class, ...",
        "definition": "The classification(s) of the product, e.g. ATC code, schedule, device class, ...",
        "min": 0,
        "max": "*",
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      }
    ]
  }
}