# 1. เรียกใช้านชุดคำสั่งที่จำเป็น
library(reticulate)
# 2. นำเข้า SymPy
<- import("sympy") sympy
7 สมการเชิงอนุพันธ์เบื้องต้นและการประยุกต์ในทางเศรษฐศาสตร์
การที่นักเศรษฐศาสตร์ต้องศึกษาสมการเชิงอนุพันธ์ (Ordinary Differential Equations: ODEs) เป็นเรื่องที่ สำคัญมาก โดยเฉพาะในสายงานเศรษฐศาสตร์ที่เกี่ยวข้องกับ พลวัตของระบบ (dynamic systems) เช่น การเจริญเติบโตทางเศรษฐกิจ, พฤติกรรมการบริโภคในระยะเวลา, หรือแม้แต่การเงินระหว่างประเทศ
7.1 ทำไมนักเศรษฐศาสตร์ต้องศึกษาสมการเชิงอนุพันธ์?
เพื่อเข้าใจพลวัตของระบบเศรษฐกิจ เศรษฐกิจเป็นระบบที่เปลี่ยนแปลงตามเวลา เช่น GDP, เงินเฟ้อ, การลงทุน ฯลฯ สมการ ODE ช่วยอธิบายว่า “ตัวแปรหนึ่งเปลี่ยนแปลงตามเวลาอย่างไร” เช่น Solow growth model: การเปลี่ยนแปลงของทุน K
ใช้สร้างแบบจำลองเศรษฐศาสตร์จุลภาคและมหภาค
Consumption models เช่น Ramsey–Cass–Koopmans model ใช้ ODE อธิบายการบริโภคระยะยาว
IS-LM dynamic model ใช้ ODE แสดงการปรับตัวของตลาดเงินและตลาดสินค้า
Overlapping Generation Model (OLG) อาศัย ODE เพื่อวิเคราะห์พฤติกรรมของรุ่นประชากรในอนาคต
ใช้ในเศรษฐศาสตร์การเงิน (Financial Economics)
การกำหนดราคาสินทรัพย์ (เช่น bond, stock)
Black-Scholes Equation เป็นสมการเชิงอนุพันธ์บางส่วน (PDE) ที่มีรากฐานจาก ODE
Interest Rate Models เช่น Vasicek model
เข้าใจพฤติกรรมสมดุลและเสถียรภาพ
การวิเคราะห์จุดสมดุล (steady state)
การดูว่าเศรษฐกิจมีแนวโน้มเข้าสู่ภาวะสมดุดลหรือไม่ โดยใช้ eigenvalue analysis จากระบบ ODE
7.1.1 ตัวอย่างสมการที่นักเศรษฐศาสตร์ควรรู้
แบบจำลอง | รูปแบบสมการ | คำอธิบาย |
---|---|---|
Solow Model | การเติบโตของทุนต่อหัว | |
Ramsey Model | พฤติกรรมบริโภคที่เหมาะสม | |
IS-LM dynamic | การปรับตัวของรายได้ | |
Predator-Prey (ในเศรษฐกิจพลังงาน/สิ่งแวดล้อม) | ทรัพยากร vs การบริโภค |
7.2 สมการเชิงอนุพันธ์ (Ordinary Differential Equation: ODE)
สมการเชิงอนุพันธ์ คือสมการที่เกี่ยวข้องกับฟังก์ชัน
การแก้สมการเชิงอนุพันธ์
เป้าหมายคือ: หา ฟังก์ชัน
ตัวอย่าง:
วิธีแก้:
- แยกตัวแปร (Separation of Variables):
- อินทิเกรตทั้งสองข้าง:
- ยกกำลัง:
คำตอบทั่วไป (General Solution): ฟังก์ชันที่ขึ้นกับค่าคงที่
คำตอบเฉพาะ (Particular Solution): เมื่อกำหนดเงื่อนไขเริ่มต้น เช่น
7.3 การแก้สมการเชิงอนุพันธ์ด้วย caracas และ SymPy
แม้ caracas
จะไม่สามารถแก้ ODE ได้โดยตรงเหมือนใน SymPy (Python) แต่เราสามารถใช้ caracas
ร่วมกับ reticulate
เพื่อเรียก SymPy
มาใช้งานได้เต็มรูปแบบในอาร์
การใช้ SymPy ด้วยอาร์มีความยุ่งยากเพิ่มขึ้นเล็กน้อย ดังนั้นในเนื้อหา ODE มีหมายถึงฟังก์ชัน ที่จะถูกใช้งานบ่อยๆ เราสามารถเปลี่ยนเป็นฟังก์ชัน ที่ช่วยให้เขียนได้สั้น และกระชับลงได้มาก ดังนี้
7.4 ฟังก์ชันที่ใช้บ่อยในการแก้ ODE ด้วย sympy
:
symbols()
– กำหนดตัวแปรFunction()
– สร้างฟังก์ชันdiff()
– หาอนุพันธ์Eq()
– นิยามสมการdsolve()
– แก้สมการเชิงอนุพันธ์
7.5 การสร้างฟังก์ชันในอาร์เพื่อใช้ SymPy แก้สมการเชิงอนุพันธ์
# โหลด SymPy
library(reticulate)
<- import("sympy")
sympy # กำหนด helper ฟังก์ชัน
# สร้างตัวแปร
<- sympy$symbols
syms # สร้างฟังก์ชัน
<- sympy$Function
func # หาอนุพันธ์
<- sympy$diff
diff_ # สร้างสมการ
<- sympy$Eq
Eq # แก้สมการเชิงอนุพันธ์
<- sympy$dsolve dsolve
ตัวอย่างการใช้งาน:
- ไม่มีเงื่อนไขเริ่มต้น:
<- syms("t")
t <- syms("k")
k <- func("y")
y <- Eq(diff_(y(t),t), k*y(t))
ode ode
Eq(Derivative(y(t), t), k*y(t))
dsolve(ode)
Eq(y(t), C1*exp(k*t))
- มีเงื่อนไขเริ่มต้น
:
<- make_ics(list("y(0)" = "y0"))
ics dsolve(ode, ics = ics)
Eq(y(t), y0*exp(k*t))
7.6 ตัวอย่างสมการเชิงอนุพันธ์ในทางเศรษฐศาสตร์
7.6.1 Consumption Growth Equation (Euler Equation)
วิธีทำ ใช้ SymPy ในการหาคำตอบ
# สร้างตัวแปร
<- syms("t")
t <- syms("theta", positive = TRUE)
theta <- syms("r", positive = TRUE)
r <- syms("rho", positive = TRUE)
rho # สร้างฟังก์ชัน
<- func("C") # ห้ามตั้งชื่อด้วย c เพราะจะไปตรงกับ c( ) ของ R
C <- Eq(sympy$diff(C(t), t), (r - rho) * C(t)/theta)
ode ode
Eq(Derivative(C(t), t), (r - rho)*C(t)/theta)
จัดเป็นสมการให้สวยงาม
latex_render(ode)
dsolve(ode)
Eq(C(t), C1*exp(t*(r - rho)/theta))
- มีเงื่อนไขเริ่มต้น
:
<- make_ics(list("C(0)" = "C0"), funcname = "C")
ics latex_render(dsolve(ode, ics = ics))
7.6.2 Solow Growth Equation (Capital Accumulation)
วิธีทำ ใช้ SymPy ในการหาคำตอบ
# สร้างตัวแปร
<- syms("s", positive = TRUE)
s <- syms("delta", positive = TRUE)
delta <- syms("alpha", positive = TRUE)
alpha
# สร้างฟังก์ชัน
<- func("k")
k <- s*k(t)^alpha-delta*k(t)
rhs <- Eq(sympy$diff(k(t), t), rhs)
ode ode
Eq(Derivative(k(t), t), -delta*k(t) + s*k(t)**alpha)
จัดเป็นสมการให้สวยงาม
latex_render(ode)
ถ้าไม่กำหนดค่า
# แทนค่า theta = 0.5
<- ode$subs(alpha, 0.5)
ode_sub ode_sub
Eq(Derivative(k(t), t), -delta*k(t) + s*k(t)**0.5)
latex_render(dsolve(ode_sub))
7.6.3 Price Adjustment Model (Adaptive Expectations)
วิธีทำ ใช้ SymPy ในการหาคำตอบ และกำหนด
# สร้างตัวแปร
<- syms("t")
t <- syms("lambda_", positive = TRUE)
lambda <- syms("p_e", positive = TRUE)
pe # สร้างฟังก์ชัน
<- func("p")
p <- Eq(sympy$diff(p(t), t), lambda*(pe-p(t)))
ode latex_render(ode)
แก้สมการ
latex_render(dsolve(ode))
- มีเงื่อนไขเริ่มต้น
:
<- make_ics(list("p(0)" = "p0"), funcname = "p")
ics latex_render(dsolve(ode, ics = ics))
7.6.4 Exponential Capital Depreciation
วิธีทำ ใช้ SymPy ในการหาคำตอบ
# สร้างตัวแปร
<- syms("t")
t <- syms("delta", positive = TRUE)
delta # สร้างฟังก์ชัน
<- func("K")
K <- Eq(sympy$diff(K(t), t), -delta*K(t))
ode latex_render(ode)
แก้สมการ
latex_render(dsolve(ode))
- มีเงื่อนไขเริ่มต้น
:
<- make_ics(list("K(0)" = "K0"), funcname = "K")
ics latex_render(dsolve(ode, ics = ics))
พฤติกรรม:
เมื่อ
,ยิ่ง
มาก ทุนลดเร็วใช้ในโมเดลการเจริญเติบโต (Growth Models) เช่น Solow, Ramsey เพื่อคำนวณทุนสุทธิ:
โดย คือการลงทุนแบบจำลองนี้แสดงให้เห็นว่าหากไม่มีการลงทุนเพิ่ม ทุนจะลดลงตามเวลาอย่างต่อเนื่อง
ใช้ได้ทั้งกับทุนกายภาพ (เครื่องจักร อาคาร) และทุนมนุษย์ (ในบางบริบท)
7.6.5 Solow Growth Model (simplified)
วิธีทำ ใช้ SymPy ในการหาคำตอบ แต่ถ้ามีค่าของตัวแปรที่ไม่ทราบค่ามากเกินไปอาจจะไม่ได้คำตอบ หรือเกิดข้อผิดพลาดได้ กำหนดให้
# ตัวแปร
<- syms("s", positive = TRUE)
s <- syms("delta", positive = TRUE)
delta <- syms("t")
t # ฟังก์ชัน
<- func("K")
K # สร้างสมการ
<- Eq(diff_(K(t),t),s * K(t)^0.5 - delta * K(t))
ode latex_render(ode)
แก้สมการ
latex_render(dsolve(ode))
7.7 แบบฝึกหัดสมการเชิงอนุพันธ์ในเศรษฐศาสตร์
7.7.1 สมการเชิงอนุพันธ์พื้นฐาน (Basic ODEs)
แก้สมการเชิงอนุพันธ์
โดยกำหนดเงื่อนไขเริ่มต้นจงหา general solution ของ
, เมื่อให้
, logistic model จงหา solution ทั่วไปของสมการนี้จงแก้สมการ
แล้วหาค่า เมื่อแก้
แล้ววิเคราะห์พฤติกรรมของ เมื่อ
7.7.2 ระบบสมการเชิงอนุพันธ์ 2 ตัวแปร
พิจารณาระบบ
จงหาจุดดุลยภาพและตรวจสอบเสถียรภาพจงหาค่า eigenvalue ของระบบ
พิจารณาระบบ
จงหาเส้นเสถียร (nullclines)
เขียน flow field ของระบบ
ระบบการเปลี่ยนผ่านทุน-แรงงาน:
จงเขียนสมการ normalized ด้วย
7.7.3 แบบจำลองพลวัตทางเศรษฐศาสตร์
พิจารณา IS curve แบบพลวัต:
เมื่อ , , คงที่ จงหาสมการ ที่เป็นรูปชัดเจนแบบจำลอง Solow:
เมื่อ , , , จงวาดกราฟ เทียบกับในโมเดล Ramsey, สมการของ
ให้ , , , จงหาโมเดลการแพร่ระบาด:
จงหาเส้น Nullcline และจุดสมดุลพิจารณาระบบราคาสินค้า:
จงเขียนระบบให้อยู่ในรูปเมทริกซ์ และหาค่า eigenvalues
7.7.4 แบบฝึกหัดเพิ่มโจทย์เชิงเศรษฐศาสตร์
ถ้าอัตราการเปลี่ยนแปลงของการออมคือ
โดย , คงที่ จงแสดงสมการ ในรูปของแบบจำลองการบริโภคมีพฤติกรรมแบบปรับตัว
, จงแก้ เมื่อ ,แบบจำลองจ้างงาน:
เมื่อ จงแทนสมการให้เหลือเพียง และสมการการเติบโตของอุตสาหกรรม
ให้ จงแทนค่าลงในสมการโมเดลการสะสมทุนแบบมีความหน่วง:
จงตั้งคำถามเกี่ยวกับ stability ของระบบนี้ (ไม่ต้องแก้)
แ