IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 附录1 opencv的一些简易算法 -> 正文阅读

[人工智能]附录1 opencv的一些简易算法

从github或是其他地方看到的一些算法感觉很有意思,在这里介绍一下

1??图像转手绘

import cv2
from PIL import Image
import numpy as np

frame = cv2.imread('old.jpg')
pilimg = Image.fromarray(np.uint8(frame))
a = np.asarray(pilimg.convert('L')).astype('float')
depth = 10.                         # (0-100)
grad = np.gradient(a)               # 取图像灰度的梯度值
grad_x, grad_y = grad               # 分别取横纵图像梯度值
grad_x = grad_x * depth / 100.
grad_y = grad_y * depth / 100.
A = np.sqrt(grad_x ** 2 + grad_y ** 2 + 1.)  # 构造x和y轴梯度的三维归一化单位坐标系
uni_x = grad_x / A
uni_y = grad_y / A
uni_z = 1. / A

vec_el = np.pi / 2.2                  # 光源的俯视角度,弧度值
vec_az = np.pi / 4.                   # 光源的方位角度,弧度值
dx = np.cos(vec_el) * np.cos(vec_az)  # 光源对x 轴的影响
dy = np.cos(vec_el) * np.sin(vec_az)  # 光源对y 轴的影响
dz = np.sin(vec_el)                   # 光源对z 轴的影响

b = 255 * (dx * uni_x + dy * uni_y + dz * uni_z)  # 光源归一化,(梯度和光源相互作用,将梯度转化为灰度)
b = b.clip(0, 255)

im2 = Image.fromarray(b.astype('uint8'))          #重构图像
charimg = np.asarray(im2)
cv2.imwrite('new.png',charimg)

这个使用了opencv,numpy与PIL

  • opencv用 pip install opencv-python
  • numpy 用 pip install numpy
  • PIL用 pip install pillow

我们需要一张图像,命名为old.jpg

  • 格式无所谓,不是这个格式改一下代码就行了

我们用这张图像

运行一下代码,我们就得到了这张图像

2??图像转水墨画?

import cv2
from PIL import Image
import numpy as np

frame = cv2.imread('old.jpg')
grayImage = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
grayImage = cv2.GaussianBlur(grayImage, (1, 1), 0)
edgeImage = cv2.Laplacian(grayImage, -1, ksize=5)
edgeImage = 255 - edgeImage
ret, edgeImage = cv2.threshold(edgeImage, 150, 255, cv2.THRESH_BINARY)
edgePreservingImage = cv2.edgePreservingFilter(frame, flags=2, sigma_s=50, sigma_r=0.4)
output = np.zeros(grayImage.shape)
output = cv2.bitwise_and(edgePreservingImage, edgePreservingImage, mask=edgeImage)
cartoon_image = cv2.stylization(frame, sigma_s=150, sigma_r=0.25)
cv2.imwrite('new.jpg',cartoon_image)

需要一张图像,我们用这个

运行后转出来的结果是这样的

3??批量修改图像尺寸

opencv是不能读取中文路径的,所以我们下面用的文件不能使用中文名称,如果用了就会报错

import os
import cv2

files = os.listdir('old/')
for file_name in files:
    img = cv2.imread('old/'+ file_name)
    img = cv2.resize(img,(256,256))
    cv2.imwrite('new/' + file_name,img)
    print(file_name,'已完成')

这个是用os和opencv做的,opencv直接pip install opencv-python就可以了,os是python自带的

使用前我们需要创建old和new两个文件夹,我们把要改变的图像放old中,改变完的图像会放在new中

(256,256)是我们要生成的图像大小,.jpg是文件格式,new与old都可以改,我们old中的文件是这样的

运行之后的new中的文件是这样的

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-26 11:41:49  更:2022-04-26 11:43:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 22:55:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码