图像分类的serving

2023-11-08 02:18
文章标签 图像 分类 serving

本文主要是介绍图像分类的serving,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import time
import requests
import json
import numpy as np
from PIL import Image
import matplotlib.pyplot as plt
import osdef mainProcess(image_data):"""核心代码: 将请求数据发送到远端模型, 返回预测结果"""start = time.time()####--------------------------核心代码----------------------------------------####""" REST API端口10.0.20.197为服务端地址my_sample为部署时设置的模型名称"""url = 'http://10.0.20.197:8501/v1/models/my_sample:predict'data = json.dumps({'inputs':image_data.tolist()}) # 要求输入的数据是json格式response = requests.post(url,data=data)# print(response)result = json.loads(response.content) # 解析返回数据# for key,val in result.items():#     print(key,val)outputs = result['outputs'][0] # 得到输出output_array = np.array(outputs) # list转numpy数组####--------------------------核心代码---------------------------------------####print(f'花费时间:{time.time()-start:.2f}s')# print(type(output_array))return output_arraydef letterbox_image(image, size):iw, ih  = image.sizew, h    = sizescale   = min(w/iw, h/ih)nw      = int(iw*scale)nh      = int(ih*scale)image   = image.resize((nw,nh), Image.BICUBIC)new_image = Image.new('RGB', size, (128,128,128))new_image.paste(image, ((w-nw)//2, (h-nh)//2))return new_imagedef preprocess_input(x):x /= 127.5x -= 1.return xdef preProcessing(filepath,input_shape:list):image = Image.open(filepath)image_data  = letterbox_image(image, [input_shape[1], input_shape[0]])image_data  = np.expand_dims(preprocess_input(np.array(image_data, np.float32)), 0)return image_data,imagedef postProcessing(output_array,class_names,image,filepath):"""对预测结果进行解码并保存结果"""saveDir = "preResults/"if not os.path.exists(saveDir):os.mkdir(saveDir)probability = np.max(output_array)cls_index = np.argmax(output_array)class_name = class_names[cls_index]plt.ion()plt.imshow(image)plt.title(f'Class:{class_name} Probability:{probability:.3f}')# 保存plt.axis('off')plt.savefig(saveDir+os.path.basename(filepath))plt.show(block=False)plt.pause(1) # 显示1splt.close()if __name__ == '__main__':input_shape = [224,224,3]class_names = ["EOSINOPHIL","LYMPHOCYTE","MONOCYTE","NEUTROPHIL"]while True:        filepath = input('请输入待预测图像路径(输入c退出): ')if filepath == 'c':break        image_data,image = preProcessing(filepath=filepath,input_shape=input_shape)# 远端预测output_array = mainProcess(image_data)# 根据预测得到的输出进行解码,并保存结果postProcessing(output_array,class_names, image,filepath)

这篇关于图像分类的serving的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/367348

相关文章

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

Verybot之OpenCV应用一:安装与图像采集测试

在Verybot上安装OpenCV是很简单的,只需要执行:         sudo apt-get update         sudo apt-get install libopencv-dev         sudo apt-get install python-opencv         下面就对安装好的OpenCV进行一下测试,编写一个通过USB摄像头采

用Pytho解决分类问题_DBSCAN聚类算法模板

一:DBSCAN聚类算法的介绍 DBSCAN(Density-Based Spatial Clustering of Applications with Noise)是一种基于密度的聚类算法,DBSCAN算法的核心思想是将具有足够高密度的区域划分为簇,并能够在具有噪声的空间数据库中发现任意形状的簇。 DBSCAN算法的主要特点包括: 1. 基于密度的聚类:DBSCAN算法通过识别被低密