我正在试图解一个方程组。下面的例子中的方程是拉格朗日函数(LDash 1到7)的第一个导数,我用笔和纸得到了它。系统的解决方案应该给出极大值和最小值的候选值。
选择变量是X1, X2, LC, LA, s, u,而所有其他符号都是正数的位置持有者。
脚本运行,但在我的控制台中没有显示任何内容。在整个SymPy文档示例中,solve输出解决方案。在下面的例子中,你能帮我找出为什么它不这样做吗?
我对Python完全陌生,所以请告诉我如何改进。谢谢!
# import stuff
from sympy.interactive import printing
printing.init_printing(use_latex=True)
from sympy import Function
from sympy.solvers import solve
import sympy as sp
X1, X2, LC, LA, s, u = sp.var('X_1, X_2, L_C, L_A, s, u', positive=True);
# import exogenous variables
a1, a2, a3, a4, S1, S2, S3, S4, p1, p2, p3, p4, fdash, vdash,f, v = sp.symbols('alpha_1, alpha_2, alpha_3, alpha_4, S_1, S_2, S_3, S_4, p_1, p_2, p_3, p_4, \hat{F}, \hat{V}, f, v', positive=True)
v0 = sp.symbols('v_0') # raw skill level
i = sp.symbols('\hat{\imath}') # children in the household - time endowment
I = sp.symbols('I') # household size and total time endowment
climate = sp.symbols('theta') # climate variable
capital = sp.symbols('K') # quasi fixed land and (non-human) capital
lam = sp.symbols('\lambda') # shadow prices (lagrange multiplier)
# pen-and-paper: derivatives of the Lagrange function w.r.t choice variables
LDash1 = a1/(X1-S1)-lam*p1 # L' w.r.t X1
LDash2 = a2/(X2-S2)-lam*p2 # L' w.r.t X2
LDash3 = -a3/(I-i-LA-S3) + 2*lam*p3 + lam*p1*fdash # L' w.r.t LA
LDash4 = -1/(i-LC) - a4/(i-LC-S4) + 2*lam*p4 + lam*p1*fdash*(-s*u + s*v +(1-s)*v0) # L' w.r.t LC
LDash5 = lam*p1*fdash *(-u*LC + v*LC - v0*LC) # L' w.r.t. s
LDash6 = lam*p1*fdash *(-s*LC + s*vdash*LC) # L' w.r.t u
LDash7 = p1*X1 + p2*X2 -2*p3*I + 2*p3*i + 2*p3*LA -2*p4*i + 2*p4*LC + p1*f # L' w.r.t lambda
solve((LDash1,LDash2, LDash3, LDash4, LDash5, LDash6, LDash7), (X1,X2,LA,LC,u,s))发布于 2021-06-17 12:37:47
您有两个问题,第一,解决电话将花费很长的时间,并有可能根本无法成功返回。其次,即使它会返回,假设您用solve(LDash1, X1)替换调用,solve的返回值永远不会被打印出来。试着用下面的代码替换最后一行,例如,以便能够调试您的方程式。
solve(LDash1, X1)答案被打印在文档中的原因是因为它们使用https://docs.python.org/3/tutorial/interpreter.html#interactive-mode,这通常由Python交互提示符>>>表示。
https://stackoverflow.com/questions/68019357
复制相似问题