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

ops/2024/10/21 10:01:51/

什么是浮雕效果?

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

不过这个图是用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.ppmy.cn/ops/27213.html

相关文章

前端开发工程师——Vue

Vue学习笔记&#xff08;尚硅谷天禹老师&#xff09;_尚硅谷天禹老师vue2021讲课笔记下载-CSDN博客 模板语法 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" co…

飞书API(6):使用 pandas 处理数据并写入 MySQL 数据库

一、引入 上一篇了解了飞书 28 种数据类型通过接口读取到的数据结构&#xff0c;本文开始探讨如何将这些数据写入 MySQL 数据库。这个工作流的起点是从 API 获取到的一个完整的数据&#xff0c;终点是写入 MySQL 数据表&#xff0c;表结构和维格表结构类似。在过程中可以有不同…

Python和Julia河流湖泊沿海水域特征数值算法模型

&#x1f3af;要点 一维水流场景计算和绘图&#xff1a; &#x1f3af;恒定透射率水头和流量计算&#xff1a;&#x1f58a;两条完全穿透畜水层理想河流之间 | &#x1f58a;无承压畜水层两侧及两条完全穿透畜水层的补给 | &#x1f58a;分水岭或渗透性非常低的岩体的不渗透边…

【C++】模板初阶

&#x1f525;个人主页&#xff1a; Forcible Bug Maker &#x1f525;专栏&#xff1a; C 目录 前言泛型编程模板函数模板概念及简单使用函数模板的原理函数模板的实例化模板参数的匹配原则 类模板概念及简单使用类模板的实例化 结语 前言 本篇博客主要内容&#xff1a;初步接…

clickhouse升级

参考链接&#xff1a; clickhouse 版本升级(rpm 安装包)_软件包 clickhouse-common-static-22.2.2.1-2.x86_64.rpm-CSDN博客

【排序算法】第二章:选择排序----普通选择排序与堆排序的详解和对比

&#x1fae1;和我一起感受 两种排序算法的魅力吧&#xff01; 前言&#xff1a;本文可能稍微涉及到一点其他排序算法&#xff0c;若想要了解可以看看&#xff1a;第一章&#xff1a;插入排序 【下面用到的&#xff1a;随机数生成测试排序性能器的代码】 一、普通选择排序 注…

OceanBase 分布式数据库【信创/国产化】- OceanBase 集群配置项

本心、输入输出、结果 文章目录 OceanBase 分布式数据库【信创/国产化】- OceanBase 集群配置项前言OceanBase 数据更新架构OceanBase 集群配置项OceanBase 配置项级别配置项的生效方式查看配置项的级别和生效方式OceanBase 分布式数据库【信创/国产化】- OceanBase 集群配置项…

数据结构(八)——排序

八、排序 8.1 排序的基本概念 排序(Sort)&#xff0c;就是重新排列表中的元素&#xff0c;使表少的元素满足按关键字有序的过程。 输入∶n个记录R1,R2...., Rn&#xff0c;对应的关键字为k1, k2,... , kn 输出:输入序列的一个重排R1,R2....,Rn&#xff0c;使得有k1≤k2≤...≤…