




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Private Sub command2_Click()Dim b, line, d, v As StringDim i, j, k, i0, j0, k0, i1, j1, k1, c, n, num, l, h As IntegerDim dist, e0, e, w, boltzmanfactor As Singleb = InputBox("输入晶体类型")Open "E:文件1" For Input As #1 '找出一个中心点Do While Not EOF(1)Line Input #1, lineIf Val(Left(line,
2、 4) = 63 Theni1 = Val(Mid(line, 7, 1)j1 = Val(Mid(line, 12, 1)k1 = Val(Mid(line, 17, 1)End IfLoopClose #1Select Case bCase "sc"Open "E:文件1" For Input As #1c = InputBox("输入序号")Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(c) Then '将输入序号对应的坐标点作为原点Te
3、xt1.Text = linei0 = Val(Mid(Text1, 7, 1)j0 = Val(Mid(Text1, 12, 1)k0 = Val(Mid(Text1, 17, 1)End IfIf i1 - i0 >= 2 Then i0 = i0 + 2 '边界判断If i1 - i0 <= -2 Then i0 = i0 - 2If j1 - j0 >= 2 Then j0 = j0 + 2If j1 - j0 <= -2 Then j0 = j0 - 2If k1 - k0 >= 2 Then k0 = k0 + 2If k1 - k0 <
4、= -2 Then k0 = k0 - 2LoopClose #1 Open "E:文件1" For Input As #1Do While Not EOF(1)Line Input #1, linei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)dist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = 1 Then '寻找近邻num = num + 1End IfLoopClose #1Text2.Text = nu
5、mFor n = 1 To 125 '求总能量Open "E:文件1" For Input As #1Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(line, 12, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(l
6、ine, 17, 4)e = Val(Mid(line, 23, 4)End Ifdist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = 1 Thenw = w + e * e0End IfLoopClose #1Next nText3.Text = -2 * wh = Int(125 * Rnd) '给出一个随机数Label5.Caption = hFor n = 1 To 125Open "E:文件1" For Input As #1Do While Not EOF(1)Line Input #1, li
7、neVal (Mid(line, 21, 4)If Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(line, 12, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)If Val(Left(line, 4) = Val(Label5) Then e0 = -Val(Mid(line, 23, 4) '改变随机数对应坐标点上磁子的方向Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = V
8、al(Mid(line, 17, 4)e = Val(Mid(line, 23, 4)If Val(Left(line, 4) = Val(Label5) Then e = -Val(Mid(line, 23, 4)End Ifdist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = 1 Thenw = w + e * e0 '求改变后的能量和End IfLoopClose #1Next nText4.Text = -2 * wText5.Text = Text3.Text - Text4.Text '输出能量差值If V
9、al(Text5.Text) > 0 Then '判断磁子能否改变方向Label7.Caption = "flipped"Elseboltzmanfactor = Exp(Val(Text5.Text) / (300 * 1.38 * 10 -23)If Int(1000 * Rnd) > Val(boltzmanfactor) ThenLabel7.Caption = "unchanged"ElseLabel7.Caption = "unflipped"End IfEnd IfCase "文件2&quo
10、t;Open "E:文件2" For Input As #1c = InputBox("输入序号")Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(c) ThenText1.Text = linei0 = Val(Mid(Text1, 7, 4)j0 = Val(Mid(Text1, 12, 4)k0 = Val(Mid(Text1, 17, 4)End IfIf i1 - i0 >= 2 Then i0 = i0 + 2If i1 - i0 <= -2 The
11、n i0 = i0 - 2If j1 - j0 >= 2 Then j0 = j0 + 2If j1 - j0 <= -2 Then j0 = j0 - 2If k1 - k0 >= 2 Then k0 = k0 + 2If k1 - k0 <= -2 Then k0 = k0 - 2LoopClose #1 Open "E:文件2" For Input As #1Do While Not EOF(1)Line Input #1, linei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(M
12、id(line, 17, 4)dist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr(3) / 2 Thennum = num + 1End IfLoopClose #1Text2.Text = numFor n = 1 To 189Open "E: 文件2" For Input As #1Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(li
13、ne, 12, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)e = Val(Mid(line, 23, 4)End Ifdist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr(3) / 2 Thenw = w + e * e0End IfLoopClose #1Next nText3.Text = -2 * wh = In
14、t(189 * Rnd)Label5.Caption = hFor n = 1 To 189Open "E: 文件2" For Input As #1Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(line, 12, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)If Val(Left(line, 4) = Val(Label5) Then e0 =
15、 -Val(Mid(line, 23, 4)Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)e = Val(Mid(line, 23, 4)If Val(Left(line, 4) = Val(Label5) Then e = -Val(Mid(line, 23, 4)End Ifdist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr(3) / 2 Thenw = w + e * e0End IfLoopClose #1Next
16、 nText4.Text = -2 * wText5.Text = Text3.Text - Text4.TextIf Val(Text5.Text) > 0 ThenLabel7.Caption = "flipped"Elseboltzmanfactor = Exp(Val(Text5.Text) / (300 * 1.38 * 10 -23)If Int(1000 * Rnd) > Val(boltzmanfactor) ThenLabel7.Caption = "unchanged"ElseLabel7.Caption = "
17、unflipped"End IfEnd IfCase "文件3"Open "E: 文件3" For Input As #1c = InputBox("输入序号")Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(c) ThenText1.Text = linei0 = Val(Mid(Text1, 7, 4)j0 = Val(Mid(Text1, 12, 4)k0 = Val(Mid(Text1, 17, 4)If i1 - i0 >= 2
18、 Then i0 = i0 + 2If i1 - i0 <= -2 Then i0 = i0 - 2If j1 - j0 >= 2 Then j0 = j0 + 2If j1 - j0 <= -2 Then j0 = j0 - 2If k1 - k0 >= 2 Then k0 = k0 + 2If k1 - k0 <= -2 Then k0 = k0 - 2End IfLoopClose #1 Open "E: 文件3" For Input As #1Do While Not EOF(1)Line Input #1, linei = Val(M
19、id(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)dist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr(2) / 2 Thennum = num + 1End IfLoopClose #1Text2.Text = num For n = 1 To 365Open "E: 文件3" For Input As #1Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Va
20、l(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(line, 12, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)e = Val(Mid(line, 23, 4)End Ifdist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr(2) / 2 Thenw = w + e * e0E
21、nd IfLoopClose #1Next nText3.Text = -2 * wh = Int(365 * Rnd)Label5.Caption = hFor n = 1 To 365Open "E: 文件3" For Input As #1Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(line, 12, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23
22、, 4)If Val(Left(line, 4) = Val(Label5) Then e0 = -Val(Mid(line, 23, 4)Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)e = Val(Mid(line, 23, 4)If Val(Left(line, 4) = Val(Label5) Then e = -Val(Mid(line, 23, 4)End Ifdist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr
23、(2) / 2 Thenw = w + e * e0End IfLoopClose #1Next nText4.Text = -2 * wText5.Text = Text3.Text - Text4.TextIf Val(Text5.Text) > 0 ThenLabel7.Caption = "flipped"Elseboltzmanfactor = Exp(Val(Text5.Text) / (300 * 1.38 * 10 -23)If Int(1000 * Rnd) > Val(boltzmanfactor) ThenLabel7.Caption =
24、"unchanged"ElseLabel7.Caption = "unflipped"End IfEnd If Case "文件4"Open "E: 文件4" For Input As #1c = InputBox("输入序号")Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(c) ThenText1.Text = linei0 = Val(Mid(Text1, 7, 4)j0 = Val(Mid(Text1, 1
25、2, 4)k0 = Val(Mid(Text1, 17, 4)If i1 - i0 >= 2 Then i0 = i0 + 2If i1 - i0 <= -2 Then i0 = i0 - 2If j1 - j0 >= 2 Then j0 = j0 + 2If j1 - j0 <= -2 Then j0 = j0 - 2If k1 - k0 >= 2 Then k0 = k0 + 2If k1 - k0 <= -2 Then k0 = k0 - 2End IfLoopClose #1 Open "E: 文件4" For Input As
26、#1Do While Not EOF(1)Line Input #1, linei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)dist = Sqr(i - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr(3) / 4 Thennum = num + 1End IfLoopClose #1Text2.Text = numFor n = 1 To 381Open "E: 文件4" For Input As #1Do While Not EO
27、F(1)Line Input #1, lineIf Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(line, 12, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)e = Val(Mid(line, 23, 4)End Ifdist = Sqr(i - i0) 2 + (j - j0) 2 + (k
28、- k0) 2)If dist = Sqr(3) / 4 Thenw = w + e * e0End IfLoopClose #1Next nText3.Text = -2 * wh = Int(381 * Rnd)Label5.Caption = hFor n = 1 To 381Open "E: 文件4" For Input As #1Do While Not EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0 = Val(Mid(line, 12,
29、4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)If Val(Left(line, 4) = Val(Label5) Then e0 = -Val(Mid(line, 23, 4)Elsei = Val(Mid(line, 7, 4)j = Val(Mid(line, 12, 4)k = Val(Mid(line, 17, 4)e = Val(Mid(line, 23, 4)If Val(Left(line, 4) = Val(Label5) Then e = -Val(Mid(line, 23, 4)End Ifdist = Sqr(i
30、 - i0) 2 + (j - j0) 2 + (k - k0) 2)If dist = Sqr(3) / 4 Thenw = w + e * e0End IfLoopClose #1Next nText4.Text = -2 * wText5.Text = Text3.Text - Text4.TextIf Val(Text5.Text) > 0 ThenLabel7.Caption = "flipped"Elseboltzmanfactor = Exp(Val(Text5.Text) / (300 * 1.38 * 10 -23)If Int(1000 * Rnd
31、) > Val(boltzmanfactor) ThenLabel7.Caption = "unchanged"ElseLabel7.Caption = "unflipped"End IfEnd IfEnd SelectEnd SubPrivate Sub command1_Click()Dim i, j, k, l, m As SingleDim a As Stringa = InputBox("输入晶体类型")Select Case aCase "文件1"GoTo 文件1Case "文件2&qu
32、ot;GoTo 文件2Case "文件3"GoTo 文件3Case "文件4"GoTo文件4End Selectbasc:For k = 0 To 4For j = 0 To 4For i = 0 To 4l = l + 1m = Int(2 * Rnd)If m = 0 Thenm = -0.5Print #1, l; Tab(6); i; Tab(11); j; Tab(16); k; Tab(22); "=" Format(m, "0.0")Elsem = 0.5Print #1, l; Tab(6); i;
33、 Tab(11); j; Tab(16); k; Tab(22); "=" Format(m, "0.0")End IfNext iNext jNext kReturn文件1:Open "E:文件1" For Output As #1 '写入文本文件GoSub basc '调用函数,输入坐标点GoTo finish文件2:Open "E:文件2" For Output As #1GoSub basck = 0.5j = 0.5i = 0.5For k = k To 4For j = j To 4Fo
34、r i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 Thenm = -0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")Elsem = 0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); F
35、ormat(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")End IfNext ii = 0.5Next jj = 0.5Next kGoTo finish文件3:Open "E:文件3" For Output As #1GoSub basck = 0j = 0.5i = 0.5For k = k To 4For i = i To 4For j = j To 4l = l + 1m = Int(2 * Rnd
36、)If m = 0 Thenm = -0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")Elsem = 0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17);
37、Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")End IfNext jj = 0.5Next ii = 0.5Next kk = 0.5j = 0.5i = 0For k = k To 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 Thenm = -0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0&
38、quot;); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")Elsem = 0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")End IfNext ii = 0Next j
39、j = 0.5Next kk = 0.5j = 0i = 0.5For k = k To 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 Thenm = -0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")Elsem =
40、0.5Print #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")End IfNext ii = 0.5Next jj = 0Next kGoTo finish文件4:Open "E: 文件4" For Output As #1GoSub basck = 0.25j = 0.25i = 0.25
41、For k = k To 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 Thenm = -0.5Print #1, l; Tab(7); Format(i, "0.00"); Tab(12); Format(j, "0.00"); Tab(17); Format(k, "0.00"); Tab(22); "=" Format(m, "0.0")Elsem = 0.5Print #1, l; Tab(7); Forma
42、t(i, "0.00"); Tab(12); Format(j, "0.00"); Tab(17); Format(k, "0.00"); Tab(22); "=" Format(m, "0.0")End IfNext ii = 0.25Next jj = 0.25Next kk = 0.75j = 0.75i = 0.25For k = k To 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 Thenm = -0.5Print #1, l; Tab(7); Format(i, "0.00"); Tab(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 开学第一课适应开学主题心理健康课
- 心型班组文化建设
- 情感的抒发与理念的表达
- 体验营销在广告中的创新应用试题及答案
- 棉织物的舒适性研究与检验试题及答案
- 2024年设计理念的多样性国际商业美术设计师考试试题及答案
- 人性模拟测试题及答案
- 2024年设计师的个人品牌建立试题及答案
- 助理广告师考试重难点的分级攻略试题及答案
- 创意广告设计的评估标准分析试题及答案
- 水利项目立项报告
- 幼儿园初级保育员考试题库(附答案)
- 【MOOC】航空燃气涡轮发动机结构设计-北京航空航天大学 中国大学慕课MOOC答案
- 家政服务人员岗前培训
- 国家生物安全培训课件
- 专题11 名著阅读之《童年》(考题猜想)(期中真题速递20题)(含答案解析)
- TSGD7002-2023-压力管道元件型式试验规则
- 无人机组装与调试 课件全套 项目1-3 无人机组装调试基础、多旋翼无人机组装与调试、垂直起降无人机组装调试
- (完整版)第八章财务报表分析习题及答案
- 民间借贷利息计算表
- 2024年浙江省中考数学试题及答案
评论
0/150
提交评论