| Size: 4540 Comment:  | Size: 14019 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 2: | Line 2: | 
| == Introduction == The !AnimInfo is a module in the Interbull Centre Data Exchange Area(IDEA) website which allows member organizations to upload additional information connected to existing animals in the pedigree module. Examples on additional information are coat color, crossbred information, herdbook number, eartag number, genetic defects etc. | |
| Line 3: | Line 5: | 
| == Preface == | The purpose of the !AnimInfo module is to collect reported information from member organizations and to use the module as an exchange area for information, not to verify or authorize information. It is possible to make different security levels for the information which means that for some !AnimInfo information only the authorized organization may view and upload information, for other information it is possible for some or all organizations to view and/or upload. | 
| Line 5: | Line 7: | 
| The IDEA !AnimInfo is a module in the Interbull Centre Data Exchange website that allows organizations to upload additional information — like %RH-genes or if the animal is genotyped — tied to animals in the pedigree, and to make this information available to the Interbull Centre and/or to other organizations in the IDEA system. The following is a description on how to, as an end-user, prepare and upload additional animal information to IDEA. | The type of additional  information that will be registered in IDEA Animinfo is decided by  member organizations in collaboration with Interbull Centre. Interbull  Centre has to update IDEA with the type of additional information (coat color, herdbook number etc) to upload before member  organizations can upload the information in the IDEA Animinfo module. Member  organizations are encourage to send requests on additional iniformation to  upload in IDEA to Interbull Centre.  The current type of information   available for registration in  IDEA/Animinfo  can be found  by clicking on the ''!AnimInfo -> Types'' menu item in the bar menu in IDEA (see figure 1). The !AnimInfo file format is an XML file format. For basic information on XML, see https://en.wikipedia.org/wiki/XML or [[public/XMLdigest]]. XML is a flexible system for complex data files and was choosen for !AnimInfo in order to ensure easy future development and extension of the module's file format and capabilities, as well as a fitting format for the current data model. The following is a description on how to, as an end-user, prepare and upload additional animal information to IDEA. | 
| Line 10: | Line 16: | 
| The workflow to upload additional information for animals existing in the pedigree modul: | |
| Line 11: | Line 18: | 
| !AnimInfo allows storing additional data and information about animals in the pedigree in the IDEA database. The purpose of the !AnimInfo is to gather reported data from sources, not to verify or authorize that information. To add data into !AnimInfo one prepares an !AnimInfo file according to the specification, and uploads it to IDEA. Depending on the type of information uploaded it will be available for viewing and uploading by none, some or all other organizations in IDEA. For some !AnimInfo data only the authorized organization may view and upload data, for other data it is possible for some or all organizations to view and/or upload it. If more than one organization uploads the same type of data for the same animal all the uploaded information will be shown when querying that animal, with indications from which organization the different pieces of data come from. | . Create a XML file with the relevant information according to ..."link" . Run a checking program to check the correctness of the file ..... "link"". . Upload the file to IDEA ... link.... . After uploading , member organizations will be able to query the information and get the information in a data file. If more than one organization uploads the same type of data for the same animal all the uploaded information will be shown when querying that animal, with indications from which organization the different pieces of data come from. | 
| Line 14: | Line 29: | 
| An overview of current available type of information to upload in IDEA/Animinfo can be found in the ''!AnimInfo -> Types'' page in IDEA (Figure 1) | |
| Line 15: | Line 31: | 
| {{attachment:animinfo_types_menu.png}} | {{attachment:animinfo_types_menu.png}} <<BR>>''Figure 1'' | 
| Line 17: | Line 33: | 
| '''Figure 1''' | Each type of information (Types) have different attributes and value where: | 
| Line 19: | Line 35: | 
| In order to add additional information to animals in IDEA one has to know which types of information that are allowed in IDEA !AnimInfo. This can be found by clicking on the ''!AnimInfo -> Types'' menu item in the bar menu in IDEA (see figure 1). Here you will be shown a list of the allowed !AnimInfo types, attributes and values: | * '''AnimInfo Types''' are written in uppercase letters followed by a short description in   italic. * '''AnimInfo Attributes''' are written below each TYPE in lowercase. The attributes holds the actual information of the relevant AnimInfo type. An attribute can only be specified once for each AnimInfo type, organization and animal. * '''AnimInfo Values''' sets the value of each attribute for each animal. The value must conform to the specification of the attribute, which can be different from attribute to attribute; ranging from a free-form text string, to a set of predefined values, to a defined pattern the value must match. | 
| Line 21: | Line 39: | 
| * '''!AnimInfo Types''' groups related !AnimInfo attributes (see below) together into a coherent logical unit in the !AnimInfo file format. They are indicated by UPPERCASE names and only alphanumeric characters are allowed, plus underscore(_) and hyphen(-).. * '''!AnimInfo Attributes''' holds the actual information of the relevant !AnimInfo type in a list of name/value-pairs, for example ''genotyped="Y"''. The first part, before the equal(=) sign is the name of the attribute, and is in lowercase, and the part after the equal sign and within quotation marks (") is the value of that attribute (see below). As with the types the attribute name can only contain alphanumeric characters, underscore and hyphen. An !AnimInfo type can contain from one to several related attributes — some of which are required, others are optional. An attribute can only be specified once for each !AnimInfo type, organization and animal. * '''!AnimInfo Values''' sets the value of each attribute for each animal. The value must conform to the specification of the attribute, which can be different from attribute to attribute; ranging from a free-form text string, to a set of predefined values, to a defined pattern the value must match. | ********************* CARL CHANGE ********************** | 
| Line 25: | Line 41: | 
| In the ''!AnimInfo -> Types'' page in IDEA you will find an overview of all the available types, attributes and values in the !AnimInfo module. There one finds a bullet list of the !AnimInfo types, in bold, uppercase letters, and with a short description in italic. Below each type, in a sub-listlevel, the type's attributes are listed in lowercase. After each attribute, in parantheses, the attribute value type is specified. Also, there is a short description in italics for each attribute. In the case of attributes with a predefined set of allowed values, these are listed in yet another level of the list, below the relevant attribute. Below the !AnimInfo types and attribute overview one finds a specification of the value types available, with a description on which pattern the value must conform to. | Here, in Figure 2, one can see the specification of the %RH-genes !AnimInfo data structure, where the type is specified as RH_GENES, and it has a single attribute, percent. The percent has the value type ''percent with not available'', which is defined in the list of value types as ''A numerical, integer value between 0 and 100, with the string N/A if not available''. This means that one can upload %RH-genes percent values (which is either a percent value or N/A for missing values) for every animal, using the !AnimInfo file format. | 
| Line 28: | Line 43: | 
| {{attachment:animinfo_overview.png}} | {{attachment:animinfo_overview.png}} <<BR>>''Figure 2'' | 
| Line 30: | Line 45: | 
| '''Figure 2''' | ''****************************************************************************************************************'' | 
| Line 32: | Line 47: | 
| Here, in Figure 2, one can see the specification of the %RH-genes !AnimInfo data structure, where the type is specified as RH_GENES, and it has a single attribute, percent. The percent has the value type ''percent with not available'', which is defined in the list of value types as ''A numerical, integer value between 0 and 100, with the string N/A if not available''. This means that one can upload %RH-genes percent values (which is either a percent value or N/A for missing values) for every animal, using the !AnimInfo file format. | === Create an AnimInfo file === The structure of the !AnimInfo XML file format is as following: | 
| Line 34: | Line 50: | 
| === Assembling an !AnimInfo file === | * '''interbull''': The root element of the Interbull XML file formats. It requires the XML attributes '''type''' and '''version''', where the values should be ''animinfo'' and ''1.0'' respectively. * '''animals''': The animals element defines the section which lists all animals and their !AnimInfo data. * '''a''': the ''animals'' section contains several a-elements which each represents a single animal. Every a-element should have an '''id'''-attribute which is the animal's international id (AID). * '''ANIMINFO TYPE''': Every animal specified by the a-element may have one or more unique !AnimInfo types specified, with each's respective attributes defined. ************ CARL CHANGE ******************************************** '''Example 1:''' Take a file which will upload %RH-genes information about two animals. Then the correctly formatted !AnimInfo XML data file would look like this: {{{#!highlight xml <interbull type="animinfo" version="1.0"> <animals> <a id="HOLUSAM000000000X11"> <CROSSBREED breed="RH" percent="50" /> </a> <a id="HOLUSAM000000000X1x"> <CROSSBREED breed="RH;SIM;BSW" percent="20;20;10" /> </a> <a id="HOLDEUF000000000Y22"> <RH_GENES percent="N/A" /> </a> </animals> </interbull> }}} === ****************************************************************************************** === === Run Checking program === Once the !AnimInfo XML file has been prepared, it has to be run through the ''!CheckAnimInfo'' program, just like with Pedigree, Links and EBV/GEBV files has to be checked before uploading to IDEA. The ''!CheckAnimInfo'' program is downloadable from the IDEA website, under Software, and is a Python 2 script https://ideatest.hgen.slu.se/idea_animinfo/software/index This will check that the !AnimInfo file format is correct and that the file includes the right !AnimInfo types, attributes and values. It will warn and give hints about what kind of errors it encounters, and how to fix them. If all goes well it will produce an !AnimInfo zip file, ready to upload through the IDEA web interface. === AnimInfo Upload === {{attachment:animinfo_upload_menu.png}} <<BR>>''Figure 3'' The !AnimInfo zip file is called ''IB-ANIMINFO-{org code}-{YEAR-MONTH-DAY}T{HOUR-MINUTE-SECOND}.zip'', and can be uploaded by clicking on the ''!AnimInfo -> Upload'' menu item (see figure 3) and then using the appropriate upload buttons. After upload the file will be checked by the server-side !CheckAnimInfo script, and if everything checks out OK the data will be passed onto the import functions in IDEA. After the data has been processed an email with feedback information will be sent. The email contains general statistics about the upload; how many !AnimInfo types and attributes that were processed, discarded and so on. Also included is an XML !AnimInfo feedback file with more detailed information about the upload. Here is the structure of the feedback XML file: * '''interbull''': Root element with '''type'''="animinfo_upload_feedback" and '''dscode''' equal to the data set code for the upload (similar to the file name, minus the initial IB- and the file ending). * '''processed''': Containing element for processed (ie. imported/updated) data. The attribute '''type''' describes what kind of information that was processed, usually "animal information". * '''action''': Containing element for a certain type of processed data according to the action taken. The '''type''' attribute determines the type, usually "new" or "updated" for !AnimInfo. * '''item''': Describes a single item that was processed, and its attributes, which may include: '''aid''' for an animal international id, '''type''' for an !AnimInfo type, '''attribute''' for an !AnimInfo attribute. * '''discarded''': Containing element for discarded data. The attribute '''type''' describes what kind of information that was processed, usually "animal information". * '''action''': Containing element for a certain type of discarded data according to the action taken. The '''type''' attribute describes the reason for discarding, for example "infotype discarded due to animal missing". * '''item''': Describes a single item that was discarded, and its attributes, which may include: '''aid''' for an animal international id, '''type''' for an !AnimInfo type, '''attribute''' for an !AnimInfo attribute. '''Example''': {{{#!highlight xml <interbull type="animinfo_upload_feedback" dscode="ANIMINFO-VIT-20151222T104450"> <processed type="animal information"> <action type="updated"> <item aid="HOLDEUM000000050208" type="RH_GENES" attribute="percent"/> <item aid="HOLDEUM000000050210" type="GENOLIST" attribute="genotyped"/> </action> </processed> <discarded type="animal information"> <action type="animal info discarded due to existing identical data"> <item aid="HOLDEUM000000050208" type="RH_GENES" attribute="percent"/> <item aid="HOLDEUM000000050210" type="GENOLIST" attribute="genotyped"/> </action> <action type="infotype discarded due to animal missing"> <item aid="HOLDEUM99930030030X" type="RH_GENES"/> </action> </discarded> </interbull> }}} === Querying AnimInfo data === {{attachment:animinfo_query_menu.png}} <<BR>>''Figure 4'' To query !AnimInfo click on the ''!AnimInfo -> Query'' menu item (see figure 4), and paste in any text containing animal international IDs. If any of the animals have !AnimInfo data that you are allowed to view, then the data will be presented to you in a dynamic data table. The columns are: AID, !AnimInfo Type, !AnimInfo Attribute, !AnimInfo Value and Submitting Organization. It is possible to filter the results dynamically by using the filter list boxes. Additionally, when doing a pedigree query there will be an indication on the animal presentation page if the animal has !AnimInfo data associated with it, and a link to said data. === Permissions === {{attachment:animinfo_permissions_menu.png}} <<BR>>''Figure 5'' !AnimInfo has a quite elaborate permissions system which can be used to allow or disallow uploading and viewing of !AnimInfo data depending on !AnimInfo type, Organization and AID. To see the current permissions one can click on the ''!AnimInfo -> Permissions'' menu item (see figure 5). There is presented a dynamic data table with an overview of all permissions pertaining to that organization's !AnimInfo data. The columns are Organization, !AnimInfo Type and Permission. Permissions can be of four types: (r) means read access to all of the data, (rw) means read and write access, ie. one can both read all and upload own data, (d) means denied access, ie. can't read the value of the !AnimInfo data, (x) means the permission is inherited from the default permissions for that !AnimInfo type. When the Organization column reads "--DEFAULT" the row indicates the default permission for that !AnimInfo type, as set by the Interbull Centre. Currently, only default permissions are allowed. In the future organizations will be able to upload !AnimInfo files with permission rules included, so they can have more control over who can view and upload what. ***************************** Here you will be shown a list of the allowed !AnimInfo types, attributes and values: * '''!AnimInfo Types''' groups related !AnimInfo attributes (see below) together into a coherent logical unit in the !AnimInfo file format. They are indicated by UPPERCASE names and only alphanumeric characters are allowed, plus underscore(_) and hyphen(-). * '''!AnimInfo Attributes''' holds the actual information of the relevant !AnimInfo type in a list of name/value-pairs, for example ''genotyped="Y"''. The first part, before the equal(=) sign is the name of the attribute, and is in lowercase, and the part after the equal sign and within quotation marks (") is the value of that attribute (see below). As with the types the attribute name can only contain alphanumeric characters, underscore and hyphen. An !AnimInfo type can contain from one to several related attributes — some of which are required, others are optional. An attribute can only be specified once for each !AnimInfo type, organization and animal. * '''!AnimInfo Values''' sets the value of each attribute for each animal. The value must conform to the specification of the attribute, which can be different from attribute to attribute; ranging from a free-form text string, to a set of predefined values, to a defined pattern the value must match. '''Example 2:''' A more complex example would like to upload %RH-genes and Genolist data (which specifies whether the animal has been genotyped or not, and if it this animal's genotype is public or not) for four animals: {{{#!highlight xml <interbull type="animinfo" version="1.0"> <animals> <a id="HOLUSAM000000000X11"> <RH_GENES percent="50" /> <GENOLIST genotyped="Y" public="Y" /> </a> <a id="HOLDEUF000000000Y22"> <RH_GENES percent="N/A" /> <GENOLIST genotyped="Y" public="N" /> </a> <a id="HOLUSAM000000000X45"> <RH_GENES percent="75" /> <GENOLIST genotyped="N" /> </a> <a id="HOLDEUF000000000Y67"> <GENOLIST genotyped="Y" public="Y" /> <RH_GENES percent="25" /> </a> </animals> </interbull> }}} | 
IDEA AnimInfo User Manual
Introduction
The AnimInfo is a module in the Interbull Centre Data Exchange Area(IDEA) website which allows member organizations to upload additional information connected to existing animals in the pedigree module. Examples on additional information are coat color, crossbred information, herdbook number, eartag number, genetic defects etc.
The purpose of the AnimInfo module is to collect reported information from member organizations and to use the module as an exchange area for information, not to verify or authorize information. It is possible to make different security levels for the information which means that for some AnimInfo information only the authorized organization may view and upload information, for other information it is possible for some or all organizations to view and/or upload.
The type of additional information that will be registered in IDEA Animinfo is decided by member organizations in collaboration with Interbull Centre. Interbull Centre has to update IDEA with the type of additional information (coat color, herdbook number etc) to upload before member organizations can upload the information in the IDEA Animinfo module. Member organizations are encourage to send requests on additional iniformation to upload in IDEA to Interbull Centre. The current type of information available for registration in IDEA/Animinfo can be found by clicking on the AnimInfo -> Types menu item in the bar menu in IDEA (see figure 1).
The AnimInfo file format is an XML file format. For basic information on XML, see https://en.wikipedia.org/wiki/XML or public/XMLdigest. XML is a flexible system for complex data files and was choosen for AnimInfo in order to ensure easy future development and extension of the module's file format and capabilities, as well as a fitting format for the current data model.
The following is a description on how to, as an end-user, prepare and upload additional animal information to IDEA.
Contents
AnimInfo usage
The workflow to upload additional information for animals existing in the pedigree modul:
- Create a XML file with the relevant information according to ..."link"
- Run a checking program to check the correctness of the file ..... "link"".
- Upload the file to IDEA ... link....
- After uploading , member organizations will be able to query the information and get the information in a data file.
If more than one organization uploads the same type of data for the same animal all the uploaded information will be shown when querying that animal, with indications from which organization the different pieces of data come from.
Preparation
An overview of current available type of information to upload in IDEA/Animinfo can be found in the AnimInfo -> Types page in IDEA (Figure 1)
 
 
Figure 1 
Each type of information (Types) have different attributes and value where:
- AnimInfo Types are written in uppercase letters followed by a short description in italic. 
- AnimInfo Attributes are written below each TYPE in lowercase. The attributes holds the actual information of the relevant AnimInfo type. An attribute can only be specified once for each AnimInfo type, organization and animal. 
- AnimInfo Values sets the value of each attribute for each animal. The value must conform to the specification of the attribute, which can be different from attribute to attribute; ranging from a free-form text string, to a set of predefined values, to a defined pattern the value must match. 
********************* CARL CHANGE **********************
Here, in Figure 2, one can see the specification of the %RH-genes AnimInfo data structure, where the type is specified as RH_GENES, and it has a single attribute, percent. The percent has the value type percent with not available, which is defined in the list of value types as A numerical, integer value between 0 and 100, with the string N/A if not available. This means that one can upload %RH-genes percent values (which is either a percent value or N/A for missing values) for every animal, using the AnimInfo file format.
 
 
Figure 2 
****************************************************************************************************************
Create an AnimInfo file
The structure of the AnimInfo XML file format is as following:
- interbull: The root element of the Interbull XML file formats. It requires the XML attributes type and version, where the values should be animinfo and 1.0 respectively. - animals: The animals element defines the section which lists all animals and their AnimInfo data. - a: the animals section contains several a-elements which each represents a single animal. Every a-element should have an id-attribute which is the animal's international id (AID). - ANIMINFO TYPE: Every animal specified by the a-element may have one or more unique AnimInfo types specified, with each's respective attributes defined. 
 
 
 
************ CARL CHANGE ********************************************
Example 1: Take a file which will upload %RH-genes information about two animals. Then the correctly formatted AnimInfo XML data file would look like this:
   1 <interbull type="animinfo" version="1.0">
   2   <animals>
   3     <a id="HOLUSAM000000000X11">
   4       <CROSSBREED breed="RH" percent="50" />
   5     </a>
   6     <a id="HOLUSAM000000000X1x">
   7       <CROSSBREED breed="RH;SIM;BSW" percent="20;20;10" />
   8     </a>
   9     <a id="HOLDEUF000000000Y22">
  10       <RH_GENES percent="N/A" />
  11     </a>
  12   </animals>
  13 </interbull>
******************************************************************************************
Run Checking program
Once the AnimInfo XML file has been prepared, it has to be run through the CheckAnimInfo program, just like with Pedigree, Links and EBV/GEBV files has to be checked before uploading to IDEA. The CheckAnimInfo program is downloadable from the IDEA website, under Software, and is a Python 2 script https://ideatest.hgen.slu.se/idea_animinfo/software/index
This will check that the AnimInfo file format is correct and that the file includes the right AnimInfo types, attributes and values. It will warn and give hints about what kind of errors it encounters, and how to fix them. If all goes well it will produce an AnimInfo zip file, ready to upload through the IDEA web interface.
AnimInfo Upload
 
 
Figure 3 
The AnimInfo zip file is called IB-ANIMINFO-{org code}-{YEAR-MONTH-DAY}T{HOUR-MINUTE-SECOND}.zip, and can be uploaded by clicking on the AnimInfo -> Upload menu item (see figure 3) and then using the appropriate upload buttons. After upload the file will be checked by the server-side CheckAnimInfo script, and if everything checks out OK the data will be passed onto the import functions in IDEA. After the data has been processed an email with feedback information will be sent. The email contains general statistics about the upload; how many AnimInfo types and attributes that were processed, discarded and so on. Also included is an XML AnimInfo feedback file with more detailed information about the upload. Here is the structure of the feedback XML file:
- interbull: Root element with type="animinfo_upload_feedback" and dscode equal to the data set code for the upload (similar to the file name, minus the initial IB- and the file ending). - processed: Containing element for processed (ie. imported/updated) data. The attribute type describes what kind of information that was processed, usually "animal information". - action: Containing element for a certain type of processed data according to the action taken. The type attribute determines the type, usually "new" or "updated" for AnimInfo. - item: Describes a single item that was processed, and its attributes, which may include: aid for an animal international id, type for an AnimInfo type, attribute for an AnimInfo attribute. 
 
 
- discarded: Containing element for discarded data. The attribute type describes what kind of information that was processed, usually "animal information". - action: Containing element for a certain type of discarded data according to the action taken. The type attribute describes the reason for discarding, for example "infotype discarded due to animal missing". - item: Describes a single item that was discarded, and its attributes, which may include: aid for an animal international id, type for an AnimInfo type, attribute for an AnimInfo attribute. 
 
 
 
Example:
   1 <interbull type="animinfo_upload_feedback" dscode="ANIMINFO-VIT-20151222T104450">
   2   <processed type="animal information">
   3     <action type="updated">
   4       <item aid="HOLDEUM000000050208" type="RH_GENES" attribute="percent"/>
   5       <item aid="HOLDEUM000000050210" type="GENOLIST" attribute="genotyped"/>
   6     </action>
   7   </processed>
   8   <discarded type="animal information">
   9     <action type="animal info discarded due to existing identical data">
  10       <item aid="HOLDEUM000000050208" type="RH_GENES" attribute="percent"/>
  11       <item aid="HOLDEUM000000050210" type="GENOLIST" attribute="genotyped"/>
  12     </action>
  13     <action type="infotype discarded due to animal missing">
  14       <item aid="HOLDEUM99930030030X" type="RH_GENES"/>
  15     </action>
  16   </discarded>
  17 </interbull>
Querying AnimInfo data
 
 
Figure 4 
To query AnimInfo click on the AnimInfo -> Query menu item (see figure 4), and paste in any text containing animal international IDs. If any of the animals have AnimInfo data that you are allowed to view, then the data will be presented to you in a dynamic data table. The columns are: AID, AnimInfo Type, AnimInfo Attribute, AnimInfo Value and Submitting Organization. It is possible to filter the results dynamically by using the filter list boxes. Additionally, when doing a pedigree query there will be an indication on the animal presentation page if the animal has AnimInfo data associated with it, and a link to said data.
Permissions
 
 
Figure 5 
AnimInfo has a quite elaborate permissions system which can be used to allow or disallow uploading and viewing of AnimInfo data depending on AnimInfo type, Organization and AID. To see the current permissions one can click on the AnimInfo -> Permissions menu item (see figure 5). There is presented a dynamic data table with an overview of all permissions pertaining to that organization's AnimInfo data. The columns are Organization, AnimInfo Type and Permission. Permissions can be of four types: (r) means read access to all of the data, (rw) means read and write access, ie. one can both read all and upload own data, (d) means denied access, ie. can't read the value of the AnimInfo data, (x) means the permission is inherited from the default permissions for that AnimInfo type. When the Organization column reads "--DEFAULT" the row indicates the default permission for that AnimInfo type, as set by the Interbull Centre. Currently, only default permissions are allowed. In the future organizations will be able to upload AnimInfo files with permission rules included, so they can have more control over who can view and upload what.
*****************************
Here you will be shown a list of the allowed AnimInfo types, attributes and values:
- AnimInfo Types groups related AnimInfo attributes (see below) together into a coherent logical unit in the AnimInfo file format. They are indicated by UPPERCASE names and only alphanumeric characters are allowed, plus underscore(_) and hyphen(-). 
- AnimInfo Attributes holds the actual information of the relevant AnimInfo type in a list of name/value-pairs, for example genotyped="Y". The first part, before the equal(=) sign is the name of the attribute, and is in lowercase, and the part after the equal sign and within quotation marks (") is the value of that attribute (see below). As with the types the attribute name can only contain alphanumeric characters, underscore and hyphen. An AnimInfo type can contain from one to several related attributes — some of which are required, others are optional. An attribute can only be specified once for each AnimInfo type, organization and animal. 
- AnimInfo Values sets the value of each attribute for each animal. The value must conform to the specification of the attribute, which can be different from attribute to attribute; ranging from a free-form text string, to a set of predefined values, to a defined pattern the value must match. 
Example 2: A more complex example would like to upload %RH-genes and Genolist data (which specifies whether the animal has been genotyped or not, and if it this animal's genotype is public or not) for four animals:
   1 <interbull type="animinfo" version="1.0">
   2   <animals>
   3     <a id="HOLUSAM000000000X11">
   4       <RH_GENES percent="50" />
   5       <GENOLIST genotyped="Y" public="Y" />
   6     </a>
   7     <a id="HOLDEUF000000000Y22">
   8       <RH_GENES percent="N/A" />
   9       <GENOLIST genotyped="Y" public="N" />
  10     </a>
  11     <a id="HOLUSAM000000000X45">
  12       <RH_GENES percent="75" />
  13       <GENOLIST genotyped="N" />
  14     </a>
  15     <a id="HOLDEUF000000000Y67">
  16       <GENOLIST genotyped="Y" public="Y" />
  17       <RH_GENES percent="25" />
  18     </a>
  19   </animals>
  20 </interbull>
