在Android上加载具有AI危害检测的TensorFlow模型

247 篇文章 8 订阅
37 篇文章 1 订阅

目录

格式化模型数据

测试模型


在本系列的上一篇文章中,我们创建了一个项目,该项目将用于驾驶员的实时危害检测,并准备了一个用于TensorFlow Lite的检测模型。在这里,我们将继续加载模型并为图像处理做准备。

要将模型添加到项目中,请在src/main创建一个名为asset的新文件夹。将TensorFlow Lite模型和包含标签的文本文件复制到src/main/assets,使其成为项目的一部分。

要使用该模型,我们必须编写代码以加载该模型并通过它传递数据。检测代码将放置在两个用户界面可以共享的类中,以便可以在静态图像(用于测试)和实时视频流上使用相同的代码。

格式化模型数据

在开始为此编写代码之前,我们需要知道模型如何期望其输入数据被结构化。数据作为多维数组传入和传出。这也称为数据的形状。通常,当您找到模型时,将记录此信息。

您也可以使用Netron工具检查数据。使用此工具打开模型时,将显示组成网络的节点。单击输入节点(显示在图的顶部)将显示输入数据(在这种情况下为图像)的信息格式以及网络的输出。在这种情况下,我们看到输入数据是一个32位浮点数的数组。阵列的尺寸为1x416x416x3。这意味着网络将一次以416 x 416像素的速度接收一个包含红色、绿色和蓝色分量的图像。如果要为此项目使用其他模型,则需要检查模型的输入和输出,并相应地调整代码。解释结果时,我们将更详细地检查输出数据。

将新类添加到名为Detector的项目中。用于管理受训网络的所有代码都将添加到此类中。构建该类时,它将接受图像并以易于使用的格式提供结果。我们应该在类中添加一些常量和字段以开始使用它。这些字段包括一个TensorFlow Interpreter对象(包含受过训练的网络),该模型可识别的对象类别列表以及应用程序上下文。

class Detector {
   val TF_MODEL_NAME = "yolov4.tflite"
   val IMAGE_WIDTH = 416
   val IMAGE_HEIGHT = 416
   val TAG = "Detector"
   val useGpuDelegate = false;
   val useNNAPI=true;
   val context: Context;
   lateinit var tfLiteInterpreter:Interpreter
   var labelList = Vector<String>()

   //These output values are structured to match the output of the trained model being used
   var buf0 = Array(1) { Array(52) { Array(52) { Array(3) { FloatArray(85) } } } }
   var buf1 = Array(1) { Array(26) { Array(26) { Array(3) { FloatArray(85) } } } }
   var buf2 = Array(1) { Array(13) { Array(13) { Array(3) { FloatArray(85) } } } }
   var outputBuffers: HashMap<Int, Any>? = null
}

此类的构造函数将创建输出缓冲区,加载网络模型,并从资产文件夹加载对象类的名称。

class Detector {
   val TF_MODEL_NAME = "yolov4.tflite"
   val IMAGE_WIDTH = 416
   val IMAGE_HEIGHT = 416
   val TAG = "Detector"
   val useGpuDelegate = false;
   val useNNAPI=true;
   val context: Context;
   lateinit var tfLiteInterpreter:Interpreter
   var labelList = Vector<String>()

   //These output values are structured to match the output of the trained model being used
   var buf0 = Array(1) { Array(52) { Array(52) { Array(3) { FloatArray(85) } } } }
   var buf1 = Array(1) { Array(26) { Array(26) { Array(3) { FloatArray(85) } } } }
   var buf2 = Array(1) { Array(13) { Array(13) { Array(3) { FloatArray(85) } } } }
   var outputBuffers: HashMap<Int, Any>? = null
}

测试模型

只需几行代码即可执行网络模型。当将图像提供给Detector类时,将调整其大小以匹配网络的要求。Bitmap图像中的数据被编码为字节。该值必须转换为32位浮点值。TensorFlow Lite库包含使此类通用转换变得容易的功能。该TensorImage类型还具有一种方便的方法,允许将其用作需要输入缓冲区的方法的缓冲区。

public fun processImage(sourceImage: Bitmap) {
   val imageProcessor = ImageProcessor.Builder()
           .add(ResizeOp(IMAGE_HEIGHT, IMAGE_WIDTH, ResizeOp.ResizeMethod.BILINEAR))
           .build()
   var tImage = TensorImage(DataType.FLOAT32)
   tImage.load(sourceImage)
   tImage = imageProcessor.process(tImage)
   tfLiteInterpreter.runForMultipleInputsOutputs(arrayOf<any>(tImage.buffer), outputBuffers!!)
}</any>

要对此进行测试,请向项目中添加新的布局。布局将具有一个简单的界面,以允许从设备中选择图像。所选图像将由检测器处理。

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout>
   <ImageView

       android:id="@+id/selected_image_view"

 />
   <Button

       android:id="@+id/select_image_button"

       android:onClick="onSelectImageClicked"

 />
</androidx.constraintlayout.widget.ConstraintLayout>

该活动的代码将打开系统映像选择器。选择图像并将其传递回应用程序后,它将图像传递给检测器。

public override fun onActivityResult(reqCode: Int, resultCode: Int, data: Intent?) {
   super.onActivityResult(reqCode, resultCode, data)
   if (resultCode == RESULT_OK) {
       if (reqCode == SELECT_PICTURE) {
           val selectedUri = data!!.data
           val fileString = selectedUri!!.path
           selected_image_view!!.setImageURI(selectedUri)
           var sourceBitmap: Bitmap? = null
           try {
               sourceBitmap =
                   MediaStore.Images.Media.getBitmap(this.contentResolver, selectedUri)
               RunDetector(sourceBitmap)
           } catch (e: IOException) {
               e.printStackTrace()
           }
       }
   }
}

fun RunDetector(bitmap: Bitmap?) {
   if (detector == null) detector = Detector(this)
   detector!!.processImage(bitmap!!)
}

 

UI布局的结果

现在我们可以选择一个图像,检测器将处理该图像,识别其中的物体。但是结果是什么意思呢?我们如何使用这些结果来警告用户危险?在本系列的下一篇文章中,我们将解释结果并将相关信息提供给用户。

https://www.codeproject.com/Articles/5291389/Loading-a-TensorFlow-Model-with-AI-Hazard-Detectio

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: TensorFlow是谷歌开源的人工智能框架,它可以辅助开发者利用人工智能算法来训练模型TensorFlow的训练模型过程可以分为以下几个步骤: 1. 数据准备:训练模型需要大量的数据集,开发者需要准备好相关的数据。在数据准备过程中,需要对数据进行清洗和转化,确保数据的质量和格式的合理性。 2. 设计模型:在训练模型的过程中,开发者需要根据需求和数据集选择合适的模型类型。目前,TensorFlow支持很多种模型类型和算法,开发者可以选择常用的卷积神经网络、循环神经网络、深度学习等算法。 3. 定义损失函数:损失函数为机器学习模型优化的指标,开发者需要根据模型类型和需求,选择合适的损失函数。 4. 选择优化算法:TensorFlow支持很多种优化算法,包括传统的梯度下降、动量优化、Adam优化等,这些算法可以通过传递参数来调整优化效果。 5. 训练模型:将准备好的数据按照一定的规则依次输入模型中进行训练,通过迭代优化损失函数来得到最优的模型。 6. 模型验证和调整:训练完成后,需要对模型进行验证和调整,确保其具有较高的性能和泛化能力。 总的来说,TensorFlow训练模型过程比较复杂,需要开发者结合自己的需求和实际情况来进行。不过,随着人工智能技术的不断发展和TensorFlow的不断完善,这个过程变得越来越容易,未来TensorFlow训练模型将会得到更广泛的应用。 ### 回答2: TensorFlow是一个用途广泛的开源机器学习工具箱,可用于各种深度学习应用。使用TensorFlow训练模型的步骤需要至少以下几个步骤: 1. 数据准备:TensorFlow通常需要将数据准备为可输送的形式。这通常需要对图像,文本等进行处理,如对图像进行裁剪,缩放,变形等操作。 2. 构建计算图:TensorFlow的中心思想是计算图,它提供了一个用于定义模型的抽象方式。模型通常是由神经网络组成的,使得它可以看成是一个有向图,其中节点是操作,边是数据流。TensorFlow还提供了许多便捷工具,如变量(Variables),常量(Constants)等来构建计算图。 3. 定义目标函数:训练模型的目标是最小化某个目标函数,例如均方误差。在TensorFlow中,目标函数通常定义为一个操作(operation),用于计算误差或损失值。 4. 训练模型:在TensorFlow中,训练模型通常涉及一个迭代过程,其中模型的参数通过反向传播优化方法进行更新,例如随机梯度下降。 5. 评估模型:训练模型后,应对其进行评估以确定其性能如何。可以使用交叉验证等方法进行评估并调整模型参数。 熟练运用TensorFlow进行模型训练需要深入理解其概念和原理,同时需要具备一定编程能力和数学基础。可以通过参加TensorFlow官方提供的教程和示例程序,或者参加培训班等方式进行学习。 ### 回答3: TensorFlow是一个基于数据流图的开源软件库,让用户能够更容易地构建、训练和部署神经网络。在TensorFlow中,用户可以通过定义计算图、使用张量并运行会话来完成模型的训练。 1. 定义计算图 在TensorFlow中,用户需要定义一个计算图来表达模型。计算图是一种由节点和边组成的有向无环图(DAG),其中每个节点表示一个操作,边表示张量(多维数组)在操作之间流动的路径。TensorFlow的核心概念是张量,用户可以用它来表示模型的输入、输出和中间状态。例如,用户可以通过以下代码创建一个计算图: ```python import tensorflow as tf # 创建两个张量 a = tf.constant(2) b = tf.constant(3) # 执行一个加法操作 c = tf.add(a, b) # 创建一个会话,运行计算图 with tf.Session() as sess: print(sess.run(c)) ``` 2. 定义模型 在计算图中定义了操作,接下来需要定义模型。用户可以使用TensorFlow提供的各种操作(例如卷积层、池化层、全连接层等)来构建模型。例如,以下代码定义了一个简单的线性回归模型: ```python import tensorflow as tf # 定义输入和输出张量 x = tf.placeholder(tf.float32) y = tf.placeholder(tf.float32) # 定义模型参数 w = tf.Variable(0.0) b = tf.Variable(0.0) # 定义模型 y_pred = w * x + b # 定义损失函数(平方误差) loss = tf.square(y_pred - y) # 定义优化器 optimizer = tf.train.GradientDescentOptimizer(learning_rate=0.01) # 最小化损失函数 train_op = optimizer.minimize(loss) ``` 3. 训练模型 有了模型和计算图,接下来是训练模型。在TensorFlow中训练模型的一般流程如下: - 准备训练数据和标签 - 开始一个会话 - 初始化模型参数 - 循环训练若干轮,每轮训练时执行以下操作: - 提供训练数据和标签 - 运行训练操作 - 计算损失函数值 - 打印损失函数值和模型参数 - 关闭会话 例如,以下代码展示了如何使用梯度下降算法训练上述线性回归模型: ```python import numpy as np import tensorflow as tf # 准备数据和标签 x_train = np.array([1, 2, 3, 4]) y_train = np.array([2, 4, 6, 8]) # 开始一个会话 with tf.Session() as sess: # 初始化模型参数 sess.run(tf.global_variables_initializer()) # 循环训练若干轮 for i in range(100): # 提供训练数据和标签 feed_dict = {x: x_train, y: y_train} # 运行训练操作和损失函数计算 _, loss_val, w_val, b_val = sess.run([train_op, loss, w, b], feed_dict=feed_dict) # 打印损失函数值和模型参数 print("iter: %d, loss: %f, w: %f, b: %f" % (i, loss_val, w_val, b_val)) ``` 以上就是TensorFlow训练模型的基本流程,当然实际上要训练一个复杂的神经网络模型可能需要更多的工作量和技巧。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值