- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我如何使用 Keras 和 Tensorflow 将图像分类模型保存为 .pb 文件及其 label.txt,以便在 android 上使用这两个文件。我有一个开始代码,代码只保存 .pb 文件但不是 label.txt
我已经完成了打洞的事情,但还没有完成 label.txt这是代码
import pandas as pd
import numpy as np
import warnings
warnings.filterwarnings('ignore')
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
import keras
from keras.models import Sequential
from keras.layers import Conv2D,MaxPooling2D,Dense,Flatten,Dropout,Activation
from keras.optimizers import Adam
from keras.callbacks import TensorBoard
from keras.layers.core import Lambda
from keras.optimizers import Adam
import keras
import keras.backend as k
import tensorflow as tf
from tensorflow.python.framework import graph_util
print(keras.__version__)
print(tf.__version__)
import os
train_df = pd.read_csv('fashionmnist/fashion-mnist_train.csv',sep=',')
test_df = pd.read_csv('fashionmnist/fashion-mnist_test.csv',sep=',')
train_data =np.array(train_df,dtype = 'float32')
test_data = np.array(test_df,dtype = 'float32')
x_train = train_data[:,1:]/255
y_train = train_data[:,0]
x_test = train_data[:,1:]/255
y_test = train_data[:,0]
x_train,x_validate,y_train,y_validate=train_test_split(x_train,y_train,test_size = 0.2,random_state = 12345)
image = x_train[50,:].reshape((28,28))
plt.imshow(image)
plt.show()
image_rows =28
image_cols= 28
batch_size =100
image_shape =(image_rows,image_cols,1)
x_train = x_train.reshape(x_train.shape[0],*image_shape)
x_test = x_test.reshape(x_test.shape[0],*image_shape)
x_validate = x_validate.reshape(x_validate.shape[0],*image_shape)
def build_network(is_training=True):
model = Sequential()
model.add(Conv2D(32, (3, 3), input_shape=image_shape, padding='same',name="1_conv"))
model.add(Activation('relu'))
model.add(Conv2D(32, (3, 3), padding='same',name="2_conv"))
model.add(Activation('relu'))
model.add(MaxPooling2D(pool_size=(2, 2),name="1_pool"))
model.add(Conv2D(64, (3, 3), padding='same',name="3_conv"))
model.add(Activation('relu'))
model.add(Conv2D(64,(3, 3), padding='same',name="4_conv"))
model.add(Activation('relu'))
model.add(MaxPooling2D(pool_size=(2, 2),name="2_pool"))
model.add(Conv2D(128,(3, 3),padding='same',name="5_conv"))
model.add(Activation('relu'))
model.add(Conv2D(128, (3, 3),padding='same',name="6_conv"))
model.add(Activation('relu'))
model.add(MaxPooling2D(pool_size=(2, 2),name="3_pool"))
model.add(Conv2D(256,(3, 3), padding='same',name="7_conv"))
model.add(Activation('relu'))
model.add(Conv2D(256, (3, 3), padding='same',name="8_conv"))
model.add(Activation('relu'))
model.add(MaxPooling2D(pool_size=(2, 2),name="4_pool"))
model.add(Flatten())
model.add(Dense(512,name="fc_1"))
model.add(Activation('relu'))
if (is_training):
#model.add(Dense(512, activation='relu'))
#model.add(Dropout(0.5, name="drop_1"))
model.add(Lambda(lambda x:k.dropout(x,level=0.5),name="drop_1"))
model.add(Dense(10,name="fc_2"))
model.add(Activation('softmax',name="class_result"))
#model.summary()
return model
tf.reset_default_graph()
sess = tf.Session()
k.set_session(sess)
model=build_network()
history_dict = {}
model.compile(loss='sparse_categorical_crossentropy',optimizer = Adam(),metrics=['accuracy'])
class TFCheckpointCallback(keras.callbacks.Callback):
def __init__(self,saver,sess):
self.saver=saver
self.sess=sess
def on_epoch_end(self,epoch,log=None):
self.saver.save(self.sess,'fMnist/ckpt',global_step=epoch)
tf_saver= tf.train.Saver(max_to_keep=2)
checkpoint_callback= TFCheckpointCallback(tf_saver,sess)
%time
tf_graph=sess.graph
tf.train.write_graph(tf_graph.as_graph_def(),'freeze','fm_graph.pdtxt',as_text=True)
%time
history = model.fit(x_train,
y_train,
batch_size=batch_size,
epochs=50,
callbacks=[checkpoint_callback],
shuffle=True,
verbose=1,
validation_data=(x_validate,y_validate)
)
sess.close()
model_folder='fMnist/'
def prepare_graph_for_freezing(model_folder):
model=build_network(is_training=False)
checkpoint=tf.train.get_checkpoint_state(model_folder)
input_checkpoint=checkpoint.model_checkpoint_path
saver=tf.train.Saver()
with tf.Session(config=tf.ConfigProto(allow_soft_placement=True)) as sess:
k.set_session(sess)
saver.restore(sess,input_checkpoint)
tf.gfile.MakeDirs(model_folder+'freeze')
saver.save(sess,model_folder + 'freeze/ckpt',global_step=0)
def freeze_graph(model_folder):
checkpoint =tf.train.get_checkpoint_state(model_folder)
print(model_folder+'freeze/')
input_checkpoint = checkpoint.model_checkpoint_path
absolut_model_folder="/".join(input_checkpoint.split('/')[:-1])
output_graph=absolut_model_folder + "/fm_freazen_model.pb"
print(output_graph)
output_node_name = "class_result/Softmax"
clear_devices = True
new_saver= tf.train.import_meta_graph(input_checkpoint + '.meta',clear_devices=clear_devices)
graph = tf.get_default_graph()
input_graph_def = graph.as_graph_def()
with tf.Session(config=tf.ConfigProto(allow_soft_placement=True)) as sess2:
print(input_checkpoint)
new_saver.restore(sess2,input_checkpoint)
output_graph_def=graph_util.convert_variables_to_constants(
sess2,
input_graph_def,
output_node_name.split(","))
with tf.gfile.GFile(output_graph,"wb") as f:
f.write(output_graph_def.SerializeToString())
print("%d ops in the final graph."% len(output_graph_def.node))
tf.reset_default_graph()
prepare_graph_for_freezing("freeze/")
freeze_graph("freeze/")
我有检查点和.pb 文件
但是我没有label.txt文件
最佳答案
就Android上的Image Classification而言,我推荐你使用TensorFlow Lite而不是直接使用 Protocol Buffer 。
首先,您需要将 Keras 模型 ( .h5
) 转换为 TensorFlow Lite 模型 (.tflite
)。
converter = tf.lite.TFLiteConverter.from_keras_model_file( 'model.h5' )
tflite_buffer = converter.convert()
open( 'tflite_model.tflite' , 'wb' ).write( tflite_buffer )
模型已准备好加载到 Android 上。要检查输入和输出 dtype
和 shape
,请参阅 this文件。
现在在 Android 上,首先在 build.gradle
中添加 TensorFlow Lite 依赖。
dependencies {
...
implementation 'org.tensorflow:tensorflow-lite:1.13.1'
...
}
现在我们将模型加载为 MappedByteBuffer
对象。
@Throws(IOException::类)
private fun loadModelFile(): MappedByteBuffer {
val MODEL_ASSETS_PATH = "model.tflite"
val assetFileDescriptor = assets.openFd(MODEL_ASSETS_PATH)
val fileInputStream = FileInputStream(assetFileDescriptor.getFileDescriptor())
val fileChannel = fileInputStream.getChannel()
val startoffset = assetFileDescriptor.getStartOffset()
val declaredLength = assetFileDescriptor.getDeclaredLength()
return fileChannel.map(FileChannel.MapMode.READ_ONLY, startoffset, declaredLength)
}
使用 interpreter.run()
方法,我们在给定一些输入的情况下产生推理。看这个file .此文件包含使用 Bitmap.createScaledBitmap
方法调整 Bitmap
大小并将其转换为 float[][]
val interpreter = Interpreter( loadModelFile() )
val inputs : Array<FloatArray> = arrayOf( some_input_image. )
val outputs : Array<FloatArray> = arrayOf( floatArrayOf( 0.0f , 0.0f ) )
interpreter.run( inputs , outputs )
val output = outputs[0]
就是这样。 TFLite 比 TensorFlow Mobile 快得多。
Note: TF Lite supports only a few number of ops. Since, ops related with CNNs are fully supported, we can use TFLite for image classification in Android and iOS too.
提示:
要减小 .tflite
文件的大小,请在使用 Python 转换模型时使用 post_training_quantize
标志。
converter = tf.lite.TFLiteConverter.from_keras_model_file( 'model.h5' )
converter.post_training_quantize = True
tflite_buffer = converter.convert()
open( 'tflite_model.tflite' , 'wb' ).write( tflite_buffer )
此外,尝试使用 Firebase MLKit 在 Firebase 中托管自定义模型。
我已经创建了许多使用 TF 对图像和文本进行分类的应用。
https://github.com/shubham0204/Spam_Classification_Android_Demo
关于android - 如何保存图像分类模型并将其用于 android,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56447659/
我尝试根据表单元素的更改禁用/启用保存按钮。但是,当通过弹出按钮选择更改隐藏输入字段值时,保存按钮不受影响。 下面是我的代码。我正在尝试序列化旧的表单值并与更改后的表单值进行比较。但我猜隐藏的字段值无
我正在尝试保存模型的实例,但我得到了 Invalid EmbeddedDocumentField item (1) 其中 1 是项目的 ID(我认为)。 模型定义为 class Graph(Docum
我有一个非常奇怪的问题......在我的 iPhone 应用程序中,用户可以打开相机胶卷中的图像,在我的示例中 1920 x 1080 像素 (72 dpi) 的壁纸。 现在,想要将图像的宽度调整为例
目前,我正在使用具有排序/过滤功能的数据表成功地从我的数据库中显示图像元数据。在我的数据表下方,我使用第三方图像覆盖流( http://www.jacksasylum.eu/ContentFlow/
我的脚本有问题。我想按此顺序执行以下步骤: 1. 保存输入字段中的文本。 2. 删除输入字段中的所有文本。 3. 在输入字段中重新加载之前删除的相同文本。 我的脚本的问题是 ug()- 函数在我的文本
任何人都可以帮助我如何保存多对多关系吗?我有任务,用户可以有很多任务,任务可以有很多用户(多对多),我想要实现的是,在更新表单中,管理员可以将多个用户分配给特定任务。这是通过 html 多选输入来完成
我在 Tensorflow 中训练了一个具有批归一化的模型。我想保存模型并恢复它以供进一步使用。批量归一化是通过 完成的 def batch_norm(input, phase): retur
我遇到了 grails 的问题。我有一个看起来像这样的域: class Book { static belongsTo = Author String toString() { tit
所以我正在开发一个应用程序,一旦用户连接(通过 soundcloud),就会出现以下对象: {userid: userid, username: username, genre: genre, fol
我正在开发一个具有多选项卡布局的 Angular 7 应用程序。每个选项卡都包含一个组件,该组件可以引用其他嵌套组件。 当用户选择一个新的/另一个选项卡时,当前选项卡上显示的组件将被销毁(我不仅仅是隐
我尝试使用 JEditorPane 进行一些简单的文本格式化,但随着知识的增长,我发现 JTextPane 更容易实现并且更强大。 我的问题是如何将 JTextPane 中的格式化文本保存到文件?它应
使用 Docker 相当新。 我为 Oracle 11g Full 提取了一个图像。创建了一个数据库并将应用程序安装到容器中。 正确配置后,我提交了生成 15GB 镜像的容器。 测试了该图像的新容器,
我是使用 Xcode 和 swift 的新手,仍在学习中。我在将核心数据从实体传递到文本字段/标签时遇到问题,然后用户可以选择编辑和保存记录。我的目标是,当用户从 friendslistViewCon
我正在用 Java 编写 Android 游戏,我需要一种可靠的方法来快速保存和加载应用程序状态。这个问题似乎适用于大多数 OO 语言。 了解我需要保存的内容:我正在使用策略模式来控制我的游戏实体。我
我想知道使用 fstream 加载/保存某种结构类型的数组是否是个好主意。注意,我说的是加载/保存到二进制文件。我应该加载/保存独立变量,例如 int、float、boolean 而不是结构吗?我这么
我希望能够将 QNetworkReply 保存到 QString/QByteArray。在我看到的示例中,它们总是将流保存到另一个文件。 目前我的代码看起来像这样,我从主机那里得到一个字符串,我想做的
我正在创建一个绘图应用程序。我有一个带有 Canvas 的自定义 View ,它根据用户输入绘制线条: class Line { float startX, startY, stopX, stop
我有 3 个 Activity 第一个 Activity 调用第二个 Activity ,第二个 Activity 调用第三个 Activity 。 第二个 Activity 使用第一个 Activi
我想知道如何在 Xcode 中保存 cookie。我想使用从一个网页获取的 cookie 并使用它访问另一个网页。我使用下面的代码登录该网站,我想保存从该连接获得的 cookie,以便在我建立另一个连
我有一个 SQLite 数据库存储我的所有日历事件,建模如下: TimerEvent *Attributes -date -dateForMark -reminder *Relat
我是一名优秀的程序员,十分优秀!