如何序列化sympy lambdified函数?

发布于 2021-01-29 16:53:16

标题说明了一切。有什么方法可以序列化sympy.lambdify生成的函数?

import sympy as sym
import pickle
import dill
a, b = sym.symbols("a, b")
expr = sym.sin(a) + sym.cos(b)
lambdified_expr = sym.lambdify((a, b), expr, modules="numpy")
pickle.dumps(lambdified_expr) # won't work
dill.dumps(lambdified_expr) # won't work either

…之所以要这样做,是因为我的代码生成了很多lambdified函数,但是我发现每次都花很长时间。

关注者
0
被浏览
29
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    实际上,你 可以
    dill腌它。dill(例如,在github上)的最新版本具有“设置”,允许在上构造腌制方式的变体dump。是的,dill此对象的默认设置失败,但是如果您使用递归跟踪全局引用(即recurse = True)的设置,则默认设置失败。此设置类似于cloudpickle默认情况下的设置。

    >>> import sympy as sym
    >>> import pickle
    >>> import dill
    >>> a, b = symbols("a, b")
    >>> a, b = sym.symbols("a, b")
    >>> expr = sym.sin(a) + sym.cos(b)
    >>> lambdified_expr = sym.lambdify((a, b), expr, modules="numpy")
    >>> 
    >>> dill.settings
    {'recurse': False, 'byref': False, 'protocol': 2, 'fmode': 0}
    >>> dill.settings['recurse'] = True
    >>> dill.dumps(lambdified_expr)
    '\x80\x02cdill.dill\n_create_function\nq\x00(cdill.dill\n_unmarshal\nq\x01U\x83c\x02\x00\x00\x00\x02\x00\x00\x00\x03\x00\x00\x00C \x00\x00s\x14\x00\x00\x00t\x00\x00|\x00\x00\x83\x01\x00t\x01\x00|\x01\x00\x83\x01\x00\x17S(\x01\x00\x00\x00N(\x02\x00\x00\x00t\x03\x00\x00\x00sint\x03\x00\x00\x00cos(\x02\x00\x00\x00t\x01\x00\x00\x00at\x01\x00\x00\x00b(\x00\x00\x00\x00(\x00\x00\x00\x00s\x08\x00\x00\x00<string>t\x08\x00\x00\x00<lambda>\x01\x00\x00\x00s\x00\x00\x00\x00q\x02\x85q\x03Rq\x04}q\x05(U\x03cosq\x06cnumpy.core.umath\ncos\nq\x07U\x03sinq\x08cnumpy.core.umath\nsin\nq\tuU\x08<lambda>q\nNN}q\x0btq\x0cRq\r.'
    

    PS我是dill作者,所以我知道。



知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看