- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近开始玩keras和vgg16,我使用的是keras.applications.vgg16。
但这里我有一个关于什么是 model.inputs
的问题,因为我看到其他人在 https://github.com/keras-team/keras/blob/master/examples/conv_filter_visualization.py 中使用它。虽然它没有初始化它
...
input_img = model.input
...
layer_output = layer_dict[layer_name].output
if K.image_data_format() == 'channels_first':
loss = K.mean(layer_output[:, filter_index, :, :])
else:
loss = K.mean(layer_output[:, :, :, filter_index])
# we compute the gradient of the input picture wrt this loss
grads = K.gradients(loss, input_img)[0]
我检查了 keras 网站,但它只说这是一个形状为 (1,224,224,3) 的输入张量,但我仍然不明白那到底是什么。这是来自 ImageNet 的图像吗?还是 keras 为 keras 模型提供的默认图像?
如果我对深度学习没有足够的理解,我很抱歉,但是请有人向我解释一下。谢谢
最佳答案
(1,224,224,3)
的 4 个维度是 batch_size
、image_width
、image_height
和 image_channels
分别。 (1,224,224,3)
表示 VGG16
模型接受形状为 224x224 的
和三个 channel (RGB)。1
批量大小(一次一张图像)
有关什么是批处理
以及批处理大小
的更多信息,您可以查看 this交叉验证的问题。
回到VGG16
,架构的输入是(1, 224, 224, 3)
。这是什么意思?为了将图像输入网络,您需要:
完成此操作后,您可以将图像输入到模型中。
Keras 提供了一些实用函数来完成这些任务。下面我展示了 Extract features with VGG16 from Usage examples for image classification models 中所示代码片段的修改版本。在文档中。
为了让它实际工作,您需要一个任意大小的jpg
,名为elephant.jpg
。您可以运行以下 bash 命令来获取它:
wget https://upload.wikimedia.org/wikipedia/commons/f/f9/Zoorashia_elephant.jpg -O elephant.jpg
为了清楚起见,我将拆分图像预处理和模型预测中的代码:
import numpy as np
from keras.preprocessing import image
from keras.applications.vgg16 import preprocess_input
img_path = 'elephant.jpg'
img = image.load_img(img_path, target_size=(224, 224))
x = image.img_to_array(img)
x = np.expand_dims(x, axis=0)
x = preprocess_input(x)
您可以一路添加打印来查看发生了什么,但这里有一个简短的摘要:
image.load_img()
加载一个 PIL 图像,该图像已经是 RGB 格式并且已经将其 reshape 为 (224, 224)image.img_to_array()
正在将此图像转换为形状为 (224, 224, 3) 的矩阵。如果访问 x[0, 0, 0],您将获得第一个像素的红色分量,作为 0 到 255 之间的数字np.expand_dims(x, axis=0)
正在添加第一个维度。 x 之后的形状为 (1, 224, 224, 3)
preprocess_input
正在进行 imagenet 训练架构所需的额外预处理。从它的文档字符串(运行help(preprocess_input)
)你可以看到它:
will convert the images from RGB to BGR, then will zero-center each color channel with respect to the ImageNet dataset, without scaling
这似乎是 ImageNet 训练集的标准输入。
预处理就这样了,现在您只需将图像输入到预训练模型中即可获得预测
y_hat = base_model.predict(x)
print(y_hat.shape) # res.shape (1, 1000)
y_hat
包含模型分配给该图像的 1000 个 imagenet 类别中每个类别的概率。
为了获取类名和可读的输出,keras 还提供了一个实用函数:
from keras.applications.vgg16 import decode_predictions
decode_predictions(y_hat)
输出,对于我之前下载的 Zoorashia_elephant.jpg
图像:
[[('n02504013', 'Indian_elephant', 0.48041093),
('n02504458', 'African_elephant', 0.47474155),
('n01871265', 'tusker', 0.03912963),
('n02437312', 'Arabian_camel', 0.0038948185),
('n01704323', 'triceratops', 0.00062475674)]]
看起来不错!
关于python - Keras:VGG16 中的 model.inputs 是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53395427/
我对 mongoosejs 中模型的使用感到有些困惑。 可以通过这些方式使用 mongoose 创建模型 使用 Mongoose var mongoose = require('mongoose');
我正在看 from django.db import models class Publisher(models.Model): name = models.CharField(max_len
我有自己的 html 帮助器扩展,我用这种方式 model.Reason_ID, Register.PurchaseReason) %> 这样声明的。 public static MvcHtmlS
假设模型原本是存储在CPU上的,然后我想把它移到GPU0上,那么我可以这样做: device = torch.device('cuda:0') model = model.to(device) # o
我过去读过一些关于模型的 MVC 建议,指出不应为域和 View 重用相同的模型对象;但我找不到任何人愿意讨论为什么这很糟糕。 我认为创建两个单独的模型 - 一个用于域,一个用于 View - 然后在
我正在使用pytorch构建一个像VGG16这样的简单模型,并且我已经重载了函数forward在我的模型中。 我发现每个人都倾向于使用 model(input)得到输出而不是 model.forwar
tf.keras API 中的 models 是否多余?对于某些情况,即使不使用 models,代码也能正常运行。 keras.models.sequential 和 keras.sequential
当我尝试使用 docker 镜像运行 docker 容器时遇到问题:tensorflow/serving。 我运行命令: docker run --name=tf_serving -it tensor
我有一个模型,我用管道注册了它: register_step = PythonScriptStep(name = "Register Model",
如果 View 需要访问模型中的数据,您是否认为 Controller 应: a)将模型传递给 View b)将模型的数据传递给 View c)都不;这不应该是 Controller 所关心的。让 V
我正在寻找一个可以在模型中定义的字段,该字段本质上是一个列表,因为它将用于存储多个字符串值。显然CharField不能使用。 最佳答案 您正在描述一种多对一的关系。这应该通过一个额外的 Model 进
我最近了解了 Django 中的模型继承。我使用很棒的包 django-model-utils 取得了巨大的成功。我继承自 TimeStampedModel 和 SoftDeletableModel。
我正在使用基于 resnet50 的双输出模型进行项目。一个输出用于回归任务,第二个输出用于分类任务。 我的主要问题是关于模型评估。在训练期间,我在验证集的两个输出上都取得了不错的结果: - 综合损失
我是keras的新手。现在,我将使用我使用 model.fit_generator 训练的模型来预测测试图像组。我可以使用 model.predict 吗?不确定如何使用model.predict_g
在 MVC 应用程序中,我加入了多个表并将其从 Controller 返回到 View,如下所示: | EmployeeID | ControlID | DoorAddress | DoorID |
我在使用 sails-cassandra 连接系统的 Sails 中有一个 Data 模型。数据。 Data.count({...}).exec() 返回 1,但 Data.find({...}).e
我正在使用 PrimeFaces dataTable 开发一个 jsf 页面来显示用户列表。用户存储在 Model.User 类的对象中。
我正在关注https://www.tensorflow.org/tutorials/keras/basic_classification解决 Kaggle 挑战。 但是,我不明白应该将什么样的数据输入
我是这个领域的新手。那么,你们能帮忙如何为 CNN 创建 .config 文件吗? 传递有关如何执行此操作的文档或教程将对我有很大帮助。谢谢大家。 最佳答案 这个问题对我来说没有多大意义,因为 .co
我是“物理系统建模”主题的新手。我阅读了一些基础文献,并在 Modelica 和 Simulink/Simscape 中做了一些教程。我想问你,如果我对以下内容理解正确: 符号操作是将微分代数方程组(
我是一名优秀的程序员,十分优秀!