非接触测量-数字光栅投影-采样云纹法学习记录

2024-03-09 01:40

本文主要是介绍非接触测量-数字光栅投影-采样云纹法学习记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对于前两天关于相位的问题有了新的理解,现在明白了怎么提取相位以及怎么使用提取出的相位。

分析

假设是一维变形,已知条件是变形前的光栅以及变形后的光栅,目标是算出位移;
展开相位1
展开相位2
以下是采样云纹法提取相位的程序


% 程序开始clc;close all;clear; % 图片的初始化
width = 1024;  
heigth = 768; % 三频率
%像素单位为个数,可以看做频率;正弦函数为周期含义freq = [70 64 59];  %频率1,2,3;
f12 = abs((freq(1) * freq(2)) / (freq(1) - freq(2)));
f23 = abs((freq(2) * freq(3)) / (freq(2) - freq(3)));
f13 = abs((freq(1) * freq(3)) / (freq(1) - freq(3)));
f123 = abs((f12 * f23) / f12 - f23);% 利用分块矩阵C存储3组共计12张图
% 三种频率,四组相位
C = cell(3,4);  for i = 1:3for j = 1:4C{i,j} = zeros(heigth,width);end
end% 利用余弦函数计算12张图的灰度值
% 图像的生成
% 三种频率,四组相位for i = 1 : 3 % 对应三种不同的频率for  j = 0 : 3 % 对应四种相位for k = 1 : widthC{i,j + 1}(:,k) = 128 + 127 * sin(2 * pi * k * freq(i) / width + j * pi / 2);endend
end% 对灰度值进行归一化处理
for i = 1 : 3for j = 1 : 4C{i,j} = mat2gray(C{i,j});end
end% 显示12张图for i = 1 : 3for j = 1 : 4n = 4 * (i-1) + j;% h = figure(n);%imshow(C{i,j});filename = sprintf('Pic(%d).bmp', n);imwrite(C{i,j},filename,'bmp');endend% 初始化三组处理后的图片灰度矩阵
% phi也是分块矩阵
% 存储相位主值图像
phi = cell(3,1);
for i = 1:3phi{i,1} = zeros(heigth,width);
end% 求取相位差
% 计算每种频率对应的相位主值
% 输出三种频率的相位主值,用于相差计算for i = 1:3 % 对于3组中的每一组图片,每一组相同频率的有四张图片I1 = C{i,1};I2 = C{i,2};I3 = C{i,3};I4 = C{i,4};for g = 1:heigthfor k = 1:width          if     I4(g,k) == I2(g,k) && I1(g,k) > I3(g,k) %四个特殊位置phi{i,1}(g,k) = 0;elseif I4(g,k) == I2(g,k) && I1(g,k) < I3(g,k) %四个特殊位置phi{i,1}(g,k) = pi; elseif I1(g,k) == I3(g,k) && I4(g,k) > I2(g,k) %四个特殊位置phi{i,1}(g,k) = pi/2;elseif I1(g,k) == I3(g,k) && I4(g,k) < I2(g,k) %四个特殊位置phi{i,1}(g,k) = 3*pi/2;elseif I1(g,k) < I3(g,k) %二三象限phi{i,1}(g,k) = atan((I4(g,k)-I2(g,k))./(I1(g,k)-I3(g,k)))+pi;elseif I1(g,k) > I3(g,k) && I4(g,k) > I2(g,k) %第一象限phi{i,1}(g,k) = atan((I4(g,k)-I2(g,k))./(I1(g,k)-I3(g,k)));elseif I1(g,k) > I3(g,k) && I4(g,k) < I2(g,k) %第四象限phi{i,1}(g,k) = atan((I4(g,k)-I2(g,k))./(I1(g,k)-I3(g,k)))+2*pi;endend             end
end% 计算相差
% 保存矩阵,用于多频相差的计算
PH1 = phi{1,1};   %频率1
PH2 = phi{2,1};   %频率2
PH3 = phi{3,1};   %频率3% 初始化相差变量
% 多频相差
PH12 = zeros(heigth,width);
PH23 = zeros(heigth,width);
PH13 = zeros(heigth,width);
PH123 = zeros(heigth,width);% 计算相差
% 相差计算
% 解相for g = 1:heigthfor k = 1:width% 计算第一组和第二组的相差if PH1(g,k) > PH2(g,k)PH12(g,k) = PH1(g,k) - PH2(g,k);elsePH12(g,k) = PH1(g,k) + 2 * pi - PH2(g,k);end% 计算第一组和第三组的相差if PH1(g,k) > PH3(g,k)PH13(g,k) = PH1(g,k) - PH3(g,k);elsePH13(g,k) = PH1(g,k) + 2*pi - PH3(g,k);end% 计算第二组和第三组的相差if PH2(g,k) > PH3(g,k)PH23(g,k) = PH2(g,k) - PH3(g,k);elsePH23(g,k) = PH2(g,k) + 2*pi - PH3(g,k);end% plot(1,k);end
end% 计算最终相差
% 相差图案
% 相位解包裹  相位展开for g = 1:heigthfor k = 1:width if PH12(g,k)>PH23(g,k)PH123(g,k) = PH12(g,k)-PH23(g,k);elsePH123(g,k) = PH12(g,k)+2*pi-PH23(g,k);endend
end% 利用外差合成的一级条纹计算不同频率的展开相位%UPH12 = zeros(heigth,width);
%UPH23 = zeros(heigth,width);
%UPH13 = zeros(heigth,width);UPH1 = zeros(heigth,width);
UPH2 = zeros(heigth,width);
UPH3 = zeros(heigth,width);for g = 1:heigthfor k = 1:width %UPH12(g,k) = PH12(g,k) +2 * pi * ceil((f12 / f123 * PH123(g,k) - PH12(g,k)) / (2*pi));%UPH23(g,k) = PH23(g,k) + 2* pi * ceil((f23 / f123 * PH123(g,k) - PH23(g,k)) / (2*pi));%UPH13(g,k) = PH13(g,k) + 2* pi * ceil((f13 / f123 * PH123(g,k) - PH13(g,k)) / (2*pi));UPH1(g,k) = PH1(g,k) + 2 * pi * ceil((freq(1) * PH123(g,k) - PH1(g,k)) / (2*pi));UPH2(g,k) = PH2(g,k) + 2*pi * ceil((freq(2) * PH123(g,k) - PH2(g,k)) / (2*pi));UPH3(g,k) = PH3(g,k) + 2*pi * ceil((freq(3) * PH123(g,k) - PH3(g,k)) / (2*pi));endend% 显示figure,imshow(mat2gray(PH12));title('1,2外差');   imwrite(mat2gray(PH12),'12外差.bmp');
figure,imshow(mat2gray(PH23));title('2,3外差');   imwrite(mat2gray(PH23),'23外差.bmp');
figure,imshow(mat2gray(PH123));title('1,2,3外差');imwrite(mat2gray(PH123),'123外差.bmp');figure,imshow(mat2gray(PH1));title('频率1相位主值');  imwrite(mat2gray(PH1),'1相位主值.bmp');  
figure,imshow(mat2gray(PH2));title('频率2相位主值');  imwrite(mat2gray(PH2),'2相位主值.bmp');  
figure,imshow(mat2gray(PH3));title('频率3相位主值');  imwrite(mat2gray(PH3),'3相位主值.bmp');%figure,imshow(mat2gray(UPH1));title('频率12展开相位');  imwrite(mat2gray(UPH12),'1展开相位.bmp');  
%figure,imshow(mat2gray(UPH2));title('频率23展开相位');  imwrite(mat2gray(UPH23),'2展开相位.bmp');  
%figure,imshow(mat2gray(UPH3));title('频率13展开相位');  imwrite(mat2gray(UPH13),'3展开相位.bmp');figure,imshow(mat2gray(UPH1));title('频率1展开相位');  imwrite(mat2gray(UPH1),'1展开相位.bmp');  
figure,imshow(mat2gray(UPH2));title('频率2展开相位');  imwrite(mat2gray(UPH2),'2展开相位.bmp');  
figure,imshow(mat2gray(UPH3));title('频率3展开相位');  imwrite(mat2gray(UPH3),'3展开相位.bmp');

5.31

去包裹相位如图;

频率1和频率2去包裹之后相位差:

频率2和频率3去包裹之后相位差:

多频外差原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

云纹法计算位移的关键在于获取变形前后的相位差。

在这里插入图片描述

这篇关于非接触测量-数字光栅投影-采样云纹法学习记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/