- Research
- Open access
- Published:
Symptoms are known by their companies: towards association guided disease diagnosis assistant
BMC Bioinformatics volume 23, Article number: 556 (2022)
Abstract
Over the last few years, dozens of healthcare surveys have shown a shortage of doctors and an alarming doctor-population ratio. With the motivation of assisting doctors and utilizing their time efficiently, automatic disease diagnosis using artificial intelligence is experiencing an ever-growing demand and popularity. Humans are known by the company they keep; similarly, symptoms also exhibit the association property, i.e., one symptom may strongly suggest another symptom’s existence/non-existence, and their association provides crucial information about the suffering condition. The work investigates the role of symptom association in symptom investigation and disease diagnosis process. We propose and build a virtual assistant called Association guided Symptom Investigation and Diagnosis Assistant (A-SIDA) using hierarchical reinforcement learning. The proposed A-SIDDA converses with patients and extracts signs and symptoms as per patients’ chief complaints and ongoing dialogue context. We infused association-based recommendations and critic into the assistant, which reinforces the assistant for conducting context-aware, symptom-association guided symptom investigation. Following the symptom investigation, the assistant diagnoses a disease based on the extracted signs and symptoms. The assistant then diagnoses a disease based on the extracted signs and symptoms. In addition to diagnosis accuracy, the relevance of inspected symptoms is critical to the usefulness of a diagnosis framework. We also propose a novel evaluation metric called Investigation Relevance Score (IReS), which measures the relevance of symptoms inspected during symptom investigation. The obtained improvements (Diagnosis success rate-5.36%, Dialogue length-1.16, Match rate-2.19%, Disease classifier-6.36%, IReS-0.3501, and Human score-0.66) over state-of-the-art methods firmly establish the crucial role of symptom association that gets uncovered by the virtual agent. Furthermore, we found that the association guided symptom investigation greatly increases human satisfaction, owing to its seamless topic (symptom) transition.
Introduction
Diagnosis is the primary and crucial stage of any medical treatment process, during which doctors investigate, analyze symptoms, and identify patients’ diseases. As reported by the World health organization (WHO), 2013 [1], the world falls short of 7.2 millions medical workers, which is expected to reach 12.9 millions in the upcoming decade. The dearth still continues as per a report by WHO, 2019 [2], there are many countries where doctor per 1000 people is less than one. These figures firmly suggest the betterment of the healthcare system by increasing health workers and utilizing their time more efficiently and critically. As a result, there is a surge of interest in utilizing Artificial Intelligence (AI) based systems to reduce the workload of medical professionals [3]. One of such manifestations is automatic diagnosis with the help of a virtual agent that can conduct a thorough symptom investigation and present a detailed report to doctors. Some automatic disease diagnosis systems such as Mayo Clinic Footnote 1, Babylon Healthcare Footnote 2 and GMAN are already deployed, which are being extensively used by both hospitals and end-users. A study conducted by Fox et al. [4] showed 35% U.S adults had utilized self-diagnosing tools before consulting with real doctors. A typical diagnosis process has been illustrated in Fig. 1.
Diagnosis system deals with exponential state space [5], and the diagnosis assistant is expected to learn a mapping of these states to appropriate diseases. Consider a diagnosis system having n number of symptoms and D number of diseases. A patient may have any combination of these n symptoms, i.e., a subset of these symptoms. With n number of elements in a set, there can be 2\(^{n}\)-1 sub-sets (excluding null set). Thus, the diagnosis assistant learns to map symptom space of size 2\(^{n}\)-1 to disease space (D). Also, there are many overlapping symptoms across diseases, which increases the problem complexity by many folds [6]. Thus, an intelligent and robust symptom investigation by virtual agents is key for diagnosing patients correctly and efficiently. In real world, a considerably large number of diseases are diagnosed by doctors through only an in-depth symptom investigation [7]. In some cases, they need further evidence through laboratory reports to reach a conclusive diagnosis. Nevertheless, symptom investigation is essential and crucial for suggesting an appropriate lab examination.
In recent few years, significant efforts have been made to build an adequate and robust disease diagnosis assistant [8]. Such virtual assistants’ primary responsibility is to aid doctors and conduct symptom investigations [9]. When we consult our health issues with doctors, they do not usually infer a condition/disease based on only our informed symptoms and signs. They investigated further symptoms and signs to reach a conclusive disease. In [10], authors have developed a task-oriented dialogue system [11] that extracts signs/symptoms in addition to patient self-report through conversation. Most of the existing disease diagnosis assistants [12, 13] are built upon this fundamental work. Some of them focus on technique improvement, such as the incorporation of hierarchical reinforcement learning (HRL) [12] and generative adversarial network (GAN) [14] while others aim to investigate some fundamental research questions [5]. Since diseases are described by a set of symptoms, an understanding of the association between these symptoms can significantly influence both symptom investigation and disease identification. Furthermore, the association guided symptom inspection can significantly enhance user satisfaction because of the seamless topic (symptom) transition. However, none of the existing diagnostic works [10, 12, 15] have investigated the role of symptom association and leveraged the information in disease diagnosis. Motivated by the research gap, we aim to investigate the efficacy of symptom association in disease diagnosis and build a symptom association-guided disease diagnosis assistant.
It is well said that a man is known by the company he keeps [16]. It has also been observed to be true for words [17], which later became key for developing different word embedding techniques such as Word2Vec [18]. In addition to the presence of suffering symptoms (s\(_i\), s\(_j\)) in the set of observed symptoms (OS), the co-occurrence of these symptoms (s\(_i\), s\(_j\) \(\in\) OS) provides vital and distinguishable information for determining the patients’ disease. Here, OS is the set of observed symptoms. The appropriateness and relevance of inspecting symptoms directly affect patients’ experience with the system. Thus, a symptom association guided investigation and diagnosis can improve both diagnosis efficacy and patients’ experience. To the best of our knowledge, this work is the first attempt to investigate the role of symptom association and model the key information in the learning process of a virtual agent responsible for automated disease diagnosis. The proposed virtual agent conducts a symptom association-guided symptom investigation and extracts symptoms and signs through a conversation with patients. Once symptom investigation completes, it diagnoses patients based on the status of investigated symptoms.
The primary objectives of any autonomous disease diagnosis system are to diagnose patients accurately and efficiently [19]. The end-users experience with it also determines its effectiveness and usability. Thus, in addition to the final outcome (diagnosis accuracy), the diagnosis assistant’s behavior with patients is also a paramount concern. A single irrelevant symptom request can substantially impact patients’ trust in the system. For instance, two automatic diagnosis systems, S\(_1\) and S\(_2\), both diagnose a patient’s disease D accurately (in equal time); system S\(_1\) will be preferred if system S\(_1\)’s relevance of symptom investigation is higher than the other. However, the existing systems [10, 12, 15, 19] have overlooked this key aspect that determines system’s efficacy and usability in real-world setting. We propose a new evaluation metric called Investigation Relevance Score (IReS) which measures the relevance of conducted symptom investigations in relation to patient’s chief complaints and conversation contexts. The main contributions of this work are as follows:
-
The work investigates the role of symptom association in diagnosis process and proposes a novel association-guided symptom investigation incorporated virtual assistant responsible for automated diagnosis using hierarchical reinforcement learning.
-
We propose a new evaluation metric called Investigation Relevance Score (IReS), which measures the relevance of symptom investigation conducted by an automatic diagnosis system.
-
The proposed model outperforms several baselines and state-of-the-art diagnosis assistants in all evaluation metrics, including human evaluation scores, and achieves state-of-the-art performance.
The paper is organized as follows: The related work section describes existing relevant works on disease diagnosis virtual assistants. The methodology section explains and illustrates the proposed symptom association guided disease diagnosis model. We describe the utilized synthetic diagnosis dataset (SD) in the dataset section. The experimental setup and parameter values are provided in the experimental setup section. We report and discuss the obtained results in the result and discussion section. In the case study and analysis section, we discuss some case studies of the performances of different diagnosis assistants. We conclude by summarizing the work and outlining some potential directions for future work.
Related work
The existing works on automatic disease diagnosis can broadly be categorized into two groups: 1. Disease prediction systems [20], which aim to predict a disease for a given patient’s medical data, such as X-ray report. 2. Automatic disease diagnostic systems [12], which conduct a symptom investigation and diagnose patient’s disease depending upon the status of investigated symptoms. The proposed work belongs to the second category. The work is mainly related to the following three research areas: Electronic health records, Automatic disease diagnosis systems, and Automatic disease diagnosis dialogue systems. We have summarized the relevant works and their limitations in the subsequent paragraphs.
Electronic health records
In the early 2000s, Electronic health records (EHR) [21, 22] based systems were proposed with the motivation of assisting patients in rural areas by virtual means. However, an EHR system requires multiple devices and their synchronization [23]. To overcome such dependencies and intensive efforts, researchers have introduced a new paradigm for automatic disease diagnosis (for non-fatal/sensitive diseases), where an interactive system conducts a thorough symptom investigation and diagnoses patients’ disease based on extracted symptoms [24]. The work [25] describes the development of a deep learning model called DDxNet for diagnosing diseases from time-varying clinical data having different modalities such as ECG, EEG, and EHR. Chakraborty et al. [26] proposed an ensemble feature selection that combines multiple machine learning classifiers such as K-Nearest Neighbors Bagging Technique (KNNBT) and Neural Network Bagging Technique (NNBT) for selecting an effective set of features from bio-medical datasets. In [27], the authors have proposed a deep learning-based smart healthcare system for heart disease prediction. The model utilizes both sensor and EHR data for patient context representation, which achieves state-of-the-art performance for the diagnosis task.
Automatic disease diagnosis systems
Tang et al. [24] have proposed an ensemble neural network model for symptom checking and diagnosis, which consists of many small models for different anatomical parts, leading to superior performance compared to existing traditional monolithic systems. However, the system utilizes a rule-based module for selecting different anatomical networks, making it harder to be adapted to another diagnosis system. Peng et al. [15] incorporated a novel feature rebuilding technique in the diagnosis process, which directly includes implied symptoms rather than enquiring explicitly. This feature rebuilding technique needs huge manual labor and analysis for an extensive diagnostic system with many common symptoms across multiple diseases; otherwise, a trivial rebuilding technique may degrade performance. In real life, doctors’ investigation also depends on patients’ personal information, such as age and gender. Motivated by such scenarios, Kao et al. [13] have proposed a context-aware symptom checker, which showed that context (patient’s personal information) such as patient’s gender and age provide key guidance in conducting an appropriate and efficient diagnosis. In [28], the authors have proposed a machine learning-based model, which identifies the possibility of both diabetes and liver disease from patient data. Autonomous heart disease prediction is one of the most focused concern of bio-medical research community. Chakraborty et al. [29] introduced a fog-based heart disease prediction model, which significantly improved both diagnosis time and accuracy. In [30], the authors have proposed an ensemble-based machine learning model which predicts several fatal diseases, including hepatitis and liver disorder.
Automatic disease diagnosis dialogue systems
In real world, doctors diagnose a considerably large number of diseases through only an in-depth symptom investigation. Motivated by the real-world scenario, Wei et al. [10] formulated diagnosis as a task-oriented dialogue system problem, which illustrated and emphasized the role of implicit symptoms extracted by the dialogue agent in addition to patient-reported symptoms for accurate diagnosis. Doctors’ prior learning is crucial for their appropriate behavior for both diagnosis and treatment. To infuse such intelligence, Xu et al. [31] have proposed a knowledge routed relational dialogue system (KR-DS) that utilizes a rich medical knowledge graph (disease-symptom) in the learning process. Liao et al. [12] have introduced an integrated and synchronized two-level policy framework using hierarchical reinforcement learning [32], which outperformed the flat policy approach [10] by a significant margin, demonstrating the efficacy of disease group aware symptom investigation. Liu et al. [33], developed a conversational medical corpus having conversations between clinicians and users. They also proposed a novel medical entity controlled medical response generation model that performs superior to existing non medical entity controlled generation models. The work [34] presents a low cost millimeter antenna for building portable 5G communication gadgets. In [9], the authors propose a variant of deep Q network (DQN) called prototype deep Q network that quickly adapts to new or rare diseases having a handful number of samples.
In real life, doctors also learn from external knowledge, such as symptom-disease relational databases. Motivated by the observation, the work [35] proposed a context-aware knowledge-infused virtual assistant that generates relevant and context-aligned responses. In real life, doctors continuously exploits extracted symptom information for intelligent symptom inspection. They hypothesize a set of probable diseases based on extracted symptoms and first inspects the potential symptoms of these candidate diseases. Tiwari et al. [5] investigated the idea and proposed a knowledge-infused context-driven (KI-CD) disease diagnosis model that inherits the doctors’ diagnosis behavior. The obtained performance by the KI-CD model firmly illustrates the effectiveness of the principle and accomplishes state-of-the-art performance. In many cases, we find it difficult to describe some of our signs and symptoms, such as mouth ulcers, through text. Thus, we often leverage visual means to describe them. Inspired by the effectiveness of visual modality in symptom investigation and diagnosis, the work [36] proposed a multimodal disease diagnosis assistant that extracts symptoms from both textual and visual responses of end-users. The study found that incorporating visual modality into symptom investigation and disease diagnosis enhanced both diagnosis accuracy and end-user satisfaction significantly.
Methodology
In a typical diagnosis, clinicians undertake a symptom investigation and diagnose a disease based on observed symptoms (Fig. 1). The detailed architecture of the proposed dialogue system, A-SIDDS (association guided symptom investigation and diagnosis dialogue system), is illustrated in Fig. 2. A patient initiates the diagnosis process by informing their suffering symptoms (explicit symptoms). The controller policy of the proposed dialogue system acts as a clinic receptionist, which activates a lower-level department policy as per the patient report. The activated departmental policy conducts a symptom investigation guided by Association and Recommendation Module (ARM). Once the lower-level policies collect adequate information, the controller policy activates the disease classifier, which diagnoses patients’ diseases depending on the collected information. The detailed working methodologies of each module are as follows:
Symptom investigation
Symptom investigation is the first stage of diagnosis, where doctors conduct an investigation and extract other relevant symptoms depending upon patients’ reported chief complaints and other confirmed symptoms during inspections. Thus, the agent aims to learn appropriate and intelligent behavior for collecting adequate symptom information in minimal time, i.e., an optimal diagnosis dialogue policy. The policy learning loop consists of three main components: I. Diagnosis Policy Learning, II. Association & relevance module (ARM), and III. Internal & Association and Recommendation (AR) critic. Each sub-stage and its detailed working method are explained below.
Diagnosis policy learning
Diagnosis policy (\(\pi\)) is the decision function, which decides whether to investigate symptoms or predict disease after observing symptoms, i.e., \(a = \pi (S)\), where S is a set of observed symptoms, and a could be a symptom or disease. To improve investigation efficacy and patient satisfaction, clinics used to have different departments such as ENT (Ear, Nose, and Throat) and pediatrics, etc. Motivated by the real-world scenario and the promising results obtained by Liao et al. [12, 37], we also utilized a hierarchical policy learning method, where the higher-level policy (controller) activates one of the lower-level policies (departmental) depending on patients’ self-report and other symptoms and the department policy conducts group-specific symptom investigation.
Controller policy
Controller policy is the first layer policy, which is responsible for activating an appropriate department policy (DP\(_i\)) and disease classifier for symptom inspection and disease projection, respectively. It can be seen as a clinic’s receptionist who refers patients to a particular department as per their chief complaint/self-report. It is also responsible for triggering the disease classifier (DC) once the lower policies (department policies) collect adequate symptom information. The controller policy selects an action (ac) depending upon current dialogue state (S) as follows: \(ac = P (A_c \vert S, \pi _c)\) where \(\pi _c\) is the controller policy, \(A_c\) is its action space which consists of department policies (\(DP_{i}\)) and disease classifier. For each action ac on a state S, the agent gets a penalty/reward (r\(_c\): Reward(S, ac)) depending upon the effectiveness of the taken action as follows:
where i is the number of turns taken by the activated lower level policy corresponding to the master action, ac\(_t\). The agent aims to maximize the cumulative reward over episodes (\(R = \sum _{n=1} ^{N} \sum _{t=0} ^{T} \gamma _{c}^{t} * rc_{t}\)), leading to adequate symptom investigation and thus accurate diagnosis. Here, N, T are the number of dialogues in an episode and the number of turns in n\(^{th}\) conversation, \(\gamma _c\) is discounted factor which governs the role of immediate and future rewards in policy learning.
The controller policy \(\pi _{c}\) is optimized using a value-based deep reinforcement learning technique called Deep Q Network (DQN) [38]. It learns a state-action value function (Q\(^c\) (S, ac)), which estimates a value for each action (department) for a given dialogue state S (informed symptoms). The policy selects an action with highest Q value (reward), i.e., \(ac = argmax_i {Q^{c} (S, A_{c}^{i} | \pi _c})\). The \(Q^c\) function has been calculated and optimized through Bellman equation [39] and temporal difference (TD) loss [40] as follows :
where \(L_{t}^{c}\) is the loss at \(t^{th}\) time step, which is difference between state-action value calculated through current policy parameter (behavior network : \(\theta _t\)) and previously froze policy parameter (target network : \(\theta _{t-1}\)).
Departmental policy
The departmental/lower lever policies (DP\(_i\): \(\pi ^{i}\)) are responsible for symptom inspection corresponding to their departments. The proposed model has nine departmental policies corresponding to each disease group. These departmental policies learn to select an appropriate action (symptom for inspection) depending upon the current dialogue state, which contains informed/confirmed symptoms. It selects an action (a\(_i\)) as follows:
where \(Q^i\) is state-action value function of \(i^{th}\) department policy (\(\pi ^{i}\)) and A\(_{ij}\) is j\(^{th}\) action of i\(^{th}\) departmental policy. The state, S, consists of the status of informed and inspected symptoms, dialogue turn, agent’s previous actions, K most relevant symptoms predicted by the ARM module, and reward. The size of the action space of each policy is N\(_i\) + 1, where N\(_i\) is the number of symptoms in i\(^{th}\) department. The additional action is to return the control to the controller policy. The department agent gets a reward /penalty (internal and ARM critic) at each time step depending upon the appropriateness and relevance of agent’s action (a\(_i\)) to the current state (S). These policies (\(\pi ^{i}_d\)) have also been optimized using the DQN algorithm as the controller policy (Equs. 2 and 3).
Association and relevance module (ARM)
The Association and Relevance Module (ARM) is responsible for conducting knowledge-aware, association-guided symptom investigation for adequate symptom information extraction. The module gets the current state (S\(_t\)) and inspected symptom (Sym\(_t\)) as inputs, and it outputs an association score & symptom recommendation (RS\(_t\)). The association module provides an association score (as\(_t\)) depending upon the relevance of the currently requested symptom (Sym\(_t\)) with the confirmed symptoms (SS), i.e.,
where SS is the set of inspected and confirmed symptoms (including patient self-report) till t\(^{th}\) turn of the dialogue and n\(_t\) is the number of symptoms in it. The association score is provided as a critic to the agent, reinforcing the agent to conduct an association-aware symptom investigation. We construct and utilize a symptom-symptom knowledge graph to calculate the associations between two symptoms. In the knowledge graph, nodes represent symptoms, and an edge between two nodes signifies the co-relation between these two symptoms. The edge between two nodes/symptoms (S\(_i\), S\(_j\)) is determined based on the frequency of their co-occurrence. The weight of the edge from the symptom \(S_i\) to \(S_j\) is computed as follows:
where \(n(S_i, S_j)\) is the number of instances in the diagnosis dataset, where S\(_i\) and S\(_j\) have co-occurred. The term k ranges in the entire symptom space (Sy). Here, the denominator represents the number of instances where the symptom \(S_i\) has occurred with symptom \(S_k\) (\(S_k\) \(\in\) Sy). Thus, the association score of the symptom \(S_i\) with \(S_j\) signifies the chances of occurrence of \(S_j\) with it. The high value of the association score (\(S_i\), \(S_j\)) indicates that a patient is most likely to suffer from symptom \(S_j\) if he/she observes symptom \(S_i\).
A symptom may strongly suggest the existence of another symptom, which are caused by a common condition. For instance, when we think about cold, the next symptom that comes to our mind is cough. Cold and cough often co-occur together. Motivated by the observation, the proposed model incorporates a recommendation module, which recommends some of the most relevant symptoms (RS) from the entire symptom set (Sy) depending upon confirmed symptoms, SS. It selects top K symptoms from symptom space, which are highly relevant to the current context (confirmed symptom set, SS) and co-occur together. This module utilizes association scores for determining top K relevant symptoms as follows:
These recommended symptoms are reflected in the current dialogue state, and the agent is reinforced to investigate these most relevant symptoms through the recommendation critic. This module aids the agent in conducting a knowledge-aware, association guided symptom investigation, which improves the user experience and reduces the number of turns required to diagnose the patient.
Internal and association and recommendation (AR) critics
A reinforcement learning agent’s reward model is one of the most critical elements, which implicitly supervises the agent for the underlying task. We propose and incorporate two novel reward functions, namely recommendation-based critic and association-based critic, to reinforce the agent for conducting context-aware, association-guided symptom investigation. The critics (intrinsic critic: r\(_d\), r\(_{rr}\): recommendation based critic, and r\(_{ar}\): association based critic) are defined as follows:
where N and \(t_i\) are the maximum no. of allowed turns for diagnosis and shaping parameters, respectively. The term, match(Sym\(_t\)) = 1 indicates that the department policy has requested a symptom (Sym\(_t\)) that the patient is truly suffering from. Here, \(Sym_t, RS_t\), and \(as_t\) are the agent’s requested symptom, recommended symptoms, and association score between \(Sym_t\) and other conformed symptoms (SS) at t\(^{th}\) turn, respectively. The terms l, h denote the lower and desired thresholds for association scores between requested symptom and confirmed symptoms (SS), respectively.
The internal critic (r\(_d\)) reinforces to complete the task successfully, whereas the immediate rewards (recommendation: r\(_{rr}\) and association: r\(_{ar}\)) act as the task behavior shaping elements. The recommendation and association reward models provide a reward/penalty depending upon the appropriateness of agent action and its relevance in relation to dialogue context (already informed symptoms including patient self-report, SS). If the agent inspects a recommended symptom, it gets a reward (case 9.1); otherwise, it gets a small penalty. The association reward (r\(_{ar}\) provides a reward/penalty proportional to the relevance (association score) of the currently requested symptom with the ongoing context/confirmed symptoms (SS), which motivates the agent to enquire relevant and knowledge-grounded symptoms.
Diagnosis state tracker, patient and disease classifier
Diagnosis state tracker is responsible for tracking dialogue (diagnosis) state, which contains information about inspected symptoms, dialogue turn, and the agent’s previous actions. After each agent and user turn, the state tracker updates dialogue state with essential information such as agent requested symptoms, user response, turn number, and the reward/critic corresponding to agent action. We have developed a pseudo environment/user simulator similar to the popular task-oriented user simulators [12, 41]. The user simulator initializes each diagnosis session with a diagnosis case from training samples. At the first turn of a conversation, the patient simulator informs the diagnosis agent’s self-report (all explicit symptoms) and asks to identify the disease/condition that the patient may be experiencing. Then, the simulator responds to each agent’s request for symptoms as per the sampled diagnosis case during the conversation. Disease classification is the final stage, which diagnoses a disease depending upon the extracted symptoms (including the patient’s self-report). In our work, it is a two-layered deep neural network, which takes a one-hot encoding representation of symptom status as input and predicts the probability distribution over all diseases.
Investigation relevance score (IReS)
Automatic disease diagnosis is a sequential decision problem in which an agent interacts with end-users over time for symptom investigation and then diagnoses the most appropriate disease based on the observed symptoms. Thus, an adequate set of symptom collection is critical to accurate diagnosis, which directly influences end-users engagement with the system. A single irrelevant symptom inspection by a diagnosis agent may cause end-users to lose trust in the system, resulting in the termination of dialogues in a large number of such cases. For instance, a person comes with difficulty of breathing, and if an agent inspects some irrelevant (less relevant) symptoms such as skin growth and knee swelling, the end-user may become annoyed and terminate the chat. However, the existing works [10, 12, 15, 24] employ objective metrics such as diagnosis accuracy and symptom investigation time for measuring their proposed models’ efficacy. Motivated by the vital significance of symptom relevance and the inability of existing evaluation metrics to capture this critical aspect, we formulate and propose a novel automatic evaluation metric called Investigation Relevance Score (IReS) for evaluating a diagnosis agent’s efficacy in terms of the relevance of symptoms inspected by the agent during symptom investigations. The metric is formulated as follows:
where m is the number of testing samples, and \(n_i\) is the number of turns taken by the agent for i\(^{th}\) diagnosis test sample. The term PSR\(_i\) and SS\(_{ij}\) denote patient self-report and confirmed symptoms till j\(^{th}\) turn of i\(^{th}\) sample, respectively. The IReS-1 measures the relevance of symptom investigation with patient self-reported symptoms (PSR), and the IReS-2 measures the relevance of symptom investigation with the ongoing context (confirmed symptoms, including PSR)
Dataset
We have experimented with the largest publicly available English medical dataset, Synthetic dataset (SD) [12], which contains 30,000 patient samples. A sample diagnosis data and the dataset statistics are reported in Fig. 3 and Table 1, respectively. The distributions of the total number of symptoms & unique symptoms across different groupsFootnote 3 are illustrated in Fig. 4.
Experimental setup
The proposed methodology Footnote 4 is trainedFootnote 5 and evaluated on 80% (24,000) and 20% (6,000) patients’ samples of the benchmarked dataset, respectively. For sufficient exploration, we have utilized the most popular and well-accepted exploration strategy called \(\epsilon\)-greedy [42]. When the agent explores, it can improve its current knowledge and gain better rewards in the long run. The model is trained for 5000 epochs, each having 100 dialogues. The values of key hyperparameters are: \(\gamma _m\) 0.9, \(\gamma _w\) 0.95, learning rate (\(\alpha\)) 0.0005, {t\(_1\), t\(_2\), t\(_3\), t\(_4\), t\(_4\), t\(_5\) } - {3, 2, 2, 15, 2}, epsilon (\(\epsilon\)) 0.1, max allowed turn (N) 28, episode size 100, and batch size 100. The epsilon value 0.1 signifies that the agent explores 10% times and exploits 90% (1-\(\epsilon\)) times. All the hyperparameter values are decided empirically.
Results and discussion
We utilize the most popular automatic diagnosis evaluation metrics (viz., diagnosis success rate, dialogue length, match rate, match rate2, and disease classifier accuracy) [10, 31, 41] for evaluating our proposed agent’s performance, comparing with state of the art methods and other baselines. Match rate is the ratio of no. of true symptoms (extracted through conversation) to the total number of agent’s symptom requests (query), and match rate 2 is the ratio of the number of true symptoms (extracted through conversation) to the total number of symptoms in patient’s implicit symptom set. The average match rate (AMR) and average match rate 2 (AMR2) are averages of match rate and match rate 2 over dialogues, respectively. These metrics are computed as follows:
-
Success rate = \(\frac{ \sum _{i = 1} ^{i = EL} DS_{i}}{EL}\), where EL (Episode length) denotes the number of simulated dialogues in an episode, \(DS_{i} = 1\) if the \(i^{th}\) dialogue ends successfully, i.e., the agent informs correct disease, otherwise 0.
-
Avg reward = \(\frac{\sum _{i=1}^{i=EL} \sum _{j = 1}^{j=t} r_{ij}}{EL}\), where r\(_{ij}\) represents reward received by agent in j\(^{th}\) turn of i\(^{th}\) dialogue session of an episode. Here t represents the number of dialogue turns in j\(^{th}\) dialogue session.
-
Avg dialogue turn = \(\frac{ \sum _{i = 1} ^{i = EL} len_{i}}{EL}\), where \(len_{i}\) denotes number of dialogue turns taken by the agent in \(i^{th}\) dialogue session of an episode.
-
Average match rate (AMR) = \(\frac{\sum _{i=1}^{i=EL} m_i/r_i }{EL}\) x 100, m\(_{i}\) indicates total number of agent’s requested symptom, which belongs to the patient’s suffering symptoms. Here, \(r_i\) signifies the total number of symptoms requested by the agent during \(i^{th}\) conversation.
-
Average match rate 2 (AMR2) = \(\frac{\sum _{i=1}^{i=EL} m_i/t_i }{EL}\) x 100, m\(_{i}\) indicates total number of agent’s requested symptoms, which belongs to the patient’s suffering symptoms. The term \(t_i\) denotes the total number of true implicit symptoms of the patient in \(i^{th}\) conversation.
We have experimented with two reinforcement learning algorithms, namely DQN and Double DQN (DDQN) [38, 43]. In addition to these standard evaluation metrics, we have also evaluated the models in terms of the proposed metric, Investigation Relevance Score (IReS).
To determine the efficacy of the proposed method, we have compared our proposed model with the following baselines and the current state-of-the-art methods. i. SVM-ex: SVM model [44] with only explicit symptoms / patient self report. ii. REFUEL The REFUEL model [15] incorporated a novel feature rebuilding technique in the diagnosis process, which directly includes implied symptoms rather than enquiring explicitly. iii. GAMP The model [14] utilizes a generative adversarial network (GAN) based symptom investigation methodology where the generator selects an action based on state, and the discriminator evaluates the effectiveness of the chosen action. iv. KR-DS The KR-DS agent [31] leverages external medical data (knowledge-graph) for learning an optimal behavior for symptom investigation and disease diagnosis. v. Flat Policy: An unified policy [10] that conducts both symptom investigation and diagnosis, vi. HRL: A hierarchical policy learning method [12] having master and worker as levels, vii. PR-SIDDA: This is our proposed model, which utilizes only patients’ self-reports for conducting an association-guided investigation, viii. A-SIDDA: Association guided symptom investigation and diagnosis dialogue system (A-SIDDA), which utilizes patients’ self-reports as well as current context (confirmed symptoms) for conducting symptom investigation.
Figure 5 shows diagnosis learning curves of different agents during training episodes. The performances of different models are reported in Table 2. Our model, A-SIDDA, outperforms the state-of-the-art methods in terms of all evaluation metrics by a significant margin. The performances of different agents with the DDQN algorithm are reported in Table 3. Our model still outperforms other baselines and state-of-the-art methods, but the diagnosis success rate and AMR are lesser and higher compared to DQN, primarily because of the reduced dialogue length.
We also evaluated these models in terms of symptom relevance (IReS-1, IReS-2) and condition coverage. The obtained results (Table 5) firmly establish the proposed association-based A-SIDDA model’s efficacy for conducting appropriate and relevant investigations, which are the key improvements over the state-of-the-art method. In Table 4, we also present a case study in which both agents perform identically in all existing evaluation metrics (Success, turn, AMR, and DC). However, the relevance of symptoms inspected by the SIDDA agent is substantially more relevant than the HRL agent, which had enquired some relatively irrelevant symptoms related to skin despite the patient informed breathing difficulty. Our proposed evaluation metric, IReS scores, captures this subjective concern and accordingly rates the symptom investigations.
Table 6 shows the performance of the proposed model across different disease departments. The performance comparison of these lower-level policies of the proposed model and the state-of-the-art model (HRL) has been illustrated in Fig. 6. The A-SIDDA model outperforms across all lower-level policies in terms of diagnosis accuracy by a significant margin.
Human evaluation
To rule out the possibility of under informative assessment done by automatic metrics, we conducted the human evaluation of 100 randomly selected test samples. In this assessment, medical domain experts, including three researchers, out of which two are clinicians, have been employed to rate each diagnosis from 0 to 5 based on investigation relevance, coherence, success, diagnosis time, and relevance of predicted disease. The obtained average scores are reported in Fig. 7.
The proposed agent’s symptom investigation relevance is tremendously better than the HRL agent. The HRL inspects the most frequently occurring symptoms (skin rash, fever, cold) more often without considering the context. The proposed agent’s efficacy reduces in case of diseases with a huge number of symptoms as the association-based recommendation leads to a wider horizon.
Key findings The key findings and observations from the experiment are enumerated as follows: i. The proposed A-SIDDA outperforms existing diagnosis assistants by a significant margin in both policy optimization algorithms (DQN and Double DQN) and achieves state-of-the-art performance. ii. The A-SIDDA outperforms the PR-SIDDA because the PR-SIDDA considers only patient self-reports while recommending a symptom for inspection in each dialogue turn. As a result, it does not capture the ongoing dialogue context, whereas the A-SIDDA uses the entire discourse, including patient self-report, to make such a recommendation. iii. We also found that our proposed assistant performs superior in terms of disease coverage (Top 3/5 disease converge) and achieves an acceptable disease identification accuracy. iv. The PR-SIDDA with only RM performs best in terms of IReS-1 primarily due to the fact that IReS-1 measures the relevance of inspected symptoms with patient self-report only (Table 5). Here, the assistant that also incorporates the recommendation module (RM) always recommends a symptom based on only patient self-report, and thus it becomes less efficient for symptom investigation. v. We found that the distribution of performances of our agent and the existing state-of-the-art model (HRL) across departmental policies is similar. Our A-SIDDA outperformed the HRL agent in every department by a significant margin. vi. We also observe that the proposed diagnosis method not only improves diagnosis efficacy but also greatly enhances end-users satisfaction because of context-aligned relevant and minimal symptom investigation (Table 2 and Fig. 7).
Case study and analysis
We have analyzed the performance of our proposed agents and the HRL agent for some common test cases (Table 7). Two such performance comparisons are reported in Table 8 and Table 9. The HRL agent inspects some completely irrelevant and frequently occurring symptoms (skin rash, skin lesion, eye pain) and informs the incorrect disease. The proposed model conducts a more relevant and appropriate symptom investigation guided and controlled by the ARM module and diagnoses patients correctly with fewer turns. The confusion matrix for failed diagnoses across disease groups is reported in Fig. 8. It shows that the diagnosis agent diagnoses an incorrect disease despite predicting the right disease group. It fails to distinguish among diseases of its corresponding disease group primarily because of many common symptoms.
Strengths and limitations The key strengths of the proposed association guided symptom investigation and diagnosis assistant (SIDA) are as follows: i. The proposed assistant diagnoses patients more accurately and in less time than any existing disease diagnosis assistants (Table 2). ii. The proposed assistant conducts symptom-association guided symptom inspection, i.e., each symptom inspection is inspired by ongoing dialogue context (previously confirmed symptoms). As a result, the conducted symptom inspection used to be quite pertinent to patient discourse and their primary complaint, making it outperform current diagnosis assistants in both quantitative and qualitative evaluations. iii. We first propose an evaluation metric, IReS, for measuring the relevance of symptom investigation conducted by a conversational assistant. Our proposed SIDA outperforms existing state-of-the-art models in all evaluation metrics, including IRes (Table 5). This metric can be utilized to evaluate a diagnostic agent’s effectiveness based on the relevance of the symptoms examined during symptom investigations.
The proposed methodology also has some weaknesses, which are as follows: i. Our key novelty lies in the central module of the dialogue system, i.e., dialogue management and dialogue policy learning [45]. The proposed framework utilizes a template-based response and diagnosis report generation. So, it may reduce an end-user’s interest due to monotonous responses. Hence, a neural context-aware generation method could be incorporated to generate context-aware engaging responses. ii. In some cases, the proposed assistant inspects significantly more symptoms than the existing diagnosis assistant (HRL) in order to arrive at a conclusive diagnosis. The primary reason for the behavior is the association-based critic, which encourages the assistant to continue inspecting more symptoms if it observes a patient’s symptom that co-occurs with a large number of symptoms. iii. In the proposed diagnosis setting, the agent assumes that end-users are familiar with medical entities such as symptom names. However, a large population is unacquainted with many symptoms, such as mouth ulcer and skin growth. Furthermore, some signs/symptoms are hard to express through text. As a result, a multimodal disease diagnosis that allows end users to express their symptoms through both text and images can be more effective and user-satisfying.
Conclusion
With the constantly expanding human population, the public healthcare system and health professionals are under strain. Thus, both research and industry communities are experiencing an ever-growing demand for artificial intelligence based tools and techniques for automatizing medical operations. Motivated by the importance of symptom association in the diagnosis process, we investigated the role of symptom association and built an association guided symptom investigation and disease diagnosis assistant (A-SIDDA). The proposed diagnosis model consists of a two-layered hierarchical policy structure, an association & recommendation module (ARM), and a disease classifier. The higher level policy decides medical department, and the lower level policy conducts department-specific symptom investigation. The ARM module reinforces the assistant to conduct context-aligned association guided symptom inspection through symptom recommendation and an additional critic. The disease classifier identifies a disease based on the patient’s self-report and the additional extracted symptoms. Furthermore, we introduced a novel evaluation metric called Investigation relevance score (IReS) to evaluate the relevance of symptom investigation, which estimates end users’ satisfaction with the system. The proposed assistant suppresses several baselines and state-of-the-art methods across multiple policy optimization algorithms by a significant margin and achieves state-of-the-art performance. We also conducted a human evaluation of the behavior of different diagnosis assistants, and we observed that the proposed assistant enhances user satisfaction significantly because of context-aligned symptom investigation. The obtained improvements (both quantitative and qualitative) firmly evidence the crucial role of symptom association and its usefulness in the diagnosis process. In future, we would like to develop a multitasking diagnosis framework that inspects symptoms and diagnoses disease using a unified network. We would also like to investigate the importance of signs/symptoms communicated through visuals in diagnosis process.
Availability of data and materials
The data and the code will be made publicly available through the Github repository - https://github.com/NLP-RL/A-SIDDS.
Notes
Division has been done as per the International Classification of Disease called ICD-10-CM https://www.cdc.gov/nchs/icd/
The data and code are available at https://github.com/NLP-RL/A-SIDDS
The model was trained for 5000 episodes on an RTX 2080 Ti GPU, which took around 22 hours
References
Rasmussen K, Belisario JM, Wark PA, Molina JA, Loong SL, Cotic Z, Papachristou N, Riboli-Sasco E, Car LT, Musulanov EM, et al. Offline elearning for undergraduates in health professions: a systematic review of the impact on knowledge, skills, attitudes and satisfaction. J Glob Health. 2014;4(1):010405.
Ramakrishnan N, Vijayaraghavan BKT, Venkataraman R. Breaking barriers to reach farther: a call for urgent action on tele-ICU services. Indian J Crit Care Med: Peer-Rev Off Publ Indian Soc Crit Care Med. 2020;24(6):393.
Yu K-H, Beam AL, Kohane IS. Artificial intelligence in healthcare. Nat Biomed Eng. 2018;2(10):719–31.
Fox S, Duggan M. Health online 2013. Health. 2013;2013:1–55.
Tiwari A, Saha S, Bhattacharyya P. A knowledge infused context driven dialogue agent for disease diagnosis using hierarchical reinforcement learning. Knowl Based Syst. 2022;242:108292.
Zhou X, Menche J, Barabási A-L, Sharma A. Human symptoms–disease network. Nat Commun. 2014;5(1):1–10.
Ceney A, Tolond S, Glowinski A, Marks B, Swift S, Palser T. Accuracy of online symptom checkers and the potential impact on service utilisation. medRxiv. 2020.
Yu C, Liu J, Nemati S, Yin G. Reinforcement learning in healthcare: a survey. ACM Comput Surv (CSUR). 2021;55(1):1–36.
Luo H, Li S-W, Glass J. Prototypical q networks for automatic conversational diagnosis and few-shot new disease adaption. Proc Interspeech. 2020;2020:3895–9.
Wei Z, Liu Q, Peng B, Tou H, Chen T, Huang X-J, Wong K-F, Dai X. Task-oriented dialogue system for automatic diagnosis. In: Proceedings of the 56th Annual meeting of the association for computational linguistics, vol. 2: short papers; 2018. pp. 201–207.
Tiwari A, Saha T, Saha S, Sengupta S, Maitra A, Ramnani R, Bhattacharyya P. A dynamic goal adapted task oriented dialogue agent. Plos one. 2021;16(4):0249030.
Liao K, Liu Q, Wei Z, Peng B, Chen Q, Sun W, Huang X. Task-oriented dialogue system for automatic disease diagnosis via hierarchical reinforcement learning. arXiv preprint arXiv:2004.14254. 2020.
Kao H-C, Tang K-F, Chang E. Context-aware symptom checking for disease diagnosis using hierarchical reinforcement learning. In: Proceedings of the AAAI conference on artificial intelligence, vol. 32; 2018.
Xia Y, Zhou J, Shi Z, Lu C, Huang H. Generative adversarial regularized mutual information policy gradient framework for automatic diagnosis. In: Proceedings of the AAAI conference on artificial intelligence, vol. 34; 2020. pp. 1062–1069.
Peng Y-S, Tang K-F, Lin H-T, Chang E. Refuel: exploring sparse features in deep reinforcement learning for fast disease diagnosis. Adv Neural Inf Process Syst. 2018;31:7322–31.
Walther JB, Van Der Heide B, Kim S-Y, Westerman D, Tong ST. The role of friends’ appearance and behavior on evaluations of individuals on facebook: are we known by the company we keep? Hum Commun Res. 2008;34(1):28–49.
Nagy WE, Herman PA, Anderson RC. Learning words from context. Read Res Q. 1985;20:233–53.
Mikolov T, Chen K, Corrado G, Dean J. Efficient estimation of word representations in vector space. arXiv preprint arXiv:1301.3781. 2013.
Liu Z, Li Y, Sun X, Wang F, Hu G, Xie G. Dialogue based disease screening through domain customized reinforcement learning. In: Proceedings of the 27th ACM SIGKDD conference on knowledge discovery & data mining, 2021. pp. 1120–1128.
Bajaj L, Kumar H, Hasija Y. Automated system for prediction of skin disease using image processing and machine learning. Int J Comput Appl. 2018;180(19):9–12.
Ventres W, Kooienga S, Vuckovic N, Marlin R, Nygren P, Stewart V. Physicians, patients, and the electronic health record: an ethnographic analysis. Ann Fam Med. 2006;4(2):124–31.
Tang PC, McDonald CJ. Electronic health record systems. In: Biomedical informatics, Springer; 2006. pp. 447–475.
Menachemi N, Collum TH. Benefits and drawbacks of electronic health record systems. Risk Manag Healthc Policy. 2011;4:47.
Tang K-F, Kao H-C, Chou C-N, Chang EY. Inquire and diagnose: Neural symptom checking ensemble using deep reinforcement learning. In: NIPS workshop on deep reinforcement learning. 2016.
Thiagarajan JJ, Rajan D, Katoch S, Spanias A. Ddxnet: a deep learning model for automatic interpretation of electronic health records, electrocardiograms and electroencephalograms. Sci Rep. 2020;10(1):1–11.
Chakraborty C, Kishor A, Rodrigues JJ. Novel enhanced-grey wolf optimization hybrid machine learning technique for biomedical data computation. Comput Electr Eng. 2022;99:107778.
Ali F, El-Sappagh S, Islam SR, Kwak D, Ali A, Imran M, Kwak K-S. A smart healthcare monitoring system for heart disease prediction based on ensemble deep learning and feature fusion. Inf Fusion. 2020;63:208–22.
Reza M, Hossain G, Goyal A, Tiwari S, Tripathi A, Bhan A, Dash P, et al. Automatic diabetes and liver disease diagnosis and prediction through SVM and KNN algorithms. In: Emerging technologies in data mining and information security, Springer;2021. pp. 589–599.
Chakraborty C, Kishor A. Real-time cloud-based patient-centric monitoring using computational health systems. IEEE transactions on computational social systems. 2022.
Kishor A, Chakraborty C. Artificial intelligence and internet of things based healthcare 4.0 monitoring system. Wirel Pers Commun. 2021. https://doi.org/10.1007/s11277-021-08708-5.
Xu L, Zhou Q, Gong K, Liang X, Tang J, Lin L. End-to-end knowledge-routed relational dialogue system for automatic diagnosis. In: Proceedings of the AAAI conference on artificial intelligence, vol. 33; 2019. pp. 7346–7353.
Dietterich TG. Hierarchical reinforcement learning with the MAXQ value function decomposition. J Artif Intell Res. 2000;13:227–303.
Liu W, Tang J, Qin J, Xu L, Li Z, Liang X. Meddg: A large-scale medical consultation dataset for building medical dialogue system. arXiv preprint arXiv:2010.07497. 2020.
Rehman R, Sheikh JA, Shah KA, Bhat ZA, Parah SA, Malik SA. Compact millimeter-wave low-cost ka-band antenna for portable 5g communication gadgets. In: Proceedings of second international conference on computing, communications, and cyber-security, Springer; 2021. pp. 53–65.
Liu W, Tang J, Liang X, Cai Q. Heterogeneous graph reasoning for knowledge-grounded medical dialogue system. Neurocomputing. 2021;442:260–8.
Tiwari A, Manthena M, Saha S, Bhattacharyya P, Dhar M, Tiwari S. Dr. can see: Towards a multi-modal disease diagnosis virtual assistant. In: Proceedings of the 31st ACM international conference on information & knowledge management, 2022. pp. 1935–1944.
Saha T, Gupta D, Saha S, Bhattacharyya P. Towards integrated dialogue policy learning for multiple domains and intents using hierarchical deep reinforcement learning. Expert Syst Appl. 2020;162:113650.
Mnih V, Kavukcuoglu K, Silver D, Graves A, Antonoglou I, Wierstra D, Riedmiller M. Playing atari with deep reinforcement learning. arXiv preprint arXiv:1312.5602. 2013.
Baird L. Residual algorithms: Reinforcement learning with function approximation. In: machine learning proceedings 1995, Elsevier; 1995. pp. 30–37.
Tesauro G. Temporal difference learning and TD-Gammon. Commun ACM. 1995;38(3):58–68.
Li X, Chen Y-N, Li L, Gao J, Celikyilmaz A. End-to-end task-completion neural dialogue systems. In: Proceedings of the eighth international joint conference on natural language processing, vol. 1: long papers; 2017. pp. 733–743.
Tang H, Houthooft R, Foote D, Stooke A, Xi Chen O, Duan Y, Schulman J, DeTurck F, Abbeel P. # exploration: A study of count-based exploration for deep reinforcement learning. Adv Neural Inf Process Syst, vol. 30. 2017.
Van Hasselt H, Guez A, Silver D. Deep reinforcement learning with double q-learning. In: Proceedings of the AAAI conference on artificial intelligence, vol. 30. 2016.
Franc V, Hlavác V. Multi-class support vector machine. In: Object recognition supported by user interaction for service robots, vol. 2; 2002. pp. 236–239. IEEE.
Tiwari A, Saha T, Saha S, Sengupta S, Maitra A, Ramnani R, Bhattacharyya P. Multi-modal dialogue policy learning for dynamic and co-operative goal setting. In: 2021 International joint conference on neural networks (IJCNN), 2021. pp. 1–8. IEEE.
Acknowledgements
Abhisek Tiwari graciously acknowledges the Prime Minister Research Fellowship (PMRF) Award supported by the Government of India for conducting this research. Dr. Sriparna Saha gratefully acknowledges the Young Faculty Research Fellowship (YFRF) Award, supported by Visvesvaraya Ph.D. Scheme for Electronics and IT, Ministry of Electronics and Information Technology (MeitY), Government of India, being implemented by Digital India Corporation (formerly Media Lab Asia) for carrying out this research.
Funding
The research is financially supported by Prime Minister Research Fellowship (PMRF) received to the first author, Abhisek Tiwari.
Author information
Authors and Affiliations
Contributions
AT: Conceptualization, Data analysis, Methodology, Validation, Analysis, Investigation, Visualization, and Writing, TS: Conceptualization, Supervision, Validation, Analysis and Writing, SS: Conceptualization, Supervision, Validation, Analysis, Project administration and Writing, PB: Conceptualization, Supervision, Validation, Analysis Project administration and Writing, SB: Methodology, Validation, Analysis, Investigation, Visualization, Writing and Supervision MD: Conceptualization, Supervision, Validation, Analysis, Project administration, ST: Conceptualization, Supervision, Validation, and Analysis. All authors reviewed the manuscript.
Corresponding author
Ethics declarations
Ethics approval and consent to participate
We have utilized the publicly available English medical dataset, Synthetic dataset (SD) [12], which is publicly available. We have utilized the dataset for only research purpose. All methods were performed in accordance with relevant guidelines and regulations and adhered to the tenets of the declaration of Helsinki. We have assured that the work and its repercussions do not violate any ethical boundaries or negatively impact any form of life.
Consent for publication
Not applicable
Competing interests
The authors declare that they have no competing interest.
Additional information
Publisher’s Note
Springer Nature remains neutral with regard to jurisdictional claims in published maps and institutional affiliations.
Rights and permissions
Open Access This article is licensed under a Creative Commons Attribution 4.0 International License, which permits use, sharing, adaptation, distribution and reproduction in any medium or format, as long as you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons licence, and indicate if changes were made. The images or other third party material in this article are included in the article's Creative Commons licence, unless indicated otherwise in a credit line to the material. If material is not included in the article's Creative Commons licence and your intended use is not permitted by statutory regulation or exceeds the permitted use, you will need to obtain permission directly from the copyright holder. To view a copy of this licence, visit http://creativecommons.org/licenses/by/4.0/. The Creative Commons Public Domain Dedication waiver (http://creativecommons.org/publicdomain/zero/1.0/) applies to the data made available in this article, unless otherwise stated in a credit line to the data.
About this article
Cite this article
Tiwari, A., Saha, T., Saha, S. et al. Symptoms are known by their companies: towards association guided disease diagnosis assistant. BMC Bioinformatics 23, 556 (2022). https://doi.org/10.1186/s12859-022-05032-y
Received:
Accepted:
Published:
DOI: https://doi.org/10.1186/s12859-022-05032-y