蒙特卡洛 光 matlab,用蒙特卡罗法模拟光散射问题

该博客探讨了如何使用蒙特卡洛方法模拟光在含有沙尘的环境中进行多次散射的问题。博主编写了一个Matlab程序,但对结果的准确性存疑,并寻求专家的指导。程序中涉及了关键参数如散射系数、吸收函数、不对称因子等,并通过循环追踪光子路径来模拟散射过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我用蒙特卡罗法模拟光在沙尘环境中的多次散射问题,编写了如下的程序,程序可以运行,但是感觉运行结果不正确。希望写过类似程序的高手可以指点一下。

fai_T=45*pi/180;%发散角

sita_T=10*pi/180;%发射仰角 45

fai_R=45*pi/180;%接收角

sita_R=10*pi/180;%接收仰角 45

Ksray=0.1;%瑞利散射系数 0.145

Ksmie=1.5;%米氏散射系数 0.261a

Ka=0.6;%吸收函数 0.039

Ks=Ksray+Ksmie;%消光系数

K=Ka+Ks; %吸收散射之和

w=1;%权重

A=1;%存活率0.01

g=0.7;%不对称因子0.2

f=0.5;%散射因子

Ar=1.8*10^(-2);%接收孔径

r=4.8;

gama=0.017;%非对称因子 大气粒子尺寸分布?

L=10;%传输距离

%for i=1:1:1000

%%发射端初始位置%%

w=1;

x=0;y=0;z=0;

ux=0;uy=0;uz=1;

while 1

ksi=unifrnd(0,1);

s=-log(ksi)/K;

x=x+ux*s;y=y+uy*s;z=z+uz*s;

if (z>0)&&(z

w=Ks/K.*w; %改变权重

if w>0.0001  %权重是否太小

ksi=unifrnd(0,1);

fai=2*pi*ksi;

temp=(1-g.^2)/(1-g+2*g*ksi);

cos_sita=(1+g.^2-temp.^2)/(2*g);

sin_sit

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值