mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-25 08:54:35 +00:00 
			
		
		
		
	testing memory defragmentation, prefetch, delay ate
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
		
							parent
							
								
									cd35caff52
								
							
						
					
					
						commit
						563f337997
					
				
					 17 changed files with 320 additions and 64 deletions
				
			
		|  | @ -86,7 +86,8 @@ namespace sat { | |||
|         scoped_ptr<extension>   m_ext; | ||||
|         parallel*               m_par; | ||||
|         random_gen              m_rand; | ||||
|         clause_allocator        m_cls_allocator; | ||||
|         clause_allocator        m_cls_allocator[2]; | ||||
|         bool                    m_cls_allocator_idx; | ||||
|         cleaner                 m_cleaner; | ||||
|         model                   m_model;         | ||||
|         model_converter         m_mc; | ||||
|  | @ -217,9 +218,16 @@ namespace sat { | |||
|         void mk_clause(literal_vector const& lits, bool learned = false) { mk_clause(lits.size(), lits.c_ptr(), learned); } | ||||
|         void mk_clause(unsigned num_lits, literal * lits, bool learned = false); | ||||
|         void mk_clause(literal l1, literal l2, bool learned = false); | ||||
|         void mk_clause(literal l1, literal l2, literal l3, bool learned = false); | ||||
|         void mk_clause(literal l1, literal l2, literal l3, bool learned = false);         | ||||
| 
 | ||||
|     protected: | ||||
|         inline clause_allocator& cls_allocator() { return m_cls_allocator[m_cls_allocator_idx]; } | ||||
|         inline clause_allocator const& cls_allocator() const { return m_cls_allocator[m_cls_allocator_idx]; } | ||||
|         inline clause * alloc_clause(unsigned num_lits, literal const * lits, bool learned) { return cls_allocator().mk_clause(num_lits, lits, learned); } | ||||
|         inline void     dealloc_clause(clause* c) { cls_allocator().del_clause(c); } | ||||
|         struct cmp_activity; | ||||
|         void defrag_clauses(); | ||||
|         bool memory_pressure(); | ||||
|         void del_clause(clause & c); | ||||
|         clause * mk_clause_core(unsigned num_lits, literal * lits, bool learned); | ||||
|         clause * mk_clause_core(literal_vector const& lits) { return mk_clause_core(lits.size(), lits.c_ptr()); } | ||||
|  | @ -301,7 +309,7 @@ namespace sat { | |||
|         void set_conflict(justification c, literal not_l); | ||||
|         void set_conflict(justification c) { set_conflict(c, null_literal); } | ||||
|         lbool status(clause const & c) const;         | ||||
|         clause_offset get_offset(clause const & c) const { return m_cls_allocator.get_offset(&c); } | ||||
|         clause_offset get_offset(clause const & c) const { return cls_allocator().get_offset(&c); } | ||||
|         void checkpoint() { | ||||
|             if (!m_checkpoint_enabled) return; | ||||
|             if (!m_rlimit.inc()) { | ||||
|  | @ -373,6 +381,7 @@ namespace sat { | |||
| 
 | ||||
|         unsigned m_conflicts_since_init; | ||||
|         unsigned m_restarts; | ||||
|         unsigned m_restart_next_out; | ||||
|         unsigned m_conflicts_since_restart; | ||||
|         unsigned m_simplifications; | ||||
|         unsigned m_restart_threshold; | ||||
|  | @ -405,7 +414,7 @@ namespace sat { | |||
|         void simplify_problem(); | ||||
|         void mk_model(); | ||||
|         bool check_model(model const & m) const; | ||||
|         void restart(); | ||||
|         void restart(bool to_base); | ||||
|         void sort_watch_lits(); | ||||
|         void exchange_par(); | ||||
|         lbool check_par(unsigned num_lits, literal const* lits); | ||||
|  | @ -437,7 +446,7 @@ namespace sat { | |||
|             if (value(l0) != l_true) | ||||
|                 return true; | ||||
|             justification const & jst = m_justification[l0.var()]; | ||||
|             return !jst.is_clause() || m_cls_allocator.get_clause(jst.get_clause_offset()) != &c; | ||||
|             return !jst.is_clause() || cls_allocator().get_clause(jst.get_clause_offset()) != &c; | ||||
|         } | ||||
| 
 | ||||
|         clause& get_clause(watch_list::iterator it) const { | ||||
|  | @ -445,13 +454,18 @@ namespace sat { | |||
|             return get_clause(it->get_clause_offset()); | ||||
|         } | ||||
| 
 | ||||
|         clause& get_clause(watched const& w) const { | ||||
|             SASSERT(w.get_kind() == watched::CLAUSE); | ||||
|             return get_clause(w.get_clause_offset()); | ||||
|         } | ||||
| 
 | ||||
|         clause& get_clause(justification const& j) const { | ||||
|             SASSERT(j.is_clause()); | ||||
|             return get_clause(j.get_clause_offset()); | ||||
|         } | ||||
| 
 | ||||
|         clause& get_clause(clause_offset cls_off) const { | ||||
|             return *(m_cls_allocator.get_clause(cls_off)); | ||||
|             return *(cls_allocator().get_clause(cls_off)); | ||||
|         } | ||||
|          | ||||
|         // -----------------------
 | ||||
|  | @ -634,6 +648,7 @@ namespace sat { | |||
|         void display_wcnf(std::ostream & out, unsigned sz, literal const* lits, unsigned const* weights) const; | ||||
|         void display_assignment(std::ostream & out) const; | ||||
|         std::ostream& display_justification(std::ostream & out, justification const& j) const; | ||||
|         std::ostream& display_watch_list(std::ostream& out, watch_list const& wl) const; | ||||
| 
 | ||||
|     protected: | ||||
|         void display_binary(std::ostream & out) const; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue