Private Sub Command1_Click()
Dim ks As Single
Dim a As Single
Dim beta As Single
Dim r1 As Single
Dim n As Single
Dim cx(1 To 100) As Single
Dim cp(1 To 100) As Single
Dim lx(1 To 100) As Single
Dim lp(1 To 100) As Single
Dim k(1 To 100) As Single
Dim h As Single
Dim k1 As Single
Dim n1 As Single
Dim n2 As Single
Dim n3 As Single
Dim c1 As Single
Dim e As Single
Dim ls As Single
ls = 0.5
beta = 0.95
a = 0.33
ks = ls * ((1 / beta - 1) / a) ^ (1 / (a - 1))
h = 2 * ks / 100
For n = 1 To 100
k(n) = n * h
lx(n) = ls
cx(n) = k(n) ^ a * lx(n) ^ (1 - a)
Next
t1 = 0
Do Until t1 > 100
For n = 10 To 90
k1 = k(n) + k(n) ^ a * lx(n) ^ (1 - a) - cx(n)
n1 = k1 / h
n2 = Int(n1)
n3 = n2 + 1
c1 = cx(n2) + (n1 - n2) * (cx(n3) - cx(n2))
l1 = lx(n2) + (n1 - n2) * (lx(n3) - lx(n2))
r1 = a * k1 ^ (a - 1) * l1 ^ (1 - a)
cp(n) = c1 / (beta * (1 + r1))
Next
w1 = (1 - a) * k(n) ^ a * lx(n) ^ (-a)
lp(n) = 1 - cx(n) / w1
e = 0
For n = 10 To 90
e = e + (cx(n) - cp(n)) ^ 2 + (lx(n) - lp(n)) ^ 2
Next
For n = 10 To 90
cx(n) = cp(n)
lx(n) = lp(n)
Next
If e < 10 ^ (-5) Then t1 = 1000
t1 = t1 + 1
Loop
Dim ms As Single
Dim px(1 To 100) As Single
Dim ps(1 To 100) As Single
Dim p1 As Single
Dim p2 As Single
Dim p3 As Single
Dim z1 As Single
Dim z2 As Single
Dim z3 As Single
Dim pi As Single
Dim pxs As Single
ms = 50
For n = 1 To 100
px(n) = 1
Next
t4 = 0
Do Until t4 > 100
For n = 10 To 90
p1 = 1.1 * px(n)
p2 = 0.9 * px(n)
k1 = k(n) + k(n) ^ a * lx(n) ^ (1 - a) - cx(n)
n1 = k1 / h
n2 = Int(n1)
n3 = n2 + 1
pxs = px(n2) + (n1 - n2) * (px(n3) - px(n2))
l1 = lx(n2) + (n1 - n2) * (lx(n3) - lx(n2))
r1 = a * k1 ^ (a - 1) * l1 ^ (1 - a)
pi = pxs / p1 - 1
iss = (1 + pi) * (1 + r1) - 1
z1 = iss * ms / (cx(n) * (1 + iss)) - p1
t3 = 0
Do Until t3 > 100
pi = pxs / p2 - 1
iss = (1 + pi) * (1 + r1) - 1
z2 = iss * ms / (cx(n) * (1 + iss)) - p2
p3 = p2 - z2 * (p2 - p1) / (z2 - z1)
If z2 ^ 2 < 10 ^ (-5) Then t3 = 1000
p1 = p2
p2 = p3
z1 = z2
t3 = t3 + 1
Loop
ps(n) = p2
Next
e = 0
For n = 10 To 90
e = e + (px(n) - ps(n)) ^ 2
Next
For n = 10 To 90
px(n) = ps(n)
Next
If e < 10 ^ (-5) Then t4 = 1000
t4 = t4 + 1
Loop
For n = 10 To 90
Debug.Print px(n)
Next
End Sub
最終更新:2009年02月13日 17:59