当前位置: 首页 > news >正文

Python实现局部二进制算法(LBP)

1.介绍

局部二进制算法是一种用于获取图像纹理的算法。这算法可以应用于人脸识别、纹理分类、工业检测、遥感图像分析、动态纹理识别等领域。

2.示例

"""
局部二进制算法,计算图像纹理特征
"""
import cv2
import numpy as np
import matplotlib.pyplot as plt
# Load an image
image = cv2.imread('../Lena.png', cv2.IMREAD_GRAYSCALE)# Define the LBP function
def local_binary_pattern(image, P, R):# Compute LBP imagelbp = np.zeros_like(image, dtype=np.uint8)for i in range(R, image.shape[0] - R):for j in range(R, image.shape[1] - R):center = image[i, j]values = []for p in range(P):x = int(round(i + R * np.cos(2 * np.pi * p / P)))y = int(round(j - R * np.sin(2 * np.pi * p / P)))values.append(1 if image[x, y] >= center else 0)lbp[i, j] = sum([v * (2**p) for p, v in enumerate(values)])return lbp# Set the number of points and radius for LBP
num_points = 8
radius = 1# Compute LBP image
lbp_image = local_binary_pattern(image, num_points, radius)# Display the original and LBP images
plt.figure(figsize=(8, 4))plt.subplot(1, 2, 1)
plt.imshow(image, cmap='gray')
plt.title('Original Image')plt.subplot(1, 2, 2)
plt.imshow(lbp_image, cmap='gray')
plt.title('LBP Image')plt.show()

http://www.lryc.cn/news/226237.html

相关文章:

  • 如何评价现在的CSGO游戏搬砖市场
  • ResourceQuota对象在K8s上的说明
  • 悟空crm二次开发 增加客户保护功能 (很久没有消息,但是有觉得有机会的客户)就进入了保护转态
  • k8s之配置资源管理
  • 赛氪助力全国大学生数学竞赛山东赛区圆满举办
  • pytorch基础语法问题
  • 【面试经典150 | 】颠倒二进制位
  • 十分钟了解自动化测试
  • Redis配置文件
  • [量化投资-学习笔记009]Python+TDengine从零开始搭建量化分析平台-KDJ
  • Activiti6工作流引擎:Form表单
  • Fortran 中的指针
  • 第七章 块为结构建模 P4|系统建模语言SysML实用指南学习
  • 提升中小企业效率的不可或缺的企业云盘网盘
  • Web 安全之时序攻击 Timing Attack 详解
  • 【objectarx.net】定时器的使用
  • C++:容器list的介绍及使用
  • 元核云亮相金博会,智能质检助力金融合规
  • Harmony 应用开发的知识储备
  • (层次遍历)104. 二叉树的最大深度
  • 【api_fox】ApiFox简单操作
  • 给CAD中添加自定义菜单CUIX
  • Qt重启windows服务
  • OD机考真题:宜居星球改造计划
  • Python每日练习:20个常用代码,初学者也可以自己实现!
  • GitHub Copilot Chat将于12月全面推出;DeepLearning.AI免费新课
  • Java的流操作:让数据处理更简单,更高效
  • 3D渲染原理及朴素JavaScript实现【不使用WebGL】
  • 解决《荒野大镖客》提示emp.dll文件丢失问题,总结5个修复方法
  • maven重新加载后Target bytecode version总是变回1.8