Next Article in Journal
Nematicidal Effect and Histological Modifications Induced by Hydrolysable Tannin Extract on the Third-Stage Infective Larvae of Haemonchus contortus
Previous Article in Journal
Enhanced Symbiotic Characteristics in Bacterial Genomes with the Disruption of rRNA Operon
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

SynSigGAN: Generative Adversarial Networks for Synthetic Biomedical Signal Generation

by
Debapriya Hazra
and
Yung-Cheol Byun
*,†
Department of Computer Engineering, Jeju National University, Jeju 63243, Korea
*
Author to whom correspondence should be addressed.
Current address: Department of Computer Engineering, Jeju National University, 102 Jejudaehak-ro, Jeju 63243, Korea.
Biology 2020, 9(12), 441; https://doi.org/10.3390/biology9120441
Submission received: 9 November 2020 / Revised: 29 November 2020 / Accepted: 30 November 2020 / Published: 3 December 2020

Abstract

:

Simple Summary

This paper proposes a novel generative adversarial networks model, SynSigGAN, to generate any kind of synthetic biomedical signals. The generation of synthetic signals eliminates confidentiality concerns and accessibility problem of medical data. Synthetic data can be utilized for training medical students and machine learning models for the advancement and automation of healthcare systems. Our proposed model performs significantly better than existing models with a high correlation coefficient that measures the generated synthetic signals’ similarity with the original signals.

Abstract

Automating medical diagnosis and training medical students with real-life situations requires the accumulation of large dataset variants covering all aspects of a patient’s condition. For preventing the misuse of patient’s private information, datasets are not always publicly available. There is a need to generate synthetic data that can be trained for the advancement of public healthcare without intruding on patient’s confidentiality. Currently, rules for generating synthetic data are predefined and they require expert intervention, which limits the types and amount of synthetic data. In this paper, we propose a novel generative adversarial networks (GAN) model, named SynSigGAN, for automating the generation of any kind of synthetic biomedical signals. We have used bidirectional grid long short-term memory for the generator network and convolutional neural network for the discriminator network of the GAN model. Our model can be applied in order to create new biomedical synthetic signals while using a small size of the original signal dataset. We have experimented with our model for generating synthetic signals for four kinds of biomedical signals (electrocardiogram (ECG), electroencephalogram (EEG), electromyography (EMG), photoplethysmography (PPG)). The performance of our model is superior wheen compared to other traditional models and GAN models, as depicted by the evaluation metric. Synthetic biomedical signals generated by our approach have been tested while using other models that could classify each signal significantly with high accuracy.

1. Introduction

Deep learning has spurred significant advances in the healthcare industry. Its technological developments have not only provided solutions to intricate problems, but also reduced costs and enhanced efficiency in the medical domain. It was predicted by the International Data Corporation (IDC) in the year 2019 that the worldwide market for artificial intelligence (AI), deep learning, and machine learning would reach 97.9 billion US dollar by 2023 with a compound annual growth rate of 28.4% [1]. Currently, deep learning algorithms utilize data provided by the electronic health records in order to predict risk factors, detect health patterns, and correctly diagnose diseases. Deep learning is not only used prediction, but also for the analyzing, tracking, and detection of health conditions or particular diseases. Nvidia published a study where advanced algorithms were able to reduce medical misdiagnosis in cancer by 85% [2]. Researchers around the world collaborated in order to apply deep learning for predicting heart failures from electronic health records up to nine months earlier than doctors manually can. Renowned companies, like Google, created convolutional neural network models to build LYmph Node Assistant (LYNA), which achieved 99% accuracy as compared to doctors who achieved 38% accuracy in detecting metastasized breast cancer. Over 415 million people in the developing countries suffer from diabetic retinopathy, which subsequently leads to blindness. Machine learning models use retinal images to detect early symptoms of diabetic retinopathy and they eliminate the potential risk of blindness in patients. Not only this, but reinforcement learning models, are currently used to track biomarkers and plan daily drug dosage courses for continuous treatment of Human Immunodeficiency Virus (HIV) [2].
Despite many advantages of AI and deep learning models, one of the risks involved is the vulnerability of private data that are stored in electronic health records. Patient’s privacy being a major concern of the hospitals, acquiring large datasets in order to train any model becomes very difficult. The impact of deep learning, AI, and machine learning in healthcare research has been relatively slower and complicated due to the lack of availability of medical data and low accessibility for potential researchers. Even if the data are accessible to the researcher, the legal requirements to acquire data by ensuring proper and protected usage of the data takes a considerable amount of time and, thereby, delays the development of advanced technology that could benefit the healthcare sector. To make medical data available, many owners anonymize data by detaching recognizable features, adding noise and grouping individuals or variables into broader categories [3]. However, the re-identification of those anonymized data in the large dataset becomes extremely difficult, time consuming, and, therefore, not approachable. Generating synthetic medical data is a solution to this problem and it is considered to be valuable when there is insufficient original data or original data are expensive. Synthetic data can be used exclusively or with the original data for training purposes, education, machine learning model development and software testing. There are many methods to generate synthetic data, but one of the most successful frameworks for generating synthetic medical data is generative adversarial networks (GAN). Understanding physiological signals and generating synthetic biomedical signals is a complicated and much required task. Each biomedical signal has its own morphological characteristics, depending on the source of organ, independent traits, noise, electrode placement, and pathological events. External devices also corrupt the quality of biomedical signals, with excessive noise making them unreadable.
In this paper, we propose a novel generative adversarial network, named as SynSigGAN, for generating synthetic biomedical signals using a small dataset of real signals. The main contribution of this paper is summarized, as below:
  • We propose a preprocessing stage to refine the biomedical signals while using a combination of discrete wavelet transform (DWT), thresholding, and Inverse discrete wavelet transform (IDWT). This model can be modified according to the signal requirement and it can be used for denoising and refining any kind of signals.
  • Our proposed generative adversarial networks model can be applied in order to generate any kind of biomedical signals.
  • We have an evaluation stage to ensure the authenticity and similarity of synthetic data as compared to the original data.
  • As the data enhance, the approach can be reused in order to generate more synthetic data.
After the generation of the synthetic data, we evaluate the Pearson correlation coefficient to verify the quality of synthetic data when compared to the original data. We also calculate the Root Mean Square Error (RMSE), Percent Root Mean Square Difference (PRD), Mean Absolute Error (MAE), and Frechet Distance (FD) for statistical analysis. The results show that our model outperforms existing models and generates synthetic biomedical signals that can be practically used for the advancement of healthcare industry.
The rest of this paper includes related works in Section 2, an explanation of datasets used for our work in Section 3, the proposed methodology for generating synthetic data in Section 4, evaluation and results in Section 5, and Section 6 concludes our proposed work.

2. Related Works

There is a large variation of machine learning and deep learning models available in the literature for experimenting with biomedical signals. Additionally, synthesized signals have been assessed for signal denoising, event detection, reconstructing illegible signals, classification, and generation of biomedical signals.
Patrick E. McSharry et al. proposed a dynamic model that was built on three coupled ordinary differential equations for generating synthetic electrocardiogram signals [4]. The generation of realistic synthetic electronic health records without the use of real electronic health records was proposed in [5]. They used the CareMap with health incidents statistics to achieve generating synthetic electronic health records. A. D. Moore synthesized Electromyography signals using the integration of diphasic waves and multiplication of sinus waves along with autoregressive models mixed with gaussian noise [6]. I.S.N. Murthy et al. generated synthetic data for electrocardiogram signals while using discrete cosine transform [7]. Radford et al. presented unsupervised learning and generated synthetic images while using deep convolutional generative adversarial networks (DCGAN) [8]. Fei Zhu et al. proposed a bidirectional long short-term memory-convolutional neural network GAN for electrocardiogram generation [9]. Fei Zhu et al. claimed that their model could generate ECG data with relatively high morphological similarity when compared to real ECG data.
Generative adversarial networks are now an emerging framework to deal with images and time series data and also for the creation of synthetic data. Stephanie Hyland et al. used recurrent conditional GANs (RCGAN) for the synthetic generation of real-valued medical time series data [10]. They evaluated their model and concluded that RCGAN can generate time series data that are useful for supervised training but with minor degradation in performance on real test data. Annie Marie Delaney et al. proposed generative adversarial networks for realistic synthetic ECG signal generation [11]. They tested their generator with two models, namely LSTM and Bidirectional LSTM, and for the discriminator they compared LSTM and CNN. The generator architecture with LSTM consisted of two layers of LSTM, followed by a fully connected layer that generated synthetic ECG data. They used 50 hidden layers in both of the LSTM layers. For the generator architecture with BiLSTM, they used two BiLSTM layers, along with a fully connected layer and 50 hidden layers. For the discriminator built with LSTM, the authors used two LSTM layers with 50 hidden layers, a minibatch discriminator layer, and a fully connected layer with a sigmoid activation function for classification. The CNN discriminator was built using a convolutional pooling layer with a ReLu activation function, followed by a minibatch discriminator and a fully connected layer for classification. Their model depicted that GAN with two bidirectional LSTM in the generator and convolutional pooling layer in the discriminator performed the best and generated high-quality ECG data.
In [12], data scientists and researchers concluded that, statistically, there is no significant difference between the original and synthetic data. Models have been trained and evaluated for classification, prediction and detection of diseases with only synthetic data and also with original data solely. In cases where there is a combination of synthetic data and original data or only synthetic data, the acquired results have been more accurate. Many physicians have confirmed that there are many cases where synthetic data met specific rare conditions that original data could not. These synthetic data can be integrated with wearable smart healthcare devices and trained in order to build models for emergency alert generation [13]. COCOA is framework that was presented by Vanessa Ayala-Rivera et al. for generating realistic synthetic microdata that can preserve the functional dependencies of data by allowing multi-attribute relationships [14].
Medical generative adversarial networks that are known as medGAN are a famous approach for creating realistic synthetic patient records. It generates high-dimensional discrete values by combining autoencoders and GAN architecture [15]. Authors have used autoencoders in medGAN to learn salient features by relating samples to lower dimensional space and, afterwards, projecting samples to the original space. Instead of directly generating patient records, GAN has been provided here with pre-trained autoencoders to generate distributed patient data. Convolutional generative adversarial networks have also been used for obtaining synthetic healthcare data [16]. The authors have utilized one-dimensional (1-D) convolutional neural networks to apprehend the correlation between consecutive diagnosis data. Subsequently, they used convolutional autoencoders to relate discrete-continuous values. Finally, fidelity and privacy risk was measured in order to conclude the proposed work. Private Aggregation of Teacher Ensembles (PATE) is another GAN model for generating synthetic data that ensures differential privacy of the generator which is significantly important for biomedical data [17]. In PATE-GAN, the generator resembles the generator of a standard GAN model, but the discriminator is built with PATE mechanism, so there are k-teacher discriminators and the training is asymmetrical. Synthesizing normal heart sounds while using GAN were proposed by Pedro Narvaez et al. [18]. They used their data as a test dataset to evaluate heart sound classification models. Brain signals or EEG data have also been synthetically generated using GAN models by many researchers. One of the models is named as neural-based generative models for SSVEP classification in EEG data [19]. Authors used deep convolutional generative adversarial networks and variational autoencoders for this purpose. A recent work also produced efficient results for generating synthetic biomedical singals while using bidirectional recurrent neural network [20].
Therefore, as the related studies depict, a lot of work has been done for the generation of synthetic medical data, including signals. However, less work has been done in order to create generalized model for generating synthetic data for all kinds of biomedical signals. In the section below, we describe the data that were used for signals and propose a methodology for generating synthetic signals.

3. Data

We have trained and evaluated our proposed model both qualitatively and quantitatively with four biomedical signal databases [21]. The biomedical signals considered in our work are electrocardiogram (ECG), electroencephalogram (EEG), electromyography (EMG), and photoplethysmography (PPG). We have acquired the ECG data from MIT-BIH Arrhythmia Database [22]; EEG data from Siena Scalp EEG Database [23,24]; EMG data from Sleep-EDF Database [25]; and, PPG data from the BIDMC PPG and respiration Dataset [26]. Description of the datasets are mentioned in the following subsections.

3.1. MIT-BIH Arrhythmia Database

The MIT-BIH Arrhythmia Database is a collection of digitized and annotated long-term ECG recordings from Boston’s Beth Israel Hospital for arrhythmia analysis. The ECG recording from 47 subjects and a total of 201 records were obtained from 48 half-hour extracts of two-channels. Twenty-three recordings were randomly chosen from 4000 Holter tapes and the rest 25 were a collection of clinically important arrhythmia’s that are generally uncommon in small samples. Among the 47 patients, 25 were men aged 32 to 89 years, and 22 women from 23 to 89 years. Mostly, one of the two channels were modified limb lead II (MLII) and the other channel was among V1, V2, V4, or V5, depending upon the patients. The sampling frequency was 360 Hz and the signal duration was 30 min. The 17 types of ECG signals that are present in the MIT-BIH Arrhythmia Database are as follows:
  • Normal Beat (NB)
  • Rhythm Change (RC)
  • Right Bundle Branch Block Beat (RBBB)
  • Left Bundle Branch Block Beat (LBBB)
  • Ventricular Escape Beat (VEB)
  • Atrial Premature Beat (APB)
  • Premature Ventricular Contraction (PVC)
  • Nodal (Junctional) Escape Beat (NEB)
  • Aberrated Atrial Premature Beat (AAPB)
  • Fusion of Ventricular and Normal Beat (FVNB)
  • Fusion of Paced and Normal Beat (FPNB)
  • Ventricular Flutter Wave (VFW)
  • Comment Annotations (CA)
  • Paced Beat (PB)
  • Non Conducted P Wave (Blocked APC) (NCPW)
  • Change in Signal Quality (CSQ)
  • Unclassifiable Beat (UB)

3.2. Siena Scalp EEG Database

The Siena Scalp EEG Database was obtained from the Unit of Neurology and Neurophysiology at University of Siena. The EEG recordings are of 14 patients, which includes nine males aged 25–71 and five females of age 20–58. The sampling rate was 512 Hz for the diagnosis of epilepsy and seizure classification. The database has recordings in European Data Format (EDF). Each patient has between one and five data files of maximum 2.11 GB size and also a text file containing seizure and data information. The dataset has an excel file containing gender, age, seizure classification, number of EEG channels, total number of seizures, and recording time in minutes. Seizures are classified as IAS, WIAS, and FBTC. The dataset contains a total of 47 seizures and recording of 128 h.

3.3. Sleep-EDF Database

Polysomnographic sleep recordings of 197 full-nights containing chin EMG recordings are obtained from the Sleep-EDF Database. The database has two types of files, namely Sleep Cassette (SC) study and Sleep Telemetry (ST) study files. Each file contains *PSG.edf, which are polysomnographic sleep recording files, and *Hypnogram.edf, which are the sleep pattern annotation file that corresponds to the PSG files. The signals were sampled at 100 Hz and event marker at 1 Hz. There are 153 SC files that study the effects of age on sleep for age group of 25 to 101 and 44 ST files from 22 males and females.

3.4. BIDMC PPG and Respiration Dataset

The signals in the BIDMC PPG and respiration dataset are extracted from the MIMIC II matched waveform database, with breath annotations being done manually by two annotators using the impedance respiratory signal. The dataset is acquired from Beth Israel Deaconess Medical Centre (Boston, MA, USA). There are 53 recordings, each of which is of 8 min duration. Each recording contains:
  • Physiological signals sampled at 125 Hz.
  • Parameters such as respiratory rate, heart rate and blood oxygen saturation level which are sampled at 1 Hz.
  • Fixed parameters such as age and gender.

4. Proposed Methodology for Generating Synthetic Biomedical Signals

The proposed methodology for generating synthetic biomedical signals has been divided into different stages as shown in Figure 1. We have processed and evaluated each of the four signals (ECG, EEG, EMG, and PPG) independently through the proposed approach. The original signals proceed through the preprocessing stage, eliminating noise and refining the signals while using discrete wavelet transform (DWT), thresholding, and inverse discrete wavelet transform (IDWT). After preprocessing, the signals are then forwarded to the segmentation stage that uses the Z-score to solve amplitude scaling problem and eliminate offset. Next is the generative adversarial networks model, which takes in the segmented signals and generates synthetic biomedical signals using bidirectional grid long short-term memory for generator network and convolutional neural network for the discriminator. In the last stage, we statistically evaluate our model to measure and prove the quality of the synthetically generated signals when compared to the original signals.

4.1. Preprocessing of the Original Signals

In the preprocessing stage, we have implemented a wavelet denoising mechanism for biomedical signals [27]. We have used wavelet transformation, since it produced a superior denoising performance for signals due to its multiresolution and windowing characteristics as compared to other mechanisms [28]. The original signals were processed through four Daubechies filters, namely, G ( z )  and H ( z ) , which are basically four tap high-pass and low-pass filters, which can be represented as in (1):
G ( z ) = G 0 z + G 1 z 1 + G 2 z 2 + G 3 z 3 H ( z ) = H 0 z + H 1 z 1 + H 2 z 2 + H 3 z 3
After this, we compute the detailed wavelet coefficients and approximate coefficients from the high and low-pass filters. The output of the low-pass filter is then subsampled by 2 and again processed through a high and low-pass filters with half cut-off frequency from the previous time, as shown in Figure 2. The frequency resolution is doubled, since the outputs are of half the frequency of the input.
In order to preserve sharp features of the biomedical signals, we incorporated thresholding that was applied to the wavelet coefficients generated by DWT. For each DWT level, we assigned an adaptive thresholding process on the wavelet coefficients that were created at that level. The adaptive threshold applied to i-th DWT level can be defined as (2):
A T i ( j ) = 1 32 n = 32 ( j 1 ) 32 j 1 | x 1 ( n ) | × 2 i
where, A T i ( j ) is the j-th threshold value for performing adaptive thresholding in the i-th level of DWT and x 1 ( n ) is the wavelet coefficient in the first DWT level. 32 is an observed choice made for the moving window length. As the DWT level increases by one, the threshold value also rises by a factor of 2, as we can see from the following Equation (3). During thresholding, the average of the absolute values of the consecutive wavelet coefficients are computed and then the data sequences obtained from the DWT are fed to the IDWT for further processing.
A T i ( 1 ) = 1 32 n = 0 31 | x 1 ( n ) | × 2 i A T i ( 2 ) = 1 32 n = 32 63 | x 1 ( n ) | × 2 i A T i ( 3 ) = 1 32 n = 64 95 | x 1 ( n ) | × 2 i
In the last phase, the IDWT generates the denoised signals by determining the inverse DWT of the wavelet coefficients that has been thresholded. Figure 3 explains the IDWT flow. In Table 1, we show the performance comparison of other denoising techniques with our used methodology (wavelet transformation) through signal-to-noise ration (SNR), root mean square error (RMSE), and percentage root-mean-square difference (PRD).

4.2. Segmentation

In the segmentation stage, we cluster the signals according to the annotations that are mentioned in each of the datasets and then segment the signals. The later step is to concatenate the signals of similar type [29]. Another approach that was taken for segmenting ECG signals was to extract the median of R-R time intervals and consider it as the nominal heartbeat period (T). We have followed the work from [30] for ECG signal segmentation. We need the same class of signals with similar sizes to forward the signals to the adversarial networks.
Let us consider a recording that has two different types of ECG signals: normal and Ventricular Escape Beat (VEB). This can be represented while using two arrays V E B and N B , as in (4) and (5):
V E B = V E B 1 V E B 2 V E B 3 . . V E B n
N B = N B 1 N B 2 N B 3 . . N B n
where n is the number of elements in the particular class. We define a vector that contains the length for each vector in the array, as mentioned in (6) and (7):
L V E B = L e n g t h ( V E B 1 ) L e n g t h ( V E B 2 ) L e n g t h ( V E B 3 ) . . L e n g t h ( V E B n )
L N B = L e n g t h ( N B 1 ) L e n g t h ( N B 2 ) L e n g t h ( N B 3 ) . . L e n g t h ( N B n )
Subsequently, we compute the minimum among all of the vectors in L V E B and L N B , and alter the size of the vectors in the array by Algorithm 1, producing the new signals. Algorithm 1 is explained in a general form that can be considered for any vectors that belong to the same class in the dataset.
m i n L c l a s s = m i n i m u m ( L c l a s s )
Algorithm 1 Changing the size of vectors
Initialize M as new matrix
for i = 1 to n do
       l l e n g t h o f c l a s s
      if l = m i n L c l a s s then
          Append class to M
      else
          rational fraction approximation of m i n L c l a s s and l
      end if
end for
R S R e s a m p l e d c l a s s e s
Append R S to M

4.3. SynSigGAN: Generative Adversarial Networks

In this section, we utilize the preprocessed signals to generate synthetic biomedical signals using generative adversarial networks. GAN consists of two networks, namely generator ( G ) and discriminator ( D ) , which compete against each other in a zero-sum game. The generator is provided with random input noise variable p z ( z ) from which the generator captures the data distribution p d over the data x. The sample that is generated by the generator and original input ground-truth data is fed to the discriminator. The task of the discriminator is to correctly evaluate the generator’s sample with respect to real data. Generator loss is the penalty for the generator if it fails to fool the discriminator. A point comes when the generator outputs excellent samples that are almost similar to the original data and the discriminator gets worse at distinguishing real from generated data. Therefore, the generator aims to minimize l o g ( 1 D ( G ( z ) ) and the value function F v ( D , G ) in the minmax game is defined as in (8). We have proposed a novel GAN architecture that uses a bidirectional grid long short-term memory (BiGridLSTM) for the generator network and a convolutional neural network for the discriminator network.
min G max D F v ( D , G ) = E x p d ( x ) [ l o g D ( x ) ] + E z P z ( z ) [ l o g ( 1 D ( G ( z ) ) ) ]
Hochreiter & Schmidhuber [31] introduced long short-term memory (LSTM), which could avoid the long-term dependency problem that is faced by recurrent neural networks (RNN) and remember information over a longer period of time. The LSTM has four interacting layers of neural network with a chain like structure of repeating modules as RNN. Cell state is the core component of the LSTM network that helps information to flow through the entire network. LSTM can, at any point, add or remove information from the cell state. The sigmoid or the forget gate F g layer makes the decision of which information is needed to be eliminated from the cell state, as shown in Figure 4. It takes in H t 1 and X t and outputs 0 (denoting information removal) or 1 (denoting keep information) for each cell state C t 1 . The next part is to determine what information we want to store in the cell state. For this, the sigmoid or the input gate I g layer first decides which value we need to update and then the tanh layer creates a vector C t with new values to be included in the cell state. Subsequently, they are combined in order to obtain a new state and update the existing state. Like any nodes in neural network, the gates in the LSTM network use weights to traverse or filter information and they can be adjusted based on the learning process.
The LSTM network at a time step t can be formulated as in (9) [32].
I t = σ ( A I X t + B I H t 1 + D I C t 1 + g I ) F t = σ ( A F X t + B F H t 1 + D F C t 1 + g F ) C ^ t = tanh ( A C X t + B C H t 1 + g C ) C t = F t C t 1 + I t C ^ t O t = σ ( A O X t + B O H t 1 + D O C t + g O ) H t = A p r o j ( O t tanh ( C t ) )
where, A, B, and D represent the weight matrix and g represents the bias vector. σ is the sigmoid activation function, ∘ represents the element-wise product, and A p r o j denotes the projection matrix.
Grid Long Short-Term Memory (GridLSTM) was first introduced in 2015 [33], which is an improved version of LSTM that could represent the LSTM blocks into a multidimensional grid. The advantage of GridLSTM is that it can deploy cells along any dimension of the network. For our proposed work, we have considered GridLSTM along two dimensions, i.e., temporal as one of the dimension and depth as the second. Along every dimension, the GridLSTM is linearly related to the gates among all of the adjacent cells, eliminating the vanishing gradient problem along each dimension. The calculation of the time and depth LSTM block in our proposed work can be defined as in (10) and (11).
Time-LSTM block in Grid-LSTM:
I t , l T m = σ ( A I , l d e p H t , l 1 d e p + B I , l T m H t 1 , l T m + D I , l T m C t 1 , l T m + g I , l T m ) F t , l T m = σ ( A F , l d e p H t , l 1 d e p + B F , l T m H t 1 , l T m + D F , l T m C t 1 , l T m + g F , l T m ) C ^ t , l T m = tanh ( A C , l d e p H t , l 1 d e p + B C , l T m H t 1 , l T m + g C , l T m ) C t , l T m = F t , l T m C t 1 , l T m + I t , l T m C ^ t , l T m O t , l T m = σ ( A O , l d e p H t , l 1 d e p + B O , l T m H t 1 , l T m + D O , l T m C t , l T m + g O T m ) H t , l T m = A p r o j , l T m ( O t , l T m tanh ( C t , l T ) )
Depth-LSTM block in GridLSTM:
I t , l d e p = σ ( A I , l d e p H t , l 1 d e p + B I , l T m H t 1 , l T m + D I , l d e p C t , l 1 d e p + g I , l d e p ) F t , l d e p = σ ( A F , l d e p H t , l 1 d e p + B F , l T m H t 1 , l T m + D F , l d e p C t , l 1 d e p + g F , l d e p ) C ^ t , l d e p = tanh ( A C , l d e p H t , l 1 d e p + B C , l T m H t 1 , l T m + g C , l d e p ) C t , l d e p = F t , l d e o C t , l 1 d e p + I t , l d e p C ^ t , l d e p O t , l d e p = σ ( A O , l d e p H t , l 1 d e p + B O , l T m H t 1 , l T m + D O , l d e p C t , l d e p + g O , l d e p ) H t , l d e p = A p r o j , l d e p ( O t , l d e p tanh ( C t , l d e p ) )
where d e p represents depth dimension and T m represents time dimension. Whereas, t represents time and l denotes the number of layers. For example, H t , 2 d e p represents the cell state of depth dimension in the depth-LSTM block of the second layer at time t. Initially, we set the value of C t , 0 d e p to zero. In our proposed word, A in GridLSTM is the weight between the gating unit and output of the upper layer grid of the depth dimension, whereas B is the weight between the gating unit and output of the previous instant of the time dimension. D can be considered as the weight of the cell states along every dimension of contiguous grid in the LSTM blocks. Figure 5 shows the structure of GridLSTM.
We have used a bidirectional grid LSTM for our generator network in the GAN architecture that integrates the GridLSTM with a bidirectional architecture. BiGridLSTM is a combination of a double GridLSTM in opposite directions, each containing a time and depth LSTM block. The BiGridLSTM has the advantage of diminishing the gradient phenomenon from two dimensions and obtaining the context information at the same time frame. It has also proved to produce excellent outcomes in time sequence problems. The output of the hidden layer of a GridLSTM in forward direction has the current instant as an input and previous moment as the output. In the proposed architecture the output of the hidden layer 1 at the time t towards the direction of the depth and in time dimension are impacted by the output H t + 1 , l T m at time t + 1 of the hidden layer 1 in the time dimension and input X t d e p in the depth direction at time t; or by the output of H t , l 1 d e p at time t of the hidden layer l 1 in the reverse GridLSTM. The final output of the BiGridLSTM is the synthetic biomedical signals by combining and connecting the outputs of the forward and reverse GridLSTM. BiGridLSTM overcomes the problem of capturing context information by scanning the input sequences together and by eliminating vanishing gradient problem in the vertical dimension. The time and depth LSTM in the reverse GridLSTM can be defined as in (12) in simple form [32].
( H t , l T m , C t , l T m ) = T i m e _ L S T M ( H t , l 1 d e p , H t + 1 , l T m , C t + 1 , l T m , T m ( H t , l d e p , C t , l d e p ) = D e p t h _ L S T M ( H t , l 1 d e p , H t + 1 , l T m , C t , l 1 T m , d e p
where represents the reverse GridLSTM block and ⊙ implies all of the parameters in the inverse LSTM block. The combined output of the hidden layer l at a given time t is defined as in Equation (13). Figure 6 shows the BiGridLSTM architecture that is used for generating synthetic biomedical signals.
O u t p u t t , l = G r i d L S T M ( H t , l d e p , H t , l d e p )
The sample of synthetic signals that are generated from the generator is then passed to the discriminator along with the original signal. The task of the discriminator is to evaluate and distinguish the real data from the data created by the generator. Hence, as the training proceeds, the generator tries to fool the discriminator, which consequently improves the quality of the synthetic signals generated. We have built our discriminator architecture with convolutional neural network, as shown in Figure 7. We have used a 1-D convolutional network that takes, as input, T data points, each represented by n-dimensional vector. The filter size has been set to H*1 and stride to P 1 ( 5 1 and 3 1 ). Accordingly, the size of the output of the first convolutional layer can be defined as [ ( N o .   o f F i l t e r s ) [ ( T H ) / P + 1 ] 1 ]. Subsequently, there are the max pooling layers and the second convolutional and pooling layer. The fully connected layer maps the softmax layer that outputs a one-hot vector. There are two components in the vector that showcase the probability of the input being true or false and, finally, outputs the decision of the discriminator, as we can see from Figure 7.

5. Evaluation and Results of the Proposed Approach

The metrics that we have used for evaluating the quality of the generated synthetic signals are Root Mean Square Error (RMSE), Percent Root Mean Square Difference (PRD), Mean Absolute Error (MAE), and Fréchet Distance (FD). We have also calculated the Pearson’s Correlation Coefficient (PCC) between the original and generated synthetic signal for statistical analysis.

5.1. Root Mean Square Error

We use the root mean square error to measure the stability between the original signal ( O ) and the generated synthetic signal ( S ) by SynSigGAN. It can be formulated, as shown in (14):
R M S E = N i = 1 N ( O i S i ) 2

5.2. Percent Root Mean Square Difference

The percent root mean square has been used to calculate the distortion between two signals, as shown in (15):
P R D = 100 i = 1 N ( O i S i ) 2 i = 1 N ( O i ) 2

5.3. Mean Absolute Error

The mean absolute error calculates the average of the absolute differences between the original and synthetic signals while using Equation (16):
M A E = 1 N i = 1 N | O i S i |

5.4. Fréchet Distance

We have measured the Fréchet Distance to find the similarity between the ordering and location of points along the curve. If O R = a 1 , a 2 , a 3 , , a R is the order of points along the segmented original curves and O S = b 1 , b 2 , b 3 , , b S is the order of points along the segmented synthetic curve, then the length l of the sequence can be measured, as in (17):
l = max i = 1 , , n l ( a u i , b v i )
where l is the euclidean distance and a u i and b v i are the sequence of the order of points. Accordingly, the Fréchet Distance can be calculated as (18) [9]:
F D ( R , S ) = min l

5.5. Pearson’s Correlation Coefficient

The relationship between two variables is measured by the correlation coefficient, which ranges between −1 and +1. Whereas, 0 indicates there is no relationship. A positive value refers to a direct relation and a negative value refers to inverse relation. The Pearson’s correlation coefficient in our proposed methodology was measured as (19) [34]
P C C = i = 1 N ( O i O ) ( S i S ) [ i = 1 N ( O i O ¯ ) ] [ i = 1 N ( S i S ¯ ) ]
The correlation values can be transcribed, as in Table 2.
Table 3 and Table 4 show the evaluation results of the signals and different models as compared to our proposed approach.

5.6. Results

This section presents the synthetic signal generation as compared to the original signals for four kinds of biomedical signals. We have shown the result of 10 patients for ECG, PPG, and EEG recordings and six patient for EMG recordings, where every patient has a different period of recording and a different number of signals. Our proposed methodology has been able to obtain a similar quantity of synthetic data as compared to original signals. We have applied our proposed approach on open and closed-eye EEG data and 17 types of ECG signals where there are same number of signals for every class and they also have the same length. Figure 8, Figure 9, Figure 10 and Figure 11 show the comparison of the original and synthetic data generation using our proposed approach. Table 5, Table 6 and Table 7 show the count of original signals and the count for the total number of synthetic signals generated for specific signal types. In this section, we have also presented different generator loss keeping the discriminator network in the GAN architecture as CNN and discriminator loss keeping the generator in the GAN architecture as BiGridLSTM. Figure 12 and Figure 13 depict the generated loss. This evaluation depicts that the combination of BiGridLSTM-CNN in the GAN architecture produces the best result. For evaluation, the synthetic signals that were delivered by our proposed model were used by other models for classification and they resulted in classifying each signal with significantly high accuracy.

6. Conclusions

We proposed a generative adversarial networks model, named as SynSigGAN, which was successfully able to generate synthetic biomedical signals with a high correlation coefficient. This paper presented a preprocessing stage that could eliminate noise and refine any kinds of biomedical signals for further processing and to help generate high quality synthetic signals. The model segmented each signal according to the annotations and trained the adversarial networks consisting of the combination of bidirectional grid long short-term memory and convolutional neural network in order to generate realistic synthetic biomedical signals.
The generation of the synthetic signals eliminates privacy concerns and the problem of accessibility of medical data among the researchers. We have used the MIT-BIH arrhythmia database for ECG signals, Sienna scalp database for EEG signals, Sleep EDF database for EMG signals, and BIDMC PPG and respiration dataset for PPG signals. We have compared the correlation between original signals and the synthetic signals generated by our proposed approach. The synthetic signals generated by our proposed approach are highly correlated to the original signals and of remarkable quality, as shown in the results section. Our model could generate signals of various lengths and characteristics. We evaluated our model based on MAE, RMSE, PRD, and FD scores, which were compared with existing models, and the outcome shows that our model performs significantly better than existing models.

Author Contributions

Conceptualization, D.H.; Formal analysis, D.H.; Funding acquisition, Y.-C.B.; Methodology, D.H.; Writing–review and editing, D.H.; Investigation, Y.-C.B.; Resources, Y.-C.B.; Project administration, Y.-C.B.; Supervision, Y.-C.B. All authors have read and agreed to the published version of the manuscript.

Funding

This work was supported by Korea Institute for Advancement of Technology(KIAT) grant funded by the Korea Government (MOTIE) (N0002327, The Establishment Project of Industry-University Fusion District).

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Esteva, A.; Robicquet, A.; Ramsundar, B.; Kuleshov, V.; DePristo, M.; Chou, K.; Cui, C.; Corrado, G.; Thrun, S.; Dean, J. A guide to deep learning in healthcare. Nat. Med. 2019, 25, 24–29. [Google Scholar] [CrossRef] [PubMed]
  2. Deep Learning in Healthcare. Available online: https://missinglink.ai/guides/deep-learning-healthcare/deep-learning-healthcare/ (accessed on 1 November 2020).
  3. Ursin, G.; Sen, S.; Mottu, J.M.; Nygård, M. Protecting privacy in large datasets—First we assess the risk; then we fuzzy the data. Cancer Epidemiol. Prev. Biomarkers 2017, 26, 1219–1224. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  4. McSharry, P.E.; Clifford, G.D.; Tarassenko, L.; Smith, L.A. A dynamical model for generating synthetic electrocardiogram signals. IEEE Trans. Biomed. Eng. 2003, 50, 289–294. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  5. McLachlan, S.; Dube, K.; Gallagher, T. Using the caremap with health incidents statistics for generating the realistic synthetic electronic healthcare record. In Proceedings of the 2016 IEEE International Conference on Healthcare Informatics (ICHI), Chicago, IL, USA, 4–7 October 2016; pp. 439–448. [Google Scholar]
  6. Moore, A.D. Synthesized EMG Waves and Their Implications. Am. J. Phys. Med. Rehabil. 1966, 46, 1302–1316. [Google Scholar]
  7. Murthy, I.; Reddy, M. ECG synthesis via discrete cosine transform. In Proceedings of the Images of the Twenty-First Century. Proceedings of the Annual International Engineering in Medicine and Biology Society, Seattle, WA, USA, 9–12 November 1989; pp. 773–774. [Google Scholar]
  8. Radford, A.; Metz, L.; Chintala, S. Unsupervised Representation Learning with Deep Convolutional Generative Adversarial Networks. arXiv 2015, arXiv:1511.06434. [Google Scholar]
  9. Zhu, F.; Ye, F.; Fu, Y.; Liu, Q.; Shen, B. Electrocardiogram generation with a bidirectional LSTM-CNN generative adversarial network. Sci. Rep. 2019, 9, 1–11. [Google Scholar] [CrossRef] [Green Version]
  10. Esteban, C.; Hyland, S.L.; Rätsch, G. Real-Valued (Medical) Time Series Generation with Recurrent Conditional Gans. arXiv 2017, arXiv:1706.02633. [Google Scholar]
  11. Delaney, A.M.; Brophy, E.; Ward, T.E. Synthesis of Realistic ECG using Generative Adversarial Networks. arXiv 2019, arXiv:1909.09150. [Google Scholar]
  12. Patki, N.; Wedge, R.; Veeramachaneni, K. The synthetic data vault. In Proceedings of the 2016 IEEE International Conference on Data Science and Advanced Analytics (DSAA), Montreal, QC, Canada, 17–19 October 2016; pp. 399–410. [Google Scholar]
  13. Campbell, M. Synthetic Data: How AI Is Transitioning From Data Consumer to Data Producer …and Why That’s Important. Computer 2019, 52, 89–91. [Google Scholar] [CrossRef]
  14. Ayala-Rivera, V.; Portillo-Dominguez, A.O.; Murphy, L.; Thorpe, C. COCOA: A synthetic data generator for testing anonymization techniques. In Proceedings of the International Conference on Privacy in Statistical Databases, Dubrovnik, Croatia, 14–16 September 2016; pp. 163–177. [Google Scholar]
  15. Choi, E.; Biswal, S.; Malin, B.; Duke, J.; Stewart, W.F.; Sun, J. Generating Multi-Label Discrete Patient Records Using Generative Adversarial Networks. arXiv 2017, arXiv:1703.06490. [Google Scholar]
  16. Torfi, A.; Beyki, M. Generating Synthetic Healthcare Records Using Convolutional Generative Adversarial Networks. 2019. Available online: http://hdl.handle.net/10919/96186 (accessed on 2 December 2020).
  17. Jordon, J.; Yoon, J.; van der Schaar, M. PATE-GAN: Generating synthetic data with differential privacy guarantees. In Proceedings of the International Conference on Learning Representations, Vancouver, BC, Canada, 30 April–3 May 2018. [Google Scholar]
  18. Narváez, P.; Percybrooks, W.S. Synthesis of Normal Heart Sounds Using Generative Adversarial Networks and Empirical Wavelet Transform. Appl. Sci. 2020, 10, 7003. [Google Scholar] [CrossRef]
  19. Aznan, N.K.N.; Atapour-Abarghouei, A.; Bonner, S.; Connolly, J.D.; Al Moubayed, N.; Breckon, T.P. Simulating brain signals: Creating synthetic eeg data via neural-based generative models for improved ssvep classification. In Proceedings of the 2019 International Joint Conference on Neural Networks (IJCNN), Budapest, Hungary, 14–19 July 2019; pp. 1–8. [Google Scholar]
  20. Hernandez-Matamoros, A.; Fujita, H.; Perez-Meana, H. A novel approach to create synthetic biomedical signals using BiRNN. Inf. Sci. 2020, 541, 218–241. [Google Scholar] [CrossRef]
  21. Goldberger, A.; Amaral, L.; Glass, L.; Hausdorff, J.; Ivanov, P.C.; Mark, R.; Mietus, J.; Moody, G.; Peng, C.; Stanley, H. Components of a new research resource for complex physiologic signals. PhysioBank PhysioToolkit PhysioNet 2000, 101, E215–E220. [Google Scholar]
  22. Moody, G.B.; Mark, R.G. The impact of the MIT-BIH arrhythmia database. IEEE Eng. Med. Biol. Mag. 2001, 20, 45–50. [Google Scholar] [CrossRef] [PubMed]
  23. Detti, P.; Vatti, G.; Zabalo Manrique de Lara, G. EEG Synchronization Analysis for Seizure Prediction: A Study on Data of Noninvasive Recordings. Processes 2020, 8, 846. [Google Scholar] [CrossRef]
  24. Detti, P. Siena Scalp EEG Database (Version 1.0.0), PhysioNet 2020. Available online: https://doi.org/10.13026/5d4a-j060 (accessed on 1 November 2020).
  25. Kemp, B.; Zwinderman, A.H.; Tuk, B.; Kamphuisen, H.A.; Oberye, J.J. Analysis of a sleep-dependent neuronal feedback loop: The slow-wave microcontinuity of the EEG. IEEE Trans. Biomed. Eng. 2000, 47, 1185–1194. [Google Scholar] [CrossRef] [PubMed]
  26. Pimentel, M.A.; Johnson, A.E.; Charlton, P.H.; Birrenkott, D.; Watkinson, P.J.; Tarassenko, L.; Clifton, D.A. Toward a robust estimation of respiratory rate from pulse oximeters. IEEE Trans. Biomed. Eng. 2016, 64, 1914–1923. [Google Scholar] [CrossRef]
  27. Chen, S.W.; Chen, Y.H. Hardware design and implementation of a wavelet de-noising procedure for medical signal preprocessing. Sensors 2015, 15, 26396–26414. [Google Scholar] [CrossRef]
  28. Ali, M.N.; El-Dahshan, E.S.A.; Yahia, A.H. Denoising of heart sound signals using discrete wavelet transform. Circuits Syst. Signal Process. 2017, 36, 4482–4497. [Google Scholar] [CrossRef]
  29. Hernandez-Matamoros, A.; Fujita, H.; Escamilla-Hernandez, E.; Perez-Meana, H.; Nakano-Miyatake, M. Recognition of ECG signals using wavelet based on atomic functions. Biocybern. Biomed. Eng. 2020, 40, 803–814. [Google Scholar] [CrossRef]
  30. Kachuee, M.; Fazeli, S.; Sarrafzadeh, M. Ecg heartbeat classification: A deep transferable representation. In Proceedings of the 2018 IEEE International Conference on Healthcare Informatics (ICHI), New York, NY, USA, 4–7 June 2018; pp. 443–444. [Google Scholar]
  31. Hochreiter, S.; Schmidhuber, J. Long short-term memory. Neural Comput. 1997, 9, 1735–1780. [Google Scholar] [CrossRef] [PubMed]
  32. Fei, H.; Tan, F. Bidirectional grid long short-term memory (bigridlstm): A method to address context-sensitivity and vanishing gradient. Algorithms 2018, 11, 172. [Google Scholar] [CrossRef] [Green Version]
  33. Kalchbrenner, N.; Danihelka, I.; Graves, A. Grid long short-term memory. arXiv 2015, arXiv:1507.01526. [Google Scholar]
  34. Swinscow, T.D.V.; Campbell, M.J. Statistics at Scholar One; BMJ: London, UK, 2002. [Google Scholar]
Figure 1. Overview of the proposed approach.
Figure 1. Overview of the proposed approach.
Biology 09 00441 g001
Figure 2. Discrete Wavelet Transform (DWT).
Figure 2. Discrete Wavelet Transform (DWT).
Biology 09 00441 g002
Figure 3. Inverese Discrete Wavelet Transform (IDWT).
Figure 3. Inverese Discrete Wavelet Transform (IDWT).
Biology 09 00441 g003
Figure 4. Long Short-Term Memory (LSTM) Layout.
Figure 4. Long Short-Term Memory (LSTM) Layout.
Biology 09 00441 g004
Figure 5. Grid Long Short-Term Memory (GridLSTM) Layout.
Figure 5. Grid Long Short-Term Memory (GridLSTM) Layout.
Biology 09 00441 g005
Figure 6. Bidirectional Grid Lon Short-Term Memory (BiGridLSTM) Architecture.
Figure 6. Bidirectional Grid Lon Short-Term Memory (BiGridLSTM) Architecture.
Biology 09 00441 g006
Figure 7. Discriminator Architecture with Convolutional Neural Network.
Figure 7. Discriminator Architecture with Convolutional Neural Network.
Biology 09 00441 g007
Figure 8. Comparison between original and synthetic ECG signals.
Figure 8. Comparison between original and synthetic ECG signals.
Biology 09 00441 g008
Figure 9. Comparison between original and synthetic PPG signals.
Figure 9. Comparison between original and synthetic PPG signals.
Biology 09 00441 g009
Figure 10. Comparison between original and synthetic EEG signals.
Figure 10. Comparison between original and synthetic EEG signals.
Biology 09 00441 g010
Figure 11. Comparison between original and synthetic EMG signals.
Figure 11. Comparison between original and synthetic EMG signals.
Biology 09 00441 g011
Figure 12. Loss for different generators with CNN as the discriminator in the generative adversarial networks (GAN) architecture.
Figure 12. Loss for different generators with CNN as the discriminator in the generative adversarial networks (GAN) architecture.
Biology 09 00441 g012
Figure 13. Loss for different discriminators with BiGridLSTM as the generator in the GAN architecture.
Figure 13. Loss for different discriminators with BiGridLSTM as the generator in the GAN architecture.
Biology 09 00441 g013
Table 1. Performance Comparison for Denoising Techniques.
Table 1. Performance Comparison for Denoising Techniques.
MethodologySNRRMSEPRD
Low Pass Filtering16.346.0117.89
Short-Time Fourier Transform17.216.5618.90
Fast Fourier Transform15.997.1017.34
Wigner-Ville Distribution14.607.8216.51
Least Mean Squares16.916.1116.01
Frequency-Domain Adaptive Filtering17.838.2517.88
Wavelet Transformation19.824.5614.34
Table 2. Representation of Correlation Values.
Table 2. Representation of Correlation Values.
Correlation ValuesRepresentation
0 to 0.3 or 0 to −0.3Negligibly correlated
0.3 to 0.5 or −0.3 to −0.5Low correlation
0.5 to 0.7 or −0.5 to −0.7Moderately correlated
0.7 to 0.9 or −0.7 to −0.9Highly correlated
0.9 to 1 or −0.9 to 1Extensively correlated
Table 3. Statistical Measure for Biomedical Signals.
Table 3. Statistical Measure for Biomedical Signals.
SignalMean Correlation
Coeficient
MAERMSEPRDFD
ECG0.99910.2180.1266.3430.936
EEG0.9970.04750.03145.9850.982
EMG0.91250.05380.05292.9710.921
PPG0.97930.06350.05965.1670.783
Table 4. Evaluation Metric Comparison with Existing Models.
Table 4. Evaluation Metric Comparison with Existing Models.
ModelMAERMSEPRDFD
BiLSTM-GRU0.590.5774.460.95
BiLSTM-CNN GAN0.50.5168.830.89
RNN-AE GAN0.790.76119.340.97
BiRNN0.60.6289.970.96
LSTM-AE0.770.79148.670.99
BiLSTM-MLP0.750.78146.350.99
LSTM-VAE GAN0.710.72144.740.98
RNN-VAE GAN0.710.72145.220.98
BiGridLSTM-CNN0.360.2566.210.79
Table 5. Details of Synthetic Photoplethysmography (PPG) Signals Generated.
Table 5. Details of Synthetic Photoplethysmography (PPG) Signals Generated.
PatientLength of
Signal
Original Signal
Data
Synthetic Signal
Data Generated
Patient 11252020
Patient 263500500
Patient 3711717
Patient 41419292
Patient 51397272
Patient 6401111
Patient 793101101
Patient 868162162
Patient 91171414
Patient 1062700700
Table 6. Details of Synthetic Electroencephalogram (EEG) Signals Generated.
Table 6. Details of Synthetic Electroencephalogram (EEG) Signals Generated.
Length of
Signal
Original Signal
Data
Synthetic Signal
Data Generated
Open-Eye1981008100
Closed-Eye1861736173
Table 7. Details of Synthetic Electromyography (EMG) Signals Generated.
Table 7. Details of Synthetic Electromyography (EMG) Signals Generated.
PatientLength of
Signal
Original Signal
Data
Synthetic Signal
Data Generated
Patient 1787070
Patient 2161111
Patient 343191191
Patient 4215555
Patient 5904141
Patient 61121717
Patient 71435454
Patient 8667171
Patient 91561515
Patient 101911919
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Hazra, D.; Byun, Y.-C. SynSigGAN: Generative Adversarial Networks for Synthetic Biomedical Signal Generation. Biology 2020, 9, 441. https://doi.org/10.3390/biology9120441

AMA Style

Hazra D, Byun Y-C. SynSigGAN: Generative Adversarial Networks for Synthetic Biomedical Signal Generation. Biology. 2020; 9(12):441. https://doi.org/10.3390/biology9120441

Chicago/Turabian Style

Hazra, Debapriya, and Yung-Cheol Byun. 2020. "SynSigGAN: Generative Adversarial Networks for Synthetic Biomedical Signal Generation" Biology 9, no. 12: 441. https://doi.org/10.3390/biology9120441

APA Style

Hazra, D., & Byun, Y. -C. (2020). SynSigGAN: Generative Adversarial Networks for Synthetic Biomedical Signal Generation. Biology, 9(12), 441. https://doi.org/10.3390/biology9120441

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop