1.算法功能简介

  遥感图像分类精度分析通常把分类图与标准数据进行比较,然后用正确分类的百分比来表示分类的精度。

  PIE SDK支持算法功能的执行,下面对精度分析算法功能进行介绍。

2.算法功能实现说明

2.1. 实现步骤

第一步

算法参数设置

第二步

算法执行

第三步

结果显示

2.2. 算法参数

算法名称

精度分析

C#算法DLL

PIE.CommonAlgo.dll

C#算法名称

PIE.CommonAlgo.ImgClassPostPAAlgo

参数结构体

StImgClassPostPA

参数说明

RealName

String

输入真实地面分类文件(*.tif;*.tiff; *.img)

ClassName

String

输入分类数据文件(*.tif;*.tiff; *.img)

RealIndex

IList<Int>

真实类别索引集合(正整数)

ClassIndex

IList<Int>

分类类别索引集合(正整数)

strRealInfo

IList<String>

真实地面信息

strClassInfo

IList<String>

分类数据信息

Fileinfo

String

精度结果

IsShp

bool

是否矢量

FuncName

String

功能名称

SelIndex

Int

选中索引

2.3. 示例代码

项目路径

百度云盘地址下/PIE示例程序/10.算法调用/图像处理/ PrecisionAnalysisDemo

数据路径

百度云盘地址下/PIE示例数据/栅格数据/08.图像分类/ distanceClassify-Julei.tif

视频路径

百度云盘地址下/PIE视频教程/10.算法调用/图像处理/精度分析.avi

示例代码

         /// <summary>
/// 分类后处理-精度分析
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void toolStripButton1_Click(object sender, EventArgs e)
{
//用分类后的结果distanceClassify-Julei.tif和真实的文件进行比对,得到精度分析结果
//参数设置
PIE.CommonAlgo.StImgClassPostPA info = new PIE.CommonAlgo.StImgClassPostPA();
info.FuncName = "精度分析";
info.ClassName = @"D:\data\图像分类2\distanceClassify-Julei.tif";//分类后数据文件
info.RealName = @"D:\data\图像分类2\roi-shp.shp";//地面真实文件(矢量或者是影像)
IList<int> listRealIndex = new List<int> { , , , };//此处没有处理索引为0的未分类数据,若处理可以加上0;
IList<int> listClassIndex = new List<int> { ,,, };
info.RealIndex = listRealIndex;//真实地面索引集合 匹配的左侧索引
info.ClassIndex = listClassIndex;//分类类别索引集合 匹配的右侧索引
info.IsShp = true; //如果是roi文件 则为true IList<string> listClassNameInfo = new List<string>();
IList<string> listRealNameInfo = new List<string>();
listRealNameInfo.Add("Unclassified");
IFeatureDataset realFeatureDataset = DatasetFactory.OpenFeatureDataset(info.RealName);
if (realFeatureDataset == null) return;
IFeature feature = realFeatureDataset.GetNextFeature();
while (feature != null)
{
string str = feature.GetValue().ToString();//默认选择索引为0的字段的值
int nSize = listRealNameInfo.Count;
if (nSize == )
{
listRealNameInfo.Add(str);
continue;
}
int isz = ;
for (isz = ; isz < nSize; isz++)
{
if (listRealNameInfo[isz] == str) break;
} if (isz == nSize)
{
listRealNameInfo.Add(str);
}
feature = realFeatureDataset.GetNextFeature();
} //分类数据的类别
IRasterDataset rasterDataset = DatasetFactory.OpenRasterDataset(info.ClassName, OpenMode.ReadOnly);
listClassNameInfo = rasterDataset.GetRasterBand().GetCategoryNames();//获取分类信息
if (listClassNameInfo == null)
{
IColorTable colTable = rasterDataset.GetRasterBand().Table;
if (colTable != null)
{
int count = colTable.GetColorEntryCount();
for (int i = ; i < count; i++)
{
listClassNameInfo.Add("Class" + i);
}
}
}
info.strClassInfo = listClassNameInfo; //分类数据类别信息
info.strRealInfo = listRealNameInfo; //真实地面信息
info.SelIndex = ; //选中的属性索引 ClassName //2、创建算法对象
ISystemAlgo algo = AlgoFactory.Instance().CreateAlgo("PIE.CommonAlgo.dll", "PIE.CommonAlgo.ImgClassPostPAAlgo");
if (algo == null) return;
algo.Params = info; //3、执行算法
bool result = AlgoFactory.Instance().ExecuteAlgo(algo);
PIE.CommonAlgo.StImgClassPostPA info1 = algo.Params as PIE.CommonAlgo.StImgClassPostPA;
string str1 = info1.Fileinfo;
MessageBox.Show(str1,"精度分析结果:");
}

2.4. 示例截图

图1:分类前数据

图2:距离分类结果(聚类调整)

图3:精度分析结果

注意:示例中的分类数据是距离分类数据distanceClassify.img;

分类之后会出现斑点问题,可以采用聚类进行消除得到distanceClassify-Julei.tif数据。

 

PIE SDK 精度分析(分类后处理)的更多相关文章

  1. PIE SDK 距离分类和最大似然分类

       1.算法功能简介 监督分类,也叫训练场地法.训练分类法,是遥感图像分类的一种,用被确认类别的样本像元去识别其他未知类别像元的过程.监督分类算法有平行算法.平行六面体法.最小距离法.最大似然法.马 ...

  2. PIE SDK ISODATA分类

    1.算法功能简介 ISODATA(IterativeSelf-OrganizingDataAnalysisTechniqueAlgorithm)即迭代式自组织数据分析技术, 其大致原理是首先计算数据空 ...

  3. PIE SDK K-Means分类

    1.算法功能简介 K-Means 算法的基本思想是:以空间中 k 个点为中心进行聚类,对最靠近他们的对象归类.通过迭代的方法,逐次更新各聚类中心的值,直至得到最好的聚类结果. 算法首先随机从数据集中选 ...

  4. PIE SDK分类合并

    1. 算法功能简介 分类合并功能是将分类文件中所设置的对应类别进行合并. PIE SDK支持算法功能的执行,下面对分类合并算法功能进行介绍. 2. 算法功能实现说明 2.1. 实现步骤 第一步 算法参 ...

  5. PIE SDK Command&&Tool工具命令一览表

    PIE SDK Command&&Tool工具命令一览表 编号 模板 名称(中文) Command&Tool 程序集 备注 1 数据管理 加载栅格数据 PIE.Controls ...

  6. PIE SDK 文章目录索引

    1.PIE SDK介绍 1.1.  PIE软件介绍 1.2.  PIE SDK介绍 1.3.  PIE支持项目介绍 1.4.  PIE.NET-SDK插件式二次开发介绍 1.5.  PIE.NET-S ...

  7. PIE SDK分类统计

    1. 算法功能简介 分类统计功能是将分类后的结果统计输出. PIE SDK支持算法功能的执行,下面对分类统计算法功能进行介绍. 2. 算法功能实现说明 2.1. 实现步骤 第一步 算法参数设置 第二步 ...

  8. PIE SDK过滤

    1. 算法功能简介 过滤功能使用斑点分组方法来消除分类文件中被隔离的分类像元,用以解决分类图像中出现的孤岛问题. PIE SDK支持算法功能的执行,下面对过滤算法功能进行介绍. 2. 算法功能实现说明 ...

  9. PIE SDK聚类

    1.算法功能简介 聚类处理时运用形态学算子将临近的类似分类区域聚类并合并. PIE SDK支持算法功能的执行,下面对聚类算法功能进行介绍. 2.算法功能实现说明 2.1. 实现步骤 第一步 算法参数设 ...

随机推荐

  1. docker仓库资源的地址修改

    docker仓库资源的地址修改 1.新增或者修改/etc/docker目录下的daemon.json文件 样例文件如下 { "registry-mirrors": ["h ...

  2. [基础]斯坦福cs231n课程视频笔记(一) 图片分类之使用线性分类器

    线性分类器的基本模型: f = Wx Loss Function and Optimization 1. LossFunction 衡量在当前的模型(参数矩阵W)的效果好坏 Multiclass SV ...

  3. Gmail Copilot是什么,有什么作用,好不好

    Gmail Copilot是一个Chrome浏览器插件,它构建在Gmail之上; 它自动列出你和联系人的所有电子邮件和对话信息: 它是一个小型CRM,可以让你查看联系人的个人信息快照,以及过去的任何邮 ...

  4. MacOS上传文件到windows ftp时链接文件不见了

    最近打包遇到了一个问题,打包完MAC的sdk包后,得到的是一个framework的文件夹,我们需要将这个framework传到ftp服务器上,另外,还要把这个文件夹下的Release文件夹里的文件替换 ...

  5. error: exportArchive: The data couldn’t be read because it isn’t in the correct format.

    在执行ios 打包的时候,我们通过执行下面的指令来打包ipa: mkdir arch archive_path=arch/${app_name}.xcarchive workspace_name=HP ...

  6. jq中

    1.jquery位置信息 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

  7. IDEA写vue项目出现红色波浪线警告如何解决??

    1.看图 2.希望对大家有帮助,只要修改了这个就可以,如有任何问题都可以留言,谢谢大家 2019-09-1923:54:11 作者:何秀好

  8. 使用dva 的思考的一个问题,数组复制的必要

    *getTags({ payload }, { call, put }) { const response = yield call(getTags, payload); const arr = re ...

  9. 解决js 0.1 + 0.2 = 0.30000000000000004 的位数精度问题

    https://www.html.cn/archives/7340 解决办法 parseFloat((0.1 + 0.2).toFixed(10))

  10. wait函数和waitpid的使用和总结

    wait和waitpid出现的原因 SIGCHLD --当子进程退出的时候,内核会向父进程发送SIGCHLD信号,子进程的退出是个异步事件(子进程可以在父进程运行的任何时刻终止) --子进程退出时,内 ...