Painless
A framework to ease parallelization of sequential CDCL SAT solvers
Loading...
Searching...
No Matches
ClauseDatabasePerSize.hpp
1#pragma once
2
3#include "containers/ClauseBuffer.hpp"
4#include "containers/ClauseDatabase.hpp"
5#include <atomic>
6#include <vector>
7
19{
20 public:
25
31
36
42 bool addClause(ClauseExchangePtr clause) override;
43
50 size_t giveSelection(std::vector<ClauseExchangePtr>& selectedCls, unsigned int literalCountLimit) override;
51
56 void getClauses(std::vector<ClauseExchangePtr>& v_cls) override;
57
63 bool getOneClause(ClauseExchangePtr& cls) override;
64
69 size_t getSize() const override;
70
75 size_t shrinkDatabase() override
76 {
77 LOGDEBUG3("This does nothing!");
78 return (size_t)-1;
79 };
80
84 void clearDatabase() override;
85
86 private:
91 void initializeQueues(unsigned int maxClsSize);
92
93 private:
97 std::vector<std::unique_ptr<ClauseBuffer>> clauses;
98
99 public:
104
109};
#define LOGDEBUG3(...)
Log a debug message with verbosity level 4 and magenta color.
Definition Logger.hpp:229
A clause database that organizes clauses based on their size.
Definition ClauseDatabasePerSize.hpp:19
bool addClause(ClauseExchangePtr clause) override
Adds a clause to the appropriate size-based buffer.
~ClauseDatabasePerSize()
Virtual destructor.
bool getOneClause(ClauseExchangePtr &cls) override
Retrieves the smallest clause from the database.
ClauseDatabasePerSize()=delete
Default constructor deleted to enforce use of parameterized constructor.
int maxClauseSize
The maximum clause size accepted in this clause database.
Definition ClauseDatabasePerSize.hpp:108
void clearDatabase() override
Clears all size-based buffers.
size_t shrinkDatabase() override
Does nothing in this implementation.
Definition ClauseDatabasePerSize.hpp:75
size_t getSize() const override
Gets the total number of clauses across all size-based buffers.
size_t initLiteralCount
Initial literal count used for buffer sizing.
Definition ClauseDatabasePerSize.hpp:103
ClauseDatabasePerSize(int maxClauseSize)
Constructor with a specified maximum clause size.
void getClauses(std::vector< ClauseExchangePtr > &v_cls) override
Retrieves all clauses from all size-based buffers.
size_t giveSelection(std::vector< ClauseExchangePtr > &selectedCls, unsigned int literalCountLimit) override
Selects clauses up to a specified total size.
Abstract base class defining the interface for clause storage and management.
Definition ClauseDatabase.hpp:27