Embodiments described herein are related to methods of embedding text and methods of predicting results where there is insufficient data to make an accurate prediction, the predictions can be used to enhance a Graphical Representation.
Obtaining accurate and comprehensive medical data is typically prohibitive. For instance, collecting data using epidemiological studies may take decades, and even then the values can be highly biased. Furthermore, emerging diseases and medical advances are two examples of circumstances whereby public health priorities shift rapidly and policy makers cannot wait for data to make thoroughly evidence-based decisions.
Accurate, comprehensive estimation of global health statistics is crucially important for informing health priorities and health policy decisions at global, national and local scales. Metrics such as the incidence and prevalence of different diseases need to be representative of the population of interest for them to be useful in tailoring health policies for different countries or different sub-populations within countries, More recently, comprehensive data on the burden of different diseases in many different settings has also become an important factor in the development of AI solutions addressing global healthcare needs.
Getting accurate estimates of the burden of different diseases globally is a challenging problem. Collecting high quality epidemiological data is not trivial; it takes a substantial amount of time, money and expertise to design rigorous data collection processes, to gather data, and to build infrastructure to support data collection on a routine or ad-hoc basis. This can be particularly problematic in developing countries where health systems are less robust and face difficulties such as lack of funding, staff shortages, and poor computer infrastructure. These problems can be compounded by the occurrence of natural disasters, disease epidemics, and civil unrest, which can disrupt existing healthcare systems.
Furthermore, graphical representations of data are used during automated diagnosis. Such models rely on the ability to understand and represent the relationship between conditions and symptoms. The data for these models and the construction of these models also requires considerable long term studies.
Embodiments will now be described with reference to the following figures in which:
In an embodiment, a computer implemented method for predicting a value of the prevalence or incidence of a condition in a population is provided, the method comprising:
In a further embodiment, a computer implemented method for developing a probabilistic graphical representation is provided, the probabilistic graphical representation comprising nodes and links between the nodes indicating a relationship between the nodes, wherein the nodes represent conditions, the method comprising:
The disclosed system provides an improvement to computer functionality by allowing computer performance of a function not previously performed by a computer. Specifically, the disclosed system provides for the accurate prediction of a condition of a population from related data. The disclosed system solves this technical problem by providing the specific embedded representation of input text. This embedded representation draws on both linguistic considerations, but also the context of the text. This allows the embedded representation to be used to train a neural network where, for example, data from one country can be applied to another country and thus allows for the prediction of results where insufficient data is provided.
This, avoids the need to gather data for all possible conditions in all locations. It also means that the machine learning model used to predict the prevalence or incidence can be trained on less data allowing computational advantages and a reduced tine to train the model.
Many diagnostic systems, both medical and others, for example, fault diagnosis, use a probabilistic graphical representation (which can also be referred to as a probabilistic graphical model or “PGM”) which mathematically models the dependencies of the various conditions. The methods described herein allow for the enhancement of a PGM both in terms of the ability to add new nodes, since the data can be predicted for new nodes, e.g. the prevalence of a condition allow a node to be introduced for a condition, and the prediction of new links between conditions.
In an embodiment, the condition can be selected from a disease, symptom or risk factor
The labels can be one or more selected from location, age and sex of population. The labels can be encoded in a context aware manner such that similar labels are encoded with similar vectors. For example, for the label of location, locations with similar populations, GDP and climate can be encoded to have similar vectors. Other labels can be one hot encoded.
The above has discussed enhancing the embedded vector with an label, but it is also possible for the enhanced embedded vector to be produced from two conditions by:
The above can be used to predict further links in the PGM by comparing the said value with a threshold, the method determining the presence of a link in the probabilistic graphical between the two conditions if the value is above the threshold and adding the link to the probabilistic graphical model.
In an embodiment, the language model is adapted to receive free text. In an embodiment, the language model is selected from BioBERT, Global Vectors for Word Representation (GloVe), the Universal Sentence Encoder (USE) or one of the GPT models. In further embodiments, a combination of language models are used. One or more of the language models may be been trained on a biomedical database.
As explained the above can be used to determine data for the incidence and prevalence of diseases where there is incomplete data. For example:
1. Where data is available on the incidence of the disease in other countries and data on the incidence of other diseases in the same country, but data is missing for a specific disease-country pairing.
2. Where data is available on the incidence of the disease in other countries, but is missing for the country of interest.
3. Where data is available on the incidence of other diseases in that same country, but no data is available on the disease of interest.
For the above, in an embodiment, the label is location and the method is used to determine a value for a condition in a specified location and the machine learning model has been trained on values for conditions including this condition for other locations and for other conditions for the specified location.
For the above, in a further embodiment, said label is location and the method is used to determine a value for a condition in a specified location and the machine learning model has been trained on values for conditions not including this condition for any location.
For the above, in a further embodiment, said label is location and the method is used to determine a value for a condition in a specified location and the machine learning model has been trained on values for conditions, but not on any values concerning the specified location.
It is possible for the enhanced embedded vector to comprise two embedded concepts and one or more labels.
In a further embodiment, a bespoke embedding can be used where using a language model to produce a context aware embedding for said condition comprises:
In an embodiment, combining said second concept vector representations comprises:
The above methods may be used within a diagnosis system to determine whether a user has a disease or some condition. Thus, in a further embodiment, a method of determining the likelihood of a user having a condition is provided, the method comprising:
In a further embodiment, a computer-readable medium comprising instructions which, when executed by a computer, cause the computer to carry out the above method. The medium may a physical medium such as a flashdrive or a transitory medium for example a download signal.
The mobile phone 3 will communicate with interface 5. Interface 5 has 2 primary functions, the first function 7 is to take the words uttered by the user and turn them into a form that can be understood by the inference engine 11. The second function 9 is to take the output of the inference engine 11 and to send this back to the user's mobile phone 3.
In some embodiments, Natural Language Processing (NLP) is used in the interface 5. NLP helps computers interpret, understand, and then use everyday human language and language patterns. It breaks both speech and text down into shorter components and interprets these more manageable blocks to understand what each individual component means and how it contributes to the overall meaning, linking the occurrence of medical terms to the Knowledge Graph. Through NLP it is possible to transcribe consultations, summarise clinical records and chat with users in a more natural, human way.
However, simply understanding how users express their symptoms and risk factors is not enough to identify and provide reasons about the underlying set of diseases. For this, the inference engine 11 is used. The inference engine is a powerful set of machine learning systems, capable of reasoning on a space of >100s of billions of combinations of symptoms, diseases and risk factors, per second, to suggest possible underlying conditions. The inference engine can provide reasoning efficiently, at scale, to bring healthcare to millions.
In an embodiment, the Knowledge Graph 13 is a large structured medical knowledge base. It captures human knowledge on modern medicine encoded for machines. This is used to allow the above components to speak to each other. The Knowledge Graph keeps track of the meaning behind medical terminology across different medical systems and different languages.
In an embodiment, the patient data is stored using a so-called user graph 15.
In an embodiment, the inference engine 11 comprises a generative model which may be a probabilistic graphical model or any type of probabilistic framework.
In this specific embodiment, to aid understanding, a 3 layer Bayesian network will be described, where one layer related symptoms, another to diseases and a third layer to risk factors. However, the methods described herein can relate to any collection of variables where there are observed variables (evidence) and latent variables.
The graphical model provides a natural framework for expressing probabilistic relationships between random variables, to facilitate causal modelling and decision making. In the model of
In this simplified specific example, the model is used in the field of diagnosis. In the first layer, there are three nodes S1, S2 and S3, in the second layer there are three nodes D1, D2 and D3 and in the third layer, there are three nodes RF1, RF2 and RF3.
In the graphical model of
The embodiments described herein relate to the inference engine.
In an embodiment, in use, a user 1 may inputs their symptoms via interface 5. The user may also input their risk factors, for example, whether they are a smoker, their weight etc. The interface may be adapted to ask the patient 1 specific questions. Alternately, the patient may just simply enter free text. The patient's risk factors may be derived from the patient's records held in a user graph 15. Therefore, once the patient identified themselves, data about the patient could be accessed via the system.
In further embodiments, follow-up questions may be asked by the interface 5. How this is achieved will be explained later. First, it will be assumed that the patient provide all possible information (evidence) to the system at the start of the process.
The evidence will be taken to be the presence or absence of all known symptoms and risk factors. For symptoms and risk factors where the patient has been unable to provide a response, these will assume to be unknown. However, some statistics will be assumed, for example, the incidence and/or prevalence of a disease in the country relevant to the user. This data is sometimes hard to obtain, the methods that will be described with reference to
When performing approximate inference, the inference engine 11 requires an approximation of the probability distributions within the PGM to act as proposals for the sampling.
In a very simple example, looking at
To determine the above, one of the unknown quantities is P(D3) which is the incidence of disease D3. This can be determined using the methods taught in the following embodiments. Typically, P(D3) will be location dependent and possible gender and age dependent Using the following embodiments P(D3) may be estimated even if D3 is an unknown new condition or if there is no data available for the country of interest.
Due to the size of the PGM, it is not possible to perform exact inference in a realistic timescale. Therefore, the inference engine 11 performs approximate inference.
These types of networks usually have three layers of nodes: the first level contains binary nodes that are risk factors; the second level, diseases; and the last level, symptoms. The network structure is designed by medical experts who assess whether there exists a direct relationship or not between a given pair of nodes.
However, there is a need to be able to obtain data for such networks. Obtaining accurate and comprehensive medical data is typically prohibitive. For instance, collecting data using epidemiological studies is costly and may take decades to complete.
Embodiments described herein allow inference to be provided for situations where the underlying data required to provide the probability distributions in the PGM is not available.
There is already data available concerning the incidence and prevalence of diseases. For example, “The Global Burden of Disease (GBD)” study, conducted by the Institute for Health Metrics and Evaluation (IHME), aims to systematically and scientifically quantify health losses globally. The GBD captures data from 195 countries globally, and combines these data to produce accurate age- and sex-specific estimates of the incidence, prevalence, and rates of disability and mortality that are caused by over 350 diseases and injuries. Also, data is available from many sources, including surveys, administrative data (including vital registration data, census data, epidemiological and/or demographic surveillance data), hospital data, insurance claims data, disease registries and other related sources such as that published in the scientific literature. These data sources can be used as ground truths for training the models that will be explained below.
In the following, the disease incidence estimates produced by the deep learning models were validated using data published in the scientific literature and in national reports.
The system of
In the input stage 401, and input is formed which, in this example, comprises 3 sections each section is represented by a vector:
Section 1—Feature extraction from condition si represented as {right arrow over (x)}i,
Section 2—Feature extraction from country ci represented as {right arrow over (y)}i,
Section 3—Feature extraction from age ai represented as {right arrow over (z)}i
The three vectors {right arrow over (x)}i, {right arrow over (y)}i and {right arrow over (z)}i are concatenated together to provide a concatenated embedding to regression stage 403.
The feature extraction to produce {right arrow over (x)}i will now be explained. There are many methods for learning word embeddings from text. Words are generally represented as binary, one-hot encodings which map each word in a vocabulary to a unique index in a vector. These word encodings can then be used as inputs to a machine learning model, such as a neural network, to learn the context of words. The information encoded in these embeddings is tied to the text that was used to train the neural network. Word embeddings can discover hidden semantic relationships between words and can compute complex similarity measures. If these embeddings were obtained from training on different data sources, the context encoded would likely differ, Consequently, better performance in downstream tasks will be linked to the information content encoded in these dense representations of words and its relationship with the task itself.
In the following embodiment, different types of word representations are discussed, obtained by different modeling strategies, on the downstream task of predicting disease incidence. This is performed by using the embeddings as inputs to a neural network for estimating disease incidence. The word embedding methods that are used are detailed below,
The Global Vectors for Word Representation (GloVe) model is built on the word2vec method which initially converts words to numeric values. The GloVe model then learns its embeddings from a co-occurrence matrix of words, where each potential combination of words is represented as an entry in the matrix as the number of times the two words occur together within a pre-specified context window. This window moves across the entire corpus. In this work, we used the pre-trained GloVe model trained on common crawl data from raw web page data.
Bidirectional Encoder Representations from Transformers (BERT) is a contextualized word representation model which learns the context for a given word from the words that precede and follow it in a body of text. In the following example BioBERT is used which is a model initialized with the general BERT model but pre-trained on large-scale biomedical corpora such as PubMed abstracts and PMC full-text articles. This enables the model to learn the biomedical context of words.
The Universal Sentence Encoder (USE) is a language model which encodes context-aware representations of English sentences as fixed-dimension embeddings.
In addition to using each of the above language models individually, feature fusion is used to combine the three word embeddings into a single vector by concatenation. The neural network was then trained on the combined representation as shown in
The process for training a neural network to predict disease incidence rates is illustrated in
In step S451, pairs of embedded vectors and prevalence/incidence values as required are obtained. If the model is to be trained for incidents prediction, then incidence values are used, if the model is to be trained for prevalence prediction then prevalence values used. The embedded vectors are constructed as explained above in relation to
As noted above, the embedding used to produce the input vector can handle free speech. Therefore, it is possible to use training data that is derived from free text scientific papers and text books, reports etc.
As explained above, the incidence values are then normalised in step S453 In an example, this can be done by pre-processing with a log 10 transformation and then normalising. These normalised values then used to train the model in step S455. Any training method can be used, for example forward and back propagation.
In a first example, the system of
In a second example, incidence values for previously unseen countries are predicted. There may be cases where there is no high-quality data available in countries with poor healthcare and data infrastructure. For these situations, it may be desirable to predict incidence rates of all diseases. For this application the case is simulated where there is no data for any disease in the target country but complete incidence data for all others.
In a third example, previously unseen diseases are predicted. This represents a situation where there is a key disease for which incidence data is difficult to obtain. This application consequently deals with the prediction of disease incidence rates for a given disease. In this case, incidence data is available for other diseases, but there is no data about the new, ‘unseen’ disease in any country.
Using the above, the condition is a disease and disease/condition embeddings are produced using each of the methods described above. For feature extraction for the country, in this example, GloVe is used to create representations of countries.
In this example, 20 age groups of 5-year periods (0-4, 5-9, . . . , 95+) were represented as binary one-hot vectors. Representing age groups in this way means that they are treated as separate categories, so that non-linear associations between incidence and age can easily be modelled.
The results that are presented below were modelled using standard 10-fold cross validation; the model parameters were estimated using 90% of the data, and validated on the remaining 10%. This avoids over-optimistic estimates of the model's performance, which can arise if the model is trained and tested on the same data. This process was repeated ten times with different, discrete 90/10 splits of the data.
The model shown in
For each of the three different examples outlined above, cross-validation was performed as follows:
For Example 1, each fold contains randomly selected country-disease pairs, where it is possible that data from the same disease or country can occur in the training and validation set but not both. This model is optimized for predicting disease incidence for country-disease combinations the model has not seen before, e.g. HIV in Singapore. In this example, the training data may contain disease incidence estimates for other diseases in Singapore, and for HIV in other countries. The model is therefore able to learn from these combinations of samples and then to predict the incidence for different disease country pair.
For Example 2, it was ensured cross-validation was independent of the country. Within each fold of the data, the model was trained on data from 90% of countries, and validated on data from the remaining 10% of countries.
For Example 3, it was ensured that cross-validation was independent of disease, but not country. Within each data fold, the model was trained on data from 90% of diseases, and validated on data using the remaining 10% of diseases.
For each of the above Examples 1 to 3, the performance of the neural network in estimating disease incidence, using each of the language models discussed above was compared. For each prediction, the predictive power of the embeddings was compared to two separate baselines. The result was first compared them to the global average for the disease and/or country of interest. Secondly, the estimates were compared with the incidence values reported in the GBD study.
The mean absolute error (MAE) in log 10 space was used to evaluate the performance of the disease incidence estimation. For example, a prediction with MAE of 0.2 is either 1.58 times larger or lower than the “ground truth” value. The factor of 1.58 is computed by inverse transformation (100.2=1.58). To measure the similarity of relative rankings of the estimates (in the cases discussed here, between the predictions and the disease name labels in the GBD study), the inter-group concordance ρc ranking was calculated whose values are bounded between 0 (worst) and 1 (best).
The performance of each language embedding was evaluated based on the three possible applications and report results for both the GBD, cross-validation results and the independent test set.
Results for the performance across various embeddings are reported for the GBD data and independent test data in Tables 1, 2, and 3. On average, models that exploited BioBERT embeddings saw the best performance. This is exemplified in all applications across both validation datasets where the BioBERT model saw consistently low MAE and high concordance scores.
Whilst most embedding methods produced accurate incidence estimates in the GBD dataset, it is apparent that BioBERT, followed by GloVe embeddings produced the best results in the independent test set when compared to USE, For instance, BioBERT and GloVe had an MAE of 0.157 and 0.157 with concordance of 0.990 and 0.988 respectively compared to an MAE of 0.168 and a concordance of 0.985 for USE in the specific disease-country pairs application (Table 1). This illustrates that these embeddings contain informative, contextual information. This is validated in the Binary model, which used one-hot encoded representations and suffered in performance as seen in the previously unseen diseases (Table 2) and previously unseen countries (Table 3) and applications.
A minor ablation study was performed on the BioBERT embeddings by comparing the performance of the neural network method (BioBERT) with a ridge regression that used BioBERT features (BioBERT*). The neural network method saw consistently better results compared to the ridge regression across all applications in the GBD datasets.
The performance of most models was consistently high in the specific disease-country pairs application (Table 1) and previously unseen countries (Table 3). However, there was a marked decrease in the validation metrics within the previously unseen diseases application (Table 2), For instance, the MAE of BioBERT rose from 0.157 (Table 1) and 0.197 (Table 3) to 0.781 whilst the concordance (ρc) of GloVe for instance dropped from 0.988 (Table 1) and 0.955 (Table 3) to 0.775.
The performance of the network trained with BioBERT features was examined across diseases with different magnitudes of incidence rate.
The distribution of errors was compared with the baseline model that predicted incidence rates using a global average estimate.
This is shown in
For the previously unseen countries application (
In the previously unseen diseases example, the error distribution in the GED validation set and the independent test set were analysed with data originating from peer-reviewed literature. This is shown in
In the above examples, the ability of different language models to encode contextual information was tested, and the corresponding embeddings were used as inputs to a neural network which was used to predict disease incidence. It was found that on average, models using BioBERT embeddings performed best across all metrics. High performance levels were observed when predicting for previously unseen countries and specific disease-country pairs, which was consistent across age groups.
Performance for previously unseen diseases was lower, varied substantially with age, and performance was notably lower for diseases which are highly dependent on location and climate. Overall, predictions were more accurate for common diseases than rare diseases.
BioBERT was the best-performing language model for creating disease embeddings for all three applications of their use; predicting disease incidence for previously unseen diseases, previously unseen countries, and specific disease-country pairs. The word embeddings for BioBERT were trained with text from medical journals and other clinical literature; this model should therefore have the most relevant context for interpreting words, which reflected in better disease incidence estimates from the neural network using these embeddings. Interestingly for previously unseen diseases and specific disease-country pairs, using feature fusion to combine information from the three language models resulted in substantially higher MAE than using BioBERT or other language models individually when the models were tested on external data from the GBD study. This suggests that using BioBERT alone results in sufficient contextual information, and further feature augmentation from other sources only adds redundant or correlated data.
When comparing the predictions to the GBD data, it was observed that performance for previously unseen diseases was significantly lower than for previously unseen countries and specific disease-country pairs. The purely data-driven neural network is able to predict disease incidence better for previously unseen countries and specific disease-country pairs because it already has data for the incidence of the disease it is trying to predict, and can draw sufficient context from the country embeddings to make a prediction for a new country. However, it is difficult to fully encapsulate how a previously unseen disease is similar to other diseases within a word embedding, and so the model's predictive ability is more limited for previously unseen diseases. This reflects the general state of knowledge; that it is possible to perform good inference for disease incidence in countries where data is lacking, based on knowledge of the country's socioeconomic situation, location, and healthcare provision, but struggle to predict the incidence of an unknown disease, regardless of how much data we have on other diseases in the same country. This is because the incidence of a disease is not only influenced by country-level factors but also by many biological, immunological, and sociodemographic factors.
Deep learning methods for predicting disease incidence, which use contextual embeddings learnt from unstructured information, have the potential to give better estimates of disease incidence than are currently available for settings where high quality data is lacking. This may be particularly valuable in areas lacking healthcare infrastructure where AI tools have the most potential to benefit people; settings where there is a lack of doctors, nurses, hospitals, etc. are very unlikely to have good data from which to estimate disease incidence.
In this work, we developed a machine learning method that is based on deep learning and transfer learning. The embedding methods were trained using a large amount of data while the target neural network for incidence estimation was only trained using data from the GBD study. As in many other data driven methods, the decision process of deep neural networks might overfit to the small training and validation dataset. Deep neural networks perform well on benchmark datasets, but can fail on real world samples outside the training data distribution. We have shown this effect by comparing the results on the validation and the test data. The performance on the test set that does not include examples from the training data was significantly lower.
Studies such as the GBD, which rigorously model disease statistics using information from multiple data sources, are limited by the time lag of data becoming available, and in their ability to incorporate new conditions due to the substantial effort involved in reviewing data and building new models. Whilst the above methods may be less rigorous, it is substantially quicker to implement for new diseases and can be easily updated to incorporate up-to-date contextual information for existing diseases, We therefore suggest it as a useful complement to existing modelling efforts, where data is required more rapidly or at larger scale than traditional methods allow for.
The above results show that the BioBERT language model performs well at encoding contextual information relating to disease incidence, and the resulting embeddings can be used as inputs to a neural network to successfully predict disease incidence for previously unseen countries and specific disease-country pairs, and for predicting for previously unseen diseases.
Further study was also performed into the nature of the embeddings. In an embodiment, it has been found that the word representations for either countries or diseases encapsulate relationships amongst each other. For instance, country embeddings for France and Spain can display similarities between each other that cover both geographical and socioeconomic metrics.
To evaluate the contextual meaning of the embeddings types, two classification experiments were performed where the input features are word embeddings obtained from either disease or country names and the labels to classify are either the GBD disease groups or country clusters. The resulting classification accuracy can serve as a metric to capture the contextual power of each embedding method when applied to either diseases or countries.
The first experiment aimed at evaluating whether disease embeddings capture context and similarities between diseases. In an embodiment, the input features are word embeddings obtained from disease names and the labels to predict are the 17 high-level GBD disease groups:
GBD disease groups
The embeddings computed from countries and can capture both geographical and economic dimensions. This can be evaluated by considering the classification of 21 country clusters such as “High-Income Asia Pacific” and “Western Europe” from country embeddings.
Linear Support Vector Machines were trained for each classification experiment across a candidate set of model hyperparameters. Models were trained and evaluated using 3-fold cross-validation. The cross-validation experiments were repeated 10 times to mitigate any potential bias in the training and validation split. The best performing models for each embedding across both experiments were then used to assess the accuracy.
Results for the classification experiments are shown below in Table 4.
The average and standard-deviation of the model accuracy across cross-validation folds are reported. For the GBD disease group classification, equitable performance was observed across the GloVe and BioBERT disease embeddings with 0.77 accuracy whilst USE embeddings saw 0.66 accuracy.
For the country cluster classification, the highest performance was observed across GloVe embeddings with 0.73 compared to 0.17 and 0.62 for BioBERT and USE respectively. This illustrates how GloVe country embeddings capture meaningful relationships between countries whilst BioBERT country embeddings are ineffective as they were trained on large-scale biomedical corpora not useful for countries.
The performance of the BioBERT model across all applications stratified by age-group was studied. Both the concordance (
The performance was analysed for the previously unseen diseases by evaluating the model across 17 disease groups based on the GBD model of diseases. The MAE (
A further experiment was also performed where incidence rates for new diseases within the United Kingdom were estimated, which falls under the previously unseen diseases application.
A further type of embedding will now be described with reference to
In
In an embodiment, these concepts are then used to train an embedder such that an embedder in step S203 can produce an embedded concept vector {right arrow over (vi)} corresponding to each concept i. For example, the embedder may be trained using skipgram.
In further embodiments a pre-trained embedder is used. The aim of this step is to provide an embedded space for clinical concepts as shown in
The output of the embedder is a dictionary of clinical concepts Ci and their corresponding embedded vectors {right arrow over (vi)} as shown in 205 Each clinical concept will also have a corresponding descriptor which is available from known medical ontologies, for example, SNOMED. The descriptor will provide text related to the concept. For example:
ConceptID 22298006:
The descriptor or descriptors are retrieved in step S207 to provide library 209. The descriptors from library 209 are then put through an embedder, for example, a universal sentence embedder (USE) in step S211 to produce an embedded sentence output library 213 which contains concepts Ci and their corresponding embedded vector.
The above results in dictionaries 205 and 213, where dictionary 205 links concepts Ci with their embedded representations {right arrow over (vi)} established on the basis of the occurrence of these concepts happening and library 213 that links concepts Ci with an embedded vector {right arrow over (xi)} based on their descriptors.
This completes the training of a model that is then used to produce a clinical context embedding (CCE) that will be described with reference to
In step S101 of
In step S105, the n closest first embedded vectors are determined as shown in
Once the n closest first embedded vectors are determined, these are mapped to their corresponding concept vectors. The corresponding concept vectors were determined in step S203 of
In step S107, these most similar concepts are then combined to produce a context vector.
The use of the CCE allows the handling of out-of-vocabulary cases. The Contextual Clinical Embedding (CCE) is a representation of concepts that are contextually most similar to any text input.
Once computed, the CCEs can be used for different ML tasks such as clustering, classification or regression.
The embodiments described herein deal with out-of-vocabulary (OOV) cases. To do this, the embodiment utilises the Universal Sentence Encoder (USE) to search for CEs with high semantic similarity. This allows the embodiment to compute a vectorised representation of free text that can denote or describe a disease and was not in the vocabulary of the training set.
In a further embodiment, in an embodiment, the representations are used, together with country, age and gender embeddings as shown in
The above examples have described the method for predicting the prevalence or incidence of a condition where there is no data for the condition within a country or even where possibly the condition is unknown. However, it is possible to use the method to also predict the conditional probability between diseases and symptoms and this in turn allows for links to be added to the PGM.
The basic method in shown in
Trained neural network 1459 is trained on known marginals for disease and symptom pairs.
Due to the use of the language model, similarities between symptoms is leveraged and similarities between conditions is leveraged. Thus, once the model is trained, a symptom and disease where their relation is unknown can be embedded through embedder 1455 to produce an embedded disease vector and an embedded symptom vector which are then concatenated to be input into the trained model. In an embodiment, the known marginals were provided as binary labels (i.e. the presence or absence of a link), for example, links with a high marginal probability were chosen to indicate the presence of a link.
In an embodiment, the probability P(D, S) is calculated with a softmax function, but other functions could be used. The above can be used for a disease and symptom pair where possibly the symptom and/or the disease is unknown to the model since the embedding allows the system to understand and leverage similarities between symptoms and leverage similarities between symptoms.
The above can therefore be used to enhance the PGM of
To build these links into the PGM, it is possible to produce an embedded disease vector for disease D3 and an embedded symptom vector S4. These vectors then concatenated and provided to network 1459. The output from network 1459 can then be compared with a threshold. For example, 0.5. If the output (D, S) is above the threshold, then it is determined that a link is present this is added to the PGM. On the other hand, if the output is below the threshold, then no link is determined. In
In the above description, the disease and the symptom is embedded using the same language model. However, this is not necessary. It is possible for them to be embedded using the same or different language models. Also, as described above, it is possible for there to be a combination of different language models which are combined. It is also possible for the embedding described with reference to
The value output from network 1461 is dependent on the training data. To determine the presence or absence of links, the network can be trained on binary labels as described above. In further embodiments, the network 1461 can be trained on P(S,D) data or P(S|D) where exact values of known conditionals are used. In practice, it is difficult to obtain correct values of conditionals to produce a large training set.
As an example, in a network trained on condition pairs, the following links were suggested where Headache was provided as a condition:
Headache as symptom->suggested link to disease
1. Intermittent headache
->Mumps
->Bacterial tonsillitis
->Subdural haemorrhage
->Chalazion
->Otitis media
->Subarachnoid haemorrhage
->Acoustic neuroma
->Hemorrhagic cerebral infarction
->Lyme disease
->Viral meningitis
->Optic neuritis
2. Unilateral headache
->Analgesia overuse headache
->Ischemic stroke
->Bruxism
->Benign intracranial hypertension
->Viral meningitis
->influenza
->Infectious mononucleosis
->Hypoglycaemic episode
->Premenstrual tension syndrome
3. Occipital headache
->Strain of neck muscle
->Trigeminal neuralgia
->Analgesia overuse headache
->Temporal arteritis
->Scleritis
->Hemorrhagic cerebral infarction
->Pituitary adenoma
->Cluster headache
4. Temporal headache
->Secondary hypertension
->Acute sinusitis
->Otitis media
->Hypoglycaemic episode
->Malignant neoplasm of brain
->Viral meningitis
1. Cluster headache
->Photopsia (unilateral)
->Unilateral arm numbness
->Occipital headache
2. Analgesia overuse headache
->Unilateral headache
->Occipital headache
The user inputs a query via their mobile phone, tablet, PC or other device at step S501. The user may be a medical professional using the system to support their own knowledge or the user can be a person with no specialist medical knowledge. The query can be input via a text interface, voice interface, graphical user interface etc. In this example, it will be assumed that the query is a user inputting a symptom.
As explained with reference to
Once a node in the PGM is activated, it is possible to determine the relevant condition nodes (i.e. the nodes which corresponds to conditions that are linked to the activated node) in step S505.
The system will be aware of various characteristics such as the country where the user is located, their age, gender etc. These characteristics might be held in memory for a user or they may be requested each time from a user.
In step S507, the marginals are determined for each of the relevant condition nodes. As explained above in relation to
The likelihood of a disease being present is then determined using inference on the PGM and the marginals and prevalence.
While it will be appreciated that the above embodiments are applicable to any computing system, an example computing system is illustrated in
Usual procedures for the loading of software into memory and the storage of data in the mass storage unit 1202 apply. The processor 1201 also accesses, via bus 1204, an input/output interface 1205 that is configured to receive data from and output data to an external system (e.g. an external network or a user input or output device). The input/output interface 1205 may be a single component or may be divided into a separate input interface and a separate output interface.
Thus, execution of the prediction unit 1206 by the processor 1201 will cause embodiments as described herein to be implemented.
The, a prediction unit 1206 can be embedded in original equipment, or can be provided, as a whole or in part, after manufacture. For instance, the prediction unit 1206 can be introduced, as a whole, as a computer program product, which may be in the form of a download, or to be introduced via a computer program storage medium, such as an optical disk. Alternatively, modifications to existing prediction unit 1206 software can be made by an update, or plug-in, to provide features of the above described embodiment
The computing system 1200 may be an end-user system that receives inputs from a user (e.g. via a keyboard) and retrieves a response to a query using prediction unit 1206 adapted to produce the user query in a suitable form. Alternatively, the system may be a server that receives input over a network and determines a response. Either way, the use of the prediction unit 1206 may be used to determine appropriate responses to user queries, as discussed with regard to
Implementations of the subject matter and the operations described in this specification can be realized in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Implementations of the subject matter described in this specification can be realized using one or more computer programs, i.e., one or more modules of computer program instructions, encoded on computer storage medium for execution by, or to control the operation of, data processing apparatus. Alternatively or in addition, the program instructions can be encoded on an artificially-generated propagated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal that is generated to encode information for transmission to suitable receiver apparatus for execution by a data processing apparatus. A computer storage medium can be, or be included in, a computer-readable storage device, a computer-readable storage substrate, a random or serial access memory array or device, or a combination of one or more of them. Moreover, while a computer storage medium is not a propagated signal, a computer storage medium can be a source or destination of computer program instructions encoded in an artificially-generated propagated signal. The computer storage medium can also be, or be included in, one or more separate physical components or media (e.g., multiple CDs, disks, or other storage devices)
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed the novel methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of methods and systems described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms of modifications as would fall within the scope and spirit of the inventions.