2023-05-05 10:01:37 -05:00
|
|
|
/******************************************************************************
|
|
|
|
|
* Top contributors (to current version):
|
2024-03-12 09:35:09 -07:00
|
|
|
* Andrew Reynolds, Aina Niemetz
|
2023-05-05 10:01:37 -05:00
|
|
|
*
|
|
|
|
|
* This file is part of the cvc5 project.
|
|
|
|
|
*
|
2025-01-23 09:54:20 -08:00
|
|
|
* Copyright (c) 2009-2025 by the authors listed in the file AUTHORS
|
2023-05-05 10:01:37 -05:00
|
|
|
* in the top-level source directory and their institutional affiliations.
|
|
|
|
|
* All rights reserved. See the file COPYING in the top-level source
|
|
|
|
|
* directory for licensing information.
|
|
|
|
|
* ****************************************************************************
|
|
|
|
|
*
|
|
|
|
|
* Test for project issue #580
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
#include <cvc5/cvc5.h>
|
|
|
|
|
|
|
|
|
|
using namespace cvc5;
|
|
|
|
|
int main(void)
|
|
|
|
|
{
|
2024-03-08 11:39:13 -08:00
|
|
|
TermManager tm;
|
|
|
|
|
Solver solver(tm);
|
2023-05-05 10:01:37 -05:00
|
|
|
solver.setOption("incremental", "false");
|
|
|
|
|
solver.setOption("produce-abducts", "true");
|
|
|
|
|
solver.setOption("sygus-grammar-cons", "any-term-concise");
|
2024-03-08 11:39:13 -08:00
|
|
|
Sort s0 = tm.getRealSort();
|
|
|
|
|
Sort s1 = tm.mkSequenceSort(s0);
|
|
|
|
|
Term t2 = tm.mkConst(s1, "_x0");
|
|
|
|
|
Term t3 = tm.mkTerm(Kind::SEQ_UNIT, {t2});
|
2023-05-05 10:01:37 -05:00
|
|
|
Sort s4 = t3.getSort();
|
2024-03-08 11:39:13 -08:00
|
|
|
Op o5 = tm.mkOp(Kind::SEQ_CONTAINS);
|
|
|
|
|
Term t6 = tm.mkTerm(o5, {t3, t3});
|
2023-05-05 10:01:37 -05:00
|
|
|
Sort s7 = t6.getSort();
|
|
|
|
|
solver.assertFormula(t6);
|
|
|
|
|
Term t8 = solver.getAbduct(t6);
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|