Как использовать разделенные предложения z3 с несинхронизированными ядрами и попытаться снова найти несинсированное ядро
Не могли бы вы рассказать, как разбить предложения несостоявшихся ядер? И вот вопрос 2 касательно обнаруженных ненасыщенных ядер, попробую еще раз поискать. Хотите рассказать, как это сделать?
Большое спасибо.
Как разделить пункты, как показано ниже
`and` (`or` (`<=_int` 1002 x1) (`<=_int` 1000 x1)) (`and` (`or` (`<=_int` 0 (`+_int` x2 (`*_int` -1003 x1))) (`<=_int` 0 (`+_int` x2 (`*_int` -1230 x1)))) (`and` (`or` (`<=_int` 0 (`+_int` x3 (`*_int` -1999 x2)))
Что касается вопроса 2,
cout<<s.check(3,assumptions)<<endl;
expr_vector core = s.unsat_core();
................
expr assumptions2[2] = {p1,p3};
cout<<"check next"<<s.check(2,assumptions2)<<endl;
expr_vector core1 = s.unsat_core();
for(unsigned int k=0;k<core1.size();++k){
cout<<"New core size "<<k<<endl;
cout<<"New unsat core "<<core1[k]<<endl;
}
вызов функции unsat core снова, она не может снова выдавать unsat core Большое спасибо.