京东金融大数据竞赛猪脸识别(8)- 识别方法之四

京东金融大数据竞赛猪脸识别(8)- 识别方法之四除了softmax层构建的深度网络,Matlab还有一个简单的构建数据分类的函数,那就是patternnet,其用法类似。可以直接对图像特征数据处理,也可以对图像集处理。代码如下:%exam1.m用训练图像特征构建深度网络并计算测试图像得分clear;load(‘JDPig_mlhmslbp_spyr.mat’);m=numel(classe_name);n=length(y)…

大家好,又见面了,我是你们的朋友全栈君。

除了softmax层构建的深度网络,Matlab还有一个简单的构建数据分类的函数,那就是patternnet,其用法类似。可以直接对图像特征数据处理,也可以对图像集处理。代码如下:

%exam1.m 用训练图像特征构建深度网络并计算测试图像得分
clear;
load('JDPig_mlhmslbp_spyr.mat');
m = numel(classe_name);
n = length(y);
label = []
for i=1:n
    label(:,i) = zeros(m,1);
    label(y(i),i) = 1;
end
testImg  = load('JDTest_mlhmslbp_spyr.mat');
if ~exist('patternnet.mat')    
    net = patternnet(1000);
    net = train(net,X,label);
    fprintf('saving net\n');
    save('patternnet.mat','net');
else
    load('patternnet.mat','net');
    fprintf('loading net\n');
end

if ~exist('resPatternnet.mat')
    view(net);
    scores = net(testImg.X);    
    save('resPatternnet.mat','scores');
else
    load('resPatternnet.mat','scores');
end
fprintf('Testing images!\n');
load('testName.mat','imgName');
for i=1:length(scores)
    for j=1:m
        indImg((i-1)*m+j) = imgName(i);
        plabel((i-1)*m+j)  = j;
        prob((i-1)*m+j)   = scores(j,i);
    end
end
T = table(indImg',plabel',prob');
writetable(T,'resPatternnet.csv');
fprintf('Image recognition finished!\n');
clear;
% 不用特征文件,对图像文件夹进行处理
trainFolder = fullfile(pwd, 'image');
testFolder = fullfile(pwd, 'query');
testSet   = imageSet(testFolder);              %query image
trainImds = imageDatastore(trainFolder,'IncludeSubfolders',true,'FileExtensions','.jpg','LabelSource','foldernames');
testImds  = imageDatastore(testFolder,'IncludeSubfolders',false);
setNum = numel(qImageSets);
y = trainImds.Labels;
n = length(y);
label = []
for i=1:n
    label(:,i) = zeros(m,1);
    label(y(i),i) = 1;
end
for i=1:
if ~exist('patternnet1024.mat')    
    net = patternnet(1024);
    net = train(net,X,label);
    fprintf('saving net\n');
    save('patternnet1024.mat','net');
else
    load('patternnet1024.mat','net');
    fprintf('loading net\n');
end

if ~exist('resPatternnet1024.mat')
    view(net);
    scores = net(testImg.X);    
    save('resPatternnet1024.mat','scores');
else
    load('resPatternnet1024.mat','scores');
end
fprintf('Testing images!\n');
load('testName.mat','imgName');
for i=1:length(scores)
    for j=1:m
        indImg((i-1)*m+j) = imgName(i);
        plabel((i-1)*m+j)  = j;
        prob((i-1)*m+j)   = scores(j,i);
    end
end
T = table(indImg',plabel',prob');
writetable(T,'resPatternnet2000.csv');
fprintf('Image recognition finished!\n');

代码功能与上节京东金融大数据竞赛猪脸识别(6)- 识别方法之三类似,可参看其注释。

转载于:https://blog.51cto.com/8764888/2086338

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151911.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月21日 下午12:16
下一篇 2022年6月21日 下午12:16


相关推荐

  • idea激活码永久【注册码】

    idea激活码永久【注册码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    44
  • C下WPF中实现贪吃蛇小游戏(超详细步骤附带源码)

    C下WPF中实现贪吃蛇小游戏(超详细步骤附带源码)一 编程思想 在制作此小游戏的时候我们应该明白我们的目标是什么 然后一步步去实现 1 首先得考虑到游戏页面的布局 游戏区域以及控制游戏的区域两部分 2 在计时器下小蛇的生成 3 小蛇自身的长度 以及位置和蛇头与蛇身的区别 4 食物的随机生成 以及食物的随机位置和渐变色 5 点击游戏开始时 播放游戏背景音乐 当音乐播放完时让其音乐重新播放也就是所谓的音乐循环播放 6 控制小蛇的移动 还有按下方向键的时候改变小蛇移动的方向 7 蛇吃到食物后自身的长度和得分加一 而且被吃到的食物消失 并播放吃到食物

    2026年3月26日
    2
  • JS中automation服务器不能创建对象

    JS中automation服务器不能创建对象今天看到 CSDN 上斌哥的 Blog 于是写了段 JS 脚本 用 QTP 执行 JS 代码的 但是提示 automation 服务器不能创建对象 问题 上网搜索 并且按照方法解决问题了 于是拷贝解决方法记录下来 1 如果是 Scripting FileSystemOb FSO 文本文件读写 被关闭了 开启 FSO 功能即可 在 运行 中执行 regsvr32scrr dll 即可 2 安全模式设置成 中

    2025年11月10日
    4
  • CouchBase_couchbase数据库

    CouchBase_couchbase数据库1.CouchBase是什么简单来说CouchBase是一款开源的,分布式的nosql数据库,主要用于分布式缓存和数据存储领域。能够通过managecache提供快速的亚毫米级别的k-v存储操作,

    2022年8月2日
    10
  • C语言打印short、long、long long和unsigned类型整数[通俗易懂]

    C语言打印short、long、long long和unsigned类型整数[通俗易懂]要打印unsignedint数字,可以使用%u符号。打印long数值,可以使用%d格式说明符。如果系统的int和long类型具有同样的长度,使用%d就可以打印long数值,但是这会给程序移植到其他系统(这两种数据类型的长度不一样的系统)带来麻烦,所以建议使用%ld打印long数值。在x和o符号前也可以使用l前缀,因此%lx表示以十六进制格式打印长整数,%lo表示

    2022年6月5日
    219
  • java-appium,jxl调用Excel中的数据,输入到文本框中。

    java-appium,jxl调用Excel中的数据,输入到文本框中。

    2021年9月17日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号