dla模型 matlab代码,DLA模型Matlab程序.doc

DLA模型Matlab程序

大学里写了一些关于DLA模型的Matlab程序,由于不懂编程,而且也不懂matlab,在程序算法的编制上走了很多弯路,这里将陆续贴出关于DLA、DLCA、先DLA后DLCA模型的Matlab下实现和分维分析,请大家指导。 程序按gpl发布(:(不明白gpl什么意思,只知道共享),如果你能有所改进也希望你能与我分享。二维dla模型程序:文件名:dla2d.m功能:生成所需粒子数的二维dla絮体,绘制回转半径与粒子数的对数关系图,空隙率与絮体半径的关系图。代码:%(1) 设置初始凝结半径 ,总凝集粒子数nsum,绘图区域;%(2)根据绘图区域确定凝集中心在屏幕上的坐标,并在中心位置画点,置n=0;%(3)根据凝结半径 确定自由离子释放半径r,,最大可凝集半径 ;%(4)在半径r0的圆周的任意位置释放一粒子,让其作布朗运动;%(5)粒子每移动一次,都要检测其上下左右的紧邻位置是否为凝集体,若是则凝???下来,n=n+1.执行第(6)步,否则,执行第(7)步;%(6)每凝结一个粒子,都要计算此粒子与凝集中心的距离是否大于凝结半径 r0,%若是则将凝结半径 置为当前距离,然后执行第4步;%(7)若粒子与凝集中心的距离小于rmax,继续作布朗运动。否则抛弃此粒子,执行第4步;%循环执行第3、4、5、6、7步,直到n=nsum为止.function dla2d(nsum)r0=2;r=8;Rr=0.5;L=2000;Xhalf=floor(L/2);Yhalf=Xhalf;szPoints=sparse(L,L);szPoints(Xhalf,Xhalf)=1;nx=Xhalf;ny=Yhalf;n=0;theta=2*pi*rand;x=nx+r*cos(theta);y=ny+r*sin(theta);nx=round(x);ny=round(y);i=0;j=1;p=-1:1;N2(Xhalf/2)=0;N2(1)=1;R=2; %%用于计算生长维的一个变量while nr+20 %theta=2*pi*rand; nx=Xhalf+r*cos(theta); ny=Yhalf+r*sin(theta); elseif szPoints(nx-1,ny)+szPoints(nx+1,ny)+szPoints(nx,ny+1)+szPoints(nx,ny-1)>0&szPoints(nx,ny)==0 szPoints(nx,ny)=1; n=n+1; s=sqrt((nx-Xhalf)^2+(ny-Yhalf)^2); k=round(s)+1; N2(k)=N2(k)+1; if s>R R=s; R1(j)=log(R/Rr); N1(j)=n; I(j)=i; j=j+1; end if s>r r=s+5; end elseif szPoints(nx,ny)==1 %theta=2*pi*rand; nx=Xhalf+r*cos(theta); ny=Yhalf+r*sin(theta); endend[u,v]=find(szPoints);figure(1);plot(u,v,'*');%%%%%%%%%%%%%%%%%%%%%%%%%%%分维采样数据分析整理%%%%%%%%%%%%%%%%%%%%%%%%%num=find(N2);b=size(num,2);for i=2:b N2(i)=N2(i)+N2(i-1); num(i)=N2(i); R2(i)=log(2*i);endR2(1)=[];num(1)=[]

DLA(Diffusion Limited Aggregation)是一种模拟颗粒聚集行为的模型,可以用来研究颗粒在凝聚过程中的自组织行为。 在MATLAB中,可以编写一个DLA模型程序程序的主要思路是模拟颗粒的扩散和聚集过程。 首先,我们需要创建一个二维矩阵来表示模拟空间。可以选择一个足够大的矩阵,以确保颗粒有足够的空间进行扩散和聚集。 接下来,我们需要选择模拟开始时的起始点,可以选择矩阵的中心或其他位置作为起始点。将起始点设置为已经被占用的位置,表示这个位置已经有一个颗粒。 然后,我们可以通过一个循环来模拟颗粒的扩散和聚集过程。在每一步中,随机选择一个未被占用的位置作为当前颗粒的位置。然后,将当前位置的邻近位置进行扩散,也就是将当前位置周围的格子标记为已占用。 接下来,从当前位置开始,判断当前位置的四个方向上的邻近位置是否已经被占用。如果邻近位置中有一个已经被占用,那么当前颗粒停止扩散并聚集到邻近位置上。 重复执行以上步骤,直到达到预设的颗粒数目或满足其他结束条件。 最后,可以将模拟结果可视化,可以使用MATLAB的绘图函数将占用位置进行绘制,呈现颗粒的分布和聚集结果。 总之,上述就是一种基本的DLA模型MATLAB程序,通过模拟颗粒的扩散和聚集过程,可以研究颗粒的自组织行为。当然,根据具体需求,程序还可以进行进一步的扩展和改进。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值