VGG16提取图像特征 (torch7)

VGG16
loadcaffe
torch7
  1. 下载pretrained model,保存到当前目录下

  1. th> caffemodel_url = 'http://www.robots.ox.ac.uk/~vgg/software/very_deep/caffe/VGG_ILSVRC_16_layers.caffemodel' 

  2. th> proto_url='https://gist.github.com/ksimonyan/211839e770f7b538e2d8#file-vgg_ilsvrc_16_layers_deploy-prototxt' 

  3. th> os.execute('wget VGG_ILSVRC_16_layers.caffemodel' .. caffemodel_url) 

  4. th> os.execute('wget VGG_ILSVRC_16_layers_deploy.prototxt' .. proto_url) 

  1. 使用loadcaffe提取图像特征


  1. require 'torch' -- 使用th命令,可忽略 

  2. require 'nn' -- 修改model用到nn包 

  3. require 'loadcaffe' -- 加在caffe训练的包 

  4. require 'image' -- 加载图像,处理图像,可以使用cv中函数替代 


  5. local loadSize = {3,256,256} -- 加载图像scale尺寸 

  6. local sampleSize = {3,224,224} -- 样本尺寸,其实就是选取scale后图像的中间一块 


  7. local function loadImage(input) 

  8. -- 将图像缩放到loadSize尺寸,为了保证aspect ratio不变,将短边缩放后,长边按比例缩放 

  9. if input:size(3) < input:size(2) then 

  10. input = image.scale(input,loadSize[2],loadSize[3]*input:size(2)/input:size(3)) 

  11. -- 注意image.scale(src,width,height),width对应的是input:size[3],height对应的是input:size[2] 

  12. else 

  13. input = image.scale(input,loadSize[2]*input:size(3)/input:size(2),loadSize[3]) 

  14. end 

  15. return input 

  16. end 


  17. local bgr_means = {103.939,116.779,123.68} --VGG预训练中的均值 

  18. local function vggPreProcessing(img) 

  19. local img2=img:clone() 

  20. img2[{{1}}] =img2[{{3}}] -- image.load 加载图像是rgb格式,需转化维bgr 

  21. img2[{{3}}] = img[{{1}}] 

  22. img2:mul(255) -- image.load()加载的图像 pixel value \in [0,1] 

  23. for i=1,3 do 

  24. img2[i]:add(-bgr_means[i]) -- 中心化 

  25. end 

  26. return img2 

  27. end 


  28. local function centerCrop(input) 

  29. local oH = sampleSize[2] 

  30. local oW = sampleSize[3] 

  31. local iW = input:size(3) 

  32. local iH = input:size(2) 

  33. local w1 = math.ceil((iW-oW)/2) 

  34. local h1 = math.ceil((iH-oH)/2) 

  35. local out = image.crop(input,w1,h1,w1+oW,h1+oH) 

  36. return out 

  37. end 


  38. local function getPretrainedModel() 

  39. local proto = 'VGG_ILSVRC_16_layers_deploy.prototxt' 

  40. local caffemodel = '/home/zwzhou/modelZoo/VGG_ILSVRC_16_layers.caffemodel' 


  41. local model = loadcaffe.load(proto,caffemodel,'nn') -- 加载pretrained model 

  42. for i=1,3 do -- 将最后3层舍掉 

  43. model.modules[#model.modules]=nil 

  44. end 

  45. -- 删除pretrained model的一些层官方方法 

  46. -- ========================== 

  47. -- for i= 40,38,-1 do 

  48. -- model:remove(i) 

  49. -- end 

  50. -- ========================== 

  51. model:add(nn.Normalize(2)) -- 添加一层正则化层,将输出向量归一化 


  52. model:evaluate() -- self.training=false ,非训练,让网络参数不变 

  53. return model 

  54. end 


  55. torch.setdefaulttensortype('torch.FloatTensor') 

  56. model = getPretrainedModel() 


  57. filepath = '/home/zwzhou/MOT16/train/MOT16-02/img1/000001.jpg' 

  58. local img1=image.load(filepath) -- rgb图像 

  59. local input = image.crop(img1,910,480,910+97,480+110) -- 里面参数时选择原图像的一个区域,boundingbox 


  60. input = loadImage(input) 

  61. local vggPreProcessed = vggPreProcessing(input) 

  62. local out = centerCrop(vggPreProcessed) 


  63. local outputs = model:forward(out) 


  64. print(outputs) 

  65. print(#outputs) 

  1. 参考项目

    VGG-19-feature-extractor

    Torch 7 利用已有VGG模型提取图片特征

VGG16提取图像特征 (torch7)的更多相关文章

  1. CNN基础二:使用预训练网络提取图像特征

    上一节中,我们采用了一个自定义的网络结构,从头开始训练猫狗大战分类器,最终在使用图像增强的方式下得到了82%的验证准确率.但是,想要将深度学习应用于小型图像数据集,通常不会贸然采用复杂网络并且从头开始 ...

  2. 原来CNN是这样提取图像特征的。。。

    对于即将到来的人工智能时代,作为一个有理想有追求的程序员,不懂深度学习(Deep Learning)这个超热的领域,会不会感觉马上就out了?作为机器学习的一个分支,深度学习同样需要计算机获得强大的学 ...

  3. 深度学习tensorflow实战笔记 用预训练好的VGG-16模型提取图像特征

    1.首先就要下载模型结构 首先要做的就是下载训练好的模型结构和预训练好的模型,结构地址是:点击打开链接 模型结构如下: 文件test_vgg16.py可以用于提取特征.其中vgg16.npy是需要单独 ...

  4. Pytorch如何用预训练模型提取图像特征

    方法很简单,你只需要将模型最后的全连接层改成Dropout即可. import torch from torchvision import models # load data x, y = get_ ...

  5. opencv批处理提取图像的特征

    ____________________________________________________________________________________________________ ...

  6. paper 131:【图像算法】图像特征:GLCM【转载】

    转载地址:http://www.cnblogs.com/skyseraph/archive/2011/08/27/2155776.html 一 原理 1 概念:GLCM,即灰度共生矩阵,GLCM是一个 ...

  7. 【图像算法】图像特征:GLCM灰度共生矩阵,纹理特征

    [图像算法]图像特征:GLCM SkySeraph Aug 27th 2011  HQU Email:zgzhaobo@gmail.com    QQ:452728574 Latest Modifie ...

  8. python实现gabor滤波器提取纹理特征 提取指静脉纹理特征 指静脉切割代码

    参考博客:https://blog.csdn.net/xue_wenyuan/article/details/51533953 https://blog.csdn.net/jinshengtao/ar ...

  9. MATLAB·提取图像中多个目标

    基于matlab工具箱提取图像中的多目标特征(代码如下): 代码前面部分为提取图像的边界信息,调用了后面的遍历函数Pixel_Search,函数实现方法见后~ %%ROI Testing close ...

随机推荐

  1. poj1584 A round peg in a ground hole【计算几何】

    含[判断凸包],[判断点在多边形内],[判断圆在多边形内]模板  凸包:即凸多边形 用不严谨的话来讲,给定二维平面上的点集,凸包就是将最外层的点连接起来构成的凸多边形,它能包含点集中所有的点. The ...

  2. Nginx + Tomcat 负载均衡配置详解

    Nginx常用操作指南一.Nginx 与 Tomcat 安装.配置及优化1. 检查和安装依赖项 yum -y install gcc pcre pcre-devel zlib zlib-devel o ...

  3. Spring - Bean Definition Bean定义 给容易提供元数据的3方法

    Spring Bean Definition https://www.tutorialspoint.com/spring/spring_bean_definition.htm The objects ...

  4. python三层架构

    conf/setting(配置文件)    一般是对utility进行相关设置   index(主文件) main函数触发某个对象的业务逻辑方法   model(数据库) admin  是对数据库的操 ...

  5. python技巧总结之set、日志、rsa加密

    一.日志模块logging模块调用 1.日志模块使用原理 #!/usr/bin/python # -*- coding:utf-8 -*- import logging # 方式一: "&q ...

  6. MapReduce的几个实现

    1.倒排索引的实现 import java.io.IOException; import java.util.StringTokenizer; import org.apache.hadoop.con ...

  7. Git 系列——第一步安装 Git

    之前也没有用过什么版本控制的工具,唯一用过的就是 SVN 了,不过也只是简单的使用而已,比如写好代码就签入,没了?是的,没了. 于是接触到了 Git 这个分布式版本控制软件,接下来就让我们好好学习,天 ...

  8. VS2010/MFC编程入门之二十五(常用控件:组合框控件Combo Box)

    上一节鸡啄米讲了列表框控件ListBox的使用,本节主要讲解组合框控件Combo Box.组合框同样相当常见,例如,在Windows系统的控制面板上设置语言或位置时,有很多选项,用来进行选择的控件就是 ...

  9. Linux命令: grep命令

    基本用法                                                                                                 ...

  10. RESTful源码笔记之RESTful Framework的Mixins小结

    0x00 引言 本篇对drf中的mixins进行简要的分析总结.Mixins在drf中主要配合viewset共同使用,实现http方法与mixins的相关类与方法进行关联. from rest_fra ...