|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/70081/70081725daed7509ef608f65744137f7751316dd" alt="../images/main/bullet_green_ball.gif" |
Constraint Blocks
|
|
|
In last few pages we saw how to contraint a random variable to legal range that we want to generate. In next few pages we will see. |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
- inclusive and exclusive (set membership)
- distribution
- conditional constraint
- foreach
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
And also some advanced constraint topics. |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/180a6/180a67ce44f79a6885b1aa1e6502087811b76b36" alt="../images/main/bulllet_4dots_orange.gif" |
Set Membership
|
|
|
Sometimes we want to randomize a variable within a set of values (inclusive) or sometimes we want to exclude some values from random values generated (exclusive). |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
- [] is used for specifying range.
- The negated form of the inside operator denotes that expression lies outside the set: !(expression inside { set }).
- Absent any other constraints, all values (either single values or value ranges) have an equal probability of being chosen by the inside operator.
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/a641b/a641bf107436728a5843fe8ccadf001de8455b7f" alt="../images/main/bullet_star_pink.gif" |
Example : Set Membership
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
1 program set_membership;
2 class frame_t;
3 rand bit [7:0] src_port;
4 rand bit [7:0] des_port;
5 constraint c {
6 // inclusive
7 src_port inside { [8'h0:8'hA],8'h14,8'h18 };
8 // exclusive
9 ! (des_port inside { [8'h4:8'hFF] });
10 }
11 function void post_randomize();
12 begin
13 $display("src port : %0x",src_port);
14 $display("des port : %0x",des_port);
15 end
16 endfunction
17 endclass
18
19 initial begin
20 frame_t frame = new();
21 integer i,j = 0;
22 for (j=0;j < 4; j++) begin
23 $display("-------------------------------");
24 $display("Randomize Value");
25 $display("-------------------------------");
26 i = frame.randomize();
27 end
28 $display("-------------------------------");
29 end
30 endprogram
You could download file set_membership.sv here
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/a641b/a641bf107436728a5843fe8ccadf001de8455b7f" alt="../images/main/bullet_star_pink.gif" |
Simulation Output : Set Membership
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
-------------------------------
Randomize Value
-------------------------------
src port : 3
des port : 2
-------------------------------
Randomize Value
-------------------------------
src port : 0
des port : 2
-------------------------------
Randomize Value
-------------------------------
src port : 18
des port : 3
-------------------------------
Randomize Value
-------------------------------
src port : 2
des port : 0
-------------------------------
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c2c27/c2c277fbe75b68ffa3f0eb99f3b30bb25fa28361" alt=""
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|