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. Oracle性能优化之表压缩及并行提高效率的测试

    1.制作测试表 create table t1 as select * from FW_T_GTXLOG insert into t1 select * from t1; create table t ...

  2. Dolls---hdu4160(最大匹配)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4160 有n个长方体形的娃娃:当长宽高都小于另一个的时候可以放进去,每一个里面最多放一个,问最优的套法下 ...

  3. Flask简介之简单应用

    Flask 0.Flask简介 Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收ht ...

  4. Python的Tornado框架的异步任务与AsyncHTTPClient 

    转载自http://www.php.cn/python-tutorials-284773.html 高性能服务器TornadoPython的web框架名目繁多,各有千秋.正如光荣属于希腊,伟大属于罗马 ...

  5. 迁移学习与fine-tuning有什么区别

    假设你要处理一个新数据集,让你做图片分类,这个数据集是关于Flowers的,问题是,数据集中flower的类别很少,数据集中的数据也不多,你发现从零开始训练CNN的效果很差,很容易过拟合,怎么办呢,于 ...

  6. 006-markdown基础语法

    1.标题 # 这是一级标题 ## 这是二级标题 ### 这是三级标题 #### 这是四级标题 ##### 这是五级标题 ###### 这是六级标题 2.字体 *这是倾斜的文字* **这是加粗的文字** ...

  7. java-mybaits-00701-与spring整合

    1.1     整合思路   需要spring通过单例方式管理SqlSessionFactory. spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSes ...

  8. PHP 自动加载的简单实现(推荐)

    基于psr的规范,使用命名空间和spl_autoload_register()来实现自动加载 文件结构: |--Api |--Account.php |--User.php |--Service |- ...

  9. Spark Core (一) 什么是RDD的Transformation和Action以及Dependency(转载)

    1. Spark的RDD RDD(Resilient Distributed Datasets),弹性分布式数据集,是对分布式数据集的一种抽象. RDD所具备5个主要特性: 一组分区列表 计算每一个数 ...

  10. glassfish3新建domain

    下载路径:http://download.oracle.com/glassfish/3.1.2.2/release/index.html .zip (解压缩)cd /glassfish3/glassf ...