基于魏格纳函数和焦散线方法的自加速光束matlab模拟与仿真

目录

1.程序功能描述

2.测试软件版本以及运行结果展示

3.核心程序

4.本算法原理

5.完整程序


1.程序功能描述

       基于魏格纳函数和焦散线方法的自加速光束matlab模拟与仿真。通过魏格纳函数法,来产生多种自加速的光束,设计自加速光束方法,模拟出相应的图结果。

2.测试软件版本以及运行结果展示

MATLAB2022A版本运行

3.核心程序

...................................................................
figure;
subplot(121);
imshow(Phase2,[])
colorbar 
title('Phase');
subplot(122);
imshow(Amp2,[])
colorbar 
title('amplititude');
%保存图片
Phase2_save = imresize(Phase2,[1080,1080],'nearest');
Amp2_save   = imresize(Amp2,[1080,1080],'nearest');
imwrite(Phase2_save,'Phase2_save.bmp','bmp'); 
imwrite(Amp2_save,'Amp2_save.bmp','bmp'); 
%%
%平面光场图,魏格纳函数
%W = Int(0..zmax){E(x+y)E(x-y)exp[2ixy]}
Wxkx    = func_wigner(X');
%光场
amp     = abs(sum(Wxkx,2));%根据魏格纳函数得到幅度,公式7
fai     = (sum([t].*Wxkx,2))./sum(Wxkx,2);%根据魏格纳函数得到相位,公式7
E       = amp'.*exp(sqrt(-1)*fai);
E       = abs(E);%根据相位和幅度得到E
E       = Zmax*[E/max(max(E))]';%E归一化

%计算光场
%根据公式11进行叠加
[s2,t2] = meshgrid(s,2*t);
%其实这里之前也没大问题,之前是用了这个sin代入了,其实只要把计算得到E代入就可以了,所以之前你才觉得去掉E还是不变这个问题
I       = abs(airy(0, E-s2,1)+airy(0,-E+s2,1));%非凸轨迹

figure;
subplot(211);
surface(t2,s2,I)  
shading interp
axis([min(t),max(t),-75,75]);
colormap(hot)
%%
%fit and xmax
%获得xmax值
[RR,CC] = size(I);
for i = 1:RR
    [VV,II]  = max(I(i,:));
    ysamp(i) = (II-RR/2)/RR*max(s);
end
ysamp=ysamp-mean(ysamp);
%进行拟合
xdata = 2*Z;
ydata = ysamp;
x     = lsqcurvefit(@myfun1,[3;1;1],xdata,ydata);%sin类型拟合
x
subplot(212);
plot(Z,x(1)*sin(x(2)*t+x(3)),'b');
hold on
plot(xdata(1:10:end),ysamp(1:10:end),'r.');
legend('拟合','主瓣位置');
axis([0,20,-8,8]);
grid on
xlabel('z/mm');
ylabel('x/um');
24_008m

4.本算法原理

       魏纳函数(Wavelet函数)和焦线方法在自适应光束加速中起着重要作用,主要应用于光学成像、光操控和光束聚焦、光束整形等领域。这种方法利用纳函数的数学描述光场分布,并结合数值模拟技术来设计特定的光束形状和传播特性,从而实现对光束的精确控制。

       光束通常可以展开为一系列基函数的线性组合,如高斯函数或拉普朗斯基尔德函数等。一个简化的例子是高斯展开:

       通过调整光束相位分布(相位φ(x,y)可以改变光束传播特性,如聚焦或加速。一个典型方法是利用相位调制的光栅格:

       魏函数 魈函数(U(x,y,z) 描述了光场的复振幅值在空间中的分布,x,y)位置坐标,z是沿光轴方向的传播距离。

       光束加速 自适应性** 通过调整光束的相位相分布,可以实现光束聚焦、加速、束整形,甚至光束的自适应传播特性。

5.完整程序

VVV

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/635264.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

springBoot+springSecurity基本认证流程

springBootspringSecurity认证流程 整合springSecurity 对应springboot版本&#xff0c;直接加依赖&#xff0c;这样版本不会错 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId…

vue实战----网易云音乐案例

1 . 能够掌握Vant组件库使用2 . 熟练查阅Vant组件库文档3 . 能够完成网易云音乐案例 案例-网易云音乐 1.本地接口 目标&#xff1a;下载网易云音乐node接口项目, 在本地启动, 为我们vue项目提供数据支持 2.本地接口启动 目标&#xff1a;启动本地node服务_拿到数据 文档: …

Golang创建文件夹

方法 package zdpgo_fileimport ("os" )// AddDir 创建文件夹 func AddDir(dir string) error {if !IsExist(dir) {return os.MkdirAll(dir, os.ModePerm)}return nil }测试 package zdpgo_fileimport "testing"func TestAddDir(t *testing.T) {data : […

二叉树(详解)

在了解二叉树之前呢我们先来了解一下树形结构&#xff0c;因为二叉树就是树形结构的一种特殊情况&#xff0c;它有这非常好的性质&#xff0c;是很常用的一种结构。 目录 一.什么是树形结构&#xff1f; 二.树形结构常见的名词 三.树的存储 四.二叉树 1.二叉树的概念 2.…

学习记录16-反电动势

一、反电动势公式 在负载下反电势和端电压的关系式为&#xff1a;&#x1d448;&#x1d43c;&#x1d445;&#x1d43f;*&#xff08;&#x1d451;&#x1d456; / &#x1d451;&#x1d461;&#xff09;&#x1d438; E为线圈电动势、 &#x1d713; 为磁链、f为频率、N…

网络协议——Modbus-TCP

目录 1、简介 2、Modbus-TCP与Modbus-RTU的区别 3、消息格式 4、功能码01H 5、功能码02H 6、功能码03H 7、功能码04H 8、功能码05H 9、功能码06H 10、功能码0FH 11、功能码10H 1、简介 Modbus-TCP&#xff08;Modbus Transmission Control Protocol&#xff09;是一…

基于Django的美团药品数据分析与可视化系统,有多用户功能,可增删改查数据

背景 随着电子商务和健康产业的迅速发展&#xff0c;药品行业数据的分析和可视化变得愈发重要。基于Django的美团药品数据分析与可视化系统的研究背景凸显了对药品数据的深入挖掘和分析的需求。该系统不仅具备多用户功能&#xff0c;允许不同角色的用户进行数据管理和分析&…

2024最新流媒体在线音乐系统网站源码| 音乐社区 | 多语言 | 开心版

简介&#xff1a; 2024最新流媒体在线音乐系统网站源码| 音乐社区 | 多语言 | 开心版 下载地址 https://www.kuaiyuanya.com/product/article/index/id/33.html 图片&#xff1a;

【无重复字符的最长子串】python,滑动窗口+哈希表

滑动窗口哈希表 哈希表 seen 统计&#xff1a; 指针 j遍历字符 s&#xff0c;哈希表统计字符 s[j]最后一次出现的索引 。 更新左指针 i &#xff1a; 根据上轮左指针 i 和 seen[s[j]]&#xff0c;每轮更新左边界 i &#xff0c;保证区间 [i1,j] 内无重复字符且最大。 更新结…

高铁VR虚拟全景展示提升企业实力和形象

步入VR的神奇世界&#xff0c;感受前所未有的汽车展示体验。VR虚拟现实技术以其独特的沉浸式模拟&#xff0c;让你仿佛置身于真实展厅之中&#xff0c;尽情探索汽车的每一处细节。 一、定制化展示&#xff0c;随心所欲 VR汽车虚拟展厅打破空间束缚&#xff0c;让汽车制造商能够…

区块链开发:区块链软件开发包装相关解析

区块链开发是指设计、构建和维护基于区块链技术的应用程序或系统的过程。区块链是一种分布式账本技术&#xff0c;它通过去中心化的方式记录和验证数据&#xff0c;确保数据的透明性、不可篡改性和安全性。区块链开发者使用各种编程语言和框架来创建这些应用程序。 在加密货币领…

C++ sort排序的总和应用题

第1题 sort排序1 时限&#xff1a;1s 空间&#xff1a;256m 输入n个数&#xff0c;将这n个数从小到大排序&#xff0c;输出。 输入格式 第1行&#xff0c;一个正整数n&#xff08;n<100&#xff09; 第2行&#xff0c;n个正整数&#xff0c;小于100 输出格式 n个整…

Windows安装mingw32/w64

1.下载 MinGW-w64 WinLibs - GCCMinGW-w64 compiler for Windows Releases niXman/mingw-builds-binaries (github.com) MinGW-w64、UCRT 和 MSVCRT 是 Windows 平台上常用的 C/C 运行库&#xff0c;它们有以下不同点&#xff1a; MinGW-w64&#xff1a;是一个基于 GCC 的…

【Hive SQL 每日一题】分析电商平台的用户行为和订单数据

需求描述 假设你是一位数据分析师&#xff0c;负责分析某电商平台的用户行为和订单数据&#xff0c;平台上有多个用户&#xff0c;用户可以在不同的日期下单&#xff0c;每个订单包含多个商品。请你完成相关业务分析&#xff0c;帮助平台优化运营策略和用户体验。 数据准备 …

NDIS小端口驱动(五)

在需要的时候&#xff0c;我们也许需要NDIS微型端口程序信息&#xff0c;下面会从多个方面来讨论如何查询NDIS微型端口驱动。 查询无连接微型端口驱动程序 若要查询无连接微型端口驱动程序维护的 OID&#xff0c;绑定协议调用 NdisOidRequest 并传递 一个NDIS_OID_REQUEST 结…

【SQL每日一练】查询“OCCUPATIONS”中的“Occupation”列并按Doctor、Professor、Singer、Actor列输出

文章目录 题目一、分析二、题解1.SqlServer2.MySQL3.Oracle 总结 题目 查询“OCCUPATIONS”中的“Occupation”列&#xff0c;使每个姓名按字母顺序排序&#xff0c;并显示在其相应的“职业》下方。输出列标题应分别为Doctor、Professor、Singer和Actor。 注意&#xff1a;当不…

【ChatGPT】 Microsoft Edge 浏览器扩展使用 GPT

【ChatGPT】添加 Microsoft Edge 浏览器插件免费使用 GPT 文章目录 准备工作添加扩展注意事项 使用 ChatGPT 可以更高效的搜索到想要的内容&#xff0c;有效节约在搜索引擎中排查正确信息的时间。 准备工作 准备一台可上网的电脑电脑上安装有 Windows 自带的 Microsoft Edge …

【Makefile】Makefile 编译 Keil 工程(Linux 环境)

本文使用的开发板为 stm32f103C8T6&#xff0c;使用的驱动库为stm32标准库。 目录 一、软件下载 1、stm32 标准库 2、arm-none-eabi 工具链 3、烧录器 二、Keil 工程改造 1、Keil 工程 2、基本 Makefile 工程 3、添加启动文件 4、添加链接脚本 5、去掉 core_cm3.c 三…

App Inventor 2 如何接入ChatGPT:国内访问OpenAI的最佳方式

如何接入OpenAI 由于国内无法访问OpenAI&#xff0c;KX上网可选大陆及香港&#xff08;被屏蔽&#xff09;以外才行。因此对于大多数人来说&#xff0c;想体验或使用ChatGPT就不太便利&#xff0c;不过App Inventor 2 为我们提供了相对便利的一种方式&#xff0c;即“试验性质…

基于STM32F407的项目迁移到STM32F427

提示&#xff1a;此文档迁移教程使用的是IAR&#xff0c;有关代码的修改使用的是Vscode,基于STM32F407的项目迁移到STM32F427 基于STM32F407的项目迁移到STM32F427 前言一、硬件区别1.1.区别&#xff1a;1.2.需要注意以下硬件区别&#xff1a; 二、引脚配置三、STM32F4273.1.晶…