Automation of Processor Verification Using Recurrent Neural Networks by Fajcik, Martin et al.
Automation of Processor Verification Using
Recurrent Neural Networks
Martin Fajcik, Pavel Smrz
Department of Computer Graphics and Multimedia
Brno University of Technology, Czech Republic
{ifajcik, smrz}@fit.vutbr.cz
Marcela Zachariasova
Department of Computer Systems
Brno University of Technology, Czech Republic
zachariasova@fit.vutbr.cz
Abstract—When considering simulation-based verification of
processors, the current trend is to generate stimuli using pseudo-
random generators (PRGs), apply them to the processor inputs
and monitor the achieved coverage of its functionality in order to
determine verification completeness. Stimuli can have different
forms, for example, they can be represented by bit vectors applied
to the input ports of the processor or by programs that are
loaded directly into the program memory. In this paper, we
propose a new technique dynamically altering constraints for
PRG via recurrent neural network, which receives a coverage
feedback from the simulation of design under verification. For the
demonstration purposes we used processors provided by Codasip
as their coverage state space is reasonably big and differs for
various kinds of processors. Nevertheless, techniques presented
in this paper are widely applicable. The results of experiments
show that not only the coverage closure is achieved much sooner,
but we are able to isolate a small set of stimuli with high coverage
that can be used for running regression tests.
Index Terms—Functional Verification, Automation of Verifica-
tion, Neural network, Recurrent Neural Network, Hopfield Net-
work, UVM, Coverage-Driven Verification, Optimization Prob-
lem, Combinatorial Optimization
I. INTRODUCTION
With a raising demand on application-specific processors in
today’s market it becomes a necessity to come up with new
improved approaches that tackle the challenging task of their
complex verification. The current trend is to automate some
of the routines of simulation-based verification, for example,
generation of stimuli or targeting corner cases in coverage.
Pseudo-random stimuli generation is well defined in the
SystemVerilog language standard [1], in the Universal Verifi-
cation Methodology (UVM) [2] and even in a new standard for
portable stimuli (currently in its final revision state). Various
pseudo-random stimuli generators (PRGs) can be utilized for
that purpose, either those inbuilt in RTL simulators or external
ones (e.g. in C++) connected through direct programming
interface. Pseudo-randomness is achieved through constraints
which are able to restrict the process of generation to gainful
scenarios. This approach was devised to strike the balance
between direct and random simulations. Instead of writing
detailed verification patterns manually, the user provides a set
This paper has been supported by Brno University of Technology (FIT-S-
17-3994) and by the EC Horizon 2020 project MegaM@Rt2 ECSEL-JU, No.
737494.
of constraints and PRG generates a huge amount of stimuli in
the order of seconds.
The completeness of stimuli generation can be measured
by various metrics commonly known as coverage (we will
consider RTL coverage metrics in this paper such as branch,
statement, expression or functional coverage). We say that the
processor reached coverage closure when the value of every
monitored coverage metric is high enough to proclaim it as
verified. Such feedback-controlled method based on coverage
analysis is called Coverage-Driven Verification (CDV). A
problem of this approach comes from redundancy inbuilt in
randomness, because if the coverage feedback is not properly
propagated to PRG and reflected by suitable constraints, the
same redundant stimuli can be applied to Design Under Verifi-
cation (DUV) without any coverage increase. Even intuitively
we can observe that if the distribution of generated stimuli
would reasonably change in every consequent stimuli genera-
tion (i.e. lower probability for already generated values), we
would accelerate the verification processes and reach corner
cases and coverage closure faster.
From the practical point of view, this paper targets two
industry-wide problems:
1) Speeding up the verification process by doing optimiza-
tion of PRG constraints in such a way that coverage
closure of DUV is achieved as fast as possible.
2) Seeking the smallest set of stimuli which reaches cover-
age closure for DUV. Such stimuli set is then ideal for
regression testing.
To resolve these problems, a new method for optimization of
PRG constraints based on recurrent neural network (RNN) is
proposed. This method has 3 significant contributions. Firstly,
it automates CDV – verification runs are repeated until either
the coverage closure is reached or terminating conditions are
met. Secondly, the proposed non-invasive solution can easily
work with all verification environments that support PRG and
coverage analysis. Thirdly, values of some RNN parameters
and methods for their further tuning are suggested based on
extensive experiments.
II. RELATED WORK
Combinatorial optimization techniques already appeared in
works related to automation of verification processes. Kitchen
ar
X
iv
:1
80
3.
09
81
0v
1 
 [c
s.O
H]
  6
 M
ar 
20
18
and Kuehlmann in [3] introduced a PRG using hybrid con-
straint solver based on Markov-chain Monte Carlo methods,
which dynamically alters PRG distribution. However, these
distributions were not biased from the coverage analysis like
this work and further mentioned works are. In the past,
two general approaches based on coverage analysis have
been proposed: feedback-based CDV (FBCDV) and CDV by
construction (CDVBC). FBCDV relies on a feedback from
coverage analysis to be present during simulation and modifies
the constraints to the PRG. In contrast, CDVBC approach
relies on a generated external model of DUV which is used
to generate stimuli designed to accurately hit the coverage
tasks. CDVBC based approaches are commonly based on
transformation of coverage tasks into Boolean logic (e.g.
conjunctive normal form) and harvesting the power of SAT
solvers [4] [5]. Although it is guaranteed that this systematic
approach hits every coverage task, and using incremental SAT
solvers it can even hit multiple tasks at once, it has been proven
that the SAT problem is NP-complete and thus probably (if
P!=NP) can never be optimal. There are also feedback-based
CDV approaches utilizing SAT solvers, e.g. in [6] the DUV
is reduced based on a current program slice (to reduce its
complexity). PRG constraints are then treated as constraint-
satisfaction problem and solved with a word-level SAT solver.
The next category covers not fully automated approaches. For
instance in [7], the tool based on feedback-adjusted Markov
Models called StressTest was proposed. The tool is capable of
on-the-fly optimization of constraints, but needs an assistance
of engineer to provide a template describing interface protocols
of the system. Finally, there are FBCDV approaches based on
genetic algorithms (GA). Authors of [8] applied GA for auto-
mated generation of stimuli based on source code of specific
software application. Naturally, such approach neglected all
the details concerning the processor hardware irrelevant to the
verified application. The most similar approach to this paper is
proposed in [9]. The work introduced capability of on-the-fly
constraint optimization as well as seeking of an optimal stimuli
set. GA was integrated directly into the UVM verification
environment with profitable values of GA parameters. The
work presented in this paper builds on the GA approach (co-
authored by M. Zachariasova). The GA optimizer has been
replaced with a simple but powerful RNN. The proposed
approach can be implemented with any verification environ-
ment that utilizes coverage analysis and PRG. Various neural
network models with different network dynamics are proposed
and compared to each other in Section IV. We also provide
a short comparison to the GA approach from [9] in order to
find out which kind of optimizer is more suitable for the CDV
task.
III. PROPOSED APPROACH
A. Integration of combinatorial optimization and verification
environment
Every optimization technique needs a method to evaluate
quality of its solutions. This method is usually referred to as
an objective function (OF) (also known as the cost or the
fitness function). Since we are proposing a feedback-based
CDV technique, the OF value needs to be determined based on
the coverage analysis data. That is the reason why the proposed
technique needs to be placed in a closed-loop architecture as
shown in Fig. 1.
Fig. 1. Integration of RNN into the closed-loop solution.
Each loop in the automated verification life-cycle is com-
posed of following steps:
1) The optimizer (in our case RNN) generates changes to
PRG constraints.
2) A stimuli set is generated via PRG.
3) The controller program starts a new simulation (or series
of simulations) using the newly generated stimuli set.
4) At the end of simulation, most of HDL simulators are
capable of exporting the database containing information
collected during the simulation.
5) A subset of the collected data (in our case various types
of coverage metrics) is used to evaluate OF.
Please note that this approach is non-invasive to the verifica-
tion environment.
The PRG constraints define syntax and semantics of valid
stimuli set. They can take many forms ranging from defining
forbidden port combinations, valid instruction combinations,
probabilities of generated values, to restrictions of already used
variables. The constraints can also reduce generated stimuli to
a subset valid for various portable stimuli scenarios. In our
experimental evaluation we focus on verification of processors.
Therefore, the optimizer is changing probability constraints
on the instruction set level,the instruction level and the sub-
instruction level (all these are closely explained in Fig. III-C2).
The generated set of stimuli is in fact represented by a set of
programs compiled into binaries. For the verification purposes
we have used the UVM environment and all the scripts
controlling RTL simulation, PRG and RNN were written in
Python 2.7.
B. Hopfield model
Today, neural networks (NN) play an important role in the
field of artificial intelligence, where they become an universal
approach for modeling cognitive processes based on human
brain image. They are currently a popular concept for the
purpose of classification and regression. In [10], J.J. Hopfield
has shown that neural networks are also capable of dealing
with combinatorial optimization problems when, using his
previously proposed RNN called Hopfield network (HN), he
was able to solve traveling salesman problem. In this paper,
Fig. 2. Schema of the neuron used in Hopfield network.
we have been inspired by his idea and we propose a similar
network models capable of dealing with automation of CDV.
HN work with autonomous units called neurons. We will
label each neuron from the network with a number from
arithmetic progression mk+1 = mk + 1 starting from the
number 1. A neuron i can be defined by a triplet: input vector
x = [x1, ..., xn]
ᵀ (also called feature vector), output state vi,
and threshold θi. Each neuron combination has a connection
parameter called connection weight. We will denote the value
of such weight from the neuron i to the neuron j as wij . For
HN of size n weights between neurons can be defined by the
weight matrix (1).
W = [w1, ...,wn] =
w11 · · · w1n... . . . ...
wn1 · · · wnn
 (1)
The output of the neuron i is given by the composition (4) of
linear basis function ξ (2) with the sigmoid activation function
(sometimes called the logistic function) Ψ (3).
ξ(x,W, θi) = xwi
ᵀ − θi =
n∑
k=1
wkixk − θi (2)
Ψ(z) =
1
1 + e−z
(3)
vi = Ψ(ξ(x,W, θi)) (4)
The schema in Fig. 2 wraps up previous definitions. From the
output vi of each neuron i we can define a network output
vector (or a state vector) v = [v1, ..., vn]ᵀ.
In addition, the network constructed from such neurons
needs to satisfy several restrictions to meet the criteria of
the HN. Let N denote a set of NN neurons, then we define
following constraints:
1) There must be a defined connection weight between each
of two neurons (HN is a fully connected network).
2) Diagonal values of W are equal to 0, so the value of
the connection to the neuron itself is not used during the
network evolution (see the further text for explaining the
evolution process).
∀i ∈ N : wii = 0 (5)
3) The network weights are symmetric.
∀i, j ∈ N : wij = wji (6)
Since HN is a RNN, its state changes over time during its
evolution. To be able to determine, when the network is
in which state, we define the model time as follows: let a
variable t; t ∈ N ∧ t > 0 be a time variable, then v(t)i is
a parametrized notation of the neuron outputs and v(t) is a
network state which will be used to denote their value in
certain evolution time t. Equation (4) that uses model time
can now be rewritten as v(t+1)i = Ψ(ξ(v
(t),W, θi)). Next,
we define a network trajectory in time t to be a sequence
of states v(1), v(2), ..., v(t). There are two approaches used
for the neuron activation policy. In the synchronous policy,
all the units are activated simultaneously in each time step.
In the asynchronous policy, only one unit at each time step
is activated. The unit being activated can be chosen either
randomly or sequentially. In the following text, we will assume
that we are working with the random asynchronous policy.
In order to solve optimization problems, the OF which is
in context of neural networks commonly called the energy
function (E), needs to be defined. In [10], J.J. Hopfield defined
a monotonically decreasing energy function, which can be
used for simple problems like TSP, but does not seem to be
applicable in this case (we will define our own in the further
text).
C. Proposed solutions
It turns out that the mapping of the CDV problem to the
RNN optimization model is quite straightforward. The state
space of the processor is reachable via input stimuli with
probabilities defined as constraints for PRG. Since probability
P (A) of an event A has a domain of [0, 1], we can represent
each of these probabilities with a neuron using a sigmoid
activation. In [11], an approach for designing custom energy
function E and tips for tuning W and θ are presented.
As a result, we defined energy function as (7). Importance
of each coverage metric c ∈ C is expressed via relative
weight coefficients ac. Function Coveragec(v) reflects the
total coverage reached so far with stimuli generated from the
network state v(t) together with all previously accepted NN
states of evolution trajectory v(1),v(2), ..., v(t−1).
E(v(t)) =
∑
c∈C
acP (Coveragec(v(t))) (7)
It can be seen that if the network evolution with trajectory
v(1), v(2), ... starts in any state and only neurons leading to
the energy difference ∆E ≥ 0; ∆E = E(v(t)) − E(v(t+1))
are activated, the optimal solution state v∗ or a near optimal
local minimum state will be reached eventually. Note that
our objective is to reward new constraint settings which
have not been used yet and lead verification process to so
far unexplored processor states, instead of seeking the best
initial configuration (as we would if we would not consider
previously collected coverage data). Finally, P represents a
penalty function. In fact, it just transforms coverage values to
fit the minimization problem expectations. Since the maximum
coverage for each metric is 100%, we define the penalty
function as (8).
P (x) = (100− x)2 (8)
To clarify, we have been using various coverage metrics in
the evaluation, e.g. functional (defined by covergroups and
coverpoints in SystemVerilog), statement, branch, expression
and FSM coverage (defined automatically by the simulation
tool). For weight coefficients ac, the value 1 has been assigned
to functional coverage (since it is the most important in
terms of functional verification) and the value 0.0001 to other
coverage metrics.
The next task is to select model parameters W, θ. These had
to be chosen in such a way that reachability of any network
state should be possible and probability of reaching these states
should not be too small. Ideally, during the NN evolution the
output value of each neuron should be able to move in both
directions, closer to 0 or closer to 1, but in general, all output
values should have an average probability value 0.5. This is
the reason for defining a balanced weights model, which must
satisfy the property (9).
∀i ∈ N(v(t)i = 0.5) =⇒ ∀i ∈ N(v(t+1)i = 0.5) (9)
Finally, the last modification is the sigmoid function (3) which
needs to be parametrized with the parameter λ in order to
adjust the function steepness as shown in (10). Intuitively, the
slope needs to fit the network in such a way that wide range
of values between [0, 1] can be selected. The value of this
parameter was chosen experimentally, see Section IV.
Ψ(z)λ =
1
1 + e−zλ
(10)
To finalize this section, the following two balanced weights
models are proposed.
1) Bipolar model: The idea behind this concept is to split
non-diagonal weights in W into two equal groups, assigning
one group with the value 1 and other group with −1 in such
a way that each neuron would have a half of the connections
with the weight 1, and the second half with the weight −1
as is shown in Algorithm 1. In case of the odd number of
non-zero weighted connections, weights of one group need to
be adjusted in order to satisfy the balanced weights model
constraint as is presented in Algorithm 2. It can be shown (by
mathematical induction) that the weight matrix of this model
cannot be symmetric.
2) Acyclic graph model: This model is designed specif-
ically for the processor verification since it uses PRG gen-
erating programs. The NN topology comes from directed
acyclic graph corresponding to the model of the instruction
set architecture (ISA). ISA is usually designed on multiple
Algorithm 1: Assigning weights to the bipolar model
Data: Number of neurons n
Result: Weight matrix W of size n× n
sign← 1;
if n− 1 is odd then
oddModifier ← n−2
n
;
else
oddModifier ← 1;
end
for i← 0 to n do
sum← 0;
for j ← 0 to n do
if i = j then
wi,j ← 0;
sum← sum + sign;
wi,j ← sign;
sign← −sign;
end
MODIFYWEIGHTS(oddModifier, sum,W)
end
return W
Algorithm 2: MODIFYWEIGHTS(oddModifier,sum,W)
if oddModifier 6= 1 then
for j ← 0 to n do
/* Determine which group has more elements
via sum */
if
(
sum > 0 and wi,j > 0
)
or
(
sum < 0 and wi,j < 0
)
then
wi,j = oddModifier ∗ wi,j
end
end
end
levels. Sub-instruction level describes elements, from which
instructions are composed, for instance, instruction operation
codes, registers or immediate operands. Instruction elements
are then put together from these sub-instructions. In addition,
sometimes it is more beneficial to put elements or other sets
together into a set and describe more complex elements on the
instruction set level (e.g. all 2-operand instructions contained
in 2_operands set have the same syntax, they just differ
with opcodes). Our PRG constraint model corresponds to ISA
model. Using such constraint model, we are able to set prob-
ability constraint for each member of the set, so each neuron
represents a unique instance of the pair (set,member), where
member is either another set or an element. In this model,
we have connected only those neuron instances in which the
member of one instance was the set of another instance or both
instances have the same set. For demonstration, see an example
of such graph in Fig. 3. PRG using such constraint model
generates instruction or sub-instruction with a probability of
the connection to his parent with respect to probabilities the
parent has with its grandparent and so on (analogically to
a Bayesian network). The construction of W matrix for this
model is shown in Algorithm 3.
D. Model usage
These models are able to solve industry-wide problems pre-
sented in Section I. Algorithm 4 can optimize PRG constraints
on-the-fly and speed up the verification process, see results in
Fig. 3. A part of acyclic graph generated from ISA. A, B, C, D are
examples of unique instance vector members – each represented by a neuron.
Neuron combinations (B,C) and (B,D) have non-zero connection weights,
since neurons B and C have the same set and the member of B is a set
of D. The probability of generating instruction i LUI by PRG is equal to
P (isa)P (2 operands|isa)P (i LUI|2 operands).
Algorithm 3: Acyclic graph model weights
Data: Number of neurons n, Unique instance vector c
Result: Weight matrix W of size n× n
sign← 1;
for i← 0 to n do
nconnections ← 0;
sum← 0;
for j ← 0 to n do
if i = j then
wi,j ← 0;
nconnections ← nconnections + 1;
end
else if ci.member = cj .set or ci.set = cj .member or
ci.set = cj .set then
wi,j ← sign;
sum← sum + sign;
sign← −sign;
nconnections ← nconnections + 1;
end
end
if nconnections − 1 is odd then
oddModifier ← nconnections−2
nconnections
;
else
oddModifier ← 1;
end
MODIFYWEIGHTS(oddModifier, sum,W)
end
return W
Section IV. Algorithm 5 seeks the smallest processor program
set that can be used as a regression test suite.
IV. RESULTS
All experiments were realized with Intel Core i7 3610QM
processor with 8GB RAM and 64-bit Debian 8.7. The objects
of verification were two processors provided by Codasip,
each of markedly different complexity. Codasip uRISC (area
16k gates in 55LP, frequency 400MHz) is a 32-bit RISC
micro-architecture with 4-stage pipeline, used mainly for
Algorithm 4: On-the-fly optimization of constraints
Result: Coverage closure if iteration limit was not exceeded.
Initialize PRG and NN;
if there is some default PRG configuration then
Generate new stimuli set, run verification, get coverage feedback;
end
Initialize network energy, from coverage feedback if there is any;
Initialize empty tabu list;
for time t from 0 to settings.MAXtime do
if tabu list contains each node then
Local minimum reached, return;
end
Activate random neuron, apply new constraints and generate new
stimuli;
Run verification above new stimuli set, get coverage feedback and
calculate NN energy for this state;
if energy decreased or
(
stochastic activation = true and
Random(0, 1) < f(t)
)
then
Activation is accepted, save new best energy energy and
empty tabu list;
else
Activation is rejected, return latest activated neuron to its
previous state and add it to tabu list;
end
end
Algorithm 5: Seeking the optimal stimuli set
Result: Coverage closure and optimal stimuli set.
Initialize PRG, NN, initial energy, best program found...;
if there is some default PRG configuration then
Run PRG settings.BESTPROGRUNS times, find best program,
save it and update energy;
end
Initialize empty tabu list;
if settings.MAXEPOCHLENGTH> number of neurons in NN then
Epoch length = number of neurons in NN;
else
Epoch length = settings.MAXEPOCHLENGTH;
end
while Coverage closure not reached and t <settings.MAXtime do
for Epoch length times do
Activate random neurons, find an activation with largest ∆E
and save its program;
end
Activate neuron leading to largest ∆E;
Empty taby list and reinitialize variables;
end
demonstration and tutorial purposes. The NN controlling PRG
for uRISC verification contained 41 neurons. Codix Cobalt
(area 24k gates in 55LP, frequency 500MHz) is a high-
performance production 32-bit RISC micro-architecture with
5-stage pipeline [12]. The NN controlling PRG for Cobalt ver-
ification contained 1020 neurons. All the generated programs
were loaded directly into the memory of the processor, each
program with an approximate length of 100 instructions. In
one of the experiments we tried a range of random distribution
models to initialize the initial NN state, such as triangular
distribution and various uniform distributions with interval
restrictions and it turns out that the uniform distribution with
values drawn from the interval [0.4, 0.6] seems to give the
best results. After several experiments, the sigmoid steepness
parameter λ has been set to 0.9. Finally, we have experimented
with various values of the parameter defining the maximal
length of the epoch and the value 20 seems to be an ideal trade-
55
60
65
70
75
80
85
90
95
100
0 5 10 15 20 25 30 35 40 45 50 55 60 65
FU
N
C
TI
O
N
A
L 
C
O
V
ER
A
G
E 
[%
]
TIME [minutes]
Optimal set
Default
Bipolar
Acyclic
GA
Fig. 4. Comparison of the proposed models and the GA during the Codasip
uRISC processor verification. The optimal stimuli set was found in 12.05
hours, the final set was able to reach 100% coverage in 8.94 minutes and
contained 70 assembler programs. In contrast, default approach generated 390
programs in the shown interval.
25
30
35
40
45
50
55
60
65
70
75
80
85
90
95
100
0 10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160 170 180 190 200
FU
N
C
TI
O
N
A
L 
C
O
V
ER
A
G
E 
[%
]
TIME [minutes]
Optimal set
Default
Bipolar
Acyclic
Fig. 5. Comparison of the proposed models during the Codix Cobalt processor
verification. After 63.73 hours of the optimal stimuli set optimization the final
set was able to reach 87.6% coverage in 55.39 minutes and it contained 326
programs. The default approach generated 1000 programs during the measured
interval.
off between the duration of seeking for an optimal stimuli set
and its qualitative properties.
The result of experiments for each model is shown in Fig. 4
and Fig. 5. Note that in our experiments, before the network
started to modify constraints, each processor had a default
PRG configuration available. The default function in both
figures shows behavior with no involvement of the neural
network or any other kind of coverage feedback-processing
optimization algorithm. Fig. 4 also contains the comparison
to the GA approach presented in [9]. We do not have such
comparison for the Cobalt processor since the GA results were
not available. The vertical dash line displays time, in which the
processor has been verified by optimal stimuli set. In addition,
Fig. 6 shows the property of the balanced weight model, the
average output value of the neuron is almost stable around the
value 0.5.
CONCLUSION
This paper has introduced a new approach of automated
feedback-based CDV accelerated by the RNN optimizer. Ex-
periments have shown that the considered approaches achieved
0.49
0.50
0.50
0.51
0.51
0.52
0.52
0 5 10 15 20 25 30 35 40 45 50
A
V
ER
A
G
E 
N
EU
R
O
N
 S
TA
TE
TIME [minutes]
Fig. 6. The average output of network neurons during the Acyclic graph
model experiment made on the Codasip uRISC.
a large speed up of the verification process and have been
able to find fairly small set of regression tests. However, in
some initial time interval of the verification process, state-of-
the-art approach (in our experiments referred to as ’default’)
seems to be more efficient than the proposed approaches. In
the future work we would like to focus on this part of the
proposed technique in order to develop further speed-ups and
to define an interconnection of our work to a new portable
stimuli standard after it will be publicly available.
REFERENCES
[1] “IEEE Standard for SystemVerilog–Unified Hardware Design, Specifi-
cation, and Verification Language,” IEEE Std 1800-2012 (Revision of
IEEE Std 1800-2009), 2013.
[2] “Universal Verification Methodology (UVM) 1.2 Users Guide,” Ac-
cellera Systems Initiative, 2015.
[3] N. Kitchen and A. Kuehlmann, “Stimulus generation for constrained
random simulation,” in 2007 IEEE/ACM International Conference on
Computer-Aided Design, Nov 2007, pp. 258–265.
[4] H.-H. Yeh and C. Y. Huang, “Automatic Constraint Generation for
guided random simulation,” in 2010 15th Asia and South Pacific Design
Automation Conference (ASP-DAC), Jan 2010, pp. 613–618.
[5] A.-C. Cheng, C.-C. J. Yen, C. G. Val, S. Bayless, A. J. Hu, I. H.-R.
Jiang, and J.-Y. Jou, “Efficient Coverage-Driven Stimulus Generation
Using Simultaneous SAT Solving, with Application to SystemVerilog,”
ACM Trans. Des. Autom. Electron. Syst., vol. 20, no. 1, pp. 7:1–7:23,
Nov. 2014. [Online]. Available: http://doi.acm.org/10.1145/2651400
[6] Y. Guo, W. Qu, T. Li, and S. Li, “Coverage Driven Test Generation
Framework for RTL Functional Verification,” in 2007 10th IEEE Interna-
tional Conference on Computer-Aided Design and Computer Graphics,
Oct 2007, pp. 321–326.
[7] I. Wagner, V. Bertacco, and T. Austin, “Microprocessor Verification via
Feedback-Adjusted Markov Models,” IEEE Transactions on Computer-
Aided Design of Integrated Circuits and Systems, vol. 26, no. 6, pp.
1126–1138, June 2007.
[8] O. Goloubeva, M. S. Reorda, and M. Violante, “Automatic generation
of validation stimuli for application-specific processors,” in Proceedings
Design, Automation and Test in Europe Conference and Exhibition,
vol. 1, Feb 2004, pp. 188–193 Vol.1.
[9] M. Simkova and Z. Kotasek, “Automation and Optimization of
Coverage-driven Verification,” in 2015 Euromicro Conference on Digital
System Design, Aug 2015, pp. 87–94.
[10] J. Hopfield, “Neural Networks and Physical Systems with Emergent
Collective Computational Abilities,” Proc. Nat. Acad. Sci., vol. 79, pp.
2554–2558, 1982.
[11] M. G. Lagoudakis, “Neural Networks and Optimization Problems - A
Case Study: The Minimum Cost Spare Allocation Problem,” 1997.
[12] Codasip Ltd. (2017) Codix Cobalt Processor Specification. [Online].
Available: https://www.codasip.com/codix-cores/#cobalt
