sig
  val name : string
  type term = Nunchaku_core.TermInner.Default.t
  type decode_state
  val elim_ind_preds :
    (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.t ->
    (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.t *
    ElimIndPreds.decode_state
  val decode_model :
    state:ElimIndPreds.decode_state ->
    (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Model.t ->
    (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Model.t
  val pipe :
    print:bool ->
    check:bool ->
    ((ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.t,
     (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.t,
     (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.Res.t,
     (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.Res.t)
    Nunchaku_core.Transform.t
  val pipe_with :
    decode:(ElimIndPreds.decode_state -> '-> 'd) ->
    print:bool ->
    check:bool ->
    ((ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.t,
     (ElimIndPreds.term, ElimIndPreds.term) Nunchaku_core.Problem.t, 'c, 'd)
    Nunchaku_core.Transform.t
end