24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 261  |  回复: 1
当前主题已经存档。

lovein

金虫 (小有名气)

[交流] 【求助】麻烦帮忙看下一个“随机游走”的程序,为什么运行时老出错!!!

整个程序如下:
(*----------------------------------------------------------------------*)
BeginPackage["RW2D`"]
  RW2D::usage = "RW2D[maxstep, ktry, range, startarea, datadirectory]
    reads the two - dimensional digital image file (text file) and
    exports the mean - square displacement of random walkers as a text
    file, 'msdlist2d.out'.
     'maxstep' is the final value of the time step of the random walker.
     'ktry' is the number of average (i.e., number of walkers).
     'range' is the lower and upper limit of the voxel intensity of
    the pore space.
     'startarea' is the dimension of a square as the percentage to
    the system size.
     The random walker starts to diffuse from inside the square which is
    located at the center of the image.
     'datadirectory' is the directory or folder name where a single
    two-dimensional digital image file (text file) is located. "
  ShowTrajectory::usage = "ShowTrajectory[kk] is for the graphic display
    of the random walk trajectory of the 'kk' - th trial. "
Begin["`Private`"]
(* Reading the two - dimensional data in 'datadirectory' *)
readdata2d[range_List, datadirectory_] :=
    Module[{dataname, datasize, x, m2d, rmin = range[[1]], rmax = \
range[[2]]},
      dataname = First[FileNames["*", {datadirectory}]];
      datasize = Round[Sqrt[Length[ReadList[ToString[dataname], Real]]]];
      m2d =
        Partition[
          Map[If[rmin
(* random walk *)
(* 'xylist' is the trajectory of 'maxstep' - step from 'o2d' *)
tra2d[maxstep_, o2d_List, m2d_List] :=
    Module[{n2d = {{1, 0}, {-1, 0}, {0, 1}, {0, -1}}, now = o2d,
        xylist = {o2d}, outoffield = 0, xmax = ymax = Length[m2d],
        step, new, x, y},
      ran2d := Random[Integer, {1, 4}];
      For[i = 1, i
(* random walk of 'ktry' - walkers *)
(* 'tra2dktry' is list of the trajectory of 'ktry' - walkers *)
rw2d[maxstep_, ktry_, startarea_, m2d_List] :=
    Module[{xdatasize = ydatasize = Length[m2d], xylist, outoffield,
        tra2dktry = {}, failure = 0},
      rano2d[lx_, ly_, sa_] :=
        {Random[Integer, {(1 - sa/100)/2 lx, (1 + sa/100)/2lx}],
         Random[Integer, {(1 - sa/100)/2 ly, (1 + sa/100)/2ly}]};
      o2d := (For[i = 1; {x0, y0} = rano2d[xdatasize, ydatasize, startarea],
            m2d[[x0, y0]] != 0, i++,
            {x0, y0} = rano2d[xdatasize, ydatasize, startarea]]; {x0, y0});
      Do[{xylist, outoffield} = tra2d[maxstep, o2d, m2d];
        AppendTo[tra2dktry, xylist]; AddTo[failure, outoffield], {i, 1, \
ktry}];
      Return[{tra2dktry, failure}];
    ];
(* calculation of the mean - square displacement *)
msd2d[data_List] :=
    Module[{ktry = Dimensions[data][[1]], maxstep = Dimensions[data][[2]] - \
1,
         d1, d2, d3, dd, ii},
      d1 = Transpose[data, {2, 1}];
      d2 = Map[(# - First[d1]) &, d1];
      d3 = Transpose[Map[(#^2) &, d2]];
      dd = Apply[Plus, Transpose[Apply[Plus, d3]/ktry]];
      ii = Range[0, maxstep];
      msdlist2d = Transpose[{ii, dd}];
      Return[msdlist2d];
    ];
RW2D[maxstep_, ktry_, range_List, startarea_, datadirectory_] :=
    Module[{failure, msdlist2d},
      (* reading the two - dimensional data in 'datadirectory' *)
      m2d = readdata2d[range, datadirectory];
      (* execution of the random walk *)
      {tra2dktry, failure} = rw2d[maxstep, ktry, startarea, m2d];
      Print["Failure = ", failure, " / Success = ", ktry];
      (* calculation of the mean - square displacement of 'ktry' walkers *)
      msdlist2d = msd2d[tra2dktry];
      (* file output of the mean - square displacement *)
      (* The file name is 'msdlist2d.out' *)
      Export["msdlist2d.out", N[msdlist2d], "Table"];
      (* graphic output of the mean - square displacement *)
      ListPlot[msdlist2d, PlotJoined -> True,
          AxesLabel -> {"time \n step", "mean-square \n displacement"}];
    ];
(* graphic output of the trajectory *)
(* Show the trajectory of a single walker as an example. *)
(* RGBColor[] of 0, 1, 2 are colors of the pore, obstacle, and trajectory,
  respectively. You can change the color as you like. *)
gtra2d[tra2d_List, m2d_List] :=
    Module[{color0 = RGBColor[0.9, 0.9, 0.9],
            color1 = RGBColor[0.5, 0.5, 0.5],
            color2 = RGBColor[0.8, 0.8, 0.8],
            plmin = 1 - 2, plmax = Length[m2d] + 1},
      tra2dshift = Map[(# - {0.5, 0.5}) &, tra2d];
      tra2dm2d = (aa2 = m2d; Map[(aa2[[#[[1]], #[[2]]]] = 2) &, tra2d]; aa2);
      Show[
        Graphics[
          RasterArray[tra2dm2d /. {0 -> color0, 1 -> color1, 2 -> color2}]],
        Graphics[{Line[Map[Reverse, tra2dshift]], AbsolutePointSize[5.0],
            Point[Reverse[First[tra2dshift]]],
            Point[Reverse[Last[tra2dshift]]]}],
        PlotRange -> {{plmin, plmax}, {plmin, plmax}}, AspectRatio -> 1];
    ];
(* Only for the 'kk' - th trial, the trajectory of the random walk is shown
  graphically *)
ShowTrajectory[kk_] := gtra2d[tra2dktry[[kk]], m2d];
End[];
EndPackage[];
(*----------------------------------------------------------------------*)
(* example of usage *)
(*----------------------------------------------------------------------*)
(* As noted below, first of all, you put the command '<< RW2D.m'. *)
(* Then you can put the command set,
  'RW2D[500, 200, {0, 34000}, 10, "DATAsingle"];' and 'ShowTrajectory[2];'. \
*)
(* 'RW2D[maxstep, ktry, range, startarea, datadirectory]' is the command for
  the performance of the random walk and the calculation of mean - square
  displacement. *)
(* The command 'ShowTrajectory[kk]' is for the graphic display of the
  trajectory of the 'kk' - th trial. *)
(* In the example below, a trajectory of the second trial will be shown
  graphically. *)
(* In[1] := << RW2D.m *)
(* In[2] := RW2D[500, 200, {0, 34000}, 10, "DATAsingle"]; ShowTrajectory[2]; \
*)
不知道为啥,运行的时候老是出错,我又看不大懂这程序,请求帮忙

[ Last edited by lovein on 2009-10-26 at 13:35 ]
回复此楼

» 猜你喜欢

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

lovein

金虫 (小有名气)

附件是程序中需要调用的图像,即the two - dimensional digital image file (text file)

太长了,只能用附件发。还望帮忙。
灰常灰常感谢!!
2楼2009-10-26 13:39:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 lovein 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[硕博家园] 招收生物学/细胞生物学调剂 +4 IceGuo 2026-03-26 5/250 2026-03-29 01:25 by griffith2014
[硕博家园] 求调剂 330分 085600材料与化工 +3 gqhhh 2026-03-22 3/150 2026-03-29 00:52 by 544594351
[考研] 0703 化学 求调剂,一志愿山东大学 342 分 +4 Shern—- 2026-03-28 4/200 2026-03-29 00:47 by 544594351
[考研] 070300化学354求调剂 +3 101次希望 2026-03-28 3/150 2026-03-29 00:28 by 544594351
[考研] 一志愿厦门大学化学学硕307求调剂 +10 y7czhao 2026-03-26 10/500 2026-03-28 14:23 by 唐沐儿
[考研] 求化学调剂 +4 wulanna 2026-03-28 4/200 2026-03-28 13:37 by 唐沐儿
[考研] 085600 286分 材料求调剂 +7 麻辣鱿鱼 2026-03-27 8/400 2026-03-28 12:17 by zllcz
[考研] 085602 307分 求调剂 +7 不知道叫什么! 2026-03-26 7/350 2026-03-28 09:57 by 神马都不懂
[考研] 291求调剂 +6 HanBeiNingZC 2026-03-24 6/300 2026-03-28 07:55 by baoball
[考研] 328求调剂 +7 嗯滴的基本都 2026-03-27 7/350 2026-03-28 04:19 by fmesaito
[考研] 材料292调剂 +12 橘颂思美人 2026-03-23 12/600 2026-03-27 15:44 by caszguilin
[考研] 276求调剂。有半年电池和半年高分子实习经历 +10 材料学257求调剂 2026-03-23 11/550 2026-03-27 10:13 by YCIT- LHL
[考研] 求调剂,一志愿 南京航空航天大学大学 ,080500材料科学与工程学硕 +4 @taotao 2026-03-26 5/250 2026-03-27 08:10 by hypershenger
[考研] 329求调剂 +5 1() 2026-03-22 5/250 2026-03-26 20:40 by fmesaito
[考研] 281求调剂 +6 Koxui 2026-03-24 7/350 2026-03-26 15:37 by 无际的草原
[考研] 一志愿中南大学化学学硕0703总分337求调剂 +7 niko- 2026-03-22 7/350 2026-03-25 20:14 by qingfeng258
[考研] 293求调剂 +7 加一一九 2026-03-24 7/350 2026-03-25 12:02 by userper
[考研] 300分,材料,求调剂,英一数二 +5 超赞的 2026-03-24 5/250 2026-03-24 21:07 by 星空星月
[考研] 一志愿山东大学药学学硕求调剂 +3 开开心心没烦恼 2026-03-23 4/200 2026-03-24 00:06 by 开开心心没烦恼
[考研] 335求调剂 +4 yuyu宇 2026-03-23 5/250 2026-03-23 23:49 by Txy@872106
信息提示
请填处理意见