发光太阳聚光器的蒙特卡洛光线追踪研究(Matlab代码实现)

 💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

📋📋📋本文目录如下:🎁🎁🎁

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码及文章


💥1 概述

蒙特卡罗技术是一种通过统计方法模拟光子在系统中传播的方法。随机数、累积分布函数(CDF)和概率密度函数(PDF)被用来从函数或谱线(如太阳AM 1.5)中进行抽样。通过这种方式,随机数决定了光子的行进方式,从而避免了复杂的辐射传输方程。

如果x是从均匀分布[0,1]中抽取的随机数,那么CDF可以被设定为x,并可以重新排列以便获得需要随机选择的变量。通过这种方式,CDF下的面积将等于从均匀分布中选择的随机数下的面积,当足够多次地进行抽样选择时,随机选择的变量将能够重新创建原始的概率密度函数。

表面相互作用是该程序的核心。首先确定光子与LSC的哪个面进行相互作用,然后通过调用is_TIR函数检查光子是反射还是透射。如果光子完全内部反射,则根据光子在反射后是否在LSC内或是否与另一个边界相交来设置PH_ACTION的状态。
首先通过whichSurface()函数确定光子与哪个面相交,并返回面的编号。Which surface首先检查光子是否与一个平面相交,然后通过确定光子和平面的交点是否在LSC边界内进行第二次检查。

Is_TIR.m
确定面后,需要确定光子是否在空气/LSC边界发生反射或透射。在光子撞击LSC的一个面后,表面相互作用调用is_TIR函数来确定光子是否完全内部反射(total internal reflection)或透过表面传输。首先从主程序中获取全反射的临界角:

详细讲解见第4部分。

📚2 运行结果

部分代码:

%% Calculate the CDF of an emission spectrum 

A = csvread('LumRed305_Emission_Spectrum.csv');
wavelength = A(:,1);  % Reads wavelengths from first column 
em = A(:,2); % Reads extinction coef from second column
num = 0;
k = length(em);
sum_Em =0;

P = trapz(em)
 % Numerical integration using trapezoidal method

    for i=1:1:(k-1)
        sum_Em = sum_Em + 0.5*(em(i+1) +em(i))*(wavelength(i+1) - wavelength(i));
    end

    % sumEm is the numerical integral of Flux over all wavelengths
    % calculate CDF_em(i) the cumulative distribution function for any wavelength i
    % Divide C(i) by integral over all wavelengths to normalise the inegral of
    % C(i) to equal 1

    % The following for loop normalises the numerical integration 
    for i=(1:1:(k))
        num =0;
        for(j=1:1:(i-1))
        
            num = num + 0.5*(em(j+1) +em(j))*(wavelength(j+1) - wavelength(j));
        end
     
    CDF_Em(i) = num /sum_Em; % Cumulative distribution function of the Emission spectrum
   
    end
    
    plot(wavelength,CDF_Em) %Plots CDF of emission spectrum
    % The following for loop returns randomly selected emission wavelengths
    % based on the CDF calculated above. The number of randomly emitted photons
    % will equal the length of the vector QY_selected_lambdas
    
    % Save CDF as CSV file for use in photons_emitted function
    t = transpose(CDF_Em);
    w = transpose(wavelength);
    dataToSave = [ wavelength transpose(CDF_Em) ]
    csvwrite('CDF_Emission_Spectrum.csv',dataToSave)

🎉3 参考文献

文章中一些内容引自网络,会注明出处或引用为参考文献,难免有未尽之处,如有不妥,请随时联系删除。

🌈4 Matlab代码及文章

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
蒙特卡洛光线追踪法(Monte Carlo Ray Tracing)是一种用于模拟光线传播和光照效果的计算方法。它通过随机采样光线路径并对其进行追踪,从而模拟出真实世界中的光线传播和反射。在Matlab实现蒙特卡洛光线追踪法可以按照以下步骤进行: 1. 定义场景:在Matlab中,首先需要定义场景中的物体、光源和相机等元素。可以使用3D坐标、几何形状或模型来表示物体,并设置它们的材质属性。 2. 发射光线:在每个像素位置,根据相机参数发射Primary Rays(主光线),并计算光线与场景中物体的相交点。 3. 相交判断:对于每个发射的光线,需要检测光线是否与场景中的物体相交。可以使用光线与物体之间的相交算法(如球面相交算法、三角形相交算法等)来判断光线是否与物体相交。 4. 反射和透射:如果光线与物体相交,则根据物体的材质属性进行反射和透射计算。根据反射和透射模型(如菲涅尔方程、镜面反射等)来计算反射和透射光线的方向和强度。 5. 光照计算:对于每个相交点,需要考虑光源对其的照射。可以使用光线与光源之间的相交算法来计算光源的照射强度,并根据物体材质的反射和透射特性来计算最终的颜色值。 6. 阴影计算:如果相交点处存在遮挡物体,则需要考虑阴影效果。可以通过发射从相交点到光源的阴影光线来判断是否存在阴影,并根据阴影的强度调整物体的颜色值。 7. 反射深度和递归:对于具有反射和透射属性的物体,需要进行递归光线追踪,即发射附加的反射和透射光线,并通过迭代计算来模拟光线的传播路径。 8. 累积和采样:在每个像素位置,通过累积所有采样的光线颜色值,并根据采样次数对颜色值进行平均,最终得到每个像素的最终颜色值。 综上所述,以上步骤描述了在Matlab实现蒙特卡洛光线追踪法的基本方法。可以根据具体需求和场景进行相应的优化和扩展,以获得更高质量和更真实的渲染结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值