/* Copyright (c) 2017 Microsoft Corporation. All rights reserved. Released under Apache 2.0 license as described in the file LICENSE. Author: Leonardo de Moura */ #pragma once #include "util/numerics/mpq.h" #include "library/type_context.h" namespace lean { class arith_instance_info { friend class arith_instance; expr m_type; levels m_levels; /* Partial applications */ optional m_zero, m_one; optional m_add, m_sub, m_neg; optional m_mul, m_div, m_inv; optional m_lt, m_le; optional m_bit0, m_bit1; /* Structures */ optional m_partial_order; optional m_add_comm_semigroup; optional m_monoid, m_add_monoid; optional m_add_group, m_add_comm_group; optional m_distrib, m_mul_zero_class; optional m_semiring, m_linear_ordered_semiring; optional m_ring, m_linear_ordered_ring; optional m_field; public: arith_instance_info(expr const & type, level const & lvl):m_type(type), m_levels(lvl) {} }; typedef std::shared_ptr arith_instance_info_ptr; arith_instance_info_ptr mk_arith_instance_info(expr const & type, level const & lvl); class arith_instance { type_context * m_ctx; arith_instance_info_ptr m_info; expr mk_structure(name const & s, optional & r); expr mk_op(name const & op, name const & s, optional & r); expr mk_pos_num(mpz const & n); public: arith_instance(type_context & ctx, arith_instance_info_ptr const & info):m_ctx(&ctx), m_info(info) {} arith_instance(type_context & ctx, expr const & type, level const & level); arith_instance(type_context & ctx, expr const & type); arith_instance(arith_instance_info_ptr const & info):m_ctx(nullptr), m_info(info) {} arith_instance(type_context & ctx):m_ctx(&ctx) {} void set_info(arith_instance_info_ptr const & info) { m_info = info; } void set_type(expr const & type); expr const & get_type() const { return m_info->m_type; } levels const & get_levels() const { return m_info->m_levels; } bool is_nat(); expr mk_zero(); expr mk_one(); expr mk_add(); expr mk_sub(); expr mk_neg(); expr mk_mul(); expr mk_div(); expr mk_inv(); expr mk_lt(); expr mk_le(); expr mk_bit0(); expr mk_bit1(); expr mk_has_zero() { return app_arg(mk_zero()); } expr mk_has_one() { return app_arg(mk_one()); } expr mk_has_add() { return app_arg(mk_add()); } expr mk_has_sub() { return app_arg(mk_sub()); } expr mk_has_neg() { return app_arg(mk_neg()); } expr mk_has_mul() { return app_arg(mk_mul()); } expr mk_has_div() { return app_arg(mk_div()); } expr mk_has_inv() { return app_arg(mk_inv()); } expr mk_has_lt() { return app_arg(mk_lt()); } expr mk_has_le() { return app_arg(mk_le()); } expr mk_partial_order(); expr mk_add_comm_semigroup(); expr mk_monoid(); expr mk_add_monoid(); expr mk_add_group(); expr mk_add_comm_group(); expr mk_distrib(); expr mk_mul_zero_class(); expr mk_semiring(); expr mk_linear_ordered_semiring(); expr mk_ring(); expr mk_linear_ordered_ring(); expr mk_field(); expr mk_num(mpz const & n); expr mk_num(mpq const & n); optional eval(expr const & e); }; };