Skip to content

Commit

Permalink
Change translation to work around CVC5 limitation. (#826)
Browse files Browse the repository at this point in the history
* Change translation to work around CVC5 limitation.

Now we translate `ConstMap Default` as just `Default`, which is hopefully
OK as we have something weaker.   This fixes #795 for the time being,
until issue #11485 in the CVC5 repo is fixed.

* Fix formatting.
  • Loading branch information
yav authored Jan 14, 2025
1 parent f662db6 commit f1782db
Showing 1 changed file with 11 additions and 3 deletions.
14 changes: 11 additions & 3 deletions backend/cn/lib/solver.ml
Original file line number Diff line number Diff line change
Expand Up @@ -992,9 +992,17 @@ let rec translate_term s iterm =
translate_term s (divisible_ (addr, t.align) loc)
(* Maps *)
| MapConst (bt, e1) ->
let kt = translate_base_type bt in
let vt = translate_base_type (IT.get_bt e1) in
SMT.arr_const kt vt (translate_term s e1)
(match IT.get_term e1 with
(* This is a work-around for the fact the CVC5 only supports `const` on
value, not vairables (see #11485 in the CVC5 repo). Until this is
fixed, with translate `MapConst Default` as just `Default`. Hopefully,
this is OK, as we are getting a weaker term (i.e., we can't assume that
all elements of the array are the same, but they might be). *)
| Const (Default t) -> default (BT.make_map_bt bt t)
| _ ->
let kt = translate_base_type bt in
let vt = translate_base_type (IT.get_bt e1) in
SMT.arr_const kt vt (translate_term s e1))
| MapSet (mp, k, v) ->
SMT.arr_store (translate_term s mp) (translate_term s k) (translate_term s v)
| MapGet (mp, k) -> SMT.arr_select (translate_term s mp) (translate_term s k)
Expand Down

0 comments on commit f1782db

Please sign in to comment.