博客
关于我
【图像评价】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/

    你可能感兴趣的文章
    ORCHARD 是什么?
    查看>>
    Struts2中使用Session的两种方法
    查看>>
    Stream API:filter、map和flatMap 的用法
    查看>>
    STM32工作笔记0032---编写跑马灯实验---寄存器版本
    查看>>
    ssm旅游信息管理系统的设计与实现bus56(程序+开题)
    查看>>
    order by rand()
    查看>>
    SSM(Spring+SpringMvc+Mybatis)整合开发笔记
    查看>>
    ViewHolder的改进写法
    查看>>
    Orderer节点启动报错解决方案:Not bootstrapping because of 3 existing channels
    查看>>
    org.apache.axis2.AxisFault: org.apache.axis2.databinding.ADBException: Unexpected subelement profile
    查看>>
    sql查询中 查询字段数据类型 int 与 String 出现问题
    查看>>
    org.apache.commons.beanutils.BasicDynaBean cannot be cast to ...
    查看>>
    org.apache.dubbo.common.serialize.SerializationException: com.alibaba.fastjson2.JSONException: not s
    查看>>
    sqlserver学习笔记(三)—— 为数据库添加新的用户
    查看>>
    org.apache.http.conn.HttpHostConnectException: Connection to refused
    查看>>
    org.apache.ibatis.binding.BindingException: Invalid bound statement错误一例
    查看>>
    org.apache.ibatis.exceptions.PersistenceException:
    查看>>
    org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned
    查看>>
    org.apache.ibatis.type.TypeException: Could not resolve type alias 'xxxx'异常
    查看>>
    org.apache.poi.hssf.util.Region
    查看>>