Question on the Intersect operator of SVA sequences

In reply to sudharshan:


b[->2] // is equivalent to:
!b[*0:$] ##1 b ##1 !b[*0:$] ##1 b
// In other words any two "b"s ending with a "b"

b[=2] // is equivalent to:
  !b[*0:$] ##1 b ##1 !b[*0:$] ##1 b ##1 !b[*0:$]
// In other words any two "b"s not necessarily ending with a "b", 
// could be NO "b"s after the last "b"

// Thus, what you need is
assert property ($rose(sop) |=> read [=2] intersect write [=3] intersect eop [-> 1]);

http://SystemVerilog.us/vf/intersect1.sv

Ben Cohen
http://www.systemverilog.us/ ben@systemverilog.us
For training, consulting, services: contact http://cvcblr.com/home


  1. SVA Alternative for Complex Assertions
    https://verificationacademy.com/news/verification-horizons-march-2018-issue
  2. SVA: Package for dynamic and range delays and repeats - SystemVerilog - Verification Academy
  3. SVA in a UVM Class-based Environment
    https://verificationacademy.com/verification-horizons/february-2013-volume-9-issue-1/SVA-in-a-UVM-Class-based-Environment