24小时热门版块排行榜    

查看: 343  |  回复: 2

loyi

银虫 (小有名气)

[求助] Microsoft 编译的这段程序哪里有问题?

本人门外汉,急求这段程序哪里有问题?怎么改?感激不尽
Sub cl2()
Public Function Concentration(Q, U, PS, TA, TB, X, Y, Z)
Din T
Din i
Din SigmaY, SigmaZ
Din CAsDouble
Q = Q / (TA / TB)
For i = 0 To TA Step TB
Din Xb, Xc
Xb = Abs((X - U * i))
Xc = Abs((U * i))
SigmaY = GetA(PS) * (X ^ GetB(PS)) * (2 ^ 0.3)
SigmaZ = GetC(PS) * (X ^ GetD(PS))
Din E
E = Exp(-0.5 * (((Xb) ^ 2) / (SigmaY ^ 2) + (Y ^ 2) / (SigmaY ^ 2) + (Z ^ 2) / (SigmaZ ^ 2)))
c = c + (2 * Q) / (6.28 ^ 1.5) / SigmaY / SigmaY / SigmZ * E
Next
Concentration = c
End Function
Function GetA(PS)
If PS = A Then
GetA(PS) = 0.527
If PS = B Then
GetA(PS) = 0.371
If PS = c Then
GetA(PS) = 0.209
If PS = D Then
GetA(PS) = 0.123
If PS = E Then
GetA(PS) = 0.098
If PS = F Then
GetA(PS) = 0.065
End Function
Function GetB(PS)
If PS = A Then
GetB(PS) = 0.865
If PS = B Then
GetB(PS) = 0.866
If PS = c Then
GetB(PS) = 0.897
If PS = D Then
GetB(PS) = 0.905
If PS = E Then
GetB(PS) = 0.902
If PS = F Then
GetB(PS) = 0.902
End Function
Function GetC(PS)
If PS = A Then
GetC(PS) = 0.28
If PS = B Then
GetC(PS) = 0.23
If PS = c Then
GetC(PS) = 0.22
If PS = D Then
GetC(PS) = 0.2
If PS = E Then
GetC(PS) = 0.15
If PS = F Then
GetC(PS) = 0.12
End Function
Function GetD(PS)
If PS = A Then
GetD(PS) = 0.9
If PS = B Then
GetD(PS) = 0.85
If PS = c Then
GetD(PS) = 0.8
If PS = D Then
GetD(PS) = 0.76
If PS = E Then
GetD(PS) = 0.73
If PS = F Then
GetD(PS) = 0.67
End Function
End Function
End Sub
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
loyi: 金币+5, 有帮助 2013-09-20 08:24:54
xzhdty: 金币+1, 谢谢参与 2013-09-21 06:40:34
sub是过程,可以看做没有返回值的function
vb的子函数结构是
sub
...
end sub

function
...
end function
必须一个结束了在写另一个开始,不能嵌套.
看你代码前2行和最后3行,就能发现,sub和function交叉嵌套,这样不行的.
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2013-09-17 16:19:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

loyi

银虫 (小有名气)

引用回帖:
2楼: Originally posted by libralibra at 2013-09-17 16:19:16
sub是过程,可以看做没有返回值的function
vb的子函数结构是
sub
...
end sub

function
...
end function
必须一个结束了在写另一个开始,不能嵌套.
看你代码前2行和最后3行,就能发现,sub和function交叉嵌 ...

改成了这样,可是Get函数有问题,能帮助下怎么改吗?
Sub cl3()
a = Concentration(Q, U, PS, TA, TB, X, Y, Z)
End Sub
Public Function Concentration(Q, U, PS, TA, TB, X, Y, Z)
Dim T
Dim i
Dim SigmaY, SigmaZ
Dim C As Double
Dim Q1
For i = 0 To TA Step TB
Xb = Abs((X - U * i))
Xc = Abs((U * i))
SigmaY = GetA(PS) * (X ^ GetB(PS)) * (2 ^ 0.3)
SigmaZ = GetC(PS) * (X ^ GetD(PS))
Q1 = Q / (TA / TB)
Dim E
E = Exp(-0.5 * (((Xb) ^ 2) / (SigmaY ^ 2) + (Y ^ 2) / (SigmaY ^ 2) + (Z ^ 2) / (SigmaZ ^ 2)))
C = C + (2 * Q1) / (6.28 ^ 1.5) / SigmaY / SigmaY / SigmZ * E
Next
Concentration = C
End Function
Function GetA(PS)
Dim ax
If PS = 1 Then
ax = 0.527
Else
If PS = 2 Then
ax = 0.371
Else
If PS = 3 Then
ax = 0.209
Else
If PS = 4 Then
ax = 0.123
Else
If PS = 5 Then
ax = 0.098
Else
If PS = 6 Then
ax = 0.065
End If
End If
End If
End If
End If
End If
GetA(PS) = ax
End Function
Function GetB(PS)
If PS = a Then
GetB(PS) = 0.865
Else
If PS = B Then
GetB(PS) = 0.866
Else
If PS = C Then
GetB(PS) = 0.897
Else
If PS = D Then
GetB(PS) = 0.905
Else
If PS = E Then
GetB(PS) = 0.902
Else
If PS = F Then
GetB(PS) = 0.902
End If
End If
End If
End If
End If
End If
End Function
Function GetC(PS)
If PS = a Then
GetC(PS) = 0.28
Else
If PS = B Then
GetC(PS) = 0.23
Else
If PS = C Then
GetC(PS) = 0.22
Else
If PS = D Then
GetC(PS) = 0.2
Else
If PS = E Then
GetC(PS) = 0.15
Else
If PS = F Then
GetC(PS) = 0.12
End If
End If
End If
End If
End If
End If
End Function
Function GetD(PS)
If PS = a Then
GetD(PS) = 0.9
Else
If PS = B Then
GetD(PS) = 0.85
Else
If PS = C Then
GetD(PS) = 0.8
Else
If PS = D Then
GetD(PS) = 0.76
Else
If PS = E Then
GetD(PS) = 0.73
Else
If PS = F Then
GetD(PS) = 0.67
End If
End If
End If
End If
End If
End If
End Function
Sub cl2()
a = Concentration(Q, U, PS, TA, TB, X, Y, Z)
End Sub
3楼2013-09-20 08:23:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 loyi 的主题更新
信息提示
请填处理意见