mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-22 15:34:36 +00:00 
			
		
		
		
	Modifies smt2 backend to recognize `$anyconst` etc. assigned to a wire with the `maximize` or `minimize` attribute and emit `; yosys-smt2-maximize` or `; yosys-smt2-minimize` directives as appropriate. Modifies `backends/smt2/smtbmc.py` and `smtio.py` to recognize those directives and emit a `(maximize ...)` or `(minimize ...)` command at the end of `smt_forall_assert()`, as described in the paper "νZ - An Optimizing SMT Solver" by Nikolaj Bjørner et al. Adds an example `examples/smtbmc/demo9.v` to show how it can be used.
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| 
 | |
| all: demo1 demo2 demo3 demo4 demo5 demo6 demo7 demo8 demo9
 | |
| 
 | |
| demo1: demo1.smt2
 | |
| 	yosys-smtbmc --dump-vcd demo1.vcd demo1.smt2
 | |
| 	yosys-smtbmc -i --dump-vcd demo1.vcd demo1.smt2
 | |
| 
 | |
| demo2: demo2.smt2
 | |
| 	yosys-smtbmc -g --dump-vcd demo2.vcd --dump-smtc demo2.smtc --dump-vlogtb demo2_tb.v demo2.smt2
 | |
| 	iverilog -g2012 -o demo2_tb demo2_tb.v demo2.v
 | |
| 	vvp demo2_tb +vcd=demo2_tb.vcd
 | |
| 
 | |
| demo3: demo3.smt2
 | |
| 	yosys-smtbmc --dump-vcd demo3.vcd --smtc demo3.smtc demo3.smt2
 | |
| 
 | |
| demo4: demo4.smt2
 | |
| 	yosys-smtbmc -s yices --dump-vcd demo4.vcd --smtc demo4.smtc demo4.smt2
 | |
| 
 | |
| demo5: demo5.smt2
 | |
| 	yosys-smtbmc -g -t 50 --dump-vcd demo5.vcd demo5.smt2
 | |
| 
 | |
| demo6: demo6.smt2
 | |
| 	yosys-smtbmc -t 1 demo6.smt2
 | |
| 
 | |
| demo7: demo7.smt2
 | |
| 	yosys-smtbmc -t 10 demo7.smt2
 | |
| 
 | |
| demo8: demo8.smt2
 | |
| 	yosys-smtbmc -s z3 -t 1 -g demo8.smt2
 | |
| 
 | |
| demo9: demo9.smt2
 | |
| 	yosys-smtbmc -s z3 -t 1 -g demo9.smt2
 | |
| 
 | |
| demo1.smt2: demo1.v
 | |
| 	yosys -ql demo1.yslog -p 'read_verilog -formal demo1.v; prep -top demo1 -nordff; write_smt2 -wires demo1.smt2'
 | |
| 
 | |
| demo2.smt2: demo2.v
 | |
| 	yosys -ql demo2.yslog -p 'read_verilog -formal demo2.v; prep -top demo2 -nordff; write_smt2 -wires demo2.smt2'
 | |
| 
 | |
| demo3.smt2: demo3.v
 | |
| 	yosys -ql demo3.yslog -p 'read_verilog -formal demo3.v; prep -top demo3 -nordff; write_smt2 -wires demo3.smt2'
 | |
| 
 | |
| demo4.smt2: demo4.v
 | |
| 	yosys -ql demo4.yslog -p 'read_verilog -formal demo4.v; prep -top demo4 -nordff; write_smt2 -wires demo4.smt2'
 | |
| 
 | |
| demo5.smt2: demo5.v
 | |
| 	yosys -ql demo5.yslog -p 'read_verilog -formal demo5.v; prep -top demo5 -nordff; write_smt2 -wires demo5.smt2'
 | |
| 
 | |
| demo6.smt2: demo6.v
 | |
| 	yosys -ql demo6.yslog -p 'read_verilog demo6.v; prep -top demo6 -nordff; assertpmux; opt -keepdc -fast; write_smt2 -wires demo6.smt2'
 | |
| 
 | |
| demo7.smt2: demo7.v
 | |
| 	yosys -ql demo7.yslog -p 'read_verilog -formal demo7.v; prep -top demo7 -nordff; write_smt2 -wires demo7.smt2'
 | |
| 
 | |
| demo8.smt2: demo8.v
 | |
| 	yosys -ql demo8.yslog -p 'read_verilog -formal demo8.v; prep -top demo8 -nordff; write_smt2 -stbv -wires demo8.smt2'
 | |
| 
 | |
| demo9.smt2: demo9.v
 | |
| 	yosys -ql demo9.yslog -p 'read_verilog -formal demo9.v; prep -top demo9 -nordff; write_smt2 -stbv -wires demo9.smt2'
 | |
| 
 | |
| clean:
 | |
| 	rm -f demo1.yslog demo1.smt2 demo1.vcd
 | |
| 	rm -f demo2.yslog demo2.smt2 demo2.vcd demo2.smtc demo2_tb.v demo2_tb demo2_tb.vcd
 | |
| 	rm -f demo3.yslog demo3.smt2 demo3.vcd
 | |
| 	rm -f demo4.yslog demo4.smt2 demo4.vcd
 | |
| 	rm -f demo5.yslog demo5.smt2 demo5.vcd
 | |
| 	rm -f demo6.yslog demo6.smt2
 | |
| 	rm -f demo7.yslog demo7.smt2
 | |
| 	rm -f demo8.yslog demo8.smt2
 | |
| 	rm -f demo9.yslog demo9.smt2
 | |
| 
 | |
| .PHONY: demo1 demo2 demo3 demo4 demo5 demo6 demo7 demo8 demo9 clean
 | |
| 
 |