This invention relates to the field of de-identification of a record. In particular, the invention relates to extracting personal information elements from unstructured portions of a record in order to remove identification information.
Privacy of information has become very important in many different fields. Privacy is an issue that is likely to last for some time, with serious implications for businesses, especially those that rely heavily on information systems and Internet technology.
The ease with which electronic data can be transmitted, together with the vital need for data and information to advance research, has brought about the need to protect the privacy of the entities whose data is used. For example, medical research requires patient data but a patient's privacy must be protected. To preserve a person's privacy, it must be ensured that the transferred information cannot be associated with any specific individual and also that only authorized individuals based on the informed consent have access to the personal information.
This privacy is achieved by disclosing only certain pieces of non-identifiable information. To ensure complete privacy, all data must go through the process known as de-identification in which any pieces of information which can be used to identify an entity (such as an individual, a group of individuals, a business entity, a government entity, or any organisation) are removed or replaced with non-identifiable information.
Several countries have already chosen to impose this concept through legislation (for example, the Health Insurance Portability and Accountability Act of 1996 (HIPAA) in the U.S.). The HIPAA in the US is specific to portability of health information and applicable to the healthcare industry only. The EU Privacy Directive for the European Union member countries or the PIPEDA (Personal Information Protection and Electronic Document Act) and FIPPA (Freedom of Information and Protection of Privacy Act) in Canada are broader and also rigid and applicable to all business entities across industries. Legislation in this area is progressing around the world.
Legislation that protects the privacy of individuals can vary greatly, depending on which part of the world is involved. Additionally, the type of information involved, the technologies required to identify this information, and the definition of privacy are continuously evolving. The combination of these factors presents a challenge when developing methods for the protection of privacy and de-identification.
An example target industry in which de-identification of documents is critical, is the healthcare and life sciences industry. Specifically, de-identification is required for the implementation of electronic patient records (EPR) and electronic health records (EHR) for the integration of de-identified personal health records for translational life sciences research. De-identification of a patient's personal data from medical records is a protective legal requirement imposed before medical documents can be used for research purposes or transferred to other healthcare providers (e.g., teachers, students, tele-consultations).
De-identification can be applied to other industries such as government, retail, financial, insurance, and manufacturing industries for de-identification of protected personal information attributes.
In the US, HIPAA defines “Protected Health Information” (PHI) fields that must be de-identified to protect the personal privacy of a patient. These information fields include the following fields with the action required:
The de-identification rules for the elements of PHI can change based on the privacy policies of individual business entities and the Institutional Review Board decisions. For example, the state and city out of the address can be kept as long as the population of the city is more than 20,000, and a date of birth can be converted to an age range if the person is 89 years or younger.
Existing methods of locating identifying personal information that can be directly used to identify a specific individual, or non-personal information (e.g. 90 years of age) that can be used indirectly to identify a specific individual, generally use natural language processing and use complex methods that require name repositories, location repositories, dictionaries, and other taxonomies that will help to detect whether a specific “word” can be used directly or indirectly to identify a person. These methods need sophisticated information retrieval techniques, must resolve ambiguity, and are required for imbedding relatively heavy processing and algorithms. Large repositories of names are required from all around the world as the population in every country today is heterogeneous as a result of large immigration.
According to a first aspect of the present invention there is provided a method of de-identification of a record, comprising: creating a vector of identification field values of a record; searching unstructured data of the record for each identification field value of the vector; and de-identifying the identification field values of the record. The unstructured data may be portions of a structured, semi-structured, or unstructured record.
In an embodiment of the present invention, the step of creating a vector of identification field values extracts the values from one or more structured portions of the record. The one or more structured portions of the record may be independent of the unstructured data of the record, for example in a different file format. Alternatively, the one or more structured portions of the record may be combined with the unstructured data of the record.
The method also preferably includes defining an action for each identification field to de-identify the identification field. An action to be applied to an identification field may be, for example, to erase, encrypt, cloak, scramble, replace with a derived value, etc.
In one embodiment, the method includes defining a mapping of unstructured portions of the record; extracting the unstructured portions of the record; and wherein the steps of searching and de-identifying are carried out on the extracted unstructured portions. The method may also include re-mapping the de-identified unstructured portions to the record.
A measure of re-identification risk of a record may be defined as the level of difficulty of inferring information in a record to specific entities. A measure of completeness may be defined as the percentage of information in a record that is not de-identified. The measure of re-identification and the measure of completeness may be used to de-identify a minimum number of identification field values in a record.
According to a second aspect of the present invention there is provided a method comprising: extracting identification field values from a record; defining a set of conversion actions with a conversion action for each identification field; storing a first set of information of the identification field values and the set of conversion actions; and storing a second set of information of the record with converted identification field values; wherein the record can be re-identified using the first and second sets of information.
The first and second sets of information may be stored securely for access only by authorised users or stored encrypted using cryptography and the decryption keys available only to authorised users.
According to a third aspect of the present invention there is provided a computer program product stored on a computer readable storage medium for de-identifying a record, comprising computer readable program code means for performing the steps of: creating a vector of identification field values of a record; searching unstructured data of the record for each identification field value of the vector; and de-identifying the identification field values of the record.
According to a fourth aspect of the present invention there is provided a system for de-identification of a record, comprising: a tool for discovering identification field values of a record; a search engine for searching unstructured data of the record for each identification field value; and a converter for de-identifying the identification field values of the record.
The converter may apply an action defined for each identification field. The tool for discovering may be configured for discovering identification field values in one or more structured portions of the record. The one or more structured portions of the record may be independent of the unstructured data of the record. Alternatively, the one or more structured portions of the record may be combined with the unstructured data of the record.
In one embodiment, the system may also include: a pointer for mapping of unstructured portions of the record; an extractor for extracting the unstructured portions of the record; and a memory for storing the unstructured portions of the record; wherein the search engine and converter are applied to the stored unstructured portions of the record.
According to a fifth aspect of the present invention there is provided a method of providing a service over a network, the service comprising: creating a vector of identification field values of a record; searching unstructured data of the record for each identification field value of the vector; and de-identifying the identification field values of the record.
This present invention provides a method to parse unstructured records, extract identification field values embedded in the natural language text documents, and anonymize them as a means to de-identify the records.
The subject matter regarded as the invention is particularly pointed out and distinctly claimed in the concluding portion of the specification. The invention, both as to organization and method of operation, together with objects, features, and advantages thereof, may best be understood by reference to the following detailed description when read with the accompanying drawings in which:
It will be appreciated that for simplicity and clarity of illustration, elements shown in the figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements may be exaggerated relative to other elements for clarity. Further, where considered appropriate, reference numbers may be repeated among the figures to indicate corresponding or analogous features.
In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of the invention. However, it will be understood by those skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known methods, procedures, and components have not been described in detail so as not to obscure the present invention.
The described method and system use the values of the fields which can identify an entity (identification fields) as a basic taxonomy vector. The process searches free text and unstructured information in a record for the appearance of any of the identification field values. This solution aims to ensure that no private information that can directly identify a person or an entity, or no other information that can indirectly identify a person or an entity (e.g. a 95 year old male in Haifa) appears anywhere in the record.
Thus, for every record, the taxonomy vector is generated dynamically from the identification fields. All free text in the record is searched against the taxonomy vector. In addition, a static taxonomy which contains potential nicknames or descriptors that are well known is created and can be used in a similar way.
A record may take many different forms. In some instances a record relates to a single entity, for example, a person, an organisation, etc. In other instances, a record may relate to more than one entity and identification field values in the record may identify one or more of the entities. Records can occur in different industries or relate to different forms of information relating to the entity. For example, the information may be medical, financial, business, government, etc.
A record generally includes one or more structured portions and one or more unstructured portions. In this way a record may be structured, semi-structured, or unstructured. The structured portions may present data in an ordered manner and the unstructured portions may be free text or data.
The unstructured portions may be separate from the structured portions and may not reside in the same portion of the record. For example, the structured portions may be represented as a CSV (comma-separated values) file, or in an XML (extended mark-up language).
On the other hand, the structured and unstructured data may be intermingled or combined. For example, an XML document with structured parts and unstructured parts, namely an XML element with free text under it.
The structured portions of a record can take different forms. For example, these may take the following forms, however other structured formats may also be envisaged:
As the record has unstructured portions, a definition of where the unstructured portions are in the record is required.
For example:
Referring to
As an example, a record may be a medical record with unstructured portions in the form of a patient chart, admission record, discharge summary, diagnostic report, referral letter, etc.
Referring to
The values of identification fields are extracted from one or more structured portions 101 of the record i 100. The identification fields may be defined in accordance with legislation (such as Protected Health Information (PHI) defined by HIPAA), or may be defined for a particular application. When identification fields are presented in a structured format, such as in relational, rectangular, XML-tagged, tabular, and comma-separated, they can be extracted by a user. The extraction can be carried out programmatically with a configurable extraction tool.
If there are multiple records which have the same format of structured portions, an extraction tool can be configured to extract the identification field values for each record programmatically.
A record may relate to a single entity (such as a patient's medical report), or to more than one entity (such as a banking report for a joint account held by two or more persons). The identification field values are the actual names, address information, dates, identification numbers, etc. from which an entity can be identified.
As the identification field values are being extracted from the structured portion 101, a taxonomy vector 201 is generated and updated.
This vector is defined as Pi−<d1, d2, d3, . . . d17>
The action to be taken on each identification field is also defined. This may be defined for a single record, or may be defined generally for a group of records. The action vector 202 is defined as:
A=<a1, a2, a3, . . . a17>
De-identification replaces entity-specific identifiers (e.g., entity's name, age, gender, etc.) with non-specific markers, such as a “*” or “research patient”. De-identification destroys some of the worth of the data (for example, if the patient's age is removed this may limit use of the data). Anonymization goes further than de-identification and attempts to replace the sensitive fields with “like” values that obscure the identity of the entity. Such substitution values are typically drawn from a population statistic/curve (e.g., a Gaussian distribution, etc.). The action vector 202 defines this substitution or conversion.
As a separate step which may be carried out simultaneously, prior to, or after the step of discovering the values of the vector 201, a schema mapping 203 is defined pointing to all the unstructured portions 111, 112, 113, 114 of the record i 100.
The schema mapping 203 is defined for all unstructured portions 111, 112, 113, 114 of the medical record i 100. The schema mapping 203 is defined by defining a collection of mapping:
F=<f1, f2, f3, . . . fn,>
The mapping function fn is represented according to the record schema structure.
In the case the record is presented in XML, fn is the XPath format of the attribute. The term XPaths refers to the paths in XML documents that lead to specific fields. As an example, Clinical Document/recordTarget/patientRole/patientPatient/Name/family presents the family name of the person and gives the exact location of the attribute.
In the case the record is presented in a database, the mapping function fn will denote tables and column names that include unstructured portions. If the record is a CSV file or tabular file, the mapping function fn will denote the positions that include unstructured portions. If the record is a DICOM file, the mapping function fn will be DICOM tags where the unstructured portions reside.
In a next stage of the described method, the unstructured portions are extracted to generate the unstructured information 205 for record i. This is done by using the mapping function F 203 to extract the unstructured portions 1, 2, 3 . . . n of the medical record i 100. To simplify the process, all unstructured information is concatenated and stored in memory while maintaining the begin/end position of each unstructured portion and the index of the attribute it represents.
The unstructured information 205 is defined as:
V=v1+v2+v3,+ . . . +vn,
Identification field values d 211, 212, 213 are contained in the unstructured information V 205. For example, a patient's name may occur numerous times in a medical record in unstructured portions such as the patient chart, admission record, patient diagnostic report, etc.
The unstructured information V 205 is searched for each entry of the vector 201 Pi for record i presented as dj.
The identification field values 230 in the unstructured information V 205 are defined as D and may take the form of, for example:
D=<d1, d2, d1, d6, d8, d2, . . . >
The configured action aj as defined for each specific identification field in action vector A 202 is carried out. In case the action desired is to erase the value, the same action will apply to the value within the unstructured information V 205. In case the action desired is to encrypt the value, the same action will apply to the value within the unstructured information V 205. In case the action desired is to substitute the value with a derived value, (e.g. substituting date of birth with age range), the same action will apply to the value within the unstructured information V 205.
The converted identification field values 235 in the unstructured information V 205 are defined as C and, following the above example for D, may take the form of:
C=<c1, c2, c1, c6, c8, c2, . . . >
The unstructured information V 205 is searched for all values in the taxonomy vector Pi 201 for the values dj and the values are converted to cj by carrying out the required action aj for the identification field. The updated unstructured information V′ 215 has all the identification values dj 211, 212, 213 converted to cj 221, 222, 223 and thus is de-identified.
The record i 100 is updated using the unstructured portions 1, 2, 3, . . . n 111, 112, 113, 114 including the converted identification field values cj 221, 222, 223 of the unstructured information V′ 215 from memory to the associated attributes as defined by the mapping function F 203. Each unstructured portion is replaced with the converted and anonymized unstructured portion according to the above algorithm.
Referring to
The memory elements may include system memory 302 in the form of read only memory (ROM) 304 and random access memory (RAM) 305. A basic input/output system (BIOS) 306 may be stored in ROM 304. System software 307 may be stored in RAM 305 including operating system software 308. Software applications 310 may also be stored in RAM 305.
The system 300 may also include a primary storage means 311 such as a magnetic hard disk drive and secondary storage means 312 such as a magnetic disc drive and an optical disc drive. The drives and their associated computer-readable media provide non-volatile storage of computer-executable instructions, data structures, program modules and other data for the system 300. Software applications may be stored on the primary and secondary storage means 311, 312 as well as the system memory 302.
The computing system 300 may operate in a networked environment using logical connections to one or more remote computers via a network adapter 316.
Input/output devices 313 can be coupled to the system either directly or through intervening I/O controllers. A user may enter commands and information into the system 300 through input devices such as a keyboard, pointing device, or other input devices (for example, microphone, joy stick, game pad, satellite dish, scanner, or the like). Output devices may include speakers, printers, etc. A display device is also connected to system bus 303 via an interface, such as video adapter 315.
Referring to
When the system 400 is in use data storage or memory 410 may store a record 100, the concatenated unstructured portions V 205 of the record, the converted concatenated unstructured portions V′ 215 and the de-identified record 120. During processing the memory may include the vector of identification field values P 201, the mapping function F 203, the conversion action vector A 202, the subset of identification values D 230, and the subset of converted identification values C 235.
Referring to
De-identification methods and algorithms must be able to detect identifiers, but should not remove information that is necessary and does not break privacy policies. The method and system described above addresses the issue of privacy protection, but does not address the issue of removing minimal information.
To address this second goal, two measurements are defined:
The above two measures can be used to de-identify a minimum number of identification field values in a record.
The above two measures are ultimately determined by the specific algorithms used for de-identification. For example, when scrubbing PHI values, it may be desirable to leave in the free-text the type of information that was scrubbed i.e. is it a patient name, a date of birth, an address. This makes the anonymized text more readable and increases the completeness level without decreasing the confidentiality level.
The described method can be extended to support the re-identification of a record by authorized people.
Referring to
A first set of information 610 is the combination of the identification field values D and the conversion method A. A second set of information is the de-identified record 620.
Neither the first set of information 610 nor the second set of information 620 contains information linking entities to their records. However, a record can be re-identified 630 using the first and second sets of information 610, 620.
This method can be summarised in the following steps:
1) Text is divided into short phrases;
2) Each phrase is converted by a one-way hash algorithm into a seemingly-random set of characters;
3) Threshold Piece 1 is composed of the list of all phrases, with each phrase followed by its one-way hash;
4) Threshold Piece 2 is composed of the text with all phrases replaced by their one-way hash values, and with high-frequency words preserved. (When a high-frequency “stop” word, such as a, an, the, or for, is encountered, it is left in place).
There are two methods to enable re-identification. One option is to generate a vector of the converted values C that corresponds to the field identification values D and then to store C and D in a secure zone that can only be accessed by authorized people. Another option is to use cryptographic technologies to generate the C vector from D and to save the private keys in a secured zone. In both cases C values replace D values in the record.
The described method and system create a relatively simple taxonomy vector for the identification field values and the taxonomy vector is used to search and identify those key words and values that are imbedded in unstructured text documents in a relatively simple and fast way without requiring any special computing resources or any specific prerequisite software or hardware.
The described method can be used as a first path to the more complex known methods using natural language processing, thereby reducing the processing required for those methods.
A method of de-identification and/or re-identification as described above may be provided as a service to a customer over a network
The invention can take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements. In a preferred embodiment, the invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
The invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer usable or computer readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus or device.
The medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read only memory (ROM), a rigid magnetic disk and an optical disk. Current examples of optical disks include compact disk read only memory (CD-ROM), compact disk read/write (CD-R/W), and DVD.
Improvements and modifications can be made to the foregoing without departing from the scope of the present invention.