|
|
- /****************************************************************************************[Dimacs.h]
- Copyright (c) 2003-2006, Niklas Een, Niklas Sorensson
- Copyright (c) 2007-2010, Niklas Sorensson
-
- Permission is hereby granted, free of charge, to any person obtaining a copy of this software and
- associated documentation files (the "Software"), to deal in the Software without restriction,
- including without limitation the rights to use, copy, modify, merge, publish, distribute,
- sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:
-
- The above copyright notice and this permission notice shall be included in all copies or
- substantial portions of the Software.
-
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT
- NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
- DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT
- OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- **************************************************************************************************/
-
- #ifndef Minisat_Dimacs_h
- #define Minisat_Dimacs_h
-
- #include <stdio.h>
-
- #include "utils/ParseUtils.h"
- #include "core/SolverTypes.h"
-
- namespace Minisat {
-
- //=================================================================================================
- // DIMACS Parser:
-
- template<class B, class Solver>
- static void readClause(B& in, Solver& S, vec<Lit>& lits) {
- int parsed_lit, var;
- lits.clear();
- for (;;){
- parsed_lit = parseInt(in);
- if (parsed_lit == 0) break;
- var = abs(parsed_lit)-1;
- while (var >= S.nVars()) S.newVar();
- lits.push( (parsed_lit > 0) ? mkLit(var) : ~mkLit(var) );
- }
- }
-
- template<class B, class Solver>
- static void parse_DIMACS_main(B& in, Solver& S) {
- vec<Lit> lits;
- int vars = 0;
- int clauses = 0;
- int cnt = 0;
- for (;;){
- skipWhitespace(in);
- if (*in == EOF) break;
- else if (*in == 'p'){
- if (eagerMatch(in, "p cnf")){
- vars = parseInt(in);
- clauses = parseInt(in);
- // SATRACE'06 hack
- // if (clauses > 4000000)
- // S.eliminate(true);
- }else{
- printf("PARSE ERROR! Unexpected char: %c\n", *in), exit(3);
- }
- } else if (*in == 'c' || *in == 'p')
- skipLine(in);
- else{
- cnt++;
- readClause(in, S, lits);
- S.addClause_(lits); }
- }
- if (vars != S.nVars())
- fprintf(stderr, "WARNING! DIMACS header mismatch: wrong number of variables.\n");
- if (cnt != clauses)
- fprintf(stderr, "WARNING! DIMACS header mismatch: wrong number of clauses.\n");
- }
-
- // Inserts problem into solver.
- //
- template<class Solver>
- static void parse_DIMACS(gzFile input_stream, Solver& S) {
- StreamBuffer in(input_stream);
- parse_DIMACS_main(in, S); }
-
- //=================================================================================================
- }
-
- #endif
|