Private Sub Command1_Click()
Dim byear As Single
Dim age As Single
Dim car As Single
Dim mis(1985 To 2100, 15 To 64, 1 To 49) As Single
Dim mos(1985 To 2100, 15 To 64, 1 To 49) As Single
Dim m2by(1900 To 2100, 15 To 64) As Single
Dim f2by(1900 To 2100, 15 To 64) As Single
Dim mdeby(1900 To 2100, 0 To 99) As Single
Dim fdeby(1900 To 2100, 0 To 99) As Single
Dim alpha(15 To 69) As Single
Dim beta(15 To 69) As Single
Dim gamma(15 To 69) As Single
Dim theta(15 To 64) As Single
Dim zan(1985 To 2100, 15 To 64, 1 To 49) As Single
Dim zant(1985 To 2100, 15 To 64, 1 To 49) As Single
Dim mde(1985 To 2100, 0 To 99) As Single
Dim mnewt(1985 To 2100) As Single
Dim z1 As Single
Dim z2 As Single
Dim z3 As Single
Dim v As Single
Open "c:/stream/gdata/変形生命表.txt " For Input As #1
Do Until EOF(1)
Input #1, a1, a2, a3, a4
byear = a1
age = a2
mdeby(byear, age) = a3
fdeby(byear, age) = a4
Loop
Close #1
Open "c:/stream/data/男子脱退力.txt " For Input As #2
Do Until EOF(2)
Input #2, a1, a2, a3, a4
age = a1
gamma(age) = a2
alpha(age) = a3
beta(age) = a4
Loop
Close #2
Open "c:/stream/data/再加入率.txt " For Input As #3
Do Until EOF(3)
Input #3, a1, a2, a3
age = a1
theta(age) = a2
Loop
Close #3
Open "c:/stream/gdata/変形厚生年金被保険者.txt " For Input As #5
Do Until EOF(5)
Input #5, a1, a2, a3, a4
byear = a1
age = a2
m2by(byear, age) = a3
f2by(byear, age) = a4
Loop
Close #5
For byear = 1985 To 2034
age = 15
mis(byear, age, 1) = m2by(byear, age)
For age = 16 To 64
z1 = (1 - gamma(age - 1)) * m2by(byear, age - 1)
z2 = m2by(byear, age) - z1
If z2 < 0 Then z2 = 0
z3 = (1 - theta(age)) * z2
z4 = theta(age) * z2
mis(byear, age, 1) = z3
z5 = 0
For car = 1 To 49
z5 = z5 + mos(byear, age - 1, car)
Next
If z5 = 0 Then z5 = 1
v = z4 / z5
If v > 1 Then v = 1
For car = 2 To 49
mis(byear, age, car) = (1 - gamma(age - 1)) * mis(byear, age - 1, car - 1) + v * mos(byear, age - 1, car - 1)
Next
For car = 1 To 49
mos(byear, age, car) = (gamma(age - 1) - alpha(age - 1) - beta(age)) * mis(byear, age - 1, car) + (1 - mdeby(byear, age) - v) * mos(byear, age - 1, car)
Next
Next
z1 = 0
For car = 1 To 24
z1 = z1 + mis(byear, 64, car) + mos(byear, 64, car)
Next
mnewt(byear) = z1
Next
Open "c:/stream/gdata/男子通算新規裁定者1.txt " For Output As #4
For byear = 1985 To 2100
Write #4, byear, mnewt(byear)
Next
Close #4
End Sub
最終更新:2009年04月17日 00:26