|
|
|
|
|
|
|
|
|
|
|
|
Conditional Constraints
|
|
|
There are two types of conditional constraints. |
|
|
|
|
|
|
|
|
|
|
|
Implication is similar to when in e language. It works like, if condition is true then apply constraint. If-else is similar to Implication => constraint, both can be used. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Example : conditional
|
|
|
|
|
|
1 class frame_t {
2 enum size_t = RUNT,NORMAL,OVERSIZE;
3 rand bit [15:0] length;
4 rand size_t size;
5
6 constraint frame_sizes {
7 size == NORMAL => {
8 length dist {
9 64 : 127 := 10,
10 128 : 511 := 10,
11 512 : 1500 := 10
12 };
13 }
14 if (size == RUNT) {
15 length >= 0;
16 length <= 63;
17 } else if (size == OVERSIZE) {
18 length >= 1501;
19 length <= 5000;
20 }
21 }
22 }
23
24 program distribution {
25 frame_t frame = new();
26 integer i,j = 0;
27 for (j=0;j < 4; j++) {
28 printf("-------------------------------\n");
29 printf("Randomize Value\n");
30 i = frame.randomize();
31 frame.object_print();
32 }
33 printf("-------------------------------\n");
34 }
You could download file conditional_con.vr here
|
|
|
|
|
|
Simulation Output : conditional
|
|
|
|
|
|
-------------------------------
Randomize Value
length : hex: 05fe
size : ENUM: frame_t::OVERSIZE
-------------------------------
Randomize Value
length : hex: 0878
size : ENUM: frame_t::OVERSIZE
-------------------------------
Randomize Value
length : hex: 001e
size : ENUM: frame_t::RUNT
-------------------------------
Randomize Value
length : hex: 0032
size : ENUM: frame_t::RUNT
-------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|