mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-26 17:29:21 +00:00 
			
		
		
		
	Fixed justification
(justification may not contain consequence)
This commit is contained in:
		
							parent
							
								
									ed5ce1ce5f
								
							
						
					
					
						commit
						8855163ccf
					
				
					 2 changed files with 6 additions and 6 deletions
				
			
		|  | @ -69,8 +69,8 @@ void PackedRow::get_reason(literal_vector& antecedents, const unsigned_vector& c | |||
|             SASSERT((*this)[col] == 1); | ||||
|             unsigned var = column_to_var[col]; | ||||
|             if (var == prop.var()) { | ||||
|                 antecedents.push_back(prop);  | ||||
|                 std::swap(antecedents[0], antecedents.back()); | ||||
|                 // In Z3 we should not have the antecedents in the justification
 | ||||
|                 //antecedents.push_back(prop); 
 | ||||
|             } | ||||
|             else  | ||||
|                 antecedents.push_back(literal(var, !tmp_col2[col])); | ||||
|  | @ -373,7 +373,7 @@ std::ostream& EGaussian::display(std::ostream& out) const { | |||
|     if (m_mat.num_rows() == 0) | ||||
|         return out; | ||||
|     for (auto const& row : m_mat) { | ||||
|         bool first = true; | ||||
|         bool first = true;  | ||||
|         for (int i = 0; i < row.get_size() * 64; ++i) { | ||||
|             if (row[i]) { | ||||
|                 if (first) | ||||
|  |  | |||
|  | @ -127,7 +127,7 @@ namespace xr { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     void solver::asserted(sat::literal l) {         | ||||
|     void solver::asserted(literal l) {         | ||||
|         TRACE("xor", tout << "asserted: " << l << "\n";); | ||||
|         force_push(); | ||||
|         m_prop_queue.push_back(l); | ||||
|  | @ -699,7 +699,7 @@ namespace xr { | |||
|             while (!m_interesting.empty()) { | ||||
|      | ||||
|                 // Pop and check if it can be XOR-ed together
 | ||||
|                 const unsigned v = m_interesting.back(); | ||||
|                 bool_var v = m_interesting.back(); | ||||
|                 m_interesting.pop_back(); | ||||
|                 if (m_occ_cnt[v] != 2) | ||||
|                     continue; | ||||
|  | @ -707,7 +707,7 @@ namespace xr { | |||
|                 unsigned indexes[2]; | ||||
|                 unsigned at = 0; | ||||
|                 unsigned_vector& ws = occurs[v]; | ||||
|                 for (unsigned i : ws)  | ||||
|                 for (bool_var i : ws)  | ||||
|                     if (!xors[i].empty())  | ||||
|                         indexes[at++] = i; | ||||
|                 SASSERT(at == 2); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue