- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是 TF 和 GCP 部署方面的新手。非常感谢您的帮助!
目前,我正在尝试使用 TensorFlow Serving 在 Google Cloud Platform(GCP) 上部署我的 Mnist 手写 Flask 应用程序。我已在 TF 服务上部署了我的模型,并使用自定义 MySimpleScaler 类来预处理图像并调整图像大小,然后再将其输入到我的模型中。我的问题是,是否有办法在我的保存模型中添加预处理和调整大小类,以便我的 Flask 应用程序没有任何 tensorflow 依赖项。原因是 TF 库对于应用程序引擎来说太大。
我的应用程序的流程如下:
1) 我的 Flask 应用程序部署在应用程序引擎上。它有一个 MySimpleScaler 类来调整从 Canvas 输入的图像大小。我允许用户从前端的 Canvas 上绘制 --> 使用 jquery 获取数据 --> 使用 parse_image 函数将其写入为 output.jpg --> 从本地驱动器读取 output.jpg 并提供给它到 MySimpleScaler 进行预处理
2) 我的模型使用 TF 服务部署在 AI 平台上。我在步骤 1 中使用 MysimpleScaler 的输出发送预测请求。然后将预测值推送到 Flask 后端,然后使用 Jinja 将其推送到前端
这是我用来获取和预处理数据的两个函数:
def parse_image(imgData):
# imgData fetch img from canvas using request.get_data()
imgstr = re.search(b"base64,(.*)", imgData).group(1)
img_decode = base64.decodebytes(imgstr)
with open("output.jpg", "wb") as file:
file.write(img_decode)
return img_decode
class MySimpleScaler(object):
def preprocess_img(self, img_decode):
# img_decode from parse_image
img_raw = img_decode
image = tf.image.decode_jpeg(img_raw, channels=1)
image = tf.image.resize(image, [28, 28])
image = (255 - image) / 255.0 # normalize to [0,1] range
image = tf.reshape(image, (1, 28, 28, 1))
return image
TL;DR:我想在将 preprocess_img 函数部署到 TF 服务之前将其添加为保存模型中的层之一。非常感谢您的参与!
最佳答案
如果您同意batch_size=1
,那么在图表中添加预处理函数应该很简单,这就是我的做法,
代码:
import tensorflow as tf
import numpy as np
print('TensorFlow:',tf.__version__)
def preprocess_single_image(image_bytes, h=299, w=299):
image = tf.image.decode_jpeg(image_bytes[0], channels=3)
image = tf.image.resize(image, size=[h, w])
image = (image - 127.5) / 127.5
image = tf.expand_dims(image, axis=0)
return image
image_bytes = tf.keras.Input(shape=[], batch_size=1, name='image_bytes', dtype=tf.string)
preprocessed_image = preprocess_single_image(image_bytes)
model = tf.keras.applications.Xception(weights='imagenet')
predictions = model(preprocessed_image)
new_model = tf.keras.Model(image_bytes, predictions)
new_model.save('export/1', save_format='tf')
print('Model Input Shape:', new_model.input_shape)
### !wget -q -O "cat.jpg" "https://images.pexels.com/photos/617278/pexels-photo-617278.jpeg?cs=srgb&dl=adorable-animal-blur-cat-617278.jpg&fm=jpg"
loaded_model = tf.saved_model.load('export/1')
cat_bytes = tf.expand_dims(tf.io.read_file('cat.jpg'), axis=0)
preds = loaded_model(cat_bytes).numpy()
print(tf.keras.applications.xception.decode_predictions(preds, top=3)[0])
输出:
TensorFlow: 2.0.0
WARNING:tensorflow:From /tensorflow-2.0.0/python3.6/tensorflow_core/python/ops/resource_variable_ops.py:1781: calling BaseResourceVariable.__init__ (from tensorflow.python.ops.resource_variable_ops) with constraint is deprecated and will be removed in a future version.
Instructions for updating:
If using Keras pass *_constraint arguments to layers.
INFO:tensorflow:Assets written to: export/1/assets
Model Input Shape: (1,)
[('n02123045', 'tabby', 0.5762127), ('n02123159', 'tiger_cat', 0.24783427), ('n02124075', 'Egyptian_cat', 0.09435685)]
PS:如果您想扩展它以支持,您可以使用tf.map_fn
batch_size > 1
关于python - tensorflow 2.0 : Add image preprocessing step in a saved model,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59344187/
当我调用 png.Decode(imageFile) 时,它返回类型 image.Image。但我找不到将其转换为 image.NRGBA 或 image.RGBA 的记录方式,我可以在其上调用 At
image/jpeg 和 image/png 包有 Decode 和 Encode 函数,可以读取和写入 jpeg 和 png 图像,但 image/gif 包没有 - 只有 Decode 和 Dec
我正在尝试从一系列任意的非调色板图像创建动画 GIF。为了创建调色板图像,我需要以某种方式想出一个调色板。 // RGBA, etc. images from somewhere else var f
我在今年夏天的空闲时间使用 Go 镜像包进行一些练习。 package main import ( "os" "image" "image/png" "image/co
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question 今天
我正在尝试在 TilePane 中列出图像。当我尝试创建图像 new ImageView("address"); 时出现错误,地址如下: "file:D:/Chrysanthemum.jpeg/" 以
我有一个用于为画廊选择图像的表单,我希望允许用户仅选择 jpg、gif 和 png 图像格式。 现在,为了测试,我将图像的扩展名更改为 .bmp,例如“image1.bmp”,当我在输入文件中单击以选
我有创建图像的代码:(m_img 是 javafx.scene.image.Image) Image m_img = new Image("file:" + p_Fil.getAbsoluteFile
假设我有一个这样的 8 位灰度图像: var pixels []byte = ... width := 100 height := 100 如何将其转换为实现 image.Image 的东西? 最佳答
这段代码是我在localhost:8088 URL上的索引/主页的一部分,如果我想将用户发送到url localhost:8088/image/1,我应该写href='image/{{$image->
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我在这个问题上花了一整天,但在堆栈溢出中没有看到答案! 我试过了但是没用: >> pil_image = Image.frombytes('RGBA', wand_image.size, wa
所以,我是那些以始终使用最新版本的浏览器而自豪的人之一(当然 Internet Explorer 除外 - 我说的不是那个浏览器)。 我遇到了 this awesome CSS3 website详细介
如果 image_tag 无法从 url 加载图像,我想呈现默认图像: 因此,如果 image_tag 无法从 url 加载图像: 然后呈现默认值: 这将生成结果 HTML: 关于image -
我正在创建一个类似横幅的组件,并将图像设置为组件的背景,但我无法让它工作。我尝试了网上发布的不同建议,但没有成功,目前我不确定我的错误是否在 react 代码中,或者是 webpack 没有正确加载文
如何解决 Dart 中的这种歧义错误。 import 'dart:io'; import 'package:flutter/material.dart'; import 'package:camera
Center( child: CachedNetworkImage( imageUrl: "http:/ sosme link he
设置 www.website.com/sds/(index.htm) 以便鼠标悬停在不同位置时显示图像。 出于某种原因,当您将鼠标悬停在蓝色气球上时,图像 2.jpg 和 3.jpg(在蓝色气球上来回
社交网络在共享 URL 时可以很好地从网站中提取标题和描述,但对于图像,仍然需要创建自定义元标记:property="og:image" name="twitter:image" itemprop="
我正在尝试写一个简短的,它将读取一个 PNG 文件,并将一个 channel 与另一个 channel (R,G,B) 交换作为可能的选择。 但是,我无法找到如何从 image.At(x,y) 返回的
我是一名优秀的程序员,十分优秀!