-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add blog infrastructure and first post. (#11)
* Add blog infrastructure and first post. * add problem to example * Add author blurb at the bottom * final updates to blog
- Loading branch information
1 parent
b554413
commit fc9855b
Showing
9 changed files
with
101 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
--- | ||
layout: default | ||
--- | ||
|
||
<small>{{ page.date | date: "%-d %B %Y" }}</small> | ||
<h1>{{ page.title }}</h1> | ||
|
||
<p class="view">by {{ page.author | default: site.author }}</p> | ||
|
||
{{content}} | ||
|
||
<!-- We can add tags back later if we want --> | ||
<!-- {% if page.tags %} | ||
<small>tags: <em>{{ page.tags | join: "</em> - <em>" }}</em></small> | ||
{% endif %} --> | ||
|
||
<p> | ||
<p> | ||
<a href="/blog" class="button">Back to All Blog Posts</a> | ||
|
||
</p> | ||
</p> |
51 changes: 51 additions & 0 deletions
51
_posts/2023-12-15-partitioning-strategies-for-distributed-smt-solving.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
--- | ||
layout: blog-post | ||
categories: blog | ||
excerpt_separator: <!--more--> | ||
title: "Partitioning Strategies for Distributed SMT Solving" | ||
author: Amalee Wilson | ||
date: 2023-12-15 | ||
--- | ||
|
||
Partitioning is a divide-and-conquer approach where a difficult problem is split into hopefully easier subproblems that can be solved in parallel. This strategy is notoriously difficult to get right with SMT problems. We found that while it’s no panacea, partitioning can be used to diversify solving and reliably improve performance in a portfolio. | ||
<!--more--> | ||
|
||
|
||
Many users of SMT solvers find that the solver’s performance is the main bottleneck in their application, yet most SMT solvers remain single-threaded. We sought to explore a divide-and-conquer strategy for accelerating SMT solving. Six main strategies were explored, using three different sources of atoms for the partitions and two different types of partitioning. More details about these partitioning strategies and the various parameters can be found in the [paper that we recently published at FMCAD 2023](https://repositum.tuwien.at/bitstream/20.500.12708/188827/1/Wilson-2023-Partitioning%20Strategies%20for%20Distributed%20SMT%20Solving-vor.pdf). | ||
Many of these partitioning strategies work well for the QF_LRA, QF_LIA, QF_IDL, QF_UF, and QF_RDL challenge benchmarks used for the paper (214 total). However, a central contribution was discovering that interesting new portfolio techniques could be applied using these different partitioning strategies. Portfolio solving is an approach in which multiple solvers (or different configurations of a solver), attempt to solve the same (or perturbed but equivalent) SMT problem in parallel. | ||
|
||
We noticed that different partitioning strategies worked well for different problems in the set of challenge benchmarks. There was no clear winner that reliably outperformed the others. So we chose to create a partitioning portfolio. The idea is that, for example, if there are 8 cores, then 2 different partitioning strategies can be used to create 2 sets of 4 partitions. Each of these sets of partitions can be solved in parallel, and when the first set of partitions is finished, the remaining 4 processes can be terminated. This approach is similar to a traditional portfolio solving strategy, but sets of partitions are treated as entries in the portfolio, as opposed to different configurations of the solver or permutations of the problem. Interestingly, the partitioning portfolio, with fewer partitions made by each strategy, can outperform a single strategy that creates more partitions at once. To be clear, two sets of 4 partitions run as a portfolio can outperform a single set of 8 partitions because one of the two sets of 4 partitions may finish before the single set of 8. This result was somewhat surprising because we expected that creating more partitions would almost always be better than creating fewer. However, the diversity introduced by using multiple partitioning strategies was more valuable than trying to further split the problem into more partitions. | ||
|
||
| ![A graph showing how a partitioning portfolio is constructed.](/assets/blog-images/2023-12-6-partitioning-strategies-for-distributed-smt-solving/partitioning-portfolio.png) | | ||
|:--:| | ||
| *This partitioning portfolio has two sets of partitions.* | | ||
|
||
Even more surprising were the performance improvements that we observed using a graduated portfolio. | ||
This approach involves creating multiple sets of partitions from one strategy, and it can outperform a single set of partitions with the same resource limits. | ||
For example, a graduated portfolio of 2, 4, 8, and 16 partitions (for a total of 30) can outperform a single set of 32 partitions made with the same partitioning strategy. | ||
This observation is interesting because the diversity is not coming from using different partitioning strategies. Instead, simply varying the number of partitions made, even when the sets of partitions share literals, introduces sufficient diversity in solving to outperform a single set of partitions when the total number of available cores for solving is kept constant. | ||
|
||
| ![A graph showing how a graduated portfolio is constructed.](/assets/blog-images/2023-12-6-partitioning-strategies-for-distributed-smt-solving/graduated-portfolio.png) | | ||
|:--:| | ||
| *The graduated portfolio introduces diversity by producing many sets of partitions with one strategy.* | | ||
|
||
The best portfolio technique, though, is the hybrid graduated partitioning portfolio. | ||
We call this approach "hybrid" because it uses both the more traditional portfolio approach of scrambling (where semantically equivalent but mutated copies of the original problem are solved in parallel) in addition to using a graduated partitioning portfolio with multiple partitioning strategies. This interesting portfolio was motivated by the observation that each aspect introduces diversity into the portfolio: varying partitioning strategies, varying the number of partitions made, and introducing a non-partitioning-based strategy. Ultimately, we believe that scrambling introduces a different type of diversity into the portfolio, and we support this claim in the discussion of the final figure in the paper. | ||
|
||
| ![A graph showing how a hybrid portfolio is constructed.](/assets/blog-images/2023-12-6-partitioning-strategies-for-distributed-smt-solving/hybrid-portfolio.png) | | ||
|:--:| | ||
| *The hybrid graduated portfolio uses half the cores to solve scrambles of the original problem and the other half to solve sets of partitions.* | | ||
|
||
If you're interested in trying out some of our partitioning strategies, they can all be found in cvc5's main branch on GitHub! Here's how you use it: | ||
|
||
For 8 time-based, cube-type partitions: | ||
``` | ||
cvc5 --partition-when=tlimit --compute-partitions=8 --partition-start-time=3 --partition-strategy=decision-cube problem.smt2 | ||
``` | ||
-\-compute-partitions=8 communicates that 8 partitions should be made, and 8 can be replaced with the desired number of partitions (must be a power of 2 for cube type partitions). | ||
-\-partition-start-time=3 communicates that the partitioner should wait 3 seconds before creating partitions, and although 3 can be replaced by any number of seconds, it is empirically a good choice. | ||
-\-partition-strategy=decision-cube communicates that cubes should be made based on decisions. This parameter can be replaced in this code snippet with either lemma-cube or heap-cube. | ||
Additional documentation for different partitioning parameters, including scatter partitions, can be found under the parallel options documentation. Note that this code snippet only produces the partitions --- it does not solve them. | ||
|
||
|
||
#### [Amalee Wilson](https://www.linkedin.com/in/amalee-wilson/) is a PhD student advised by Clark Barrett in the Stanford Center for Automated Reasoning ([Centaur](https://centaur.stanford.edu/)) Lab. Her PhD work is focused on strategies for distributed SMT solving. |
Binary file added
BIN
+203 KB
...2-6-partitioning-strategies-for-distributed-smt-solving/graduated-portfolio.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+163 KB
...3-12-6-partitioning-strategies-for-distributed-smt-solving/hybrid-portfolio.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+184 KB
...-partitioning-strategies-for-distributed-smt-solving/partitioning-portfolio.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
--- | ||
layout: default | ||
title: Blog | ||
--- | ||
|
||
# Blog | ||
|
||
Updates are posted every other month, sometimes more frequently. | ||
|
||
|
||
{% for post in site.posts %} | ||
<h2><a href="{{ post.url }}">{{ post.title }}</a></h2> | ||
<p>{{ post.date | date_to_string }} <p> </p> {{ post.excerpt | strip_html }} | ||
<a href="{{ post.url }}" class="read-more">Read More</a> </p> | ||
{% endfor %} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters