Loading [MathJax]/jax/output/HTML-CSS/jax.js

First time here? Check out the FAQ!

Ask Your Question
1

Calculate FOC of a simple economics problem

asked 1 year ago

sora16 gravatar image

Set C(t) is the consumption of time t; beta is the discount factor

The objective function of customer (choose C(t) for on each time t) is the sum of beta^t * log(C(t)) ; t is from 0 to +oo.

The budget constrain is Y(t) - C(t) + r(t)K(t) = K(t+1) for t = 0 ... +oo

How to get the right FOC of this function to C(t) and K(t) from SegaMath

for example: FOC wrt C(t) : beta^t * 1/C(t) - lambda(t) = 0 FOC wrt K(t) : ...

Additionally, how to set the objective function as a expectation on time t (E_t(sum of beta^t * log(C(t)) ; t is from 0 to +oo) and get similar FOCs

Preview: (hide)

Comments

Welcome to Ask Sage! Thank you for your question!

slelievre gravatar imageslelievre ( 1 year ago )

1 Answer

Sort by » oldest newest most voted
0

answered 1 year ago

Cyrille gravatar image

updated 1 year ago

29/05/2023 (worked with SageMath 9.7)

I have tried to partially solve your problem. When i say partially it's not really correct since I have solved it in finite time (hopping I have make no mystakes). I need some help to go to infinite horizon. In what concerns expectations, I have not open my Sargent, Lucas.... since at least 15 years so it needs reflexion and certainly the definition of the properties of the expectation operator since if you know the distribution there is no great difficulties. But to construct the attached notebook, I use at least 3 days of work. It was interesting since I encounter some unexpected difficulties.

Hope I have not make mistakes in the resolution but I think the code is full functional or at least shows "a" path you must follow to solve such a problem. I will try to resolve it in continuous time as soon as I will have some time.

The attached code is in french. Hope you can understand it. Else you can translate some sentences. Normaly there is no difficulties in inserting it in a Jupyter notebook. I cannot upload her a notebook (I do not know why here the two first latex centered equation are not computed by the site, but copied in a notebook they are correctly displayed.

c1###Put this cell in a markup cell

soit à résoudre le programme suivant :

\max_{{c_t}} \left{\left.\left(\sum_{t=0}^\infty\beta^t \log(C_t)\right) + B(x_T)\right| K_{t+1} = Y_t - C_t +r_t K_t, K_0 = \overline{K},\text{conditions}\right}

On sait que pour résoudre un tel programme, il faut définir un hamiltonien et des fonctions adjointes. Commençons par résoudre le programme en temps fini :

\max_{{c_t}} \left{\left.\left(\sum_{t=0}^{T-1}\beta^t \log(C_t)\right)+B(x_T)\right| K_{t+1} = Y_t - C_t +r_t K_t,K_0 = \overline{K},\text{conditions}\right}

On sait que pour résoudre un tel programme, il faut définir un hamiltonien et des fonctions adjointes :

¯Ht=βtf(xt,ut,t)+μt+1g(xt,ut,t)pourt=0,1,,T1

avec ici f(xt,ut,t)=log(Ct), xt=KT, ut=Ct, Kt+1=g(xt,ut,t)=YtCt+rtKt, Yt et rt étant des fonctions données et ¯K une constante et BT=B(xT) une fonction d'héritage (qui détermine l'état du système en fin d'horizon -- T est ce que l'on appelle l'horizon).

On sait qu'il est possible de réécrire l'hamiltonien en valeur courantes en posant μ(t)=βtλ(t).

¯Ht=βtf(xt,ut,t)+βt+1λt+1g(xt,ut,t)pourt=0,1,,T1

ce qui donne

βt¯Ht=Ht=f(xt,ut,t)+βλt+1g(xt,ut,t)pourt=0,1,,T1

Les conditions nécessaires d'optimalité affirment que l'Hamiltonien Ht est maximisé par rapport à la variable de commande à chaque instant, soit :

Htut=0soit iciHtCt=0

À ces conditions d'optimalité, on doit rajouter les conditions adjointes :

λt=Htxtsoit iciλt=HtKtpourt=0,1,,T1

On doit alors rajouter la condition de transversalité :

λT=B(xT)

Les conditions signifient qu'il peut aussi y avoir des contraintes sur les commandes ut ou sur l'état xt (mais pour l'instant nous ne les prendrons pas en considération). Dans un premier temps, nous considèrerons que B(xT)0.

Commençons par définir les fonction U et g et les variables. Comme <it>SageMath</it> n'accepte pas les indices de la forme t+1, nous aurons ts et t+1t.

#

c2 ###code cell

β, s, λ_t, Y_s, C_s, K_s, K_t, r_s, s = var('β s λ_t Y_s C_s K_s K_t r_s s', domain='real')
U=function('U')(x)
U(x) = log(x)
H(C_s,K_s)= log(C_s)+β*λ_t*(Y_s- C_s + r_s*K_s)
show(LatexExpr(r'\text{Le hamiltonien est définit comme la fonction suivante : }'),H)
sol = solve(diff(H(C_s,K_s),C_s)==0, C_s)
CC=sol[0].rhs()
show(LatexExpr(r'''\text{A l'optimum, le long du sentier de croissance optimale : } C_s ='''),CC)
#

c3###Markup cell

On doit encore évaluer :

#

c4###code cell

A= diff(H(C_s,K_s),K_s)
show(LatexExpr(r'\frac{\partial H_t}{\partial K_t} = '),A)
#

c4###Markup cell

Après substitution, on doit donc résoudre les deux équations de récurrence :

Kt+1=Yt(1/λt+1)+rtKt,K0=¯K λt=rtλt+1λT=B(xT)

La seconde équation est une équation de récurrence linéaire.

λt+1=1rtλt

avec une condition terminale λT. Nous supposerons, qu'il n'y a pas de motif d'héritage. Donc λT=0. Et nous supposerons que rt=r constante.

#

c5###Code cell

t, r, K_0, T, K_T=var('t r K_0 T K_T')
from sympy import Function, Symbol, rsolve
from sympy.abc import n
λ = Function('λ')
rs=rsolve(λ(n+1)-r*λ(n),λ(n),{λ(0):K_0})
λ(n)=rs
λ(t)
show(LatexExpr(r'λ(t) = '),λ(t))
#

c6###Markup cell

On doit donc trouver la valeur de K0 telle que λ(t)=KT

#

c7###Code cell

ksol=solve(λ(T)==K_T,K_0)
show(LatexExpr(r'K_0 = '),ksol[0].rhs())
λ(t)=λ(t).substitute(K_0=ksol[0].rhs())
show(LatexExpr(r'λ(t) = '),λ(t))
#

c8###Code cell

ksol=solve(λ(T)==K_T,K_0)
show(LatexExpr(r'K_0 = '),ksol[0].rhs())
λ(t)=λ(t).substitute(K_0=ksol[0].rhs())
show(LatexExpr(r'λ(t) = '),λ(t))
c(t) = CC.subs_t==λ(t))
show(LatexExpr(r'\text{Le long du sentier de croissance optimale : }C(t) = '),c(t))
#

c9###Code cell

var('t r Y_0 T γ')
from sympy import Function, Symbol, rsolve
from sympy.abc import n
K = Function('K')
rs1=rsolve(K(n+1)-r*K(n)+ Y_0*γ^n-c(n),K(n),{K(0):Y_0})
K(n)=rs1
K(t)
show(LatexExpr(r'K(t) = '),K(t).full_simplify())
#

On more time I hope ther is no mystakes.

Preview: (hide)
link

Your Answer

Please start posting anonymously - your entry will be published after you log in or create a new account.

Add Answer

Question Tools

Stats

Asked: 1 year ago

Seen: 633 times

Last updated: May 29 '23