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 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> 我用Python把抖音上的美女图片转字符画,期望的AI目标更进一步【机器学习算法实战小项目,k聚类算法图片转化字符画】 -> 正文阅读

[Python知识库]我用Python把抖音上的美女图片转字符画,期望的AI目标更进一步【机器学习算法实战小项目,k聚类算法图片转化字符画】

大家好,我是辣条。

最近在学习算法,今天给大家带来一个机器学习实战小项目

项目效果展示

学习目标

?1.cv2转换图片数据
?2.numpy提取图片矩阵数据
?3.k均值算法获取图片的分类

工具使用

开发工具: pycharm

开发环境: Windows10,Python3.7

使用工具包: cv2,numpy

项目准备

  • 你所需要转换对应的图片 -cv2的工具包的下载: pip install opencv-python

CV2是什么意思
?
CV2指的是OpenCV2,OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库copy,可以运行在Linux、Windows、Android和Mac OS操作系统上。它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。
?
OpenCV 拥有包括 500 多个C函数的跨平台的中、百高层 API。它不依赖于其它的外部库——尽管也可以使用某些外部库。
?

项目思路解析

首先准备需要处理的图片

在这里插入图片描述

利用opencv读取对应的图片数据

  • 读取图片

 ?  fp = r"1.jpg"
 ?  img = cv2.imread(fp) ?
 ?  print(img.shape)

读取的数据返回的是矩阵元组数据分别是(高度, 宽度,通道数)

  • 将图片转换成灰度 -通过黑白两种颜色来区分图片颜色的深浅 -利用kmeans算法进行区分画点

 ?  height, width, *_ = frame.shape
 ?  frame_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
 ?  frame_array = np.float32(frame_gray.reshape(-1))
 ?  compactness, labels, centroids = cv2.kmeans(frame_array, K, None, (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 10, 1.0), 10, cv2.KMEANS_RANDOM_CENTERS)
?

kmeans:返回三个参数 compactness:紧密度,返回每个点到相应重心的距离的平方和 labels:结果标记,每个成员被标记为分组的序号,如 0,1,2,3,4...等 centers:由聚类的中心组成的数组

  • 将的到的对应的中心点进行排序 -0最暗, 分类的多少是由自己决定的 -排序之后在将对应的图片相素点跟换成中心点的分类 -就能得到图片对应的颜色深浅关系 -颜色暗的用字符代替 -颜色浅的可以跟换成空白,或者横杆 -提现出颜色的差距感 -替换之后在将其放入到新的画布 -拼接成新的图片(注意图片的缩放比列)

简易源码分享

import cv2
import random
import numpy as np
?
?
def img2strimg(frame, K=3):
 ? ?height, width, *_ = frame.shape
 ? ?frame_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
 ? ?# 转换数据类型,一列显示
 ? ?frame_array = np.float32(frame_gray.reshape(-1))
 ? ?compactness, labels, centroids = cv2.kmeans(frame_array, K, None, (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 10, 1.0), 10, cv2.KMEANS_RANDOM_CENTERS)
 ? ?centroids = np.uint8(centroids) ?# 转换成整形
 ? ?# labels的数个矩心以随机顺序排列,所以需要简单处理矩心.
 ? ?# 返回一个折叠成一维的数组
 ? ?centroids = centroids.flatten()
 ? ?# 排序
 ? ?centroids_sorted = sorted(centroids)
 ? ?# 获得不同centroids的明暗程度,0最暗
 ? ?centroids_index = np.array([centroids_sorted.index(value) for value in centroids])
 ? ?bright = [abs((3 * i - 2 * K) / (3 * K)) for i in range(1, 1 + K)]
 ? ?bright_bound = bright.index(np.min(bright))
 ? ?shadow = [abs((3 * i - K) / (3 * K)) for i in range(1, 1 + K)]
 ? ?shadow_bound = shadow.index(np.min(shadow))
 ? ?labels = labels.flatten()
 ? ?# 将labels转变为实际的明暗程度列表,0最暗。
 ? ?labels = centroids_index[labels]
 ? ?labels_picked = [labels[rows * width:(rows + 1) * width:2] for rows in range(0, height, 2)]
 ? ?canvas = np.zeros((3 * height, 3 * width, 3), np.uint8)
 ? ?canvas.fill(255) ?# 创建长宽为原图三倍的白色画布。
 ? ?y = 0
 ? ?for rows in labels_picked:
 ? ? ? ?x = 0
 ? ? ? ?for cols in rows:
 ? ? ? ? ? ?if cols <= shadow_bound:
 ? ? ? ? ? ? ? ?cv2.putText(canvas, str(random.randint(2, 9)), (x, y), cv2.FONT_HERSHEY_PLAIN, 0.45, 0.1)
 ? ? ? ? ? ?elif cols <= bright_bound:
 ? ? ? ? ? ? ? ?cv2.putText(canvas, "-", (x, y),cv2.FONT_HERSHEY_PLAIN, 0.4, 0, 1)
 ? ? ? ? ? ?x += 6
 ? ? ? ?y += 6
?
 ? ?return canvas
?
?
if __name__ == '__main__':
 ? ?fp = r"1.jpg"
 ? ?img = cv2.imread(fp)
 ? ?print(img)
 ? ?str_img = img2strimg(img)
 ? ?cv2.imwrite("result.jpg", str_img)

辣条建立了一个小白Python学习交流扣群383855172【广告、大佬勿扰】


?

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-07-09 17:31:20  更:2021-07-09 17:31:33 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/3 22:12:10-

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