This invention relates, generally, to object segmentation and classification within images. More specifically, it relates to improvements in the field of object segmentation and classification through the use of capsule networks and deformable capsules, as opposed to convolutional neural networks, thereby increasing accuracy and efficiency of the segmented and/or classified objects.
The task of segmenting objects from images can be formulated as a joint object recognition and delineation problem. The goal in object recognition is to locate an object's presence in an image, whereas delineation attempts to draw the object's spatial extent and composition (Bagci et al. [2012]). Solving these tasks jointly (or sequentially) results in partitions of non-overlapping, connected regions, homogeneous with respect to some signal characteristics. Object segmentation is an inherently difficult task, apart from recognizing the object, the object must also be labeled at the pixel level, which is an ill-posed problem.
Object segmentation in the medical imaging and computer vision communities has remained an interesting and challenging problem over the past several decades. Early attempts in automated object segmentation were analogous to the if-then-else expert systems of that period, where the compound and sequential application of low-level pixel processing and mathematical models were used to build-up complex rule-based systems of analysis. Over time, the community came to favor supervised techniques, where algorithms were developed using training data to teach systems the optimal decision boundaries in a constructed high-dimensional feature space. In computer vision fields, super-pixels and various sets of feature extractors such as scale-invariant feature transform (SIFT) (Lowe [1]) or histogram of oriented gradients (HOG) (Dalal and Triggs [2]) were used to construct these spaces. Specifically, in medical imaging, methods such as level sets (Vese and Chan [3]), fuzzy connectedness (Udupa and Samarasekera [4]), graph-based (Felzenszwalb and Huttenlocher [5]), random walk (Grady [6]), and atlas-based algorithms (Pham et al. [7]) have been utilized in different application settings.
Object segmentation literature is vast, both before and in the deep learning era. Herein, the most popular deep learning-based segmentation algorithms are summarized. In the last few years, deep learning methods, in particular convolutional neural networks (CNNs), have become the state-of-the-art for various image analysis tasks. For example, based on Fully Convolutional Networks (FCNs) (Long et al. [8]) for semantic segmentation, Ronneberger et al. [9] introduced an alternative CNN-based pixel label prediction algorithm, called U-Net, which forms the backbone of many deep learning-based segmentation methods in medical imaging today. Other encoder-decoder style CNNs have also been proposed, such as Mortazi et al. [10], which have become the desired models for various medical image segmentation tasks.
Following this, many subsequent works follow this encoder-decoder structure, experimenting with dense connections, skip connections, residual blocks, and other types of architectural additions to improve segmentation accuracies for particular medical imaging applications. For instance, a recent example by Jégou et al. [11] combines a U-Net-like structure with the very successful DenseNet (Huang et al. [12]) architecture, creating a densely connected U-Net structure, called Tiramisu. As another example, Mortazi et al. [13] proposed a multi-view CNN, following this encoder-decoder structure and adding a novel loss function, for segmenting the left atrium and proximal pulmonary veins from MRI. Other successful frameworks for segmentation are SegNet (Badrinarayanan et al. [14]), RefineNet (Lin et al. [15]), PSPNet (Zhao et al. [16]), Large Kernel Matters (Peng et al. [17]), ClusterNet (LaLonde et al. [18]), and DeepLab (Chen et al. [19]).
Examples of object segmentation applications in the medical field focus on anatomical and pathological segmentations. Recently, deep learning algorithms have been shown to be generally successful for image segmentation problems. Specific to radiology scans, accurately segmenting anatomical structures and/or pathologies is a continuing concern in clinical practice because even small segmentation errors can cause major problems in disease diagnosis, severity estimation, prognosis, and other clinical evaluations. Despite its importance, accurate segmentation of pathological lungs from CT scans remains extremely challenging due to a wide spectrum of lung abnormalities such as consolidations, ground glass opacities, fibrosis, honeycombing, tree-in-buds, and nodules (Mansoor et al. [20]).
In the field of object classification, leaps forward in progress are in large part due to advances in machine learning algorithms and specifically what has become known as deep learning. One of the first instances of these leaps forward came when AlexNet (Krizhevsky et al. [48]), bested the next closest state-of-the-art method for image classification on the ImageNet Large Scale Visual Recognition Challenge by more than 10.8%. At its core, deep learning owes is great success to its joining of two essential tasks—feature extraction and feature classification, learned in a joint manner, usually through a form of backpropagation. As such, deep learning is a step away from feature engineering, in which experts would hand-craft the most import set of discernible characteristics for a task, whereas classification of these features typically employed some form of machine learning. While this direction has dramatically improved the performance on a wide array of tasks, it has also come at a great cost, the sacrifice of human-level explainability.
Deep learning-based computer-aided diagnosis (CAD) systems have largely failed to be adopted into routine clinical work-flows. Unlike detection tasks, diagnosis (classification) requires radiologists to explain their predictions through the language of high-level visual attributes. For deep learning-powered CAD systems to be adopted by the healthcare industry and other high-risk domains, methods must be developed which can provide this same level of explainability. Towards this goal, a novel multi-task deep capsule-based architecture for learning visually-interpretable feature representations within the vectors of the capsules is proposed. The method can be applied to many computer vision problems, examples of which are described below, and include a high-impact healthcare problem of effective cancer diagnosis.
The CNNs, despite showing remarkable flexibility and performance in a wide range of computer vision tasks, inherently include their own sets of flaws. For example, due to the scalar and additive nature of neurons in CNNs, neurons at any given layer of a network are ambivalent to the spatial relationships of neurons within their kernel of the previous layer, and thus within their effective receptive field of the given input. In addition, most recent attempts in the computer vision and medical imaging literature utilize the extension of these methods to address the segmentation problem. Since the success of deep learning depends on finding an architecture to fit the task, currently several researchers are working on designing new and more complex deep networks to improve the expected outcome. This naturally brings high numbers of hyperparameters to be configured, making the overall network too complex to be optimized.
Recently Sabour et al. [21] introduced the idea of capsule networks, where information at the neuron level is stored as vectors, rather than scalars. These vectors contain information about spatial orientation, magnitude/prevalence, and other attributes of the extracted feature, with the information being represented by each capsule type of that layer. These sets of neurons, henceforth referred to as capsule types, are then “routed” to capsules in the next layer via a dynamic routing algorithm which takes into account the agreement between these capsule vectors, thus forming meaningful part-to-whole relationships not found in standard CNNs. As shown in
Performing object segmentation with a capsule-based network is difficult for a number of reasons. The original capsule network architecture and dynamic routing algorithm is extremely computationally expensive, both in terms of memory and run-time. Additional intermediate representations are needed to store the output of “child” capsules in a given layer while the dynamic routing algorithm determines the coefficients by which these children are routed to the “parent” capsules in the next layer. This dynamic routing takes place between every parent and every possible child. One can think of the additional memory space required as a multiplicative increase of the batch size at a given layer by the number of capsule types at that layer. The number of parameters (i.e. object size and shape, pixel distribution, spatial resolution, signal-to-noise ratios, etc.) required quickly swells beyond control as well, even for trivially small inputs such as MNIST and CIFAR-10. For example, given a set of 32 capsule types with 6×6, 8D-capsules per type, being routed to 10×1, 16D-capsules, the number of parameters for this layer alone is 10×(6×6×32)×16×8=1,474,560 parameters.
Accordingly, what is needed is a more efficient system through which capsule networks can perform object segmentation, thereby decreasing the cost, time, and memory space required to accurately analyze images. However, in view of the art considered as a whole at the time the present invention was made, it was not obvious to those of ordinary skill in the field of this invention how the shortcomings of the prior art could be overcome.
The long-standing but heretofore unfulfilled need for an efficient method of accurately performing object segmentation is now met by a new, useful, and nonobvious invention.
The novel method includes the steps of receiving an input image at a computing device, and passing the input image through a convolutional layer. By passing the image through a convolutional layer, the method produces a plurality of feature maps of spatial dimensions for the input image. The feature maps form a set of children capsules that have an associated set of parameters. The set of parameters and children capsules are then used to create a set of prediction vectors that are locally-constrained within each of the parent capsules' kernels, in an effort to produce locally-accurate predictions for components of the input image. The prediction vectors are used to determine a set of parent capsules that are selected after comparing the prediction vectors—the computing device calculates the likelihood that a certain prediction vector is correct based on the agreement between itself and the other prediction vectors for a given parent capsule. To reduce memory and parameter burden on the computing device, the set of parameters is shared for all children capsules within each capsule type and utilized to ensure accuracy throughout the process. Finally, the input image is reconstructed by using the above information, and via a masked segmentation process. During the masked segmentation process, the prediction vectors associated with the input image are mapped, and all other pixels are treated as background. As such, the method provides for the segmentation of input image components, the accurate prediction of the components based on the prediction vectors, and the reconstruction of the input image after performing the segmentation steps above.
An object of the invention is to decrease the space, time, and monetary costs associated with object segmentation, while increasing the accuracy of object segmentation methods, allowing for a computing device to recognize images in a batch that are similar to an input image.
These and other important objects, advantages, and features of the invention will become clear as this disclosure proceeds.
The invention accordingly comprises the features of construction, combination of elements, and arrangement of parts that will be exemplified in the disclosure set forth hereinafter and the scope of the invention will be indicated in the claims.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee.
For a fuller understanding of the invention, reference should be made to the following detailed description, taken in connection with the accompanying drawings, in which:
In the following detailed description of the preferred embodiments, reference is made to the accompanying drawings, which form a part thereof, and within which are shown by way of illustration specific embodiments by which the invention may be practiced. It is to be understood that other embodiments may be utilized and structural changes may be made without departing from the scope of the invention.
As used in this specification and the appended claims, the singular forms “a,” “an,” and “the” include plural referents unless the content clearly dictates otherwise. As used in this specification and the appended claims, the term “or” is generally employed in its sense including “and/or” unless the context clearly dictates otherwise.
The present invention includes an improved method of performing object segmentation that reduces the memory required to perform the segmentation, while increasing segmentation accuracy. Convolutional neural networks (CNNs) have shown remarkable results over the last several years for a wide range of computer vision tasks. A new architecture recently introduced by Sabour et al. [21], referred to as capsule networks with dynamic routing, has shown great initial results for digit recognition and small image classification. The success of capsule networks lies in their ability to preserve more information about the input by replacing max-pooling layers with convolutional strides and dynamic routing, allowing for preservation of part-whole relationships in the data. This preservation of the input is demonstrated by reconstructing the input from the output capsule vectors. The present invention expands the use of capsule networks to the task of object segmentation for the first time in the literature; extends the idea of convolutional capsules with locally-connected routing and propose the concept of deconvolutional capsules; and extends the masked reconstruction to reconstruct the positive input class. The convolutional-deconvolutional capsule network, referred to as SegCaps, shows strong results for the task of object segmentation with substantial decrease in parameter space.
As illustrated in
At layer , ∃ a set of capsule types ={, , . . . |n∈}. For every ∈, ∃ an × grid of -dimensional child capsules, C={c11, . . . , , . . . , , . . . , }, where × is the spatial dimensions of the output of layer −1. At the next layer of the network, +1, ∃ a set of capsule types +1={, , . . . , |m∈}. And for every ∈, ∃ an × grid of -dimensional parent capsules, P={p11, . . . , , . . . , , . . . , }, where × is the spatial dimensions of the output of layer .
In convolutional capsules, every parent capsule pxy∈P receives a set of “prediction vectors,” {, , . . . , }, one for each capsule type in . Hence, this set is defined as the matrix multiplication between a learned transformation matrix, , and the sub-grid of child capsules outputs, , within a user-defined kernel centered at position (x, y) in layer ; hence, =·, ∈. Therefore, we can see each has shape kh×kw×, where kh×kw are the dimensions of the user-defined kernel. Each has shape kh×kw××||× for all capsule types where || is the number of parent capsule types in layer +1. Each does not depend on the spatial location (x, y), as the same transformation matrix is shared across all spatial locations within a given capsule type (similar to how convolutional kernels scan an input feature map). Conversely, the proposed method can exploit parameter sharing to dramatically cut down on the total number of parameters to be learned. The values of these transformation matrices for each capsule type in a layer are learned via the backpropagation algorithm with a supervised loss function.
To determine the final input to each parent capsule pxy∈P, the weighted sum is computed over these “prediction vectors,” pxy=|xy, where |xy are the routing coefficients determined by the dynamic routing algorithm. These routing coefficients are computed by a “routing softmax,”
whose initial logits, |xy are the log prior probabilities that prediction vector should be routed to parent capsule pxy.
The method differs from the dynamic routing implemented by Sabour et al. [2017] in at least two ways. First, the creation of the prediction vectors is locally constrained. Second, the child capsules are only routed within the user-defined kernel to the parent, rather than routing every single child capsule to every single parent. The output capsule is then computed using a non-linear squashing function,
where vxy is the vector output of the capsule at spatial location (x, y) and pxy is its final input. Lastly, the agreement is measured as the scalar product |xy=vxy·. A final segmentation mask is created by computing the length of the capsule vectors in the final layer and assigning the positive class to those who magnitude is above a threshold, and the negative class otherwise. The pseudocode for this locally constrained dynamic routing is summarized in Algorithm 1, which is depicted in
As a method of regularization, the idea of reconstructing the input is extended to promote a better embedding of the input space. This forces the network to not only retain all necessary information about a given input, but also encourages the network to better represent the full distribution of the input space, rather than focusing only on its most prominent modes. Since the method seeks only to model the distribution of the positive input class and treat all other pixels as background, the method masks out segmentation capsules which do not belong to the positive class and reconstructs a similarly masked version of the input image. The reconstruction is performed via a three layer 1×1 convolutional network, a weighted mean-squared error (MSE) loss computed between only the positive input pixels and this reconstruction.
Experiments were conducted on the LUNA16 subset of the LIDC-IDRI database, randomly split into four training/testing folds for performing k-fold cross-validation. The LUNA16 subset contains a range of lung CT scans from severe to no pathologies present. Ground-truth annotations were provided in the form of segmentation masks created by an automated algorithm (van Rikxoort et al. [22]). Manual inspection led to the removal of 10 of the 888 CT scans due to exceedingly poor annotations. Because of the lack of expert human-annotations, the proposed methods and baselines were observed to typically outperform these ground-truth segmentation masks for particularly difficult scans. This, in turn, lead to higher dice scores for worse performance in those cases, as they typically failed in a similar way. To compensate for such outliers, all numeric results are reported in terms of median rather than mean averages.
U-Net, Tiramisu, the three-layer baseline capsule segmentation network (as shown in
As shown in
As shown in
As shown in
The proposed deep learning algorithm for object segmentation, called SegCaps, showed its efficacy in a challenging problem of pathological lung segmentation from CT scans. The proposed framework is the first use of the recently introduced capsule network architecture and expands it in several significant ways. First, the original dynamic routing algorithm is modified to act locally when routing children capsules to parent capsules and to share transformation matrices across capsules within the same capsule type. These changes dramatically reduce the memory and parameter burden of the original capsule implementation and allows for operating on large image sizes, whereas previous capsule networks were restricted to very small inputs. To compensate for the loss of global information, the concept of a deep convolutional-deconvolutional capsule architecture for pixel level predictions of object labels was introduced. Finally, the masked reconstruction of the target class was extended as a regularization strategy for the segmentation problem. Experimentally, the system produces slightly improved accuracies for lung segmentation on the LUNA16 subset of the LIDC-IDRI database, in terms of dice coefficient, when compared with state-of-the-art networks U-Net (Ronneberger et al. [9]) and Tiramisu (Jégou et al. [11]). More importantly, the proposed system architecture contains 95.4% fewer parameters than U-Net and 38.4% fewer than Tiramisu. The proposed algorithm fundamentally improves the current state-of-the-art object segmentation approaches, and provides strong evidence that capsules can successfully model the spatial relationships of the objects better than traditional CNNs.
Finally, as noted above, a single layer of a typical capsule network system, operating on only 6×6-pixel inputs, may include around 1.5 million parameters: however, in the present invention, the entire deep convolutional-deconvolutional capsule network with local-constrained dynamic routing operates on 512×512-pixel inputs, and includes roughly the same number of parameters in its entire network as that single layer.
Colorectal cancer is one of the leading causes of cancer-related death worldwide, with the majority of colorectal cancer cases arising from precursor legions that are referred to as polyps. These polyps are typically classified into one of three categories: 1) hyperplastic; 2) serrated (comprised of sessile serrated adenomas and traditional serrated adenomas); and 3) adenomas. Hyperplastic polyps are considered benign and can safely be left in situ; however, serrated polyps and adenomas are considered premalignant and should be resected during colonoscopy. Typically, polyp diagnosis and classification is performed by taking a sample and performing a histopathological analysis, commonly referred to as a biopsy. However, biopsies are time-consuming and expensive, and can present perforation and bleeding risks for some patients. As such, it is desirable to provide an optical method of analyzing a polyp to efficiently and safely determine whether a polyp is likely to be benign, or whether the polyp is premalignant or malignant and requires removal.
Attempts have been made to provide colonoscopy screening technologies, including the introduction of narrow-band imaging (NBI), which uses a blue light optical imaging modality to enhance mucosal detail and vascular structures. This improves over traditional white light (WL) endoscopies, which do not highlight or enhance the details provided by NBI methods. However, test accuracies and sensitivities under such methods remain below recommended levels [24-26]. Moreover, current consensus guidelines suggest the removal and pathological evaluation of all visualized polyps; however, such practice is expensive and often unnecessary, presenting risks to the patients while removing some polyps that may not require removal [27]. Accordingly, there is a need for a computer-aided diagnosis (CAD) system to efficiently provide polyp diagnosis during colonoscopy, such as the deep capsule system discussed in detail above. In particular, there is a need to diagnose polyps having a challenging appearance, such as clouded surfaces, irregular shapes, and dark spots.
CAD systems have been used to train data sets for classifying hyperplastic polyps versus adenomas. For example, in [28], 3D shape information from colonoscopy video was extracted using Structure-from-Motion, color, and texture features. Deep learning was incorporated in [29] by extracting the first 3-4 layers of a network trained to classify the extracted deep features. The first end-to-end trained network employed an AlexNet style network trained from scratch with data augmentation to classify polyps as hyperplastic, adenomas, neither, or unsuitable images [30]. The test with the highest accuracy used a pretrained Inceptionv3 network with a new top layer trained to classify hyperplastic polyps from adenomas [31].
The system discussed in Example 1 above was applied to a data set including colorectal polyp images, as shown in
In each capsule layer, there are individual capsules which form a grid. Then, at each layer, there are multiple sets of these grids which form the capsule types. Capsules within a lower layer are referred to as child capsules and in a higher layer being routed to as parent capsules. The locally connected dynamic routing works by forming prediction vectors over a kernel of the child capsules centered at the location of the set of parent capsule types. For every parent capsule at a given (x, y) position, a set of prediction vectors are formed via the multiplication between a locally-defined window and a transformation matrix which is shared across the spatial dimension (but not the capsule type dimension). These transformation matrices act analogous to affine transformation in feature space, allowing for a strong notion of equivariance to input features. Once prediction vectors are formed for a given (x, y) location, and therefore for a set of parent capsules, the modified dynamic routing algorithm then routes all child capsules to all parents capsules only at that given spatial location. One can think of this as sort of “convolutionalized” dynamic routing. By following this method, the size of the images can be dramatically increased beyond the likes of MNIST, CIFAR-10 and smallNORB.
During training, the backpropagation signal updates the weight transformation matrices which form the prediction vectors. The weights used to route these prediction vectors are not learned but are rather a measure of agreement between all child capsules and any given parent capsule. To determine the final input to each parent capsule, after the specified number of routing iterations takes place, wherein a weighted sum is computed by a routing softmax function, a non-linear squashing function is applied. The final output capsule vector is computed by
where vnm is the final input on the last routing iteration.
To make the system more efficient, full-connect capsules were removed in favor of global average pooling. For multi-class classification, we produce a capsule type for each output class. The tensors are then split along the capsule type dimension into individual capsule types. Global average pooling is then performed to reduce the spatial dimension to a flat array of length equal to the length of the final output capsule vector. These vectors are then recombined into an (n×a) tensor where n is the number of classes and a is the vector length of the output. To decide a class score, the magnitude of each vector is computed, where the longest vector is chosen as the prediction. In the case where multiple images of the same polyp were given, the votes for each images are averaged, weighted by the relative confidence of the vote being cast.
Reconstruction of the input is then performed via a dense layer followed by two deconvolutions and a final convolution. The reason for the final convolution is to remove artifacts produced by the upsampling in the previous deconvolution layers. The reconstruction serves the purpose of providing a learned inverse mapping from output to input, in order to help preserve a better approximation of the distribution of the input space. Without the inverse mapping, the network will be prone to only learn the most common modes in the training dataset.
An advantage of the proposed D-Caps architecture is the relatively small number of parameters needed to achieve high performance. The D-Caps architecture shown in
Experiments were performed on a colorectal polyp dataset, referred to herein as Mayo, collected at the Mayo Clinic, Jacksonville by [27] with an institutional review board approval. A total of 552 patients were included in this study with 963 polyps collected. Polyps were collected from both a standard colonoscope and a dual-focus colonoscope. The dual focus colonoscope contains near and far modes for both WL and NBI settings, referred to as WLN, WL-F, NBI-N, and NBI-F. In this dataset, a subset of very challenging cases/images of each polyp type are chosen by expert interpreters (usually just one of each imaging type). Therefore, in terms of images, the Mayo dataset is a very small and challenging dataset. Experiments were conducted using stratified 10-fold cross validation.
Three sets of data experiments were conducted. In the first set, images were split into two categories, hyperplastics and adenomas (with serrated adenomas excluded). In the second set, images were split again into two categories now with serrated adenomas included in the adenoma class. In the third set, images were split between hyperplastics and serrated adenomas with the adenoma images excluded. With 10-fold cross-validation, three sets of experiments, and three models being trained, a total of 90 experiments were conducted. Additionally, another round of experiments was conducted on the hyperplastic vs adenomas with the Mayo dataset while varying the amount of dynamic routing iterations performed inside D-Caps.
All networks were trained and tested on a single Titan X GPU using the Keras and TensorFlow frameworks. For Inceptionv3 trained from scratch, a batch size of 8 was used with the Adam optimizer at its default settings. For Inceptionv3 fine-tuned, the base network layers had their weights frozen and a global average pooling layer was added, followed by a fully-connected layer with 1024 nodes and then a final fully-connected layer with a single output and sigmoid activation. The initial learning rate was lowered to 0:0001 on Adam due to the process starting from trained weights. The batch size was lowered to 4 for the SegCaps method described above. The loss function for all networks was a binary cross-entropy.
The results of the three sets of experiments in presented in Tables 2-5, which appear in
The proposed D-Caps architecture shows strong performance on this particularly challenging colonoscopy imaging data, where D-Caps consistently outperformed Inceptionv3 by a significant margin when both networks were trained from scratch. Although Inceptionv3 was able to achieve slightly high results when pre-trained on ImageNet, it is not unreasonable to suspect D-Caps would see a similar rise in performance if pre-trained. While all CAD methods compared still fall below human expert level diagnosis numbers, the current performance is comparable or above the typical non-expert endoscopists, and further work could be done to improve these numbers more. Furthermore, the D-Caps architecture has been shown to be extremely efficient compared to other deep network architectures for the same diagnosis tasks while maintaining the overall diagnostic accuracy. Overall, the proposed CAD system shows promising accuracy and efficiency for a small but very challenging dataset, wherein automatic differentiation of polyps increases cost-efficiency of the current standards.
The most apparent future work to investigate would be to first localize the polyps before attempting diagnosis, as many times polyps were only a very small portion of the image. This procedure is called ‘detection’. Incorporating a region of interest as a result of detection procedure and conducting the automated diagnosis procedure will highly likely improve the diagnostic rate. One may improve optimization of the network with an automated way (such as deep reinforcement learning or genetic algorithms) instead of empirically and experimentally defined hyperparameters. The capsule network can benefit from such approaches largely because the literature for capsule network, its parameters, and the harmony between its components are subject to extensive investigations and automated optimization algorithms can help filling such knowledge gaps.
Lung cancer is the leading cause of cancer-related deaths in both men and women, and is incurable in the majority of cases due to the advanced stage at the time of most diagnoses. The National Lung Screening Trial (NLST) showed that screening patients with low-dose computed tomography (CT) has reduced lung cancer specific mortality by 20% [32, 33]. Despite this promising increase in screening technology, only 16% of lung cancer cases are diagnosed at an early stage [34]. The reasons behind this low diagnosis rate at an early stage are due to the screening/diagnosis related challenges including (a) high false positive rates, (b) over-diagnosis, and (c) missed tumors during screening [35]. Based on DL models such as 2D and 3D deep convolutional neural networks (CNN), there have been large number of studies conducted to alleviate these challenges [36-46], and such explorations were partially successful and improved both nodule detection and image-based diagnostic rates drastically. Noticeably, a few of them achieved highly successful diagnosis results, comparable to or even better than expert level diagnosis [40]. However, black-box nature of the machine generated results did not help these methods to make their way into clinical routine. In other words, previous studies have failed to demonstrate a link between the machine generated results and its explanation, which can be provided through the capsule-based networks discussed in detail above.
Radiologists typically use six high-level visual attributes for determining the malignancy status of a screen detected nodule: calcification, spiculation, sphericity, lobulation, margin, and texture. Each of these attributes are interpretable and there are moderate to significant associations between malignancy status vs. these attributes. Using the methods described herein, these visual attributes are modelled with capsules. Since radiologists' scores for both malignancy and visual characteristics vary significantly between each other for a given nodule, it is not possible to train the proposed network directly against these scores. Previous works instead train against the mean of the radiologist scores and convert the mean to a binary label (malignant or benign). However, this throws away significant information. In the capsule method, a Gaussian distribution of mean and variance equal to that of the radiologists' scores for a given nodule is used, and the mean squared error between this and the network output is computed for supervised training. In this way, overconfidence by the network on more ambiguous nodules is punished in proportion to radiologists' agreement, and likewise for underconfidence. This additionally provides for the production of classification scores across all five possible score values, rather than simply binary classifications.
The method was trained and tested on the Lung Image Database Consortium and Image Database Resource Initiative (LIDC-IDRI) [47]. In short, radiologists visually labeled a collection of lung nodules with scores ranging from 1-5 across a set of visual characteristics, indicating their relative appearance. These characteristics and scores shown in
The first approach, referred to as explainable capsules, or X-Caps, shown in
The input was also reconstructed as a form of regularization, with the regularization extended to perform a sudo-segmentation. Whereas in segmentation, the goal is to output a binary mask of pixels which belong to the nodule region, in the formulation only the pixels which belong to nodule region are reconstructed, with the remaining pixels being mapped to zero. More specifically,
where LR is the supervised loss for the reconstruction regularization, y is a weighting coefficient for the reconstruction loss, Rx,y is the reconstruction target pixel, Sx,y is the ground-truth segmentation mask value, and Orx,y is the output of the reconstruction network at pixel location (x, y), respectively, and X and Y are the width and height of the input image, respectively. This adds another task to the multitask learning approach and an additional supervisory signal that can help distinguish visual characteristics from background noise. The malignancy prediction score, as well as each of the visual attribute scores, also provide a supervisory signal in the form of
La=ΣnNan∥An−Oan∥, and (6)
Lm=β∥M−Om∥, (7)
where La is the combined loss for the visual attributes, An is the average of the attribute scores given by, at minimum, three radiologists for attribute n, N is the total number of attributes, an is the weighting coefficient places on the nth attribute, Oan is the network prediction for the score of the nth attribute, Lm is the loss for the malignancy score, M is the average of the malignancy scores given by, at minimum, three radiologists, Om is the network prediction for the average malignancy score, and β is the weighting coefficient for the malignancy score. The overall loss of the X-Caps method is thereby
L=Lm+La+LR. (8)
A very deep network structure is shown in
In order to perform classification, using such a deep network, the more memory-intensive fully-connected capsule was replaced with a capsule-based global average pooling (cGAP) algorithm which splits apart capsules by capsule type in a given layer and reforms new capsules as the average of the vectorized activations from the previous layer. More formally, for a given layer li, there exists a set of capsule types C={c1, c2 . . . , cn|∈}. Within each capsule type, there exists a 2D grid of capsule vectors V={v11, . . . , v1,w, . . . vh,1, . . . , vh,w}, where h×w is the spatial dimensions of the capsule type at layer l and each v has dimensions 1×a, where a is the length of the capsule vectors. Parent capsules are formed by computing the average across the spatial grid along each dimension of the capsule vectors, v. Therefore, each child capsule in C has exactly one corresponding parent capsule, where the set of parent capsules is denoted as P={p1, p2, . . . , pm|∈}. For each p in P, we compute the following pi=Σxw Σyhvx,y, where each pi now have dimensions of 1×a. A single overall parent capsule is formed be concatenating each pi to form a 2D vector of dimension m×a. In the case of the DX-Caps method, m is the number of score classes available—in this case, five. The output is then formed by computing the length of each vector in this 2D grid to arrive at a final m value corresponding to the classification prediction.
Using the method, the output is a classification array, rather than a single value, to attempt to regress the score. This provides a better model for the uncertainty present in the labels provided by the radiologists. Rather than simply trying to regress the average of the values submitted by radiologists, or performing binary classification of these values rounded to above or below as score of 3 as done in nearly all previous works, the distribution of scores is predicted. For a given nodule, three radiologists, at minimum, provide score values for each attribute and for malignancy prediction. The mean and standard deviation of those values is computed and fit to a Gaussian function, which is in turn used as the ground-truth for our classification vector. The method allows the modelling of the uncertainty present in the labels in a way that no previous method has allowed. Nodules with strong radiologist agreement produce a sharp peak and wrong or unsure (i.e. low prediction score) answers are severely punished. However, the same is true for low radiologist agreement nodules.
As noted above, the method was tested on the LIDC-IDRI dataset, which includes 1018 volumetric CT scans with a slice thickness varying from 0.45 mm to 5.0 mm. Each CT scan was interpreted by at most four radiologists by the LIDC-IDRI project team. Lung nodules that have diameters equal to or greater than 3.0 mm were given scores by participating radiologists for each of six visual attributes. Visual scores were ranged from 1 to 5 where 1 denoted benign and 5 meant high malignancy. For simplicity, and including malignancy indecision among radiologists, lung nodules were excluded from the consideration when their mean visual score was 3. Hence, this left 1149 lung nodules to be evaluated (646 benign and 503 malignant). Predictions were considered correct if within 1.0 of the radiologists' average score. Table 6 shows the summary of visual score distribution of lung nodules evaluated by at least three radiologists.
Five-fold stratified cross-validation was performed to split the nodules into training and testing sets. Further, 10% of each training set was set aside for validation of the models and early stopping during training. All models were trained using the Adam optimizer method with an initial learning rate of 0:001 while this was dropped by a factor of 10 after validation loss stagnated. All code is implemented in Keras with TensorFlow backend support.
Table 7 demonstrates the prediction of visual attributes with the proposed X-Caps and DX-Caps in comparison with conventional prior art capsule networks. As a result of experiments with 5-fold cross validation settings, we have identified that DXCaps outperformed baseline prior art capsule networks, as well as X-Caps, in predicting individual and overall visual attributes. Experimental results indicate that the global average pooling operation allows creation of deep capsule networks which predict visual attributes better than baseline X-Caps and prior art capsule networks.
It should be noted that the best prediction of visual attributes was obtained when determining sphericity of a nodule. This is not surprising because sphericity is a well-defined visual attribute and has the lowest uncertainty among radiologists' visual scoring compared to other visual attributes which share some similarities with each other and inherent difficulties of finding an appropriate score based on appearance of nodules.
Much of the analysis in deep-learning-assisted medical image diagnosis focuses on improving prediction abilities, rather than explaining decisions made by the methods. The studies that focus on explaining deep-learning models typically focus on visualization of meaningful patterns either at the neuronal level or at the entire network. However, capsule-based networks with interpretable vector representations for anatomical anomalies, such as lung nodules, have not been performed prior to this method. Accordingly, by utilizing the methods discussed herein, image-based disease diagnosis can be performed in a meaningful and accurate way.
While the examples described above discuss locally-constrained routing algorithms, such constrained methods can be expanded beyond small datasets by introducing a method that balances computing efficiency with the ability for a capsule to represent any pose and deformation of an object (i.e. where child capsules can be found in different spatial relationships to one another for the same parent). In such a formulation, global information is not explicitly required, but it does require parent capsules to have more flexibility over the child capsules from which they draw information. The reason for the deformation is that parent capsules must capture common deformations of the objects they represent within their vectors; accordingly, the choice of which children to aggregate information from must be handled in a deformable manner as well. As such, an embodiment of the present invention includes the use of deformable capsules which allow parents to adaptively gather projections from a non-spatially-fixed set of children, and thus effectively and efficiently model objects' poses.
To achieve this overall goal, the same efficient convolutional capsule paradigm as the examples above is followed, in which projection vectors are formed via a convolution operation with a kernel centered on the parent capsules' spatial location; however, an additional set of weights are learned for each parent capsule. These learnable weights are the same shape as each parent's kernel, and represent the offset values for the spatial sampling of child capsules for that parent. Based on the child capsule representation vectors in the previous layer, these weights learn which children a parent capsule should adaptively sample from for a given input image. Dynamic routing then determines how to weight the information coming from each of these children based on their agreement for each projected parent.
For example, given a grid of child capsules of a size H=128 by W=128, including child capsules with ci=32 capsule types of ai=8 atoms each, being routed to a set of cj=10 parent capsule types of aj=16 atoms each, the fully-connected capsules of [21] would require H×W×ci×ai×cj×aj→128×128×32×8×10×16≈671M parameters for this layer alone (assuming the goal is classification, with detection requiring a multiplicative increase by the detection grid size). Instead, using the deformable capsules method described herein with a k2=52 kernel, only 64K parameters are required (2×k×k×ai×cj×aj→2×5×5×8×10×16≈64K). Convolutional capsules with locally-constrained routing require 32K parameters, not needing the additional spatial offsets kernel, but as mentioned above, they are fundamentally limited in the poses and deformations that they can represent. In the experiments, deformable capsules are found to converge faster and to much higher performance than convolutional capsules.
As shown in
As noted above, the original CapsNet by [21] was extremely expensive in computation; as such, a need exists to balance non-rigid deformations of objects while remaining memory efficient. Moreover, for large-scale datasets, such as MS COCO, there is a more significant memory hurdle that capsule networks must overcome when scaling up. Currently, capsule networks represent each class with its own parent capsule vector. On small scale classification datasets (and using deformable routing), this is not an issue, amounting to 2×k×k×ai×cj×aj parameters and N×cq×c1×aj×4 bytes to store the intermediate representations to be routed for the parents, where cj is typically around 10 classes to represent. Assuming 5×5 kernels with 32 input capsule types of 8 atoms per capsule, 10 output capsule types of 16 atoms per capsule, and a batch size of 32, there would be 2×5×5×8×10×16=64K parameters and 32×32×10×16×4=655 KB.
When scaling to object detection, representation for every possible object location must be stored; for MS COCO, 80 possible classes must be represented, resulting in 2×k×k×ai×cj×aj→2×5×5×8×80×16=512K parameters and N×H×W×ci×cj×aj×4 bytes→32×128×128×32×80×16×4=86 GB for the intermediate representations, assuming the output grid of detections is 128×128 with a single detection (i.e., bounding box) predicted per class per location. Similarly, large-scale classification datasets, such as ImageNet, suffer computationally as well, with 1000 classes that require 2×5×5×8×1000×16=6.4M parameters and 32×32×1000×16×4≈66 GB for the intermediate representations, despite losing the grid of predictions. Most GPU memories are limited to 12-64 GB, rendering such larger-scale datasets difficult to classify under the prior art.
Accordingly, herein the capsule architecture SplitCaps is used to more efficiently scale capsule networks to large-scale computer vision tasks, including two parent capsule types, each with a different number of atoms per capsule, for each location of the detection grid. In SplitCaps, the two parent capsule types are as follows: a first capsule type that learns the instantiation parameters necessary to model the possible variations of an object (class-agnostic instantiation capsules), and a second capsule type that predicts which classes of objects are present in a given input (class presence capsules).
The class-agnostic object instantiation capsules model the possible variations (in pose, deformation, texture, etc.) of objects within a vector of instantiation parameters, the span of which should cover all possible variations for that object at test (hence why capsules are better than CNNs at generalizing to unseen poses). While previous capsule networks did this in a class-wise manner, such a formulation is not required and is redundant. Many variations (e.g., rotation, skew, stroke thickness) may be class-independent, and thus to model these variations class-wise would require repetition across each capsule type. Instead, all classes within a single capsule type are modeled (i.e., class-agnostic). In this way, while class-dependent variations would each require their own dimensions of the vector, class-independent variations can each be modeled along a single dimension for all possible objects. Assuming there will be at least some class-specific variations, the default vector dimension is increased from 16 to 64 to accommodate for possible class-specific instantiation parameters.
During training, if an object is present at a given spatial location, the 64-dimensional capsule vector for that location is fed to a reconstruction regularization sub-network to construct the mask of that object as similar to the reconstruction regularization used by [21] for classification. The sub-network is a relatively small and fast addition: a set of three ReLU-activated 1×1 convolutional layers with 256 filters each, followed by a final sigmoid-activated 1×1 convolution with N=n2=282=784 filters, before reshaping outputs to n×n. Since objects' scales vary dramatically, all objects' ground-truth masks are scale normalized to be 28×28. Supervised training is conducted by computing the Dice loss between the predicted reconstruction (r) and the object's mask (m):
where is used to provide a regularization signal to the instantiation parameters being learned.
The class presence capsules attempt to model which classes of objects are present in the input at each spatial location, if any. This is accomplished by setting the atoms per capsule to the number of classes being represented (i.e., 80 for MS COCO). Just as Hinton et al. (2018) separately modeled pose (with a matrix) and activation (with a scalar), this 80-dimensional vector can be viewed as a class-dependent set of activation values. The activation values are then passed through a sigmoid function and thresholded; if one or more activation values are above the threshold, an object is determined to be at that spatial location with the strongest activated dimension determining the class label.
To produce a smooth loss function during training, a ground-truth heatmap is created by fitting a Gaussian distribution, as opposed to a single point, to the center-point of each object's bounding box, with variance proportional to the size of the box. More specifically, the heatmap
containing each down-scaled ground truth center-point
for each class k∈K using a Gaussian kernel
where d is the amount of downsampling and σp is an object-size-adaptive derivation. In the case of overlapping Gaussians, the element-wise maximum is used. To handle the large class imbalance between objects and backgrounds in the heatmaps, a penalty-reduced pixel-wise logistic regression with a focal loss is used:
where α, β are hyper-parameters of the focal loss, and P is the number of center-points in the input, used to normalize all positive focal loss instances to 1. In experiments related to the method, α=2 and β=4 were used; in addition, a 3×3 max-pooling was run over the thresholded spatial map to retrieve the object's exact center.
To predict the height and width of the bounding boxes of objects and recover the x, y offsets needed to map back to the upscaled image dimensions, the same formulation as [50] was followed and the backbone features were passed through a 3×3 convolutional layer with 256 feature maps, then a 1×1 convolutional layer with 2 feature maps. These layers predict the local offset,
and size prediction,
for each center-point and are supervised by;
respectively. The final objective function is thus defined as =h+λrr+λSS+λOO. The parameter λS is maintained at 0.1, the parameter λO is maintained at 1, and the parameter λr is set to 0.1 initially and stepped up to 2.0 at the half-way mark during training.
As a core component of capsule networks, dynamic routing seeks to maximize the agreement between child capsule projections for parent capsules and to fully-leverage the richer representations being stored. Since SplitCaps introduces a unique capsule head structure, where instantiation parameters and activations are split across different capsule types, previous dynamic routing algorithms can no longer be directly applied. To overcome this, a new dynamic routing algorithm is used that takes inspiration from Squeeze-and-Excitation networks [51], referred to as SE-Routing, as shown in
Previously proposed dynamic routing algorithms were typically iterative, requiring a hand-tuned loop of routing iterations, which proved to be slow and temperamental in practice. Different studies found different numbers of iterations to be effective, and one meta-study of five different iterative dynamic routing algorithms found them all to be largely ineffective [52]. To avoid this pitfall, the new routing algorithm dynamically assigns weights to child capsule projections based on their agreement, computed in a single forward pass using a simple gating mechanism with sigmoid activation. Unlike [21], which uses a routing softmax to force a one-hot mapping of information from each child to parents, SE-Routing learns a non-mutually-exclusive relationship between children and parents to allow multiple children to be emphasized for each parent.
To create child capsule projection descriptors, following the Squeeze-and-Excitation paradigm, the squeeze must be computed (i.e., a set of descriptors which summarize relevant information about each feature) to create a set of child capsule projection descriptors. To accomplish the goal to maximize the agreement between child projections, for both the instantiation parameters and class presence of the object being modeled, three separate descriptors are computed which are fed into the excitation phase of the routing: (i) cosine angle between the mean projection vector and each child's projection, which captures object instantiation agreement; (ii) Kullback-Leibler (KL) divergence of each child's predicted class distribution and an aggregated distribution, which captures class presence agreement; and (iii) variance of each child's predicted class distribution, which captures class presence uncertainty.
The cosine angle descriptor, a, is calculated in a similar manner to [21]. A mean projection vector, ũ={ũ1, ũ2 . . . , ũN}. Then, a set of cosine angles between each individual projection and the mean are computed, ũ={a1, a2 . . . , aN}, where ai=(ũ·ũi)/(|ũ|·|ũi|).
Similarly, a KL divergence descriptor, b, is calculated by first creating an aggregate object class distribution, with each child capsule type treated as an expert giving its prediction about the true underlying class distribution. A simple linear opinion pool is computed, p({tilde over (z)})=ΣiN σs(zi)/N, where p({tilde over (z)}) is the aggregated probability distribution, Z={z1, z2 . . . zN} is the set of child class presence projection vectors, and σs(zi)j=ez
Last, the variance of the child capsules' prediction distributions, σs(zi), is calculated to estimate the uncertainty of each child: ci=ΣkK(σs(zi)k−ΣkK σs(zi)k)2. The three sets of descriptors are efficiently computed for all capsules simultaneously (i.e., for the entire batch and across spatial locations) on GPU in parallel with matrix operations, and are then concatenated, s=a⊕b⊕c, and fed to the excitation layers of the routing mechanism shown in
The excitation stage of the SE-Routing algorithm has the task of learning a mapping from the concatenated set of capsule descriptors, s, into a set of routing coefficients for the child capsule projections. Since parents capsule types are no longer different classes in the formulation, but rather two separated aspects of modeling objects, a single set of routing coefficients is computed at each spatial location for both parents. Formally, the mapping is computed as r=σ(W2δ(W1s)), where
δ is the ReLU activation function, a is the sigmoid activation function, and t is the reduction ratio used to form the mapping into a two fully-connected (FC) layer bottleneck.
Finally, with the determined routing coefficients r={r1, r2 . . . rN}, the output of the SplitCaps detection head can be computed. Projection vectors from each child to each parent are computed using the proposed deformable capsules, as described above. These projections are then combined and weighted by the routing coefficients to form the final parent capsules. The final parent capsules contain the instantiation parameters, vobj=ΣiN riûobj|i, and class presence, vcis=ΣiN riûcis|i, of any objects being represented at the given spatial location within the detection grid.
The deformable capsule object detection framework on the MS COCO dataset ([53]), which contains 118K training, 5K validation and 20K hold-out testing images. Average precision (AP) is reported over all IOU thresholds and at thresholds 0.5 (AP50) and 0.75 (AP75). The training procedure of [49] was followed, training on 512×512 pixel inputs, yielding 128×128 detection grids, using random flip, random scaling (between 0.6 to 1.3), cropping, and color jittering as data augmentation, and Adam optimization ([23]) to optimize the objective function. Due to limited compute resources, the backbone network weights were initialized from CenterNet and only trained for 40 epochs with a batch size of 12 and learning rate of 5e-4 with 5×drops at 5, 15, and 25 epochs; it should be appreciated that longer training would likely yield superior results.
As shown in
All referenced publications are incorporated herein by reference in their entirety. Furthermore, where a definition or use of a term in a reference, which is incorporated by reference herein, is inconsistent or contrary to the definition of that term provided herein, the definition of that term provided herein applies and the definition of that term in the reference does not apply.
While certain aspects of conventional technologies have been discussed to facilitate disclosure of the invention, Applicants in no way disclaim these technical aspects, and it is contemplated that the claimed invention may encompass one or more of the conventional technical aspects discussed herein.
The present invention may address one or more of the problems and deficiencies of the prior art discussed above. However, it is contemplated that the invention may prove useful in addressing other problems and deficiencies in a number of technical areas. Therefore, the claimed invention should not necessarily be construed as limited to addressing any of the particular problems or deficiencies discussed herein.
In this specification, where a document, act or item of knowledge is referred to or discussed, this reference or discussion is not an admission that the document, act or item of knowledge or any combination thereof was at the priority date, publicly available, known to the public, part of common general knowledge, or otherwise constitutes prior art under the applicable statutory provisions; or is known to be relevant to an attempt to solve any problem with which this specification is concerned.
This nonprovisional application is a continuation-in-part of and claims priority to nonprovisional application Ser. No. 16/431,387, entitled “Capsules for image analysis,” filed on Jun. 4, 2019, which is a continuation of and claims priority to provisional application No. 62/680,411, entitled “Capsules for object segmentation,” filed on Jun. 4, 2018, each of which sharing inventorship with this nonprovisional application, and each of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
20160037082 | Wang | Feb 2016 | A1 |
20180276497 | Madabhushi | Sep 2018 | A1 |
20180276498 | Madabhushi | Sep 2018 | A1 |
20190303742 | Bonnell | Oct 2019 | A1 |
20210097377 | Wang | Apr 2021 | A1 |
Entry |
---|
Long et al., Fully convolutional networks for semantic segmentation. Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR). 2015: 3431-3440. |
Huang et al., Densely connected convolutional networks. Proceedings of the IEEE Computer Vision and Pattern Recognition (CVPR) 2017: 4700-4703. |
Rikxoort et al., Automatic lung segmentation from thoracic computed tomography scans using a hybrid approach with error detection. Medical physics. 2009. vol. 36 (No. 7): 2934-2947. |
Kingma and BA. Adam: A method for stochastic optimization. 3rd International Conference for Learning Representations (ICLR 2015). 2015: 1-15. |
Kuiper et al., Accuracy for optical diagnosis of small colorectal polyps in nonacademic settings. Clinical Gastroenterology and Hepatology. 2012. vol. 10:1016-20. |
Ladabaum et al., Real-time optical biopsy of colon polyps with narrow band imaging in community practice does not yet meet key thresholds for clinical decisions. Gastroenterology. 2013. vol. 144: 81-91. |
Rees et al., Narrow band imaging optical diagnosis of small colorectal polyps in routine clinical practice: the detect inspect characterize resect and discard 2 (discard 2) study. Gut. 2017. vol. 66: 887-895. |
Wallace et al., Accuracy of in vivo colorectal polyp discrimination by using dual-focus high-definition narrow-band imaging colonoscopy. Gastrointestinal Endoscopy. 2014. vol. 80 (No. 6): 1072-1087. |
Mesejo et al., Computer-aided classification of gastrointestinal lesions in regular colonoscopy. IEEE Transactions on Medical Imaging. 2016. vol. 35 (No. 9): 2051-2063. |
Shin et al., Deep convolutional neural networks for computer-aided detection: CNN architectures, dataset characteristics and transfer learning. IEEE transactions on medical imaging. 2016. vol. 35 (No. 5): 1285-1298. |
Setio et al. Validation, comparison, and combination of algorithms for automatic detection of pulmonary nodules in computed tomography images: the luna16 challenge Medical image analysis 2017. vol. 42: 1-13. |
Setio et al. Pulmonary nodule detection in CT images: false positive reduction using multi-view convolutional networks. IEEE transactions on medical imaging. 2016. vol. 35 (No. 5): 1160-1169. |
Huang et al., Lung nodule detection in CT using 3d convolutional neural networks. 2017 IEEE 14th International Symposium on Biomedical Imaging. 2017: 379-383. |
Ding et al., Accurate pulmonary nodule detection in computed tomography images using deep convolutional neural networks. International Conference on Medical Image Computing and Computer-Assisted Intervention. 2017: 559-567. |
Dou et al., Multilevel contextual 3-d CNNs for false positive reduction in pulmonary nodule detection. IEEE Transactions on Biomedical Engineering. 2017. vol. 64 (No. 7): 1558-1567. |
Zhou et al., Objects as points. 2019. arXiv preprint arXiv: 1904.07850v2: 1-12. |
Yu et al., Deep layer aggregation. Proceedings of the IEEE conference on computer vision and pattern recognition: 2019: 2403-2412. |
Hu et al., Squeeze-and-excitation networks. Proceedings of the IFFF conference on computer vision and pattern recognition (CVPR). 2018: 7132-7141. |
Paik et al., Capsule networks need an improved routing algorithm. Proceedings of Machine Learning Research (ACML). 2019. vol. 101: 489-502. |
Number | Date | Country | |
---|---|---|---|
20210279881 A1 | Sep 2021 | US |
Number | Date | Country | |
---|---|---|---|
62680411 | Jun 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16431387 | Jun 2019 | US |
Child | 17302800 | US |