博客
关于我
【图像评价】SVM图像无参考质量评价【Matlab 028期】
阅读量:710 次
发布时间:2019-03-21

本文共 1835 字,大约阅读时间需要 6 分钟。

简介

本项目旨在通过图像处理技术,分析并计算图像的多个特征参数。这些参数包括均值、方差、熵、局比率和偏度等,用于对图像进行详细描述和分析。技术实现采用了支持向量机(SVM)的方法,以实现对图像特征的精准识别和分类。

代码解释

以下是实现该项目的源代码,代码主要包括以下几个部分:

  • 加载数据文件CID2013.mat,加载数据库中相关数据。
  • 提取图像和对应的标签。
  • 使用支持向量机(SVM)对数据进行训练,设置相应的参数。
  • 对输入图像进行处理,提取图像的多个特征参数。
  • 计算归一化值并生成预测结果。
  • 输出预测结果并进行准确率验证。
  • load ./CID2013.mat;  % 加载数据文件train_data = Data(:,[1:5]); % 提取特征数据train_label = Data(:,6); % 提取标签信息% 训练支持向量机模型model = svmtrain(train_label, train_data, '-s 3'); % 设置为分类svm% 加载测试图像img_path = 'img004.png';img = imread(img_path);% 提取特征并计算归一化值disim = img;if size(disim, 3) > 0    dis_file_gray = rgb2gray(disim); % 将颜色图转单色图else    dis_file_gray = disim; % 单色图直接使用endi = 1; % 计算归一化参数% 均值计算mean_val = mean2(dis_file_gray);value(i,1) = 1/(sqrt(2*pi)*26.0625) * exp(-(mean_val - 118.5585)^2/(2*26.0625^2));% 方差计算std_val = std2(dis_file_gray);value(i,2) = 1/(sqrt(2*pi)*12.8584) * exp(-(std_val - 57.2743)^2/(2*12.8584^2));% 熵计算entropy_val = entropy(dis_file_gray);value(i,3) = 1 / 0.2578 * exp((entropy_val - 7.5404)/0.2578) * exp(-exp((entropy_val - 7.5404)/0.2578));% 局比率计算kurtosis_val = kurtosis(double(dis_file_gray(:)));value(i,4) = sqrt(19.3174/(2*pi*kurtosis_val^3)) * exp(-19.3174*(kurtosis_val - 2.7292)^2/(2*(2.7292^2)*kurtosis_val));% 偏度计算skewness_val = skewness(double(dis_file_gray(:)));value(i,5) = 1/(sqrt(2*pi)*0.6319) * exp(-(skewness_val - 0.1799)^2/(2*0.6319^2));% 模型预测与验证test_label = 0;[predicted_label, accuracy, decision_values] = svmpredict(test_label, value, model);% 输出预测结果disp('Score:');disp(predicted_label);

    代码说明

  • 数据加载:使用load命令加载CID2013.mat文件,提取训练数据和标签。
  • 特征计算:对输入图像img004.png进行处理,分别计算均值、标准差、熵、局比率和偏度等特征。
  • 归一化处理:对计算结果进行归一化处理,确保不同特征范围下的值具有一致性。
  • 模型预测:利用训练好的支持向量机模型对特征参数进行预测,生成最终的分类结果。
  • 结果验证:通过svmpredict函数验证模型的准确性,输出预测结果。
  • 代码开发环境

    本代码基于MATLAB编写,适用于去 Conditioning 的图像特征分析。开发工具为MATLAB R2018b,代码结构清晰,逻辑严谨,实现简单易懂。如果需要进一步的代码优化或功能扩展,欢迎通过联系邮箱 912100926@qq.com 进行交流和合作。

    转载地址:http://wrjrz.baihongyu.com/

    你可能感兴趣的文章
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>