The present invention relates generally to methods and systems for solving constraint satisfaction problems (CSPs), and specifically to methods for modeling and solution of CSPs comprising sub-problems that may be duplicated an arbitrary number of times.
Many of the tasks that are addressed by decision-making systems and artificial intelligence can be framed as constraint satisfaction problems (CSPs). In this framework, the task is specified in terms of a set of variables, each of which can assume values in a given domain, and a set of predicates, or constraints, that the variables must simultaneously satisfy. The set of variables and constraints is referred to as a constraint network. Each constraint may be expressed as a relation, defined over some subset of the variables, denoting valid combinations of their values. A solution to the problem (referred to hereinbelow as a “concrete solution”) is an assignment of a value to each variable from its domain techniques were surveyed by Kumar in a paper entitled “Algorithms for Constraint Satisfaction Problems: A that satisfies all of the constraints. CSP solving Survey,” Artificial Intelligence Magazine 13:1 (1992), pages 32-44.
Constraint satisfaction methods have been found useful in a variety of applications, including:
For example, Bin et al. describe a constraint satisfaction method for use in automated generation of test programs, in a paper entitled “Using a Constraint Satisfaction Formulation and Solution Techniques for Random Test Program Generation,” IBM Systems Journal 41:3 (2002), pages 386-402. The authors show how random test program generation can be modeled as a CSP, and they describe a set of solution techniques that are used in practical test-case generation tools. Adir et al. describe a test generator that uses a dedicated CSP solver in a paper entitled “Piparazzi: A Test Program Generator for Micro-architecture Flow Verification,” Eighth IEEE International High-Level Design Validation and Test Workshop (Nov. 12-14, 2003), pages 23-28. The test generator converts user requests for micro-architectural events into test programs. Further aspects of the use of CSP solving in automatic test-case generation are described in U.S. Patent Application Publication 2002/0169587 A1.
A number of other constraint satisfaction systems are described in the patent literature. For example, U.S. Pat. No. 5,636,328 describes methods and apparatus for finding values that satisfy a set of constraints, applied particularly to control of a robotic arm. U.S. Pat. No. 5,617,510 describes a method, useful in computer-aided design, of identifying possible solutions to an over-constrained system having a collection of entities and constraints.
The concept of a CSP was generalized by Mittal et al. to cover more complex problems in which variables may be active or inactive, in a paper entitled “Dynamic Constraint Satisfaction Problems,” Proceedings of the Eighth National Conference on Artificial Intelligence (AAAI-90) (Boston, Massachusetts, July 1990), pages 25-32. This generalization is commonly referred to as “Conditional CSP,” or CondCSP. In contrast to the traditional definition of a CSP, a variable in a CondCSP can be either active or inactive. The variable is assigned a value only if it is active. The CondCSP includes compatibility constraints, which specify the set of allowed combinations of values for a set of variables, and activity constraints, which determine whether a given variable is active. A compatibility constraint is active only if all its variables are active. A solution to a CondCSP contains (a) a set of active variables and (b) a value assignment to all the active variables, in which each variable is assigned a value from its domain. The assignment and the set of active variables must satisfy all the activity constraints and all the active compatibility constraints.
There is therefore provided, in accordance with an embodiment of the present invention, a computer-implemented method for modeling a target system. The method includes defining a cloned constraint satisfaction problem (CSP) that characterizes the target system in terms of a set of variables and constraints applicable to the variables, wherein the cloned CSP includes a non-predetermined number of duplicate sub-problems corresponding to instances of a repeating feature of the target system. To solve the cloned CSP, the variables are partitioned so as to define an abstract CSP containing a subset of the variables relating to the duplicate sub-problems. This abstract CSP is solved to generate an abstract solution indicating the number of duplicate sub-problems to use in the cloned CSP. A concrete solution to the cloned CSP is then found using the abstract solution. Apparatus and computer software products for defining and solving a cloned CSP are also provided.
The present invention will be more fully understood from the following detailed description of the embodiments thereof, taken together with the drawings in which:
The nature of the testing to be carried out, as dictated by definition 24 and test requirements 26, may include multiple instances of some feature of the target system, such as multiple instances of a repeating task or other function to be performed by a certain unit in the target system. The number of instances is not predetermined, i.e., it is not necessarily defined in advance and may be allowed to vary arbitrarily over some range. An example of this sort of test is described hereinbelow with reference to
In one embodiment of the present invention, for example, the variables provided by system definition 24 comprise possible inputs to a hardware device or software program under development. These inputs are typically instructions, addresses and possibly other properties that would be input to the device or program in the course of actual operation. Generator 22 uses test requirements 26 provided by the operator, together with constraints that it computes automatically itself, to determine test cases 30 in the form of combinations of instructions and addresses to use as test inputs to the device. These inputs may then be applied to the device or program itself, or (as shown in
Typically, test generator 22 comprises a general-purpose or dedicated computer, programmed with suitable software for carrying out the functions described herein. The software may be supplied to the computer in electronic form, over a network or communication link, for example, or it may be provided on tangible media, such as CD-ROM or DVD. Further aspects of automatic test generation using CSP solutions are described in U.S. patent applications Ser. No. 11/092,000 and 11/040,241, which are assigned to the assignee of the present patent application and whose disclosures are incorporated herein by reference.
Although the embodiments described hereinbelow relate specifically to test-case generation, the principles of the present invention may be applied in solving a wide range of other types of constraint satisfaction problems. CSP solver 28 may be adapted, either in the configuration of a stand-alone computer or integrated with other input and output devices, to carry out substantially any function that can be associated with a constraint network. Some examples of such functions are listed in the Background of the Invention. Exemplary applications include controlling a robot based on sensor inputs; analyzing visual or spatial information to identify and characterize objects in an image; parsing natural language input to interpret its meaning; suggesting medical diagnoses based on symptoms and test results; determining resource allocations and scheduling; belief maintenance; temporal reasoning; graph problems; and design of floor plans, circuits and machines. Other applications will be apparent to those skilled in the art.
Once the descriptors are ready, CPU 48 of node 42 initiates data transfer, at a kickoff step 64. At this step, the CPU informs adaptor 52 that there is a descriptor list waiting in a specified location in memory 50, and instructs the adaptor to move the data. The data mover in adaptor 52 of node 42 goes to the head of the transmit descriptor list, reads the first entry, and transfers the data from the memory locations indicated by this entry to node 44, at a data transfer step 66. After completing the first descriptor, the data mover proceeds to execute the next descriptor, and so on until the end of the list. Upon receiving each segment of the data, the adaptor of node 44 reads the next descriptor from the receive descriptor list and places the data in the memory location indicated by the descriptor.
Descriptor list 80 in this example has the form of a linked list. A head entry 82 (to which CPU 48 directs adaptor 52 at step 64) points to the memory address (0x2000 in this example) at which a first descriptor 84 is stored. Descriptor 84 comprises three fields: an address 90, pointing to the beginning of the corresponding data block (in this case block 74, at 0xC800); a length 92, giving the size of the data block; and a next pointer 94, indicating the address at which the next descriptor is written. Adaptor 52 reads pointer 94 to find a second descriptor 86 (at address 0x3000), which in turn points to a final descriptor 88. Next pointer 94 of final descriptor 88 is null, indicating to adaptor 52 that this is the end of the list.
In order to test the mechanism of
Test generator 22 frames the type of situation exemplified by
The CSP solver then solves the abstract problem in order to determine an abstract solution, i.e., a solution to the CondCSP, which includes assignment of values to the variables in the abstract problem. The abstract solution gives a value of the multiplicity and compatible values of the associated variables. In the abstract solution, the conditionality of the sub-problems is resolved, i.e., the activity status (active or inactive) of each of the duplicate sub-problems is known, since the multiplicity value indicates the number of active sub-problems. The remaining sub-problems are inactive and may be eliminated from the current solution. The abstract solution is then used as the basis for finding a concrete solution of the complete CSP. This approach permits the multiplicity values to be chosen at random, while facilitating efficient computation of full solutions that maintain the mutual influence of the multiplicity on the other problem variables and vice versa.
In the example shown in
A vector size 114 is added as a variable below sub-problem root 108. The vector size is an integer variable, which indicates how many of sub-problem instances 110 are active in a given solution. For ease of solution, an existence variable 116 is added as a leaf to each sub-problem instance. The existence variable is TRUE if the corresponding sub-problem is active, and FALSE otherwise. The use of this sort of existence variables in CondCSP solving is described in detail in the above-mentioned patent application by Geller et al. In the present example, for sub-problem [i] and vector size n, the existence variable is TRUE for i≦n and FALSE otherwise. Alternatively or additionally, other CondCSP formalisms, as are known in the art, may be used to represent the number of sub-problems and the activity constraints on each of the sub-problems.
Each sub-problem instance includes all the constraints that apply to the sub-problem variables within the instance, i.e., the constraints applicable to address 90, length 92, next pointer 94 and memory-mapped address 112 in the present example. In addition, system definition 24 and test requirements 26 may comprise constraints that depend on the overall structure of the array of sub-problems below root 108. Constraints of this general type are referred to herein as “vector constraints.” These vector constraints may, for example, include constraints over multiple sub-problem instances, as well as constraints applicable to certain instances because of their position in the sequence of sub-problems, such as constraints pertaining to the first or last instance. Multi-instance constraints may include second-order logic quantifiers, such as “for each” to express repeating relations, and “all” to refer globally to all the active sub-problems. Examples of these sorts of vector constraints include:
In order to define the abstract CSP with respect to the multiple conditional sub-problems, CSP solver 28 extracts from the total constraint network of the complete CSP all the constraints that support vector size 114 and existence variables 116 (i.e., all the constraints that directly affect the values of the size and existence variables), at a constraint extraction step 120. For each of these constraints, the CSP solver also extracts the other variables that are connected to the constraint. A user of system 20 may specify additional variables that are believed to influence the sub-problem multiplicity, at a user selection step 122. This step permits the user's intuition regarding the problem structure to be brought to bear, specifically with regard to variables that are likely to affect the multiplicity, even if they are not directly linked by constraints to the vector size. These user-selected variables are also added to the abstract CSP.
A synchronization constraint is added to the abstract CSP at a synchronization step 124, in order to synchronize the vector size and existence variables during solution of the abstract CSP. The semantics of the synchronization constraint are as follows: For S=current domain of the vector size variable, with m=min(S) and n=max(S), then for each k>n existence[k]=FALSE, and for each j<m existence[j]=TRUE.
To complete the constraint network of the abstract CSP, all the constraints from the complete CSP that connect the leaves (variables) in the abstract CSP are added to the abstract CSP, at a constraint addition step 126. In addition, any “for each” constraints in the abstract CSP are duplicated as an individual constraint on each of instances 110. If these individual constraints cause inconsistency within any of the sub-problems, they will cause the existence variable of that sub-problem to be set to FALSE when the abstract CSP is solved. The FALSE existence variable, in turn, will limit the possible values of the vector size.
Constraints on aggregate values taken over all the sub-problems (referred to herein as aggregate constraints) and constraints on the “last” sub-problem are added into the abstract CSP, at a constraint wrapping step 128. These constraints cannot simply be attached to the variables in any particular sub-problem, since the vector size (and hence the last sub-problem) is not known in advance. Therefore, CSP solver 28 builds a “wrapper constraint” to replace each of the aggregate and “last” constraints. The wrapper constraint has the form of a disjunction over all possible values of the vector size. For example, a constraint of the form of the total length (TL) constraint listed above would be expressed as follows:
(vs=1ˆTL=L[1]) (vs=2ˆTL=L[1]+L[2]) K(vs=NˆTL=L[1]+L[2]+K+L[N])
wherein vs is the vector size, and L[k] is the value of the “length” variable in sub-problem k. “Last” constraints may be restated in like fashion.
After constructing the abstract constraint network in steps 120-128, CSP solver 28 solves the abstract CSP, at an abstract solution step 130. The abstract CSP is a CondCSP, as defined above, and any suitable method of CondCSP solution may be used at step 130. One such method is described in the above-mentioned patent application by Geller et al. Another method is described in U.S. Patent Application 11/040241, filed Jan. 21, 2005, which is assigned to the assignee of the present patent application and whose disclosure is incorporated herein by reference.
The solution to the abstract CSP gives a value of the vector size, as well as values of the other variables in the abstract CSP that are compatible with this vector size. Using this information, CSP solver 28 builds a static (non-conditional) CSP that contains the number of sub-problem instances 110 indicated by the vector size value, at a concrete solution step 132. The variables that were assigned values in the abstract solution keep the same values in the static CSP. The CSP solver finds an assignment of all the remaining variables that solves the static CSP. Test generator 22 then outputs this assignment as one of test cases 30.
As noted earlier, although the embodiments described above relate specifically to the field of test generation, the novel principles of CSP formulation and solution that are embodied in test generator 22 may similarly be applied in other areas in which CSP solving is used. It will thus be appreciated that the embodiments described above are cited by way of example, and that the present invention is not limited to what has been particularly shown and described hereinabove. Rather, the scope of the present invention includes both combinations and subcombinations of the various features described hereinabove, as well as variations and modifications thereof which would occur to persons skilled in the art upon reading the foregoing description and which are not disclosed in the prior art.