The present disclosure is related to modeling tools, and more particularly to inferring or identifying the semantics from a graphical model.
Conventional modeling tools allow the user to model specific model types intended by the tool. On the other hand, meta modeling tools allow the user to create a modeling tool, provided that the user supplies the semantics (meta model) explicitly. The present disclosure addresses the problem of inferring the semantics from a graphical model (or models), that represent possible instance of the model type.
U.S. Pat. No. 6,988,062 discloses meta model generation on the basis of examples of target models, and addresses meta models which represent directed multi graph models. That patent, however, is not concerned with extracting the meta model from drawings or diagrams other than those that are in the form of nodes and edges.
U.S. Pat. No. 7,240,327 discloses creating a meta-data for a modeling tool from the instance information for pre-defined object types input in a GUI. “MetaBuilder: the diagrammer's diagrammer” by R. I. Ferguson and A. Hunter discloses generating a meta model by drawing items in a specific notation. The meta model is further used for automatically generating a target tool. The notation is based upon the concept of a mathematical graph consisting of nodes and edges.
U.S. Pat. No. 7,096,454 discloses a method for creating models using gestures drawn by user. The gesture is interpreted based on a meta-model and an algorithm creates or modifies model elements based on the interpretations. WO06106495A1 discloses generating a meta model from a data model by extracting meta data from an existing data model. U.S. Patent Application Publication 2005/0160401A1 discloses customizing a modeling tool according to user's needs. U.S. Pat. No. 7,000,219 discloses developing a software system using a metamodel.
“Using meta-modelling and graph grammars to create modelling environments” by
De Lara Jaramillo, Juan; Vangheluwe, Hans; and Moreno, Manuel Alfonseca discloses combined use of meta-modeling and graph grammars for the generation of visual modeling tools for simulation formalisms.
A method and system for identifying graphical model semantics are provided. The method, in one aspect, may comprise receiving a graphical diagram and associating each of a plurality of elements in the graphical diagram with one or more predetermined meta-types. The method may also comprise identifying a plurality of types and determining a category for the plurality of types. The method may further comprise executing containment relationship identification rules to identify one or more containers in the graphical diagram and executing multiplicity identification rules to identify multiplicity relationships in the graphical diagram. The method may further comprise executing advanced semantic rules to identify visual elements that represent attributes and refine relationships between the plurality of types to identify unique behavior.
A system for identifying graphical model semantics, in one aspect, may comprise a module operable to receive a graphical diagram, associate each of a plurality of elements in the graphical diagram with one or more predetermined meta-types, identify a plurality of types in the graphical diagram, and determine a category for each of elements in said graphical diagram. A rules execution module is operable to execute containment relationship identification rules to identify one or more containers in the graphical diagram, execute multiplicity identification rules to identify multiplicity relationships in the graphical diagram, and execute advanced semantic rules to identify visual elements that represent attributes and refine relationships between the plurality of types to identify unique behavior.
A program storage device readable by a machine, tangibly embodying a program of instructions executable by the machine to perform a method of identifying graphical model semantics may be also provided.
Further features as well as the structure and operation of various embodiments are described in detail below with reference to the accompanying drawings. In the drawings, like reference numbers indicate identical or functionally similar elements.
A method and system of the present disclosure in one embodiment comprise the following two stages for deducing model types, relationships between the model types and other model behavioral aspects:
For the initial setting we describe herein two different methods that apply a set of rules. Rules are logical conditions that are based on criteria which people use to identify the diagram building blocks (“element types”). Examples for criteria for type identification may be: the Shape of an element, the Color of an element, the Stereotype of an element, Repetitive Text that appears on different elements, or any combination of these. In the application herein two methods are demonstrated for the initial setting; A Probabilistic Method and a Compact Representation Method. Other methods may be used for the initial setting and the present disclosure does not limit the methodology to the two.
In the present disclosure, the following terminologies are used:
Metadata: Data that represents models. For example, a Unified Modeling Language (UML) model; a Common Object Requesting Broker Architecture (CORBA) object model expressed in Interface Definition Language (IDL); and a relational database schema expressed using Common Warehouse Metamodel (CWM™).
Metamodel: A special kind of model that specifies the abstract syntax of a modeling language; an abstract language for a kind of metadata.
Model: A model represents a concrete or abstract thing of interest, with a specific purpose in mind. The model is related to the thing by an explicit or implicit isomorphism. Models are instances of metamodels and therefore include model elements and links between them. Hereafter, we use “model” and “model instance” interchangeable. We also refer to the semantically enriched business diagrams that serve as input to our algorithm as model instances. These business diagrams are usually being used by practitioners like Business Analysts and Business Architects to illustrate a business issue at hand.
Element (A Model Element): An object in the input model instance.
Link: A connector or association in the input model instance.
Type: With respect to the Object Management Group (OMG) MetaObject Facility (MOF) definitions of “Model” and “MM” above, a type (an element type) is a building block of the meta model (“MM”). For example, if the MM is illustrated in UML class diagram, a type in the metamodel is a “class” of model elements. Consequently, in UML modeling, an Actor is a type in a use case (“UC”) diagram. Another example is: in a Business Process Management Notation (BPMN model), a “task” and a “collapsed processes” are types in the metamodel, in the model instance itself there may appear many different tasks and collapsed processes.
Rule: A logical condition that is applied on a model instance to determine an aspect which will help in the MM creation; rules may include those that identify the types, and others that identify multiplicity relationships between types and other aspects of the MM.
Two methods for the initial setting are described below:
1. A probabilistic method
2. A compact representation method
The probabilistic method comprises two phases: a training session phase and a runtime phase. The training session defines measures (probabilities) to be used later on in the runtime phase. These measures are used in the run time phase as predictions to reveal the dominant rule in a given model. Types are determined according to the revealed dominant rule. Therefore, if people tend to identify types first and mostly according to the ‘Shape’ of the element, the result of the training phase will be that “identify types according to shape” will be given a higher probability. Similarly, if people tend to use three criterions in conjunction very rarely, then rules with a combination of three criterions will be given relatively low probability. At runtime, the hypothesis for each rule (namely—is that rule ‘the right’ one for a given model) is tested by using the probabilities outcomes of the training session. The training session can be performed once and then its outcomes used at the runtime for different diagrams.
The following describes determining rules applicability in one embodiment of the present disclosure.
A rule is effective if it serves as a good criterion to identify types in the model instance.
A ‘good criterion’ is quantified according to the probability distribution of that rule. The probability distribution describes the values of our measured “event” and probabilities associated with it. The measured event is the number of types each rule found when applied on a given model. Accordingly, for example, when one applies the “identify types according to shape of element” (the “shape rule”), the measured event is the number of different shapes that exists in the model. The probability distribution for the shape rule is obtained by the probability values versus “number of shapes”. Probabilities are computed by using “Bayes Theorem”.
In the training session the probability distribution of an effective rule is expected to be relatively high with relation to certain value (or values) of “number of types”. Accordingly, for an ineffective rule there is no significant “number of types” which is discovered when applied on a diagram (a model instance). For example, a uniform distribution indicates an ineffective rule (no significant number of types) while Gaussian distribution indicates an effective rule. Thus, the rule effectiveness is affected by the distribution Mean and Variance.
In one embodiment, to decide which rules are effective and how effective they are, i.e., the degree of their effectiveness, a “training session” may be conducted. The input to the training session in one embodiment may be:
The result of the training session may be the collection of prior probabilities, conditional probabilities and unconditional probabilities to be used in the Run Time session, for example, as terms in the “Bayes Formula”.
The Training Session:
1. In one embodiment, the first phase of the training session is running the entire rule set received as input, to record the number of types (# types) identified in each model with relation to each rule. For each model only the number of types of the “right rule” was received as input. The rest of the rules' results (i.e., number of types) per model are being calculated in this phase.
2. Next, we determine each rule's probability distribution according to Bayse Theorm as follows:
Let m be the number of types a rule found, and let Rule be a certain rule (e.g., “identify types according to shape” or “identify types according to stereotype”) then the probability distribution of Rule is computed as follows:
Where:
P(Rule|m) denotes the probability that Rule is the “right” rule given that Rule found m types (Rule may have the values; Shape, Color, Stereotype etc.);
P(Rule) denotes the prior probability of the rule (obtained from training session using the “Ground Truth” as explained above);
P(m|Rule) denotes the probability that Rule found m types while Rule is the “right” one.
P(m) denotes the probability that Rule found m types.
For example, for the Rule “identify types according to shape” and number of shapes (3) our training session module will compute:
Where:
P(Shape) is the prior probability of the shape rule in the training session population. It is obtained as follows: let N be the sample size and NS the number of samples in which shape was the right rule (considering their ground truth), then
P(m=3|Shape) is obtained as follows: let NS be the number of samples in which shape was the right rule, and XS be the number of samples in which there where three shapes (i.e., shape found three types) and also was the right rule (considering their ground truth), then
P(m=3) is obtained as follows: let X be the number of samples in which there where three shapes (i.e., shape found 3 types) and N the sample size (i.e., number of models in the training session), then
Following are two extensions to the above method:
1. Despite the fact that in every model at hand only one rule is the right rule, one may also take into account the number of types other rules find when executed on the same model. The reason for such a desire may be an assumption one may have for the existence of dependency between these values. This option imposes a restriction on the probability model that can de dealt with a joint distribution as follows:
Let mv be a vector of values. Each component in vector indicates ‘number of types’ that was obtained by a certain rule over the given model.
Let Rule be a certain rule (e.g., “identify types according to shape” or “identify types according to stereotype”). The probability distribution of Rule is computed as follows:
Where:
P(Rule|mv) denotes the probability that Rule is the “right” one (Rule may have the values: Shape, Color, Stereotype etc), given mv which is the array of types found all the rules P(Rule) denotes the prior probability of the rule that is under question (obtained from training session using the “Ground Truth” as explained above);
P(mv|Rule) denotes the probability that the array of values mv was obtained while Rule is the “right” one;
P(mv) denotes the probability to obtain the array mv.
For example, for the Rule “identify types according to shape” and number of shapes 5, number of colors 1, number of stereotypes 1, the training session module will compute:
Where:
P(Shape) is the prior probability of the shape rule in the training session population.
It is obtained as follows: let N be the sample size and NS the number of samples in which shape was the right rule (considering their ground truth), then
P(mv=(5,1,1)|Shape) is obtained as follows: let NS be the number of samples in which shape was the right rule, and XS be the number of samples in which there where 5 shapes (i.e. shape found 5 types), 1 (or none) colors and 1 (or none) stereotypes and also shape was the right rule (considering their ground truth), then
P(mv=(5,1,1)) is obtained as follows: let X be the number of samples in which there where 5 shapes (i.e. shape found 5 types), 1 (or none) colors and 1 (or none) stereotypes, and let N be the sample size (i.e. number of models in the training session), then
2. The following formula is the second extension to the method. It may be applied as a relaxation of the former restriction. In the formula provided below one may assume independency between the number of types that the different rules found given that one rule is right. Despite the independency said, these terms are not omitted from the formula as in the original one (Formula 1). It is worth noting that the difference between the following formula (Formula 3) and the original formula (Formula 1) is that the latter formula's significant terms are: the probability to receive a certain number of types in a model given that one Rule is right and the prior probability of that Rule. Whereas in the following formula (Formula 3), given that one Rule is right, still the probability to receive values for number of types by the other rules is not considered negligible. Therefore the probability distribution of Rule is computed as follows:
Where:
P(Rule|mv) denotes the probability that Rule is the “right” one (Rule may have the values: Shape, Color, Stereotype etc), given mv which is the array of types found by all the rules P(Rule) denotes the prior probability of the rule that is under question (obtained from training session using the “Ground Truth” as explained above);
P(mrule|Rule) denotes the probability that the component mrule in the array of values mv was obtained while Rule is the “right” one (the component mrule denotes the number of types that rule found, rule may have the values: shape, color, stereotype etc.);
P(rule1) denotes the prior probability of rule);
P(mrule
For example, for the Rule “identify types according to shape” and number of shapes 5, number of colors 1, number of stereotypes 1, the training session module will compute:
Where:
P(Shape) is the prior probability of the shape rule in the training session population. It is obtained as follows: let N be the sample size and NS the number of samples in which shape was the right rule (considering their ground truth), then
P(Color) is the prior probability of the color rule in the training session population. It is obtained as follows: let N be the sample size and NC the number of samples in which color was the right rule (considering their ground truth), then
P(Stereotype) is the prior probability of the stereotype rule in the training session population.
It is obtained as follows: let N be the sample size and NST the number of samples in which stereotype was the right rule (considering their ground truth), then
P(Mshape=5|Shape) is obtained as follows: let NS be the number of samples in which shape was the right rule, and XS be the number of samples in which there where 5 shapes (i.e., shape found 5 types) and also shape was the right rule (considering their ground truth), then
P(mcolor=1|Shape) is obtained as follows: let NS be the number of samples in which shape was the right rule, and XC be the number of samples in which there where 1 (or none) colors (i.e., color found 1 type) and also shape was the right rule (considering their ground truth), then
P(mstereotype=1|Shape) is obtained as follows: let NS be the number of samples in which shape was the right rule, and XST be the number of samples in which there where 1 (or none) stereotypes (i.e., stereotype found 1 type) and also shape was the right rule (considering their ground truth), then
P(mshape=5|Color) is obtained as follows: let NC be the number of samples in which color was the right rule, and YS be the number of samples in which there where 5 shapes (i.e., shape found 5 types) and also color was the right rule (considering their ground truth), then
P(mcolor=1|Color) is obtained as follows: let NC be the number of samples in which color was the right rule, and YC be the number of samples in which there where 1 (or none) colors (i.e., color found 1 type) and also color was the right rule (considering their ground truth), then
P(mstereotype=1|Color) is obtained as follows: let NC be the number of samples in which color was the right rule, and YST be the number of samples in which there where 1 (or none) stereotype (i.e., stereotype found 1 type) and also color was the right rule (considering their ground truth), then
P(mshape=5|Stereotype) is obtained as follows: let NST be the number of samples in which stereotype was the right rule, and ZS be the number of samples in which there where 5 shapes (i.e., shape found 5 types) and also stereotype was the right rule (considering their ground truth), then
P(mcolor=1|Stereotype) is obtained as follows: let NST be the number of samples in which stereotype was the right rule, and ZC be the number of samples in which there was 1 (or none) color (i.e., color found 1 type) and also stereotype was the right rule (considering their ground truth), then
P(mstereotype=1|Stereotype) is obtained as follows: let NST be the number of samples in which stereotype was the right rule, and ZST be the number of samples in which there was 1 (or none) stereotype (i.e., stereotype found 1 type) and also stereotype was the right rule (considering their ground truth), then
Input to the run time session may be:
Optional input may include:
The results of the run time session may be:
The run time session procedure may be:
Steps b. and c. above may further include the following principle:
Following is an example of the run time session procedure:
Consider the diagram on
Another method for the initial setting is described below:
The compact representation method is based on “Graph Theory”. This method can find the best way for the user to draw a model instance (and derive diagram building blocks accordingly). The method tries to minimize the number of operations the user needs in order to draw an element. For instance, if a diagram building block which is stereotyped “Process” appears on the model instance only with the notation of a blue ellipse, than the tool will realize this, thus put a blue ellipse process on palette ready for the user to drag and drop to canvas whenever drawing a new model instance, that is, the user will not need to specify the color or shape when the user works with process elements.
The input to the compact representation method may be:
The result of the compact representation method may be:
1. A set of types that make up the diagram structure.
2. For each type the combination of criteria that relate to it.
The procedure of the compact representation method is as follows:
The algorithm performs four consecutive steps:
First it builds a collection of trees each corresponds to a specific order of criteria.
Second the algorithm applies a shrinking technique that reduces trees average height.
Third the algorithm reduces the number of suggested trees by using business rules.
Fourth the algorithm applies a method (hereafter two optional ones are suggested) to pick the best tree and output its top level nodes that correspond to the MM types.
Let II be the input model instance in the form of a collection of nodes.
For each permutation of criteria p compose an array Ap that each of its entries reflects a criterion. For example if the set of criteria is {Shape, Color, Stereotype}, compose 6 (3!) arrays.
For each array of permutations Ap construct an associated tree Tp. Each level l in Tp is associated with an entry in Ap and each node u at l is associated with a possible value of Ap's entry such that a path from the root r to u corresponds to an existing combination of criteria values in II.
The tree on
The construction of Tp may be done as follows:
The algorithm starts by constructing the root r of Tp (the root is the only node in Tp with no relation to Ap's entries). The algorithm traverses over the collection of elements II, picks one element and then expands the tree iteratively according to levels. Let vl be the value of a criterion of some element e in II (this criterion corresponds to the current level of Tp that the algorithm now expands). The algorithm builds a node u in Tp corresponds to vl, after searching all sub-trees in Tp and locating the sub-tree that its combination of criteria values equals to these of e. The node u will be added to Tp in that sub-tree as a child to the leaf in the path that represent the above mentioned combination, only if such leaf do not exist yet in Tp.
For example, consider the tree on
Reducing Trees' Height (“Shrinking Technique”)
The leaves of each tree represent all combinations of elements' features in the model. Therefore, the path length from root to leaf serves as an indicator for the amount of work the user has to do (when acting in a drawing tool) until they reach their desired notation. The shrinking operation is done in order to collapse branches that correspond to sequence of operations that can be reduced. Shrinking can be done both forward and backwards.
Forward shrinking may be done according to the following method:
Examine levels of tree iteratively, starting from the root. At each level search for nodes that have only one child, then join parent and child to create a node that corresponds to the combined criteria.
For example, consider the tree of
Backwards shrinking may be done according to the following method:
Examine levels of tree iteratively, starting from the leaf level. At each level search for nodes that have children that are unique to them (i.e., other nodes at their level do not have a child that is equal to the one being examined). Then join parent and child to create a node that corresponds to the combined criteria.
For example, consider
For each tree the algorithm performs forward shrinking, then backwards shrinking and then forward shrinking again.
Reducing the number of suggested trees by using business rules
To reduce the number of candidate trees before selecting the best tree, eliminate trees according to overriding rules. Overriding rule may be as follows:
Selecting the Best Tree
Each of the collection of trees from the previous step corresponds to a possible set of types of the MM. The selection of the best tree may be done according to two example approaches: the height approach and the frequent approach.
In the height approach the algorithm selects the tree that has the minimum height. That tree represents the set of types that minimize the number of operations a user has to do to get to a full featured element in a diagram instance.
Following is the height method. Let d be the length of some path (length is measured according to number of edges) from the tree root to a leaf. Then the algorithm selects the tree which adheres to:
In the frequent approach the algorithm selects the tree that has the minimum weight. That tree represents the set of types that minimize the number of operations a user has to do to get to the most frequent full featured elements in the diagram instance.
Following is the weight method. Let d be the length of some path from the tree root to a leaf, and let n be the number of elements from the input instance that suit the criteria values combination that this path represents. Then the algorithm selects the tree which adheres to:
Following is an example for weights determination: Consider the diagram on
The weight of the tree is computed according to the following values:
And the tree weight is therefore: 1*3+2*1+2*1+2*1+2*3+2*1+1*5+2*2+2*2=30.
The set of types the algorithm outputs corresponds to the nodes at the first level of the selected tree. Therefore, if the tree of
The following describes deducing model types and semantics of a given diagram in one embodiment of the present disclosure.
At 202, a diagram (model) is being consumed by the algorithm. At 204, associate type with meta-type (e.g., node, link, container). At 206, run initial setting stage to identify types. At 208 find element's category. At 210 infer semantics. At 212 output a model definition instance (i.e., the required MM).
Step 204 (associate type with meta-type) refers to meta-types that may be provided as an input for the algorithm. Some processing should be done on the input in order to achieve this goal. For example if diagrams are provided with underlying XML representation then a parser for that XML representation can extract its meta-types data (this parser may be a separate module of the system, separate from the algorithm herein). Elements may be associated with multiple meta-types. An example may be a type which is both a link and a container.
At initial setting step 206, types are identified. As described above, different methods may be used to identify types. For instance, a probabilistic method or a compact representation method to perform this task. Other methods may be employed. If a probabilistic method is chosen, a training session is run, upon which the types identification of the run time session is determined.
Step 206 may further include the following steps:
1. As a preprocessing step collect elements of diagram into buckets according to their meta-types. For example, if the set of meta-types includes {nodes, links}, divide the set of elements in a given diagram to: nodes subset and links subset. Then perform the initial setting step (206) on each subset to infer types. For example, if the subsets are nodes and links, infer node types and link types using either the probabilistic or the compact representation method.
2. This step is optional. Different set of meta-types belong to different “Model Family”. Models can be classified into Model Families according to shared structural characteristics like the set of meta-types and constrains on the relations between element types. For example, the most frequent family is the “graph” family which is made of nodes and edges (links) meta-types, an example of which is illustrated in
Step 208 in
1. Categorize according to links, when the links induce a partition which is based on the linkage between types. For example,
2. Categorize according to the “identifying types” rules results. A rule will be considered as a “categorizing rule” if:
In infer semantics step 210, the semantic representation, i.e., constraints that are induced by the diagram, are extracted. While traversing over the diagram, build a matrix that will be composed of the elements from the diagram. For each element summarize all the information about containment, connectivity, etc. Next, search for certain behaviors. For example, is there a certain connector used only when connecting types that belong to different containers?
This step may include the following stages:
1. Run “containment relationship” identification to identify which types are aggregated in a container type.
3.1 Identify visual elements that represent attributes (as opposed to types). When visual element represents an attribute (characteristic of a type), it is usually a non connected element that can be identified as follows:
Use the conjunction of the following cases:
For example,
3.2 Refine relationships to identify unique behavior. Example for such behavior may be, “Yellow rectangles can be connected only to white rectangles”, “Components of separate containers can be connected only with dashed lines”. The advanced semantic constraints can be searched while traversing over the above mentioned matrix that is composed of all the elements from the diagram each with reference to its metadata (types and attributes) that were inferred at early stages of the algorithm.
Step 212 represents the result of the algorithm. The algorithm outputs a model definition comprising the building blocks of the input model and its semantic representation, i.e., a description of all the constraints that are induced by the diagram in a compact manner.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements, if any, in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Various aspects of the present disclosure may be embodied as a program, software, or computer instructions embodied in a computer or machine usable or readable medium, which causes the computer or machine to perform the steps of the method when executed on the computer, processor, and/or machine. A program storage device readable by a machine, tangibly embodying a program of instructions executable by the machine to perform various functionalities and methods described in the present disclosure is also provided.
The system and method of the present disclosure may be implemented and run on a general-purpose computer or special-purpose computer system. The computer system may be any type of known or will be known systems and may typically include a processor, memory device, a storage device, input/output devices, internal buses, and/or a communications interface for communicating with other computer systems in conjunction with communication hardware and software, etc.
The terms “computer system” and “computer network” as may be used in the present application may include a variety of combinations of fixed and/or portable computer hardware, software, peripherals, and storage devices. The computer system may include a plurality of individual components that are networked or otherwise linked to perform collaboratively, or may include one or more stand-alone components. The hardware and software components of the computer system of the present application may include and may be included within fixed and portable devices such as desktop, laptop, server. A module may be a component of a device, software, program, or system that implements some “functionality”, which can be embodied as software, hardware, firmware, electronic circuitry, or etc.
The embodiments described above are illustrative examples and it should not be construed that the present invention is limited to these particular embodiments. Thus, various changes and modifications may be effected by one skilled in the art without departing from the spirit or scope of the invention as defined in the appended claims.
This application is related to U.S. patent application Ser. No. ______ entitled, “MODELING TOOL BUILDER—GRAPHICAL EDITOR CONSTRUCTION,” (attorney docket IL920080047U1 (22482)), filed on Dec. 19, 2008, and is a divisional application of U.S. patent application Ser. No. 12/339,458 entitled, “A METHOD AND SYSTEM FOR IDENTIFYING GRAPHICAL MODEL SEMANTICS” both are assigned to the same assignee in the present application, contents of which are incorporated by reference herein in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 12339458 | Dec 2008 | US |
Child | 13604156 | US |