引言

熟悉PS的人也许知道,PS滤镜中有一个Redfield Fractalius,可以让图片展现出魔幻的效果,比如一直可爱的喵星人,经过魔幻光影滤镜处理之后就会展现出下面威武霸气的样子:

还有这样

这样

那么我们能不能用OpenCV来实现这样的效果呢?答案显然是可以的。而且OpenCV还提供了相应的例子,这就大大简化了我们学习的负担。今天我们就来看看这个程序吧。

程序要点

这是OpenCV的自带例程,代码可以在如下路径找到:\opencv\sources\samples\python\gabor_threads.py

所以代码放在最后,我对代码加了部分注释。先说下代码中比较重要的几点。代码里需要注意的有三点,分别是定义的三个函数:

  • build_filters():代码如下:

    
    # 创建滤波器(们)def build_filters():filters = []ksize = 31# 此处创建16个滤波器,只有getGaborKernel的第三个参数theta不同。for theta in np.arange(0, np.pi, np.pi / 16):kern = cv.getGaborKernel((ksize, ksize), 4.0, theta, 10.0, 0.5, 0, ktype=cv.CV_32F)kern /= 1.5*kern.sum()filters.append(kern)return filters

    注意到filters后面加s了,即滤波器不止一个。实际上,这个函数通过调用函数getGaborKernel()一共创建了16个Gabor滤波器,不同之处只在于getGaborKernel()函数的第三个参数theta不同。

  • process():单线程处理函数。这个函数也表明了魔幻滤镜效果的处理过程:

    
    # 单线程处理def process(img, filters):# zeros_like:返回和输入大小相同,类型相同,用0填满的数组accum = np.zeros_like(img)for kern in filters:fimg = cv.filter2D(img, cv.CV_8UC3, kern)# maximum:逐位比较取其大np.maximum(accum, fimg, accum)return accum

    总结一下,魔幻滤镜效果可以分为以下几步:

    1. 创建多个Gabor滤波器
    2. 创建一个与原图大小相同的0值矩阵accum
    3. 分别用不同的滤波器对原图进行滤波
    4. 滤波后的图像与accum逐位比较取其大者,再复制给accum
    5. 重复3、4两步。
  • process_threaded():多线程处理函数。可以通过这个函数大致学习下Python中多线程的用法:

    
    # 多线程处理,threadn = 8def process_threaded(img, filters, threadn = 8):accum = np.zeros_like(img)def f(kern):return cv.filter2D(img, cv.CV_8UC3, kern)pool = ThreadPool(processes=threadn)for fimg in pool.imap_unordered(f, filters):np.maximum(accum, fimg, accum)return accum

    其中pool = ThreadPool(processes=threadn)即建立一个八个线程的线程池。后面的for循环两句:

      for fimg in pool.imap_unordered(f, filters):np.maximum(accum, fimg, accum)

    pool.imap_unordered(f, filters)即把filters作为参数迭代地传递给函数f并执行。imap_unordered的意思是,不保证返回结果与迭代传入的顺序一致。不过对于这个魔幻滤镜的处理过程来说,顺序不重要。

效果图

程序的效果显然比不了PS各种调整之后的效果。我们调整合适的参数看看,虽然有所不及,但是也有了点魔幻的感觉。

处理之后

再来一张

处理之后

需要说明的是:

  • 也许不是所有的图都能做出魔幻的效果。
  • 这个处理过程参数众多,有时或者大部分时候需要同时调整几个参数才能达到理想的

注释过的代码

完整的并且被注视过的代码如下:

#!/usr/bin/env python'''
gabor_threads.py
=========Sample demonstrates:
- use of multiple Gabor filter convolutions to get Fractalius-like image effect (http://www.redfieldplugins.com/filterFractalius.htm)
- use of python threading to accelerate the computationUsage
-----
gabor_threads.py [image filename]'''# Python 2/3 compatibility
from __future__ import print_functionimport numpy as np
import cv2 as cv
from multiprocessing.pool import ThreadPool# 创建滤波器(们)
def build_filters():filters = []ksize = 31# 此处创建16个滤波器,只有getGaborKernel的第三个参数theta不同。for theta in np.arange(0, np.pi, np.pi / 16):kern = cv.getGaborKernel((ksize, ksize), 4.0, theta, 10.0, 0.5, 0, ktype=cv.CV_32F)kern /= 1.5*kern.sum()filters.append(kern)return filters# 单线程处理
def process(img, filters):# zeros_like:返回和输入大小相同,类型相同,用0填满的数组accum = np.zeros_like(img)for kern in filters:fimg = cv.filter2D(img, cv.CV_8UC3, kern)# maximum:逐位比较取其大np.maximum(accum, fimg, accum)return accum# 多线程处理,threadn = 8
def process_threaded(img, filters, threadn = 8):accum = np.zeros_like(img)def f(kern):return cv.filter2D(img, cv.CV_8UC3, kern)pool = ThreadPool(processes=threadn)for fimg in pool.imap_unordered(f, filters):np.maximum(accum, fimg, accum)return accumif __name__ == '__main__':import sysfrom common import Timer# 输出文件开头由''' '''包含的注释内容print(__doc__)try:img_fn = sys.argv[1]except:img_fn = 'cat1.jpg'img = cv.imread(img_fn)# 判断图片是否读取成功if img is None:print('Failed to load image file:', img_fn)sys.exit(1)filters = build_filters()with Timer('running single-threaded'):res1 = process(img, filters)with Timer('running multi-threaded'):res2 = process_threaded(img, filters)print('res1 == res2: ', (res1 == res2).all())cv.imshow('img', img)cv.imshow('result', res2)cv.waitKey()cv.destroyAllWindows()

公众号CVPy,分享有意思的,不仅限于OpenCV和Python的内容。

魔幻光影滤镜(2):仿Redfield Fractalius滤镜相关推荐

  1. 魔幻光影滤镜(3):美女人像“划重点”

    (上面霉霉的处理效果图在末尾) 上一篇文章:魔幻光影滤镜(2):仿Redfield Fractalius滤镜 之中,所有示例都是用的动物图片,不论是开头的PS示例还是后面程序用的,都是动物图. 有位小 ...

  2. 图像滤镜艺术---(Lightleaks Filter)漏光滤镜

    原文:图像滤镜艺术---(Lightleaks Filter)漏光滤镜 (Lightleaks Filter)漏光滤镜 漏光拍摄其实就是一种摄影手法,最初是因为强烈光照导致相片交卷的过分曝光,最终在成 ...

  3. 图像滤镜艺术---(Nostalgla Filter)老照片滤镜

    原文:图像滤镜艺术---(Nostalgla Filter)老照片滤镜 (Nostalgla Filter)老照片滤镜 Nostalgla Filter主要是通过算法来模拟一种复古,陈旧的照片风格,以 ...

  4. html图片如何滤镜,学会使用CSS3滤镜,必需先知道的滤镜的常规用法

    说到滤镜,搞前端的应该都不陌生,因为不管是曾经还是现在,你都有可能用过或者在用Photoshop.所有滤镜在这个软件中都是按分类在菜单中.滤镜,主要是用来实现图像的各种特殊效果. 简单来说,CSS滤镜 ...

  5. ps2021神经网络AI滤镜在哪,ps2021神经滤镜不能下载

    PS里边的滤镜怎样下载.安装?? 谷歌人工智能写作项目:神经网络伪原创 PS的滤镜怎么下载和安装? 滤镜下载:很多滤镜都不用安装的直接保存到相应的文件 如你的CS2装在D盘,D:\Program Fi ...

  6. ps神经网络滤镜用不了,ps滤镜工具怎么使用

    ps中滤镜怎么使用 方法新建文件,设置前景色和背景色分别为白色和天空蓝.2.然后执行滤镜/渲染/云彩,看看效果吧!是不是就有天空的效果了.3.ps的滤镜很多,有时候可能需要好几个滤镜综合使用,才出现很 ...

  7. php实现图片液化,ps液化滤镜怎么用 ps液化滤镜功能教程

    ps液化滤镜主要是用来实现图像的各种特殊效果.滤镜的操作是非常简单的,但是真正用起来却很难恰到好处它在Photoshop 具有神奇的作用.ps液化滤镜可用于推.拉.旋转.反射.折叠和膨胀图像的任意区域 ...

  8. ps2021神经网络滤镜不可用,ps神经网络滤镜用不了

    adobe 神经滤镜错误怎么办? adobe神经滤镜错误是因为adobe盗版不支持神经滤镜操作.而且神经AI滤镜是需要上传云端,由Adobe官方服务器人工智能运算的.所以导致错误,只能下载正版才能解决 ...

  9. photoshop神经滤镜是什么,神经滤镜功能揭秘~

    来啦,备受期待的ps神经滤镜终于可以安装使用了,随着最新Photoshop v24.4.1更新上线,黑科技神经滤镜功能终于可以随心所欲的使用啦,很多小伙伴耳闻的比较多,具体功能强大之处还有些许的不了解 ...

最新文章

  1. 计算机组成原理2套题,计算机组成原理试卷及答案2套.doc
  2. Layer Normalization
  3. httpd服务的访问控制
  4. 009_IOC注解开发
  5. c# 学习笔记 (1) 类型转换
  6. 项望烽:移动 IM 开发之心跳​
  7. PowerShell正则替换+批量修改文件名
  8. 分区未分配linux,在Linux下对未分配剩余空间分区
  9. 2017黑色主题 server sql_王智好美,一袭黑色亮片吊带长裙,造型简约大气,时尚优雅...
  10. 搜狗云输入法对外提供调用体验
  11. 《MATLAB智能算法30个案例》:第6章 遗传算法工具箱详解及应用
  12. 微信小程序模板全行整理合集
  13. 明小子3.5检测网站应用
  14. stata如何快速导出表格
  15. linux gtx驱动程序,NVIDIA 430.09 Linux 驱动发布:支持 GTX 1650
  16. 如何网页访问摄像机?海康威视官方文档
  17. 9月20日云栖精选夜读:异构计算高性能计算分论坛——揭秘拿什么实现超算平民化、国际化?
  18. 给ACCESS2003加密码和去掉密码
  19. 软件测试项目经验案例,软件测试心得与经验总结......
  20. java 打码_java基础(二)

热门文章

  1. 38:计算多项式的导函数
  2. 闲鹿工作流 activiti6.0 显示已结束的流程图
  3. 小程序助力博物馆餐厅,用“艾”打造品牌
  4. 在Vue项目中出现的报错--------npm ERR code 1
  5. 经常说的 CPU 上下文切换是什么意思?
  6. Apache网页优化 ---配置防盗链
  7. Vue开发Web阅读器(一)
  8. Outlook 客户端邮件莫名其妙“失踪”
  9. 虚拟信用卡(VCC)对比实体信用卡有哪些特点和优势?
  10. TIOBE 2021 年度编程语言:Python