refactor(library/fun_info_manager): use expr_unsigned_map
This commit is contained in:
parent
7312dd77b8
commit
9a1a9f3b5a
2 changed files with 18 additions and 20 deletions
|
@ -65,22 +65,25 @@ list<unsigned> fun_info_manager::get_core(expr const & fn, buffer<param_info> &
|
||||||
}
|
}
|
||||||
|
|
||||||
fun_info fun_info_manager::get(expr const & e) {
|
fun_info fun_info_manager::get(expr const & e) {
|
||||||
if (auto r = m_cache_get.find(e))
|
auto it = m_cache_get.find(e);
|
||||||
return *r;
|
if (it != m_cache_get.end())
|
||||||
|
return it->second;
|
||||||
buffer<param_info> pinfos;
|
buffer<param_info> pinfos;
|
||||||
auto result_deps = get_core(e, pinfos, std::numeric_limits<unsigned>::max());
|
auto result_deps = get_core(e, pinfos, std::numeric_limits<unsigned>::max());
|
||||||
fun_info r(pinfos.size(), to_list(pinfos), result_deps);
|
fun_info r(pinfos.size(), to_list(pinfos), result_deps);
|
||||||
m_cache_get.insert(e, r);
|
m_cache_get.insert(mk_pair(e, r));
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
fun_info fun_info_manager::get(expr const & e, unsigned nargs) {
|
fun_info fun_info_manager::get(expr const & e, unsigned nargs) {
|
||||||
if (auto r = m_cache_get_nargs.find(mk_pair(nargs, e)))
|
expr_unsigned key(e, nargs);
|
||||||
return *r;
|
auto it = m_cache_get_nargs.find(key);
|
||||||
|
if (it != m_cache_get_nargs.end())
|
||||||
|
return it->second;
|
||||||
buffer<param_info> pinfos;
|
buffer<param_info> pinfos;
|
||||||
auto result_deps = get_core(e, pinfos, nargs);
|
auto result_deps = get_core(e, pinfos, nargs);
|
||||||
fun_info r(pinfos.size(), to_list(pinfos), result_deps);
|
fun_info r(pinfos.size(), to_list(pinfos), result_deps);
|
||||||
m_cache_get_nargs.insert(mk_pair(nargs, e), r);
|
m_cache_get_nargs.insert(mk_pair(key, r));
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,13 +194,15 @@ fun_info fun_info_manager::get_specialization(expr const & a) {
|
||||||
expr g = a;
|
expr g = a;
|
||||||
for (unsigned i = 0; i < num_rest_args; i++)
|
for (unsigned i = 0; i < num_rest_args; i++)
|
||||||
g = app_fn(g);
|
g = app_fn(g);
|
||||||
if (auto r = m_cache_get_spec.find(mk_pair(num_rest_args, g)))
|
expr_unsigned key(g, num_rest_args);
|
||||||
return *r;
|
auto it = m_cache_get_spec.find(key);
|
||||||
|
if (it != m_cache_get_spec.end())
|
||||||
|
return it->second;
|
||||||
buffer<param_info> new_pinfos;
|
buffer<param_info> new_pinfos;
|
||||||
copy_prefix(prefix_sz, pinfos, new_pinfos);
|
copy_prefix(prefix_sz, pinfos, new_pinfos);
|
||||||
auto result_deps = get_core(g, new_pinfos, num_rest_args);
|
auto result_deps = get_core(g, new_pinfos, num_rest_args);
|
||||||
fun_info r(new_pinfos.size(), to_list(new_pinfos), result_deps);
|
fun_info r(new_pinfos.size(), to_list(new_pinfos), result_deps);
|
||||||
m_cache_get_spec.insert(mk_pair(num_rest_args, g), r);
|
m_cache_get_spec.insert(mk_pair(key, r));
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,8 @@ Released under Apache 2.0 license as described in the file LICENSE.
|
||||||
Author: Leonardo de Moura
|
Author: Leonardo de Moura
|
||||||
*/
|
*/
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "library/expr_lt.h"
|
#include "kernel/expr_maps.h"
|
||||||
|
#include "library/expr_unsigned_map.h"
|
||||||
#include "library/type_context.h"
|
#include "library/type_context.h"
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
|
@ -82,16 +83,8 @@ public:
|
||||||
dependencies, implicit binder info, etc. */
|
dependencies, implicit binder info, etc. */
|
||||||
class fun_info_manager {
|
class fun_info_manager {
|
||||||
type_context & m_ctx;
|
type_context & m_ctx;
|
||||||
struct unsigned_expr_cmp {
|
typedef expr_map<fun_info> cache;
|
||||||
int operator()(pair<unsigned, expr> const & p1, pair<unsigned, expr> const & p2) const {
|
typedef expr_unsigned_map<fun_info> narg_cache;
|
||||||
if (p1.first != p2.first)
|
|
||||||
return p1.first < p2.first ? -1 : 1;
|
|
||||||
else
|
|
||||||
return expr_quick_cmp()(p1.second, p2.second);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
typedef rb_map<expr, fun_info, expr_quick_cmp> cache;
|
|
||||||
typedef rb_map<pair<unsigned, expr>, fun_info, unsigned_expr_cmp> narg_cache;
|
|
||||||
cache m_cache_get;
|
cache m_cache_get;
|
||||||
narg_cache m_cache_get_nargs;
|
narg_cache m_cache_get_nargs;
|
||||||
narg_cache m_cache_get_spec;
|
narg_cache m_cache_get_spec;
|
||||||
|
|
Loading…
Reference in a new issue