版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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 * wIf 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 = "unflipped"End IfEnd IfCase &quo
17、t;文件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 Then i0 = i0 + 2If i1 - i0 <= -2
18、 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(Mid(line, 7, 4)j = Val(Mid(line, 12,
19、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) = Val(n) Theni0 = Val(Mid(line, 7, 4)j0
20、= 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 * e0End IfLoopClose #1Next nText3.Text =
21、-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, 4)If Val(Left(line, 4) = Val(Label
22、5) 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(2) / 2 Thenw = w + e * e0End IfLoop
23、Close #1Next nText4.Text = -2 * wIf 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 = "unflipped"End IfEnd
24、 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, 12, 4)k0 = Val(Mid(Text1, 17, 4)If i1 - i0 >= 2 Then i0 = i0 + 2If i1
25、- 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 #1Do While Not EOF(1)Line Input #1, linei = Val(Mid(line, 7, 4)j = Val(M
26、id(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 EOF(1)Line Input #1, lineIf Val(Left(line, 4) = Val(n) Theni0 = Val(Mid(li
27、ne, 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(3) / 4 Thenw = w + e * e0End IfLoopClose #1Next nT
28、ext3.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, 4)k0 = Val(Mid(line, 17, 4)e0 = Val(Mid(line, 23, 4)If Val(Left(line, 4)
29、 = 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(3) / 4 Thenw = w + e *
30、e0End IfLoopClose #1Next nText4.Text = -2 * wIf 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 = "unflipped&qu
31、ot;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"GoTo 文件2Case "文件3"GoTo 文件3Case "文件4"GoTo文件4End Selectbasc:For k = 0 To 4For j = 0 To
32、4For i = 0 To 4l = l + 1m = Int(2 * Rnd)If m = 0 ThenPrint #1, l; Tab(6); i; Tab(11); j; Tab(16); k; Tab(22); "=" Format(m, "0.0")ElsePrint #1, l; Tab(6); i; Tab(11); j; Tab(16); k; Tab(22); "=" Format(m, "0.0")End IfNext iNext jNext kReturn文件1:Open "E:文件
33、1" For Output As #1 '写入文本文件GoSub basc '调用函数,输入坐标点GoTo finish文件2:Open "E:文件2" For Output As #1GoSub bascFor k = k To 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 ThenPrint #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17);
34、 Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")ElsePrint #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 iNext jNext kGoTo finish文件3:Open &q
35、uot;E:文件3" For Output As #1GoSub basck = 0For k = k To 4For i = i To 4For j = j To 4l = l + 1m = Int(2 * Rnd)If m = 0 ThenPrint #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")E
36、lsePrint #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 jNext iNext ki = 0For k = k To 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 ThenPrint #1, l; Tab
37、(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m, "0.0")ElsePrint #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=&
38、quot; Format(m, "0.0")End IfNext ii = 0Next jNext kj = 0For k = k To 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 ThenPrint #1, l; Tab(7); Format(i, "0.0"); Tab(12); Format(j, "0.0"); Tab(17); Format(k, "0.0"); Tab(22); "=" Format(m
39、, "0.0")ElsePrint #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 iNext jj = 0Next kGoTo finish文件4:Open "E: 文件4" For Output As #1GoSub bascFor k = k To
40、 4For j = j To 4For i = i To 4l = l + 1m = Int(2 * Rnd)If m = 0 ThenPrint #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")ElsePrint #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")End IfNext iNext jNext kFor k = k To 4For j = j To 4For i = i To 4l = l + 1m
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 唐山市新区2025-2026学年第二学期五年级语文期中考试卷(部编版含答案)
- 平凉地区灵台县2025-2026学年第二学期四年级语文第六单元测试卷(部编版含答案)
- 红河哈尼族彝族自治州开远市2025-2026学年第二学期三年级语文期中考试卷(部编版含答案)
- 张掖地区张掖市2025-2026学年第二学期六年级语文第五单元测试卷部编版含答案
- 工程服务方案
- 深度解析(2026)《CBT 4424-2015钢索索节》
- 深度解析(2026)《AQT 1020-2006 煤矿用袋式除尘器》
- 游泳题库及答案
- 市政桥梁工程结构设计考题及答案
- 嵌入式系统开发技术与实践技能题库及答案
- DB29-296-2021 海绵城市雨水控制与利用工程设计规范
- 资源教室工作方案设计
- 工程经济学第2版杜春艳习题答案
- 《走进文言文》八年级1-7单元的翻译
- 2015版ISO90001标准课件教学
- GB/T 12451-2023图书在版编目数据
- 年产万吨电铜电解车间的设计
- 那垌小学内部控制考核评价报告
- 星火英语四级词汇
- 物业品质服务提升计划表最终版
- 人教版(2022)高中语文必修上册同步训练第八单元综合检测word版含答案
评论
0/150
提交评论