The present invention relates to a method and an apparatus for displaying gene expression patterns resulting from hybridization with a specific gene at certain time points in a display format (or an output format) that displays the patterns in a visually apprehensible manner so that the functions and roles of the genes can easily be studied.
With the increase in the number of species that have been determined of their genome sequences, so called genome comparison has extensively been performed. Genome comparison aims at finding something based on gene difference among species, for example, finding genes involved in evolution, finding a collection of genes which are considered to be common to all species, or conversely studying the nature unique to specific species.
The recent development of infrastructures such as DNA chips and DNA microarrays has changed the interest in the art of molecular biology from information of interspecies to information of intraspecies, namely coexpression analysis, and broadened the study covering from extraction of information to correlation of information, including the conventional comparison between species.
For example, if an unknown gene has an expression pattern identical to that of a known gene, the unknown gene can be assumed to have a similar function to that of the known gene. Such functional meanings of genes and proteins are studied as function units or function groups. The interactions between the function units or function groups are also analyzed by correlating with known enzymatic reaction data or metabolism data, or more directly, by knocking out or overreacting a specific gene to eliminate or accelerate expression of the gene to study the direct and indirect influences on the gene expression patterns of the whole collection of genes.
One successful case in this art field is the expression analysis of yeast by the group of P. Brown from the Stanford University (Michel B. Eisen et al., Clustering analysis and display of genome-wide expression patterns, Proc. Natl. Acad. Sci. (1998), Dec 8; 95(25): 14863-8). They hybridized genes with a gene extracted from a cell in a time series using a DNA microarray and numerated the expression levels thereof (i.e., numerated the brightness of the hybridized fluorescent signals). By converting the values into colors, the expression pattern of each gene can be displayed in a visually apprehensible manner. At this point, genes that have a similar expression pattern during their gene cycles (genes having closer expression levels at the same point) are clustered together.
The above-described displaying method allows a supposition that genes belonging to the same cluster may possibly share common functional characteristics.
With the gene expression patterns, however, it is not so simple as to elucidate the relationship among all of the genes in a cell by finding some gene groups having similar expression patterns for the entire cell cycle.
For example, different genes may exhibit similar expression for having similar function at a certain time point. However, they may have different roles at other time point, at which point, of course, the expressions are different. According to the conventional method in which similar expression patterns are clustered together over the entire cell cycle, these genes are classified into different clusters. Therefore, it is difficult to find the above-mentioned characteristics.
In an actual analysis of gene expression patterns, enormous amount of data will be subjected to clustering as shown in
The thus-obtained dendrogram 2602 represents the precise course of joining the most similar clusters. However, it is difficult for the user to find out how many clusters have briefly been classified by looking at this display to judge and guess the groupings of the genes.
It would be useful for the user if the system can suggest the possible cases of the number of the clustering groups so that the user can select the most suitable clustering level. Specifically, data are automatically calculated into groups for various levels of clustering (e.g., 7, 28, 105 and 372 clusters) so that the user may be able to study the grouping of the genes by selecting, from the menu of clustering levels, the suitable results of grouping closer to the desirable level of clustering.
The present invention has an objective of solving such conventional art problems by providing a method and an apparatus for effectively displaying gene expression patterns by finding different genes exhibiting similar expression for having the same function at one time point but having different roles at a different time point.
The present invention also has an objective of providing a method and an apparatus for displaying gene expression patterns by automatically extracting brief groupings of clusters from the results of clustering so that a user can select a desirable level of the grouping for more comprehensible display to study the groupings of the genes. In other words, the present invention has an objective of providing a method and an apparatus for effectively displaying gene expression patterns by providing multiple selectable clustering levels.
In order to achieve the above-described objectives, the present invention provides a method for displaying gene expression pattern for visually displaying time sequential expression patterns of multiple genes whose expressions change according to experiment cases where a first axis represents the genes and a second axis represents the experiment cases, the method comprising the steps of: designating a segment along the second axis in the expression pattern data of the multiple genes; and clustering the expression pattern data within the designated segment along the second axis based on a predetermined reference value, repeating clustering within the same cluster in a forward or reverse direction along the second axis while changing the reference value, and displaying the results according to a predetermined display format.
The reference value refers to value for determining whether expression patterns of distinct genes are the same or different.
Furthermore, the present invention displays two or more different genes according to the predetermined display format where they have the same expression pattern at the beginning but become to have different expression patterns within the segment along the second axis.
The present invention also displays two or more different genes according to the predetermined display format where they have different expression patterns at the beginning but become to have the same expression pattern within the segment along the second axis.
The experiment cases may be time sequential experiments, states of individual's tissue, species of individuals, individual's sites, or presence and absence of an artificial condition. Alternatively, the experiment cases may be combinations of some of the group consisting of time sequential experiments, states of individuals tissue, species of individuals, individual's sites, and presence and absence of an artificial condition.
The present invention is also an apparatus for analyzing gene expression patterns, which acquires, from a database, expression pattern data of multiple genes whose expressions change according to experiment cases, and which visually displays the expression patterns on a screen of a display device where a first axis represents the genes and a second axis represents the experiment cases, the apparatus comprising:
In order to achieve the above-described objectives, the present invention comprises a step of displaying a round number of the cluster groups for each clustering phase taking a recognition error range in consideration, for the results of the clustering analysis of the gene expression pattern data.
For example, the results of the analysis at multiple phases are stored regardless of the recognition error range input by a user so that the user can choose the briefness of the analysis results to be displayed from multiple phases presented.
In displaying the results, a phase scale bar and a dendrogram cross-cutting line are provided for selecting the phase from the multiple phases. The user can select a specific result at a desirable phase by moving the dendrogram cross-cutting line on the phase scale bar. Upon moving the dendrogram cross-cutting line on the phase scale bar, the number of gene groups (clusters) at that phase. Moreover, dividing lines for distinguishing the gene groups at that phase are displayed, and the gene groups of a predetermined size are specified.
This specification includes part or all of the contents as disclosed in the specifications and/or drawings of Japanese Patent Applications Nos. 11-277918 and 2000-88695 which are priority documents of the present invention.
Hereinafter, the present invention will be described in more detail with reference to the accompanying drawings. In the following example, time sequential experiments are exemplified as typical experiment cases.
An alternative embodiment is configured such that the data of gene expression patterns is acquired from, instead of the storage medium 101, database supervised by a remotely provided server computer via a network or the like.
According to this embodiment, a time segment is designated among the cell cycle to perform clustering within this time segment in a small range.
Specifically, genes belonging to the same cluster are gathered together and a dividing line is drawn between distinctive clusters. Clustering is further performed for the genes belonging to the same cluster. As shown in
In other words, the expression patterns within the clustering-applied region are arranged that they have the same expression levels at the beginning but become different at some point in the time segment. When such a display is obtained, it can be assumed that different genes exhibited similar expressions at the beginning for having the same function, but became to give different expressions at some time point for having different roles.
Similarly, when small-range clustering is performed from the end of the clustering-applied region in reverse time direction, the gene expression patterns may be arranged into a reverse-tree structure as shown in
This display indicates expression patterns that are different at the beginning of the region but become the same at some point in the time segment. It can be assumed that, in this case, different genes have different functions at the beginning but at some time point become to have similar roles.
First, initial parameters are set (Step 401) and a display area is determined (Step 402). The initial parameters will be described later in more detail. Then, displaying process is performed (Step 403), whereby the whole processing is ended. The present algorithm is for displaying expression patterns of different genes which at the beginning are the same but becomes different at some time point (
First, data of gene expression patterns are read out from the storage medium 101. As shown in
Then, the keyboard 103 and the mouse 104 are used to input a clustering-applied region (starting time Tstart and ending time Tend), positive values (Kstart, Kstart+1, . . . Kend) as reference values for distinguishing clusters, an integer (S) indicating a range of clustering, and the methods of clustering (Step 602).
The solid lines 201 in
The reference value for distinction between different clusters is a minimum value, namely threshold K, of dissimilarity between the clusters. Since thresholds can variably be set as Kstart, Kstart+1, . . . , Kend, the level of clustering may be regulated to be brief or detailed along the time axis.
The present system does not target the entire expression data obtained at time T0, T1, . . . Tn for calculating dissimilarity for clustering, but selects a certain time segment to target data within that time segment for calculating dissimilarity. As shown in
In the clustering process, the similarity or dissimilarity which indicates correlation between the genes upon clustering (Pearson's correlation coefficient, squared Euclidean distance, standardized squared Euclidean distance, Mahalanobis' distance, Minkowsky distance, etc.) and algorithm for joining the clusters (nearest neighbor method, furthest neighbor method, group average method, centroid method, median method, Ward method, flexible method, etc.) are designated. The present algorithm utilizes dissimilarity. When similarity is selected for clustering, a minus sign may be applied in front of the calculated similarity to give an inverse number as for conversion to dissimilarity.
Once these values are set, each item is checked whether it is proper or not. The items are (i) whether the clustering-applied region Tstart to Tend is included in the region T0 to Tn (Step 603), (ii) whether the clustering range S is within the width of the clustering-applied region (S≦end-start) (Step 604), and (iii) whether the similarity or dissimilarity complies with the algorithm of the selected clustering method (for example, when centroid method, median method or Ward method is employed as the algorithm, squared Euclidean distance should be selected) (Step 606). If any of these values is not proper, an error signal is output to the display device 102 to demand re-entering (Step 607).
When all of the set items are confirmed proper, an average level Gi=(g[0] [i]+g[1] [i]+ . . . g[n] [i])/n) of expressions of a gene gi (where i=1, 2, . . . m) is calculated (Step 608).
In order to store display information of each gene, an array l[I] (I=0, 1, . . . m) 502 (
The present algorithm employs an abstract data type called “cluster” which indicates set of integers. A cluster has an interface for registration and deletion of an integer and for reference of the registered data.
Finally, cluster B is generated to which {0, 1, 2, . . . m} is registered (Step 612), whereby the whole process is ended.
After the above-described initialization, the clustering- applied region 201 is processed. Specifically, the display area is determined by using t and B set above as arguments (Process A in Step 402 of
First, let the given cluster and time be B and t, respectively, as arguments (Step 701). Then, B is subjected to clustering (Process B) where t and B are given as arguments. As a result of Process B, the total number of the clusters and the clustering results are set to cmax and A[J](J=1, 2, . . . , cmax), respectively (Step 702). Details of Process B will be described later.
Then, whether “t+S” equals “end” is judged (Step 703). When they are equal, it means that the end of the slit 501 has reached the end of the clustering-applied region 201, whereby the clustering process is ended. The following process is executed for each cluster until J exceeds cmax (starting from J=1) (Steps 704 and 705). Where the elements of cluster A[J] are {il, . . . , ik} these elements are aligned and displayed under a certain rule. Here, the average of the expression levels Gil, . . . . Gik corresponding to the elements are aligned in a descending order to be rearranged as Gjl, . . . Gjk (Step 706).
Then the value for array l is entered. Specifically, “l[ ].index” which indicates the positional information of the expression pattern data is set as l[lmax].index=j1, l[lmax+1].index=j2, . . . , l [lmax+k−1].index=jk such that they are arranged in a descending order according to their average brightness (Step 707). The value “t” is entered into “l[lmax+k−1].linepos” which indicates the line for dividing distinctive clusters (a solid line 202 extending in horizontal direction is representatively shown in
Next, k is added to lmax for indicating the maximum number of the already entered data of array l (Step 709). Then, J is incremented to perform the next clustering (Step 710).
On the other hand, when “t+S” does not equal “end” (i.e., when the end of the slit 501 does not reach the end of the clustering-applied region 201) at Step 703, t is incremented and J is set to “1” (Step 711). The following procedure is performed for each cluster until J exceeds cmax (Step 712). Specifically, A[J] is substituted for B (Step 713), and the display area is determined using time t and cluster B as arguments (Process A) (Step 714). Then, the value “t” is entered into “l[lmax−1].linepos” which indicates a line for dividing distinctive clusters from time “t” to “Tend” (Step 715). Then, J is incremented to perform the next clustering (Step 716). If the procedure is finished for all clusters A[J] (J=1, . . . , cmax), the process is ended.
First, the entered cluster and time are used as arguments B and t, respectively (Step 801).
Then, where the elements of cluster B are i1, . . . , ik, similarity or dissimilarity dij (i<j and i,j∈{i1, i2, . . . , ik}) between genes corresponding to i1, . . . , ik from time t to time t+S is calculated (Step 802).
The similarity (dissimilarity) of gene expression data {g [0] [i], g [1] [i], . . . , g [n] [i]} of genes gi, gj is a value obtained, for example, by the following calculation (Step 802).
(1) When Pearson's correlation coefficient is designated as similarity,
Since the present algorithm targets dissimilarity, the obtained similarity has to be converted to dissimilarity by providing with a minus sign to give an inverse number.
(2) When squared Euclidean distance is designated as dissimilarity,
(3) When standardized squared Euclidean distance is designated,
(4) When Mahalanobis' distance is designated,
di,j=t(g[i]−g[j])S−1(g[i]−g[i]) (4)
(5) When Minkowsky distance is designated,
Then, clusters C[l], . . . , C[k] are generated which are registered as C[l]←{i1}, . . . , C[k]←{i2} (Step 803) Variable ccnt indicating the number of the generated clusters is substituted with k (Step 804). Then, a null set of cluster D is generated (Step 805).
Then the minimum value dp,q of the calculated dissimilarity di,j (i,j∈{1, 2, . . . , ccnt}−D) is obtained to judge whether it is less than the preset threshold Kt (Steps 806 and 807). When dp,q is less than Kt, the following procedure takes place. Cluster C[ccnt+1] is newly generated. A sum set of elements contained in clusters C[p] and C[q] is registered into cluster C[ccnt+1] (Step 808) and the elements are deleted (Step 809). Since C[p] and C[q] are no longer necessary, p,q are registered into D (Step 810). Then, dissimilarity dh,ccnt+1 between cluster C[h] (h ∈{1, 2, . . . , ccnt}−D) and cluster C[ccnt+1] from time t to time t+S is obtained (Step 811). dh,ccnt+1 can be obtained by the following calculation, where when n(k) is the number of elements in cluster C[k] and:
Then, “1” is added to the variable ccnt indicating the number of the generated clusters (Step 812). The above-described procedure is repeated until the minimum value of updated dij (i,j∈{1, 2, . . . ccnt}−D) exceeds Kt.
When the minimum value dp,q of di,j exceeds Kt at Step 807, clustering is finished and the results are output. First, clusters which do not contain a null set are judged and determined among clusters C[1] to C[ccnt] and the total number thereof is entered as cmax (Step 813). Then, cmax number of clusters A[1], . . . , A[cmax] are generated (Step 814). Average expression levels of genes contained in the clusters without a null set are calculated, that is, to obtain G′p=(Gil+ . . . +Gi,k)/k for clusters C[p]=il, . . . , il. Where the obtained values sequentially aligned in a descending order are G′p1, . . . G′pcma, A[1], . . . A[cmax] are registered as C[p1], . . . C[pcmax] (Step 815). Finally, the total cluster number cmax and clusters A[1], . . . , A[cmax] are output (Step 816), thereby ending the whole process.
First, let value i be “0” (Step 1000) and repeat the following procedure for each gene expression data until value i equals lmax (Step 1001). Then, the values of expression data g[k] [x] (k=0, 1, . . . , n) corresponding to a single row of a gene indicated by x=l[i].index is converted to correlating display colors to be displayed as an ith row (Step 1002). The dividing line between the clusters is drawn immediately below the just displayed ith row from time [i].linepos to Tend (Step 1003).
Where l[i].linepos is initial value Tend, there is no need of drawing a dividing line between the clusters. i is incremented for 1 (Step 1004) and the entire procedure is ended when i becomes lmax at Step 1001.
By the above-described process, expression patterns of different genes can effectively be displayed such that the patterns are arranged to be the same at the beginning of the clustering- applied region and become different at some time point in the region, as shown in
On the other hand, gene expression patterns of different genes can effectively be displayed such that the patterns are arranged to be different at the beginning of a clustering-applied region and become the same at some time point in the region, as shown in
Hereinafter, an exemplary application of such clustering method will be described, where clustering is performed by shifting the slit from the beginning of the clustering-applied region in a forward direction along the time axis to give a display shown in
Furthermore, where Tstart, Tend and slit width S are set to T0, Tn and n, respectively, the same display as that of the result of P. Brown et al. mentioned in the Background of the Invention can be obtained.
The present example is not limited to the above description, and details can be modified upon practice. For example, the boundary where the expression pattern changes can be displayed with a combination of known display formats, such as a flicker display, a bright display and a color reversion display.
The processing by the clustering processor 105 can be stored as a program in a storage medium (e.g., CD-ROM) to be provided to a user of a computer.
The data of genes is not limited to time sequential expression data, and the horizontal axis (time axis) shown in
Other than comparing difference between states at different time points or between states of tissues, comparison can be made for difference between species such as human and yeast, difference between sites of individual such as stomach, large intestine and heart, difference of expression patterns obtained upon electric shock, shock by high temperature or shock by low temperature, difference between presence and absence of an artificial condition, for example, expression patterns before and after drug administration, or difference of a combination thereof.
Hereinafter, another embodiment of the invention will be described.
The display shown in
In
A dividing line 1304 is drawn on the gene expression pattern data 1300 and the resulting gene groups A, B and C are specified (by a gene group-specifying marks 1305).
The leaf-type cluster structure 1501 corresponds to expression pattern data of each gene (i.e., each array data of
The node-type cluster structure 1502 is sequentially generated upon the joining process during clustering. The two clusters prior to joining can be reached based on the values of the left member and the right member, and the distance therebetween is stored as a value of the distance member. The level of the cluster is set considering a value of a recognition error range (e.g., 5).
Each interval structure 1701 has members such as num_clust, min_dist, max_dist and borders. The num_clust member has information of the number of the gene groups upon grouping, min_dist and max_dist members have the minimum and maximum values, respectively, in the phase with respect to the distance between the clusters, and the borders member has the positional information (the line number) for drawing a dividing line in the gene expression pattern data 1300.
In order to determine which vector data corresponding to the gene ID (
First, the gene expression pattern data 100 stored in the storage medium 101 is read by the display processor 105 (Step 1800). The specific structure of the expression pattern data 100 is shown in
Next, each of the parameters necessary for the clustering analysis is set (Step 1801). At this point, the recognition error range entered by the user with the keyboard 103 is accepted and stored as variable E. The recognition error range provides a threshold for defining dissimilarity or similarity between expression pattern data of two genes shown in
After setting the parameters, clustering analysis is performed (Step 1802). During this clustering analysis, information necessary for the display according to this embodiment is collected and display data is calculated, which will be described later in detail.
Finally, the results of the analysis are displayed (Step 1803). The previously collected and calculated display data are used for the characteristic display of the present embodiment (i.e., the phase scale bar 1301, the dendrogram cross-cutting line 1302, the dividing line 1304 of the gene expression pattern data, and the gene-group-specifying marks 1305).
It is also possible to display the gene-group-specifying marks 1305 only for clusters consisting of at least a predetermined number of gene expression data, and not to display for clusters consisting of data less than the predetermined number of gene expression data.
Referring to
First, two clusters having a minimum relative distance therebetween are selected from the registered cluster structures (Step 1903). A node-type cluster structure C is newly generated (Step 1904), and the number of the node-type clusters is incremented (Step 1905). The new node-type cluster structure is registered as the nclusth structure of the array node_clusters[ ] (Step 1906). The two clusters selected in Step 1903 are registered as the left and right members of the new node-type cluster structure, and the distance therebetween is registered as the distance member of the new node-type cluster structure (Step 1907).
It is also possible to set up a judging basis for which one of the two clusters should be the left or right member.
Finally, the two cluster structures are removed from the target cluster structures to be joined, a new node-type cluster structure is registered (Step 1908) and the value of cnum (the number of the clusters to be joined) is decremented (Step 1909).
When the value of cnum equals “1” upon the judgement of Step 1902, the process proceeds to a procedure of the flowchart shown in
The node-type cluster structures generated by the first-stage process are all registered in the array node_clusters[ ] (
When the distance members are judged that they are not aligned in an ascending order by this verification, node_clusters[ ] is subjected to a sorting process. Alternatively, only the part not in an ascending order may be detected and subjected to an additional process.
Then, each variable is initialized (Step 2001). Specifically, the variables are counter i of the array node_clusters[ ] (initial value: 1), cluster level level (initial value: 1), a value of distance member curr_dist of the presently processed node-type cluster (initial value: 0), and a value of distance member prev_dist of the previously processed node-type cluster (initial value: 0).
The value of counter i and the value of variable nclus are compared to perform the following procedure to each element of the array node_clusters[ ] (Step 2002).
First, a distance member value of an ith node-type cluster is stored as variable curr_dist (Step 2003) to judge whether or not the difference between the variables curr_dist and prev_dist is smaller than the recognition error range E determined by the user (Step 2004).
When the difference is greater than E, the variable level is incremented (Step 2005) and an interval structure is newly generated. Then, the values of prev_dist, curr_dist and (nclus−i+1) are set as min_dist, max_dist and num_clust members of the newly generated structure, respectively, and register the newly generated interval structure as a levelth element of the array intervals[ ] (Step 2006). The borders member is provided with a null set as a default value.
When the difference between values curr_dist and prev_dist is less than E in Step 2004, steps 2005 and 2006 are omitted and the following procedure proceeds.
The value of the variable level is registered as a value of the level member of the node-type cluster structure registered in the node_clusters[i] (Step 2007).
Finally, the curr_dist value is shifted to prev_dist, the counter i is incremented (Step 2008) and the process returns to Step 2002.
When all of the elements of the array node_clusters[ ] are completely subjected to the procedure of steps 2003 to 2008 (Step 2002), a procedure shown in
First, variable j indicating an index of array disp_leaf_clusters[ ] is set to “1”, and a value of an argument cluster used for the subsequent display data generating process (Process A) is set to a node-type cluster structure indicated by the nclusth element of array node_clusters[ ] (Step 2100).
Then, Process A (display data generating routine) is called using cluster as an argument (Step 2101). In step 2101, Process A is recursively called to collect and calculate display data during the course of tree-walking along the tree-structure of clusters generated according to the flowchart of
First, a value of the type member of the cluster structure given by the argument cluster is checked (Step 2200).
When the given cluster structure is of a leaf-type, a value of the gene ID member of that cluster structure is set as jth element of array disp_leaf_clusters[ ] (Step 2201) and j is incremented (Step 2202).
On the other hand, when the cluster structure given by the argument cluster is of a node-type, Process A using the left member cluster as an argument is recursively called (Step 2203). Then, the given cluster is subjected to a process (Steps 2204 to 2206) and finally, Process A using the right member cluster as an argument is recursively called (Step 2207).
As to the process of the given cluster, first, the level member of the given cluster, the level member of a cluster linked via the left member and the level member value of a cluster linked via the right member are set to variables my_level, l_level and r_level, respectively (Step 2204). Then, either smaller value of 1_level or r_level is compared with the value of my_level (Step 2205).
When the value of my_level is greater than the other, while index k is incremented from min{l_level, r_level} to (my_level−1), the value of the variable j is added to a set of borders member of the interval structure indicated by intervals[k] (Step 2206).
When my_level is smaller than the other upon comparison in Step 2205, process of Step 2206 is omitted and the process proceeds to Step 2207.
When the above-described series of processes performed on the leaf- and node-type cluster structures are finished, Process A is ended.
Thus, clustering analysis can be displayed as shown in
First, the gene expression pattern data 1300 can be displayed line by line from the top by utilizing information of array disp_leaf_cluster[ ]. The dendrogram can be displayed based on the tree-structure data having clusters as roots indicated by node_clusters[nclus].
The phase scale bar 1301 and the dendrogram cross-cutting line 1302 which are characteristic of the present embodiment can be displayed with reference to the min_dist and max_dist member values of each interval registered in array intervals[ ]. The number of the resulting gene groups 1303 can be displayed with reference to num_clust member value.
The dividing line 1304 between the displayed gene groups in the gene expression pattern data and the gene-group-specifying marks 1305 can be displayed with reference to the borders member value.
The processes shown in
Herein, the result of the analysis is displayed on a display device. However, the results can be printed out with a multicolor printer which has recently been greatly improved. According to the present invention, the idea of display also comprises a printed out display.
According to the present invention, expression of a part of cell cycle can be designated to perform clustering in that region in a small range. Based on the displayed results, the user can observe the course of expression status of genes in more detail to efficiently study the biological functions of the genes from its expression status.
Furthermore, the present invention can automatically extract brief results from the entire results of clustering and select and display the results at multiple phases selectable by the user in an apprehensible manner. Thus, the user can readily judge from the display how many clusters have been grouped for studying the grouping of genes.
All publications, patents, and patent applications cited herein are incorporated herein by reference in their entirety.
Number | Date | Country | Kind |
---|---|---|---|
1999/277918 | Sep 1999 | JP | national |
2000/088695 | Mar 2000 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5889523 | Wilcox et al. | Mar 1999 | A |
6263287 | Zheng et al. | Jul 2001 | B1 |