An open API service indexing awesome lists of open source software.

https://github.com/empobla/pproblemsolver

A CLI program that verifies input solutions for input K-SAT problems.
https://github.com/empobla/pproblemsolver

k-sat p-problem

Last synced: 3 months ago
JSON representation

A CLI program that verifies input solutions for input K-SAT problems.

Awesome Lists containing this project

README

        

[![Portfolio][moreinfo-shield]][moreinfo-url]
[![LinkedIn][linkedin-shield]][linkedin-url]




P Problem Solver


A CLI program that verifies input solutions for input K-SAT problems.





Table of Contents



  1. About The Project


  2. Abilities Mastered


  3. Getting Started


  4. Usage

  5. License

  6. Contact

## About The Project

A CLI program where the user inputs a `.txt` file with a K-SAT problem and a solution to verify. The program then responds with a 1 if the user's solution was accepted or with a 0 if the user's solution was rejected for the K-SAT problem in question.

(back to top)

### Built With

[![Python][Python]][Python-url]

(back to top)

## Abilities Mastered

* Text conversion to correct format (string parsing)
* Efficient verification for P-Problem solutions

(back to top)

## Getting Started

To get a local copy up and running follow these simple example steps.

### Installation

1. Clone the repo
```sh
git clone https://github.com/empobla/PProblemSolver.git
```

(back to top)

## Usage

Each *P* problem must be saved as a `.txt` file individually inside the `/Input` directory for the program to run properly in the following format (which includes DIMACS CNF):

```sh
c A SAT instance generated from a 3-CNF formula that had 91 clauses and 20 variables
p cnf 20 91
10000111101010101010
9 -3 16 0
4 -16 20 0
-4 6 5 0
-6 -5 4 0
-6 -12 -13 0
-19 -16 13 0
1 -20 -9 0
6 -2 5 0
-4 -11 15 0
-16 8 10 0
-5 2 18 0
-5 8 3 0
-4 -20 -6 0
7 -6 20 0
-17 2 -3 0
-8 -9 -11 0
...
8 10 -19 0
```

Where the first line describes the problem in question, the second line provides a shorthand summary of the problem, and the third line provides an input binary string to be tested against the clauses starting from the fourth line untill the last line.

### Sample Input
Two sample inputs (one that accepts and one that rejects respectively) are provided in the `/Input` directory as `demoaccept.txt` and `Instance_3SAT_example.txt`.

### Output

This program will output a 0 if the binary string provided in line 3 is rejected or a 1 if the binary string provided in the line 3 is accepted.

(back to top)

## License

This project is property of Emilio Popovits Blake, Patricio Tena, Ana Paola Minchaca, and Rodrigo Benavente. All rights are reserved. Modification or redistribution of this code must have _explicit_ consent from any owner.

(back to top)

## Contact

Emilio Popovits Blake - [Contact](https://emilioppv.com/contact)

Ana Paola Minchaca García - [Github](https://github.com/anapao-minchaca)

Project Link: [https://github.com/empobla/PProblemSolver](https://github.com/empobla/PProblemSolver)

(back to top)

[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?style=for-the-badge&logo=linkedin&colorB=555
[linkedin-url]: https://linkedin.com/in/emilio-popovits

[Python]: https://img.shields.io/badge/python-3776ab?style=for-the-badge&logo=python&logoColor=ffdc52
[Python-url]: https://www.python.org/

[moreinfo-url]: https://emilioppv.com/projects#p-problem-verifier
[moreinfo-shield]: https://img.shields.io/badge/more%20info-1b1f24?style=for-the-badge&logo=