Assume property in FPV

In reply to r.murugesan:
You’ll need support logic:
If I understand you correctly you want an assumption where “a” behaves as follows:


// cycle         0 1 2 3 4 5 6 7 
//  a    0 0 0 0 1 0 1 0 1 0 1 0 
//                 <-> <-> <-> 
// repeat           1   2   3  
bit instart; // support bit 
function void f(bit w); instart=w; endfunction 
am_a_toggle: assume property(@(posedge clk( 
         ($rose(a) && instart==0, f(1)) |->
              (##1 !a ##1 a)[*3] ##1 (!a, f(0)) ) else f(0);
// At (rose(a) and !instart) set instart to 1 to prevent other starts 
// after 3 sets of a== 0, a==1, continue the sequence with a==0 and reset the instart to 0.
// In simulation, if the assume fails, reset the instart to 0. 

Ben Cohen
Ben@systemverilog.us
Link to the list of papers and books that I wrote, many are now donated.

or Cohen_Links_to_papers_books - Google Docs

Getting started with verification with SystemVerilog