罗曼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

相关文章

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

在Unity环境中使用UTF-8编码

为什么要讨论这个问题         为了避免乱码和更好的跨平台         我刚开始开发时是使用VS开发,Unity自身默认使用UTF-8 without BOM格式,但是在Unity中创建一个脚本,使用VS打开,VS自身默认使用GB2312(它应该是对应了你电脑的window版本默认选取了国标编码,或者是因为一些其他的原因)读取脚本,默认是看不到在VS中的编码格式,下面我介绍一种简单快

霍夫曼编码/译码器

赫夫曼树的应用 1、哈夫曼编码   在数据通信中,需要将传送的文字转换成二进制的字符串,用0,1码的不同排列来表示字符。例如,需传送的报文为“AFTER DATA EAR ARE ART AREA”,这里用到的字符集为“A,E,R,T,F,D”,各字母出现的次数为{8,4,5,3,1,1}。现要求为这些字母设计编码。要区别6个字母,最简单的二进制编码方式是等长编码,固定采用3位二进制,可分别用

HDU 2064 汉诺塔III(水题)

题目: http://acm.hdu.edu.cn/showproblem.php?pid=2064 题目大意: 有三根杆,求把n个圆盘从左边移到右边,最少需要移动圆盘的次数。移动规则为大盘不能放在小盘上,比原始的汉诺塔题改变的地方是,只能通过中间的杆往左右两边的杆移动。 心得: 此题心得在题外,不在题内,初看此题,尼玛吓了一跳,好像很难的样子,手贱百度了一下,只注意到俩字“水题”,赶紧

Base64编码 及 在HTML中用Base编码直接显示图片或嵌入其他文件类型

1.为什么要用到BASE64编码的图片信息      Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一。Base64 主要不是加密,它主要的用途是把一些二进制数转成普通字符用于网络传输。由于一些二进制字符在传输协议中属于控制字符,不能直接传送需要转换一下。最常见的用途是作为电子邮件或WebService附件的传输编码.  2.base64编码定义    目前的internet