24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 380  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 320分,材料与化工专业,求调剂 +8 一定上岸aaa 2026-03-27 12/600 2026-03-28 13:08 by 松花缸1201
[考研] 265求调剂11408 +3 刘小鹿lu 2026-03-27 3/150 2026-03-27 20:53 by nihaoar
[考研] 272求调剂 +7 脚滑的守法公民 2026-03-27 7/350 2026-03-27 17:23 by laoshidan
[考研] 一志愿 西北大学 总分282 英语一62 求调剂 +7 18419759900 2026-03-25 8/400 2026-03-27 16:38 by 18419759900
[考研] 一志愿北京化工大学 070300 学硕 336分 求调剂 +9 vv迷 2026-03-22 9/450 2026-03-27 15:59 by 不吃魚的貓
[考研] 283求调剂(080500) +4 A child 2026-03-27 4/200 2026-03-27 15:34 by XPU李庆
[考研] 一志愿郑大085600,310分求调剂 +5 李潇可 2026-03-26 5/250 2026-03-27 11:14 by 不吃魚的貓
[考研] 304材料求调剂 +4 钟llll 2026-03-26 4/200 2026-03-27 03:42 by wxiongid
[考研] 325求调剂 +5 李嘉图·S·路 2026-03-23 5/250 2026-03-27 00:42 by wxiongid
[考研] 281求调剂 +3 亚克西good 2026-03-26 5/250 2026-03-26 19:48 by 不吃魚的貓
[考研] 化学工程085602 305分求调剂 +17 RichLi_ 2026-03-25 17/850 2026-03-26 19:44 by plmuchong
[考研] 中国科学院深圳先进技术研究院-光纤传感课题组招生-中国科学院大学、深圳理工大学联培 +5 YangTyu1 2026-03-26 5/250 2026-03-26 18:27 by 猫咪猫咪呀
[考研] 085601求调剂总分293英一数二 +4 钢铁大炮 2026-03-24 4/200 2026-03-26 16:28 by dick_runner
[考研] 263求调剂 +6 yqdszhdap- 2026-03-22 10/500 2026-03-26 13:11 by 公瑾逍遥
[考研] 环境专硕324分求调剂推荐 +5 轩小宁—— 2026-03-26 5/250 2026-03-26 12:05 by i_cooler
[考研] 材料与化工328分调剂 +6 。,。,。,。i 2026-03-23 6/300 2026-03-25 22:30 by 418490947
[考研] 一志愿武理085500机械专业总分300求调剂 +3 an10101 2026-03-24 7/350 2026-03-25 00:00 by 山鬼0-
[考研] 一志愿河北工业大学0817化工278分求调剂 +7 jhybd 2026-03-23 12/600 2026-03-24 09:03 by jhybd
[考研] 石河子大学(211、双一流)硕博研究生长期招生公告 +3 李子目 2026-03-22 3/150 2026-03-22 21:01 by 怎么释怀
[考研] 一志愿南大,0703化学,分数336,求调剂 +3 收到VS 2026-03-21 3/150 2026-03-21 18:42 by 学员8dgXkO
信息提示
请填处理意见