罗曼III型编码

2024-02-02 06:59
文章标签 编码 iii 罗曼

本文主要是介绍罗曼III型编码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

罗曼III编码

罗曼和郎恩利用迂回相位效应制成迂回相位全息图有三类,现在对最常见的罗曼III型编码进行说明。矩形通光孔径的宽度为定值 B m n B_{mn} Bmn,高度 H m n H_{mn} Hmn随采样点(m,n)的振幅值 A m n A_{mn} Amn 的变化而改变, d m n d_{mn} dmn透明孔的中心偏离抽样点的距离,偏离的距离随采样点(m,n)相位 Φ m n \Phi_{mn} Φmn 而变化。设物函数是第(m,n)个抽样点的表示 [ 1 − 5 ] ^{[1-5]} [15]
Φ m n = A m n e x p [ j ϕ m n ] \Phi_{mn}=A_{mn}exp[j\phi _{mn}] Φmn=Amnexp[jϕmn]
即通过矩形孔的高度 H m n H_{mn} Hmn 和矩形孔的位置来编码复波前的频谱的振幅和相位,图中各参量对应的关系为
在这里插入图片描述 H m n = A m n y \ H_{mn} = A_{mn}y  Hmn=Amny
d m n = x 0 Φ m n / 2 π \ d_{mn} = x_{0}\Phi_{mn}/2\pi  dmn=x0Φmn/2π
B m n = B \ B_{mn} = B  Bmn=B
m x 0 mx_{0} mx0 n y 0 ny_{0} ny0 表示抽样单元的中心,模拟实验是采用’光’字作为实验对象,大小为N×N=64×64,为方便计算,计算全息图的单元划分为s×s,通过孔的宽度设置为s/2,所以罗曼III迂回相位编码的全息图大小为(64×s) ×(64×s),而不是傅里叶频谱相同的64×64像素。因而,模拟重建时的图像会有很多级次同时出现。MATLAB程序如下,仅供参考。

U0=imread('guang.bmp');
U0=double(U0(:,:,1)); 
r=64; c=64;                   
U0=imresize(U0,[r,c]);         
figure,imshow(U0,[])                      
[r,c]=size(U0);                           
ef1=0.8;                                    
FU0=fftshift(fft2(U0.*exp(j.*rands(r,c).*pi.*ef1))); 
Am=abs(FU0);                               
Ph=mod(angle(FU0),2*pi);                 
Ph=Ph./2/pi;                              
w=3;                                           %通光孔径的宽度(设为偶数)
wth=round(w/2);                         %通光孔径的一半
s=6;                                           %设置编码单元的大小(像素)
CGH=zeros(r*s,c*s);                     
%= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
%(罗曼Ⅲ型)
maxAm=max(abs(FU0(:)));                   
ef2=1.5;                                  
th=maxAm/ef2;                             
Am(Am>th)=th;                             
lmn=round(Am/th*w);                      
pmn=round(Ph*w);                           %将相位量化到0,1,2,…,w
%= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
%全息图赋值
for m=1:r;                                for n=1:c;                            cgh=zeros(s,s);                   if lmn(m,n)==0;                          %对模不为零的点进行编码elseif pmn(m,n)<=wth           %相位值小于π/2,不出现模式溢出cgh(w+1-lmn(m,n):w+lmn(m,n),w-wth+pmn(m,n)+1:2*w-wth+pmn(m,n))=1;elseif pmn(m,n)>wth            %相位值大于π/2,出现模式溢出cgh(w+1-lmn(m,n):w+lmn(m,n),w-wth+pmn(m,n)+1:s)=1;cgh(w+1-lmn(m,n):w+lmn(m,n),1:pmn(m,n)-wth)=1;endCGH((m-1)*s+1:m*s,(n-1)*s+1:n*s)=cgh;%将生成的抽样单元放到计算全息图中end
end
figure;imshow(CGH,[]);                    
%= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
%再现运算
RU=fftshift(ifft2(CGH));                  
RI=RU.*conj(RU);                        
figure;imshow(RI,[0,max(RI(:))/1000]),colormap(pink);

参考文献
[1 ] 古德曼 ,傅里叶光学导论[M],北京:电子工业出版社,2006,第3版
[2] 钱晓凡,信息光学数字实验室[M],北京:科学出版社,2014
[3]陈家壁,苏显渝.光学信息技术原理及应用[M].北京:高等教育出版社,2001
[4]虞祖良,金国藩. 计算机制全息图[M]. 北京:清华大学出版社,1984
[5 ]于美文.光全息学及其应用[M].北京:北京理工大学出版社,1996

这篇关于罗曼III型编码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/669829

相关文章

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

VSCode中C/C++编码乱码问题的两种解决方法

《VSCode中C/C++编码乱码问题的两种解决方法》在中国地区,Windows系统中的cmd和PowerShell默认编码是GBK,但VSCode默认使用UTF-8编码,这种编码不一致会导致在VSC... 目录问题方法一:通过 Code Runner 插件调整编码配置步骤方法二:在 PowerShell

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

form表单提交编码的问题

浏览器在form提交后,会生成一个HTTP的头部信息"content-type",标准规定其形式为Content-type: application/x-www-form-urlencoded; charset=UTF-8        那么我们如果需要修改编码,不使用默认的,那么可以如下这样操作修改编码,来满足需求: hmtl代码:   <meta http-equiv="Conte

4-4.Andorid Camera 之简化编码模板(获取摄像头 ID、选择最优预览尺寸)

一、Camera 简化思路 在 Camera 的开发中,其实我们通常只关注打开相机、图像预览和关闭相机,其他的步骤我们不应该花费太多的精力 为此,应该提供一个工具类,它有处理相机的一些基本工具方法,包括获取摄像头 ID、选择最优预览尺寸以及打印相机参数信息 二、Camera 工具类 CameraIdResult.java public class CameraIdResult {

Python字符编码及应用

字符集概念 字符集就是一套文字符号及其编码的描述。从第一个计算机字符集ASCII开始,为了处理不同的文字,发明过几百种字符集,例如ASCII、USC、GBK、BIG5等,这些不同的字符集从收录到编码都各不相同。在编程中出现比较严重的问题是字符乱码。 几个概念 位:计算机的最小单位二进制中的一位,用二进制的0,1表示。 字节:八位组成一个字节。(位与字节有对应关系) 字符:我们肉眼可见的文字与符号。

在Eclipse环境下修改Tomcat编码的问题

问题: 由于BMS需要设置UTF-8编码,要不就会出现中文乱码问题; 一、项目保持UTF-8格式; 二、由于可能会多次移除项目、加载项目,不想每次都要修改tmp0\conf 原因: 如果在eclipse中配置了tomcat后,其实,tomcat所用的所有tomcat配置文件,都不是catalina_home/config下面的xml文件,而是在eclipse所创建的Serve