US20050166096A1 - Method and apparatus for generation of validation tests - Google Patents

Method and apparatus for generation of validation tests Download PDF

Info

Publication number
US20050166096A1
US20050166096A1 US11/035,138 US3513805A US2005166096A1 US 20050166096 A1 US20050166096 A1 US 20050166096A1 US 3513805 A US3513805 A US 3513805A US 2005166096 A1 US2005166096 A1 US 2005166096A1
Authority
US
United States
Prior art keywords
ast
test program
test
population
data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US11/035,138
Inventor
Charles Yount
Melvyn Goveas
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Individual
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Individual filed Critical Individual
Priority to US11/035,138 priority Critical patent/US20050166096A1/en
Publication of US20050166096A1 publication Critical patent/US20050166096A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/22Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing
    • G06F11/26Functional testing
    • G06F11/263Generation of test inputs, e.g. test vectors, patterns or sequences ; with adaptation of the tested hardware for testability with external testers

Definitions

  • the invention relates generally to validation methods and more specifically to computer implemented validation methods that efficiently generate test programs that satisfy a criterion established by a user or by a system designer.
  • Validation test programs are a series of inputs that are used to verify the functionality of a device such as a microprocessor. Validation of a device may be performed in numerous ways. For example, the device being tested may be simulated by a computer program. Alternatively, the device itself may be tested.
  • Validation methods include test-based methods, coverage-based validation methods, and other known methods.
  • a coverage-based method for example, executes a test program that generates new coverage data that is then manually evaluated in view of existing coverage data to determine whether the desired coverage has been reached.
  • Coverage data may be used to gauge the “goodness” of test programs that are used to find “bugs” in a design of a device such as a processor.
  • Coverage data is data that indicates what elements of a given set of conditions were activated during a dynamic or static evaluation of a device under test.
  • Determining whether the coverage data generated from a test program has achieved the coverage that is necessary is a very labor intensive process. Additionally, a significant amount of effort to redirect a test generator to create a new test program is required.
  • a computer system and a computer-implemented method for generating validation test programs.
  • the computer system comprises a processor coupled to a storage device.
  • the storage device has stored therein at least one routine.
  • the routine causes the processor to generate and analyze a test program.
  • the routine also generates at least one subsequent test program to be generated until at least one termination criterion is met.
  • FIG. 1 illustrates an exemplary computer system in accordance with an embodiment of the invention
  • FIG. 2 illustrates a flow chart of an exemplary creation process for an individual test program in a population in an embodiment of the invention
  • FIG. 3 illustrates an exemplary creation process for each individual test program in a population in an embodiment of the invention
  • FIG. 4 illustrates a computer system using shared resources in accordance with an embodiment of the invention
  • FIG. 5 illustrates displays that may be revealed to a use in accordance with an embodiment of the invention.
  • FIG. 6 illustrates results of an embodiment of the invention.
  • the present invention relates to a method and an apparatus for generating validation test programs that are used to simulate a device by using a computer program before the device has been fabricated or the device itself can be tested.
  • an initial population of test programs is either input or generated.
  • the test program(s) are then stored on the storage device.
  • a test program is then selected for execution.
  • the coverage data generated from the execution of a test program is analyzed to determine whether the desired coverage has been attained.
  • the coverage that is required is typically designated by a user or system designer.
  • test programs are selected for genetic mutation and/or recombination which is used to create a new test program. This new test program is then executed generating new coverage data to be analyzed. This process is repeated until the required coverage is attained.
  • Disclosed techniques may be used in various forms of validation, including architectural validation, micro-architectural validation, unit-level validation, external bus validation, etc. More specifically, the techniques used in performing functional validation in digital systems including microprocessors and generating functional test suites for computer program or software systems. Generally, the invention is able to attain the same or higher level of coverage in less time with less human effort compared to traditional methods.
  • new test programs are created by a test generator (TG), by using a genetic operation.
  • a genetic operation includes operations such as a mutation operation, a cross-over operation, or numerous other suitable operations.
  • a mutation involves at least one test program that whenever an operation is used to generate a new test program, data from the population is selected and used in the algorithm. If the designated coverage is not attained (or some other termination criterion or criteria have not been met), the test program is modified by the TG and the process is repeated. Alternatively, an operator using a monitor may input a new test program, thereby injecting “hints” into the operation. A test program is then generated and executed. New coverage data is created and evaluated to determine whether the desired coverage has been attained.
  • FIG. 1 illustrates one embodiment of a computer system 10 which implements the principles of the present invention.
  • Computer system 10 comprises a processor 17 , a storage device 18 , and a bus 15 .
  • Processor 17 is coupled to the storage device 18 by bus 15 .
  • a number of user input/output devices such as a keyboard 20 and a display 25 , are also coupled to the bus 15 .
  • Processor 17 represents a central processing unit of any type of architecture (e.g., the Intel architecture, Hewlett Packard architecture, Sun Microsystems architectures, IBM architectures, etc.), or hybrid architecture.
  • processor 17 could be implemented on one or more chips.
  • Storage device 18 represents one or more mechanisms for storing data such as population data, coverage data, etc.
  • Storage device 18 may include read only memory (ROM), random access memory (RAM), magnetic disk storage mediums, optical storage mediums, flash memory devices, and/or other machine-readable mediums.
  • Bus 15 represents one or more buses (e.g., AGP, PCI, ISA, X-Bus, VESA, etc.) and bridges (also termed as bus controllers). While this embodiment is described in relation to a single processor computer system, the invention could be implemented in a multi-processor computer system.
  • a network 30 may be present.
  • Network 30 represents one or more network connections for transmitting data over a machine readable media. The invention could also be implemented on multiple computers connected via such a network.
  • FIG. 1 also illustrates that the storage device 18 has stored therein data 135 and software 136 .
  • Data 135 represents data stored in one or more of the formats described herein.
  • Software or computer program 136 represents the necessary code for performing any and/or all of the techniques described with reference to FIGS. 2-6 . It will be recognized by one of ordinary skill in the art that the storage device 18 preferably contains additional software (not shown), which is not necessary to understanding the invention.
  • FIG. 2 provides one example of an application of evolutionary computation involving a representative algorithm. It will be appreciated that numerous examples exist and that the invention is not limited to any one example.
  • an optimization problem is defined by the user. To illustrate, a user may define the optimization problem as generating iA32 (32-bit Intel Architecture) test programs that, when executed, reach many new states in a new microprocessor design.
  • iA32 32-bit Intel Architecture
  • Each solution is called an individual.
  • Each individual test program may be encoded as an abstract syntax tree (AST).
  • AST encodes the structure and data of an iA32 test program. For example, some nodes in the AST contain the instructions to be executed during the test program.
  • a fitness function is defined by the user or system designer.
  • the number of different types of fitness functions is unlimited.
  • the fitness function defines the “goodness” of a particular individual.
  • the fitness function of each individual test program may be defined as the number of new states it reaches in the new microprocessor design.
  • an initial set of individuals is created.
  • This initial set of individuals is referred to as the initial population.
  • an iA32 random test generator is used to create a set of random test programs.
  • the population may start with a set of existing test programs.
  • the individuals are evaluated in the population according to the fitness function.
  • the new microprocessor may be simulated and how many new states that are reached are recorded. This number is referred to as the individual's fitness.
  • the process is terminated at 132 .
  • the process is ended. It will be appreciated that a variety of termination criterion may be input by a user and the claimed invention is not limited by examples provided herein.
  • some of the better individuals in the population are selected. For example, a user may require that genetic operations be randomly chosen for a mutation or crossover operation. The user may further require that, for example, eight random individuals from the population be selected. From the eight individuals, an individual is chosen that has the highest fitness. (This is known in the art as “tournament” selection.) If a crossover operation is chosen, this process is repeated to select another individual.
  • new individuals are created by applying one of several genetic operations. These new individuals are then added to the population.
  • a mutation operation is selected, some of the iA32 instructions from the selected test program are randomly removed and are replaced with new random instructions. If a crossover operation is selected, some of the iA32 instructions from the first selected test program are randomly removed and are replaced with randomly selected instructions from the second selected test program.
  • the new microprocessor is simulated and the number of new states that are reached (i.e., its fitness) is recorded.
  • the new test program and its fitness are then placed into the population.
  • some of the poorer individuals in the population are removed from the population. For example, eight random individuals may be selected from the population. At least one individual that has the lowest fitness among the eight individuals is removed from the population. Operations 125 to 145 are then repeated until the termination criterion or criteria are met.
  • FIG. 3 shows one embodiment of the invention for generating new test programs using coverage data as a mechanism to guide the generation of each test program.
  • test generation includes a microprocessor test generator that may generate a sequence of microprocessor instructions and data that will be executed by a model of the microprocessor or an actual microprocessor.
  • Another example includes a unit-level test generator that may generate a sequence of electrical signals that may be fed sequentially to the device under test. The process described below is repeated until a test program is executed which generates coverage data that satisfy the coverage designated by a user or system designer.
  • coverage data may be processed in series or in parallel when practicing the invention.
  • FIG. 3 further illustrates one embodiment of the invention in which a computer program comprises four modules or routines—a test builder (TB) 204 , a test generator (TG) 206 , a test analyzer (TA) 208 , and a feedback engine (FE) 202 .
  • modules may run on the same computer system or one or more may run on separate computer systems that may be connected through a network.
  • One embodiment of the invention relates to generating high-coverage validation test suites having the characteristics of using search techniques that rely upon improvement of evolutionary computation methods and evaluating newly generated coverage data using existing coverage metrics as a feedback mechanism to guide these methods.
  • One search technique navigates through a space of potential solutions by evaluating a subset of those solutions based upon the selection of new test programs and using the evaluation to choose new test programs until the desired coverage is found or a criterion or criteria established by a user or a system designer are met.
  • the search technique uses algorithms.
  • the algorithms that may be used are known and include genetic algorithms, genetic programming algorithms, evolutionary programming algorithms, simulated annealing algorithms, neural-net training algorithms, and other suitable algorithms.
  • Coverage monitors may be used to gather or collect coverage data either during or after executing a test program to allow the new coverage data to be evaluated relative to the existing coverage metrics.
  • Coverage monitors include manually-generated specific-event monitors, silicon-based monitors, automatically-generated coverage monitors, code coverage monitors, or other suitable monitors. Additionally, it will be appreciated that the test program-execution medium can vary from software-based simulation to hardware-accelerated simulation to actual hardware.
  • the process of evaluating the new coverage data generated from a test program involves comparing the coverage data to the desired coverage designated by a user or system designer. If the desired coverage has not been met, the new coverage data is used as evaluation criterion to guide the process to achieve iterative improvement in order to quickly find the designated coverage. Although there are many types of coverage data, the disclosed techniques use coverage data that is measurable.
  • FIG. 3 further shows that the FE is used in determining whether the population has reached its maximum size or desired size at operation 210 . For example, if the population has not met its actual maximum size at operation 210 , an empty abstract syntax tree (AST) is created at operation 220 . A random microprocessor test generator is used to create random instructions and data to complete the AST at operation 230 . At operation 240 , a translator is used to translate the AST into an executable test program.
  • AST abstract syntax tree
  • the executable test program may be executed, for example, on an RTL simulation model wherein reporting data is generated at operation 260 .
  • Reporting data relates to coverage of a set of microarchitectural events, sequences of microarchitectural events, or any combination thereof. This operation may run on TA 208 .
  • the AST and the corresponding coverage data are placed into the population 270 at operation 280 .
  • the AST and corresponding coverage data may replace a portion of the existing data in the population, if necessary.
  • the necessity of replacing a portion of the data in the population is based upon the maximum or desired size of the population and a replacement algorithm known in the art.
  • the operation is ended at operation 285 provided that the desired coverage has been met. If not, a new generation process for an individual test program in the population is performed looping back to operation 210 followed by the subsequent operations as shown in FIG. 3 .
  • One AST is selected based upon coverage and subjected to a strategy for mutating it 224 . Mutation involves changing a test program by replacing a portion of it by a modified or random portion. Thereafter, operations 230 , 240 , 260 , and so on are followed.
  • One method of selecting a genetic operation indicated to the system may involve a designated percentage of operations, such as 90% of the genetic operations selected must be cross-over.
  • Another method is referred to as adaptive tuning.
  • the system tracks the genetic operation that provides the most gains in coverage. Each type of genetic operation and its average coverage gain generated are recorded in storage device 18 . The genetic operation is then automatically selected that provided the greatest coverage gain. Consequently, the desired coverage may be more quickly achieved by this method of selecting the genetic operation.
  • the cross-over operation 225 involves combining at least one or more characteristics from at least one individual test program and at least one or more characteristics from at least one other test program. These characteristics are used to form a new AST. Thereafter, operations 240 , 260 , and so on are followed.
  • FIG. 4 shows another embodiment of the invention in which a distributed computation framework is shown using shared computer resources. Shared resources reduce the time required to practice the invention.
  • This embodiment of the invention comprises a local execution scheduler (LES), a global execution scheduler (GES), component servers, components and graphical user interfaces. Other configurations also may be used.
  • LES local execution scheduler
  • GES global execution scheduler
  • component servers components
  • graphical user interfaces Other configurations also may be used.
  • Each application requires a different sequence of operations to be performed with regard to each test program to find the coverage data for that test program.
  • the LES requests a component from the GES, uses it, and then releases that component so that another application may use that component.
  • This operation can be performed for one or more test programs. For multiple test programs, the operation may be performed in series or in parallel.
  • the GES is a central process to which all other processes may attach. Resources may be shared by a project group by running one GES. Resources such as components may be shared when two or more applications are attached.
  • the GES is capable of sending a request to component servers to start components. Once the GES sends a request to the component server to start the components, the components perform application-specific functions such as building or analyzing test programs.
  • FE and LES are part of the computer program.
  • LES requests a component from the GES.
  • LES uses the component and then releases the component to allow another application to use it. This process is generally performed in series but it can be performed in parallel for multiple test programs.
  • the GES performs the function of controlling data flow from the various component servers.
  • component server 660 , component server 662 , and component server 664 are coupled to GES 675 . This allows data to flow to and from these components to GES 675 .
  • Coupled to these component servers are a plurality of individual components.
  • component 666 and component 668 are coupled to component server 660 .
  • component 670 is coupled to component server 662 .
  • Component server 672 and component 674 are coupled to component server 664 .
  • Component servers start the components when the component servers are requested to do so by the GES.
  • GES 675 is also coupled to graphical user interface 680 and to FE 605 , LES 610 , FE 640 , LES 650 , and a remote GUI 655 .
  • a remote GUI may be used to view properties, control applications and the GES for machines other than those upon which these processes were started.
  • FE 605 and LES 610 form one application program.
  • FE 640 and LES 650 form another application program. Both of these applications are also coupled to a GUI and population data.
  • FE 605 and LES 610 are coupled to GUI 600 and to the population data 620 .
  • FE 640 and LES 650 are coupled to GUI 630 and population data 660 .
  • FIG. 5 shows displays that may result on the GUI by running a test program. For example, from these displays, a user can input directions to FE, if necessary.
  • FIG. 6 shows that an embodiment of the invention achieves the coverage that is desired in less time and in less computation cycles than conventional methods.
  • the results for the number of test programs are shown for the floating point coverage percentage for the invention compared to a conventional method.
  • the point of 40.9% coverage was achieved in 15,000 test programs by the control run (no feedback system) compared to only 2,584 required by the invention's feedback system.
  • the feedback system shows an 83% reduction in the amount of effort required to find this level of coverage.
  • running the same number of test programs (15,000) with the invention compared to a conventional method results in achieving 24.7% additional coverage by the invention. Accordingly, the invention improves the chances of finding the desired coverage in a shorter period of time in comparison to conventional methods.

Abstract

A computer system and a computer-implemented method for generating test programs that satisfy at least one termination criterion. The computer system includes a hardware unit to transmit data. A processor is coupled to the hardware unit and to a storage device. The storage device has stored therein at least one algorithm and a plurality of routines. When the processor executes a routine(s), data is generated. The routine causes the processor to access an algorithm, generate a test program, and analyze a test program. A computer implemented method is also disclosed for generating test programs.

Description

    BACKGROUND OF THE INVENTION
  • 1. Field of the Invention
  • The invention relates generally to validation methods and more specifically to computer implemented validation methods that efficiently generate test programs that satisfy a criterion established by a user or by a system designer.
  • 2. Description of Related Art
  • Validation test programs are a series of inputs that are used to verify the functionality of a device such as a microprocessor. Validation of a device may be performed in numerous ways. For example, the device being tested may be simulated by a computer program. Alternatively, the device itself may be tested.
  • Validation methods include test-based methods, coverage-based validation methods, and other known methods. A coverage-based method, for example, executes a test program that generates new coverage data that is then manually evaluated in view of existing coverage data to determine whether the desired coverage has been reached. Coverage data may be used to gauge the “goodness” of test programs that are used to find “bugs” in a design of a device such as a processor. Coverage data is data that indicates what elements of a given set of conditions were activated during a dynamic or static evaluation of a device under test.
  • Determining whether the coverage data generated from a test program has achieved the coverage that is necessary is a very labor intensive process. Additionally, a significant amount of effort to redirect a test generator to create a new test program is required.
  • SUMMARY OF THE INVENTION
  • In one embodiment, a computer system and a computer-implemented method are disclosed for generating validation test programs. The computer system comprises a processor coupled to a storage device. The storage device has stored therein at least one routine. When the processor executes at least one routine, data is generated. The routine causes the processor to generate and analyze a test program. The routine also generates at least one subsequent test program to be generated until at least one termination criterion is met.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The features, aspects, and advantages of the invention will become more thoroughly apparent from the following detailed description, appended claims, and accompanying drawings in which:
  • FIG. 1 illustrates an exemplary computer system in accordance with an embodiment of the invention;
  • FIG. 2 illustrates a flow chart of an exemplary creation process for an individual test program in a population in an embodiment of the invention;
  • FIG. 3 illustrates an exemplary creation process for each individual test program in a population in an embodiment of the invention;
  • FIG. 4 illustrates a computer system using shared resources in accordance with an embodiment of the invention;
  • FIG. 5 illustrates displays that may be revealed to a use in accordance with an embodiment of the invention; and
  • FIG. 6 illustrates results of an embodiment of the invention.
  • DETAILED DESCRIPTION OF THE INVENTION
  • The present invention relates to a method and an apparatus for generating validation test programs that are used to simulate a device by using a computer program before the device has been fabricated or the device itself can be tested. The following detailed description and accompanying drawings are provided for the purpose of describing and illustrating presently preferred embodiments of the invention only and are not intended to limit the scope of the invention.
  • In one embodiment of the invention, an initial population of test programs is either input or generated. The test program(s) are then stored on the storage device. A test program is then selected for execution. The coverage data generated from the execution of a test program is analyzed to determine whether the desired coverage has been attained. The coverage that is required is typically designated by a user or system designer. Based upon the analysis of the new coverage data, test programs are selected for genetic mutation and/or recombination which is used to create a new test program. This new test program is then executed generating new coverage data to be analyzed. This process is repeated until the required coverage is attained.
  • Disclosed techniques may be used in various forms of validation, including architectural validation, micro-architectural validation, unit-level validation, external bus validation, etc. More specifically, the techniques used in performing functional validation in digital systems including microprocessors and generating functional test suites for computer program or software systems. Generally, the invention is able to attain the same or higher level of coverage in less time with less human effort compared to traditional methods.
  • In another embodiment of the invention, new test programs are created by a test generator (TG), by using a genetic operation. A genetic operation includes operations such as a mutation operation, a cross-over operation, or numerous other suitable operations. A mutation involves at least one test program that whenever an operation is used to generate a new test program, data from the population is selected and used in the algorithm. If the designated coverage is not attained (or some other termination criterion or criteria have not been met), the test program is modified by the TG and the process is repeated. Alternatively, an operator using a monitor may input a new test program, thereby injecting “hints” into the operation. A test program is then generated and executed. New coverage data is created and evaluated to determine whether the desired coverage has been attained.
  • FIG. 1 illustrates one embodiment of a computer system 10 which implements the principles of the present invention. Computer system 10 comprises a processor 17, a storage device 18, and a bus 15. Processor 17 is coupled to the storage device 18 by bus 15. In addition, a number of user input/output devices, such as a keyboard 20 and a display 25, are also coupled to the bus 15. Processor 17 represents a central processing unit of any type of architecture (e.g., the Intel architecture, Hewlett Packard architecture, Sun Microsystems architectures, IBM architectures, etc.), or hybrid architecture. In addition, processor 17 could be implemented on one or more chips. Storage device 18 represents one or more mechanisms for storing data such as population data, coverage data, etc. Storage device 18 may include read only memory (ROM), random access memory (RAM), magnetic disk storage mediums, optical storage mediums, flash memory devices, and/or other machine-readable mediums. Bus 15 represents one or more buses (e.g., AGP, PCI, ISA, X-Bus, VESA, etc.) and bridges (also termed as bus controllers). While this embodiment is described in relation to a single processor computer system, the invention could be implemented in a multi-processor computer system. In addition to other devices, one or more of a network 30 may be present. Network 30 represents one or more network connections for transmitting data over a machine readable media. The invention could also be implemented on multiple computers connected via such a network.
  • FIG. 1 also illustrates that the storage device 18 has stored therein data 135 and software 136. Data 135 represents data stored in one or more of the formats described herein. Software or computer program 136 represents the necessary code for performing any and/or all of the techniques described with reference to FIGS. 2-6. It will be recognized by one of ordinary skill in the art that the storage device 18 preferably contains additional software (not shown), which is not necessary to understanding the invention.
  • FIG. 2 provides one example of an application of evolutionary computation involving a representative algorithm. It will be appreciated that numerous examples exist and that the invention is not limited to any one example. At operation 100, an optimization problem is defined by the user. To illustrate, a user may define the optimization problem as generating iA32 (32-bit Intel Architecture) test programs that, when executed, reach many new states in a new microprocessor design.
  • At operation 105, different solutions to the optimization problem are defined by the system designer or user. Each solution is called an individual. Each individual test program may be encoded as an abstract syntax tree (AST). Each AST encodes the structure and data of an iA32 test program. For example, some nodes in the AST contain the instructions to be executed during the test program.
  • At operation 115, a fitness function is defined by the user or system designer. The number of different types of fitness functions is unlimited. The fitness function defines the “goodness” of a particular individual. For example, the fitness function of each individual test program may be defined as the number of new states it reaches in the new microprocessor design.
  • At operation 120, an initial set of individuals is created. This initial set of individuals is referred to as the initial population. For example, an iA32 random test generator is used to create a set of random test programs. Alternatively, the population may start with a set of existing test programs.
  • At operation 125, the individuals are evaluated in the population according to the fitness function. For each test program, the new microprocessor may be simulated and how many new states that are reached are recorded. This number is referred to as the individual's fitness.
  • At operation 130, if the termination criterion (or criteria) is satisfied, the process is terminated at 132. For example, if all known states in the new microprocessor have been reached, the process is ended. It will be appreciated that a variety of termination criterion may be input by a user and the claimed invention is not limited by examples provided herein.
  • At operation 135, some of the better individuals in the population are selected. For example, a user may require that genetic operations be randomly chosen for a mutation or crossover operation. The user may further require that, for example, eight random individuals from the population be selected. From the eight individuals, an individual is chosen that has the highest fitness. (This is known in the art as “tournament” selection.) If a crossover operation is chosen, this process is repeated to select another individual.
  • At operation 140, new individuals are created by applying one of several genetic operations. These new individuals are then added to the population.
  • Several genetic operations may be chosen to illustrate this operation. If a mutation operation is selected, some of the iA32 instructions from the selected test program are randomly removed and are replaced with new random instructions. If a crossover operation is selected, some of the iA32 instructions from the first selected test program are randomly removed and are replaced with randomly selected instructions from the second selected test program.
  • For this newly-created test program, the new microprocessor is simulated and the number of new states that are reached (i.e., its fitness) is recorded. The new test program and its fitness are then placed into the population.
  • At operation 145, some of the poorer individuals in the population are removed from the population. For example, eight random individuals may be selected from the population. At least one individual that has the lowest fitness among the eight individuals is removed from the population. Operations 125 to 145 are then repeated until the termination criterion or criteria are met.
  • FIG. 3 shows one embodiment of the invention for generating new test programs using coverage data as a mechanism to guide the generation of each test program. Examples of test generation includes a microprocessor test generator that may generate a sequence of microprocessor instructions and data that will be executed by a model of the microprocessor or an actual microprocessor. Another example includes a unit-level test generator that may generate a sequence of electrical signals that may be fed sequentially to the device under test. The process described below is repeated until a test program is executed which generates coverage data that satisfy the coverage designated by a user or system designer. Although an embodiment of the invention uses coverage data to determine the “goodness” of an individual, it will be appreciated other methods may be used. Data may be processed in series or in parallel when practicing the invention.
  • FIG. 3 further illustrates one embodiment of the invention in which a computer program comprises four modules or routines—a test builder (TB) 204, a test generator (TG) 206, a test analyzer (TA) 208, and a feedback engine (FE) 202. These modules may run on the same computer system or one or more may run on separate computer systems that may be connected through a network.
  • One embodiment of the invention relates to generating high-coverage validation test suites having the characteristics of using search techniques that rely upon improvement of evolutionary computation methods and evaluating newly generated coverage data using existing coverage metrics as a feedback mechanism to guide these methods. One search technique navigates through a space of potential solutions by evaluating a subset of those solutions based upon the selection of new test programs and using the evaluation to choose new test programs until the desired coverage is found or a criterion or criteria established by a user or a system designer are met. The search technique uses algorithms. The algorithms that may be used are known and include genetic algorithms, genetic programming algorithms, evolutionary programming algorithms, simulated annealing algorithms, neural-net training algorithms, and other suitable algorithms.
  • Coverage monitors (not shown) may be used to gather or collect coverage data either during or after executing a test program to allow the new coverage data to be evaluated relative to the existing coverage metrics. Coverage monitors include manually-generated specific-event monitors, silicon-based monitors, automatically-generated coverage monitors, code coverage monitors, or other suitable monitors. Additionally, it will be appreciated that the test program-execution medium can vary from software-based simulation to hardware-accelerated simulation to actual hardware.
  • The process of evaluating the new coverage data generated from a test program involves comparing the coverage data to the desired coverage designated by a user or system designer. If the desired coverage has not been met, the new coverage data is used as evaluation criterion to guide the process to achieve iterative improvement in order to quickly find the designated coverage. Although there are many types of coverage data, the disclosed techniques use coverage data that is measurable.
  • FIG. 3 further shows that the FE is used in determining whether the population has reached its maximum size or desired size at operation 210. For example, if the population has not met its actual maximum size at operation 210, an empty abstract syntax tree (AST) is created at operation 220. A random microprocessor test generator is used to create random instructions and data to complete the AST at operation 230. At operation 240, a translator is used to translate the AST into an executable test program.
  • The executable test program may be executed, for example, on an RTL simulation model wherein reporting data is generated at operation 260. Reporting data relates to coverage of a set of microarchitectural events, sequences of microarchitectural events, or any combination thereof. This operation may run on TA 208.
  • The AST and the corresponding coverage data are placed into the population 270 at operation 280. The AST and corresponding coverage data may replace a portion of the existing data in the population, if necessary. The necessity of replacing a portion of the data in the population is based upon the maximum or desired size of the population and a replacement algorithm known in the art. The operation is ended at operation 285 provided that the desired coverage has been met. If not, a new generation process for an individual test program in the population is performed looping back to operation 210 followed by the subsequent operations as shown in FIG. 3.
  • One AST is selected based upon coverage and subjected to a strategy for mutating it 224. Mutation involves changing a test program by replacing a portion of it by a modified or random portion. Thereafter, operations 230, 240, 260, and so on are followed.
  • It will be appreciated that a variety of methods may be used to determine what genetic operation is used, and the claimed invention is not limited by any example. One method of selecting a genetic operation indicated to the system may involve a designated percentage of operations, such as 90% of the genetic operations selected must be cross-over. Another method is referred to as adaptive tuning. In this method, the system tracks the genetic operation that provides the most gains in coverage. Each type of genetic operation and its average coverage gain generated are recorded in storage device 18. The genetic operation is then automatically selected that provided the greatest coverage gain. Consequently, the desired coverage may be more quickly achieved by this method of selecting the genetic operation.
  • The cross-over operation 225 involves combining at least one or more characteristics from at least one individual test program and at least one or more characteristics from at least one other test program. These characteristics are used to form a new AST. Thereafter, operations 240, 260, and so on are followed.
  • FIG. 4 shows another embodiment of the invention in which a distributed computation framework is shown using shared computer resources. Shared resources reduce the time required to practice the invention. This embodiment of the invention comprises a local execution scheduler (LES), a global execution scheduler (GES), component servers, components and graphical user interfaces. Other configurations also may be used.
  • 1. Local Execution Scheduler (LES)
  • Each application requires a different sequence of operations to be performed with regard to each test program to find the coverage data for that test program. To perform each operation, the LES requests a component from the GES, uses it, and then releases that component so that another application may use that component. This operation can be performed for one or more test programs. For multiple test programs, the operation may be performed in series or in parallel.
  • 2. Global Execution Scheduler (GES)
  • The GES is a central process to which all other processes may attach. Resources may be shared by a project group by running one GES. Resources such as components may be shared when two or more applications are attached.
  • The GES is capable of sending a request to component servers to start components. Once the GES sends a request to the component server to start the components, the components perform application-specific functions such as building or analyzing test programs.
  • As noted above, FE and LES are part of the computer program. To perform each operation, LES requests a component from the GES. LES uses the component and then releases the component to allow another application to use it. This process is generally performed in series but it can be performed in parallel for multiple test programs.
  • In FIG. 5, the GES performs the function of controlling data flow from the various component servers. For example, component server 660, component server 662, and component server 664 are coupled to GES 675. This allows data to flow to and from these components to GES 675. Coupled to these component servers are a plurality of individual components. For example, component 666 and component 668 are coupled to component server 660. Additionally, component 670 is coupled to component server 662. Component server 672 and component 674 are coupled to component server 664. Component servers start the components when the component servers are requested to do so by the GES.
  • GES 675 is also coupled to graphical user interface 680 and to FE 605, LES 610, FE 640, LES 650, and a remote GUI 655. A remote GUI may be used to view properties, control applications and the GES for machines other than those upon which these processes were started.
  • FE 605 and LES 610 form one application program. FE 640 and LES 650 form another application program. Both of these applications are also coupled to a GUI and population data. For example, FE 605 and LES 610 are coupled to GUI 600 and to the population data 620. FE 640 and LES 650 are coupled to GUI 630 and population data 660.
  • FIG. 5 shows displays that may result on the GUI by running a test program. For example, from these displays, a user can input directions to FE, if necessary.
  • FIG. 6 shows that an embodiment of the invention achieves the coverage that is desired in less time and in less computation cycles than conventional methods. The results for the number of test programs are shown for the floating point coverage percentage for the invention compared to a conventional method. The point of 40.9% coverage was achieved in 15,000 test programs by the control run (no feedback system) compared to only 2,584 required by the invention's feedback system. Thus, the feedback system shows an 83% reduction in the amount of effort required to find this level of coverage. Additionally, running the same number of test programs (15,000) with the invention compared to a conventional method results in achieving 24.7% additional coverage by the invention. Accordingly, the invention improves the chances of finding the desired coverage in a shorter period of time in comparison to conventional methods.
  • In the preceding detailed description, the invention is described with reference to specific embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.

Claims (26)

1-20. (canceled)
21. A method comprising:
generating a first test program population to test the functionality of an integrated circuit (IC), the first test program population comprising a plurality of test programs, each test program having a first set of instructions and data;
executing each of the test programs in the first test program population;
evaluating a first set of coverage data from the first test program population to determine if the IC has been sufficiently tested, wherein evaluating the first set of coverage data comprises comparing the coverage data to a predetermined coverage requirement; and
generating a second program population if the IC has not been sufficiently tested by the first test program population, the second test program population comprising a plurality of updated test programs, wherein each updated test program is a mutation of a test of the first test program-population for a combination of two or more of the test programs of the first test program population.
22. The method of claim 21, further comprising:
executing the second test program population.
23. The method of claim 22, wherein generating the first test program population comprises:
generating a first abstract syntax tree (AST);
generating the first set of instructions and data for the first AST; and
translating the first AST into a first executable test program.
24. The method of claim 23, wherein generating the second test program population comprises:
generating a second abstract syntax tree (AST);
generating a second set of instructions and data for the second AST; and
translating the second AST into a second executable test program population.
25. The method of claim 24, further comprising mutating a selected AST.
26. The method of claim 25, wherein mutating a selected AST comprises:
selecting an AST;
removing a segment of the selected AST; and
inserting a replacement segment into the selected AST to form a mutated AST.
27. The method of claim 26, further comprising:
generating a third set of instructions and data for the mutated AST; and
translating the mutated AST into a third executable test program population.
28. The method of claim 25, wherein mutating a selected AST comprises:
selecting the first AST and the second AST; and
combining a segment of the first AST with a segment of the second AST to form a mutated AST.
29. The method of claim 28, further comprising:
generating a third set of instructions and data for the mutated AST; and
translating the mutated AST into a third executable test program population.
30. The method of claim 23, further comprising:
adding the first AST and the first set of coverage data into a test program after the first test program population has been executed.
31. A computer system comprising:
a storage device coupled to a processor and having stored therein at least one routine, which when executed by the processor, causes the processor to generate data, the routine causing the processor to,
generate a first test program population to test the functionality of an integrated circuit (IC), the first test program population comprising a plurality of test programs, each test program having a first set of instructions and data;
execute each of the test programs in the first test program population;
evaluate a first set of coverage data from the first test program population to determine if the IC has been sufficiently tested, wherein evaluating the first set of coverage data comprises comparing the coverage data to a predetermined coverage; and
generate a second program population if the IC has not been sufficiently tested by the first test program population, the second test program population comprising a plurality of updated test programs, wherein each updated test program is a mutation of a test of the first test program-population for a combination of two or more of the test programs of the first test program population.
32. The computer system of claim 31, wherein the routine further causes the processor to,
execute the second test program population.
33. The computer system of claim 32, wherein generating the first test program population comprises:
generating a first abstract syntax tree (AST);
generating the first set of instructions and data for the first AST; and
translating the first AST into a first executable test program.
34. The computer system of claim 33, wherein generating the second test program population comprises:
generating a second abstract syntax tree (AST);
generating a second set of instructions and data for the second AST; and
translating the second AST into a second executable test program population.
35. The computer system of claim 34, wherein the routine further causes the processor to mutate a selected AST.
36. The computer system of claim 35, wherein mutating a selected AST comprises:
selecting an AST;
removing a segment of the selected AST; and
inserting a replacement segment into the selected AST to form a mutated AST.
37. The computer system of claim 36, wherein the routine further causes the processor to,
generate a third set of instructions and data for the mutated AST; and
translate the mutated AST into a third executable test program population.
38. The computer system of claim 35, wherein mutating a selected AST comprises:
selecting the first AST and the second AST; and
combining a segment of the first AST with a segment of the second AST to form a mutated AST.
39. The computer system of claim 38, wherein the routine further causes the processor to,
generating a third set of instructions and data for the mutated AST; and
translating the mutated AST into a third executable test program population.
40. The computer system of claim 33, wherein the routine further causes the processor to,
add the first AST the first set of coverage data into test program population after the first test program has been executed.
41. A validation test system comprising:
a test builder to generate test program populations to test the functionality of an integrated circuit (IC);
a test generator to translate the test program populations into an executable test;
a test analyzer to execute the test program populations; and
a feedback engine to build and update a population of test programs by generating an abstract syntax tree (AST) for each test program populations.
42. The system of claim 41, wherein the feedback engine determines whether a predetermined test program population threshold has been reached after a test program populations has been executed.
43. The system of claim 42, wherein the feedback engine generates one or more mutated ASTs if it is determined that the predetermined test program population threshold has been reached.
44. The system of claim 43, wherein the feedback engine generates a mutated AST by selecting a first AST, removing a segment of the first AST and inserting a replacement segment into the first AST.
45. The system of claim 43, wherein the feedback engine generates a mutated AST by selecting a first AST and a second AST and combining a segment of the first AST with a segment of the second AST to form.
US11/035,138 1999-12-30 2005-01-13 Method and apparatus for generation of validation tests Abandoned US20050166096A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/035,138 US20050166096A1 (en) 1999-12-30 2005-01-13 Method and apparatus for generation of validation tests

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/475,526 US6931629B1 (en) 1999-12-30 1999-12-30 Method and apparatus for generation of validation tests
US11/035,138 US20050166096A1 (en) 1999-12-30 2005-01-13 Method and apparatus for generation of validation tests

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/475,526 Continuation US6931629B1 (en) 1999-12-30 1999-12-30 Method and apparatus for generation of validation tests

Publications (1)

Publication Number Publication Date
US20050166096A1 true US20050166096A1 (en) 2005-07-28

Family

ID=34794170

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/475,526 Expired - Fee Related US6931629B1 (en) 1999-12-30 1999-12-30 Method and apparatus for generation of validation tests
US11/035,138 Abandoned US20050166096A1 (en) 1999-12-30 2005-01-13 Method and apparatus for generation of validation tests

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/475,526 Expired - Fee Related US6931629B1 (en) 1999-12-30 1999-12-30 Method and apparatus for generation of validation tests

Country Status (1)

Country Link
US (2) US6931629B1 (en)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2420886A (en) * 2004-12-03 2006-06-07 Advanced Risc Mach Ltd Scoring mechanism for automatically generated test programs
US20070225826A1 (en) * 2006-03-21 2007-09-27 Chien-Chung Huang Validation system with flow control capability
US20100057424A1 (en) * 2004-07-30 2010-03-04 Joerg Grosse Method for evaluating a test program quality
US20110078651A1 (en) * 2009-09-28 2011-03-31 Cadence Design Systems, Inc. Method and system for test reduction and analysis
US20170060582A1 (en) * 2015-09-01 2017-03-02 Freescale Semiconductor, Inc. Arbitrary instruction execution from context memory

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6931629B1 (en) * 1999-12-30 2005-08-16 Intel Corporation Method and apparatus for generation of validation tests
US7152227B1 (en) * 2003-06-17 2006-12-19 Xilinx, Inc. Automated assessment of programming language coverage by one or more test programs
US20050050524A1 (en) * 2003-08-25 2005-03-03 Arm Limited Generating software test information
US20060195681A1 (en) * 2004-12-06 2006-08-31 Arm Limited Test program instruction generation
US20060150154A1 (en) * 2004-12-06 2006-07-06 Arm Limited Test program instruction generation
US20070234309A1 (en) * 2006-03-31 2007-10-04 Microsoft Corporation Centralized code coverage data collection
DE102006056432A1 (en) * 2006-11-28 2008-05-29 Certess, Inc., Campbell Method for testing a computer program
US8453115B2 (en) * 2007-04-27 2013-05-28 Red Hat, Inc. Automatic data manipulation to influence code paths
US7984335B2 (en) * 2008-03-20 2011-07-19 Microsoft Corporation Test amplification for datacenter applications via model checking
US8140476B2 (en) * 2009-12-16 2012-03-20 International Business Machines Corporation Statistical quality monitoring and enhancement

Citations (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4729096A (en) * 1984-10-24 1988-03-01 International Business Machines Corporation Method and apparatus for generating a translator program for a compiler/interpreter and for testing the resulting translator program
US5335342A (en) * 1991-05-31 1994-08-02 Tiburon Systems, Inc. Automated software testing system
US5475843A (en) * 1992-11-02 1995-12-12 Borland International, Inc. System and methods for improved program testing
US5651111A (en) * 1994-06-07 1997-07-22 Digital Equipment Corporation Method and apparatus for producing a software test system using complementary code to resolve external dependencies
US5754760A (en) * 1996-05-30 1998-05-19 Integrity Qa Software, Inc. Automatic software testing tool
US5754860A (en) * 1996-07-23 1998-05-19 Digital Equipment Corporation Method and apparatus for software testing using a differential testing technique to test compilers
US5799266A (en) * 1996-09-19 1998-08-25 Sun Microsystems, Inc. Automatic generation of test drivers
US5841947A (en) * 1996-07-12 1998-11-24 Nordin; Peter Computer implemented machine learning method and system
US5930780A (en) * 1996-08-22 1999-07-27 International Business Machines Corp. Distributed genetic programming
US5946673A (en) * 1996-07-12 1999-08-31 Francone; Frank D. Computer implemented machine learning and control system
US6031990A (en) * 1997-04-15 2000-02-29 Compuware Corporation Computer software testing management
US6138112A (en) * 1998-05-14 2000-10-24 Microsoft Corporation Test generator for database management systems
US6175948B1 (en) * 1998-02-05 2001-01-16 Motorola, Inc. Method and apparatus for a waveform compiler
US6226716B1 (en) * 1998-12-22 2001-05-01 Unisys Corporation Test driver for use in validating a circuit design
US6347388B1 (en) * 1997-06-03 2002-02-12 Verisity Ltd. Method and apparatus for test generation during circuit design
US6393594B1 (en) * 1999-08-11 2002-05-21 International Business Machines Corporation Method and system for performing pseudo-random testing of an integrated circuit
US6425118B1 (en) * 1997-07-18 2002-07-23 Compaq Computer Corporation System for automatically generating tests to ensure binary compatibility between software components produced by a source-to-source computer language translator
US6438722B1 (en) * 1999-08-11 2002-08-20 International Business Machines Corporation Method and system for testing an integrated circuit
US6931629B1 (en) * 1999-12-30 2005-08-16 Intel Corporation Method and apparatus for generation of validation tests
US6948154B1 (en) * 1999-03-22 2005-09-20 Oregon State University Methodology for testing spreadsheets

Patent Citations (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4729096A (en) * 1984-10-24 1988-03-01 International Business Machines Corporation Method and apparatus for generating a translator program for a compiler/interpreter and for testing the resulting translator program
US5335342A (en) * 1991-05-31 1994-08-02 Tiburon Systems, Inc. Automated software testing system
US5475843A (en) * 1992-11-02 1995-12-12 Borland International, Inc. System and methods for improved program testing
US5651111A (en) * 1994-06-07 1997-07-22 Digital Equipment Corporation Method and apparatus for producing a software test system using complementary code to resolve external dependencies
US5754760A (en) * 1996-05-30 1998-05-19 Integrity Qa Software, Inc. Automatic software testing tool
US6098059A (en) * 1996-07-12 2000-08-01 Nordin; Peter Computer implemented machine learning method and system
US5841947A (en) * 1996-07-12 1998-11-24 Nordin; Peter Computer implemented machine learning method and system
US5946673A (en) * 1996-07-12 1999-08-31 Francone; Frank D. Computer implemented machine learning and control system
US5754860A (en) * 1996-07-23 1998-05-19 Digital Equipment Corporation Method and apparatus for software testing using a differential testing technique to test compilers
US5930780A (en) * 1996-08-22 1999-07-27 International Business Machines Corp. Distributed genetic programming
US5799266A (en) * 1996-09-19 1998-08-25 Sun Microsystems, Inc. Automatic generation of test drivers
US6031990A (en) * 1997-04-15 2000-02-29 Compuware Corporation Computer software testing management
US6347388B1 (en) * 1997-06-03 2002-02-12 Verisity Ltd. Method and apparatus for test generation during circuit design
US6425118B1 (en) * 1997-07-18 2002-07-23 Compaq Computer Corporation System for automatically generating tests to ensure binary compatibility between software components produced by a source-to-source computer language translator
US6175948B1 (en) * 1998-02-05 2001-01-16 Motorola, Inc. Method and apparatus for a waveform compiler
US6138112A (en) * 1998-05-14 2000-10-24 Microsoft Corporation Test generator for database management systems
US6226716B1 (en) * 1998-12-22 2001-05-01 Unisys Corporation Test driver for use in validating a circuit design
US6948154B1 (en) * 1999-03-22 2005-09-20 Oregon State University Methodology for testing spreadsheets
US6393594B1 (en) * 1999-08-11 2002-05-21 International Business Machines Corporation Method and system for performing pseudo-random testing of an integrated circuit
US6438722B1 (en) * 1999-08-11 2002-08-20 International Business Machines Corporation Method and system for testing an integrated circuit
US6931629B1 (en) * 1999-12-30 2005-08-16 Intel Corporation Method and apparatus for generation of validation tests

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100057424A1 (en) * 2004-07-30 2010-03-04 Joerg Grosse Method for evaluating a test program quality
US8311793B2 (en) * 2004-07-30 2012-11-13 Springsoft Usa, Inc. Method for evaluating a test program quality
GB2420886A (en) * 2004-12-03 2006-06-07 Advanced Risc Mach Ltd Scoring mechanism for automatically generated test programs
US20060123272A1 (en) * 2004-12-03 2006-06-08 Arm Limited Scoring mechanism for automatically generated test programs
US7444271B2 (en) * 2004-12-03 2008-10-28 Arm Limited Scoring mechanism for automatically generated test programs
GB2420886B (en) * 2004-12-03 2009-06-03 Advanced Risc Mach Ltd Scoring mechanism for automatically generated test programs for testing a data processing apparatus
US20070225826A1 (en) * 2006-03-21 2007-09-27 Chien-Chung Huang Validation system with flow control capability
US7496464B2 (en) * 2006-03-21 2009-02-24 Mediatek Usa Inc. Validation system with flow control capability
US20110078651A1 (en) * 2009-09-28 2011-03-31 Cadence Design Systems, Inc. Method and system for test reduction and analysis
US8719771B2 (en) * 2009-09-28 2014-05-06 Cadence Design Systems, Inc. Method and system for test reduction and analysis
US20170060582A1 (en) * 2015-09-01 2017-03-02 Freescale Semiconductor, Inc. Arbitrary instruction execution from context memory
US9785538B2 (en) * 2015-09-01 2017-10-10 Nxp Usa, Inc. Arbitrary instruction execution from context memory

Also Published As

Publication number Publication date
US6931629B1 (en) 2005-08-16

Similar Documents

Publication Publication Date Title
US20050166096A1 (en) Method and apparatus for generation of validation tests
US7331007B2 (en) Harnessing machine learning to improve the success rate of stimuli generation
US7644398B2 (en) System and method for automatic test-case generation for software
Beberg et al. Folding@ home: Lessons from eight years of volunteer distributed computing
US7373636B2 (en) Automated software testing system and method
US7512839B2 (en) Methods, systems, and media for generating a regression suite database
US7117484B2 (en) Recursive use of model based test generation for middleware validation
US9465718B2 (en) Filter generation for load testing managed environments
US7472034B2 (en) System and method for test generation for system level verification using parallel algorithms
US7478371B1 (en) Method for trace collection
Luo et al. ICS protocol fuzzing: Coverage guided packet crack and generation
WO2008074529A2 (en) Method, system and computer program for performing regression tests
JPS5995657A (en) Logic simulator
CN110633200A (en) Method and device for testing intelligent contracts
US20080294941A1 (en) Method and System for Test Case Generation
US7860700B2 (en) Hardware verification batch computing farm simulator
CN112148582A (en) Policy testing method and device, computer readable medium and electronic device
Surendran et al. Evolution or revolution: the critical need in genetic algorithm based testing
US20090055331A1 (en) Method and apparatus for model-based testing of a graphical user interface
Reger et al. Checkable Proofs for First-Order Theorem Proving.
Nguyen et al. Automated continuous testing of multi-agent systems
CN111814414A (en) Coverage rate convergence method and system based on genetic algorithm
US20050203717A1 (en) Automated testing system, method and program product using testing map
GB2420886A (en) Scoring mechanism for automatically generated test programs
US20050188275A1 (en) Systems and methods for error tracking and recovery in an expectation-based memory agent checker

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION