目录
1、题目要求
先确定布朗运动的点数 n 和一个温度 s(或速度)。比如 n=20, s=0.002。达到最好的动画效果的 n、 s 与使用的计算机的性能有关。在以原点为中心、边长为 1 的正方形内产生 n 个位置随机分布的点。
在单位正方形里绘制所有的点。设置图形的“ EraseMode”属性为异或( xor),即当图形的某个点的位置变化时,不用全部重绘图形,而只绘制不相同的部分,这将大大提高绘图速度。
用 while 循环实现动画效果,在每一次循环中给点的坐标加上一些正态分布的噪声,这样整个图形中只有点的坐标发生变化,而不用全部重绘整个图形。
2、代码实现
clc,clear
n=20;s=0.002;
axis square
grid off
x=rand(n,1)-0.5;y=rand(n,1)-0.5;
h=plot(x,y,'.');
set(h,'EraseMode','xor','MarkerSize',18)
while 1
x=x+s*rand(n,1);y=y+s*rand(n,1)
set(h,'Xdata',x,'Ydata',y)
if all(x>1)