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. Win平台下窗口操作(Unity)

    Unity发布在Win平台时, 可以通过user32.dll的方式与Win API通信, 最小化窗口代码: public static class DllImports { private const ...

  2. 李宏毅-Network Compression课程笔记

    一.方法总结 Network Pruning Knowledge Distillation Parameter Quantization Architecture Design Dynamic Com ...

  3. 基本 Python 面试问题

    目录 1.为什么学习Python? 2.通过什么途径学习的Python? 3.Python和Java.PHP.C.C#.C++等其他语言的对比? 4.简述解释型和编译型编程语言? 5.Python解释 ...

  4. 201871010133-赵永军《面向对象程序设计(java)》第十一周学习总结

    201871010133-赵永军<面向对象程序设计(java)>第十一周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...

  5. 残差residual VS 误差 error

    https://blog.csdn.net/jmydream/article/details/8764869 In statistics and optimization, statistical e ...

  6. css样式添加错误导致烦扰

    省厅和市州 两个ul 之间切换  分别能显示两者对应的内容 但是在做过程中,出现省厅界面有市州的内容… 找了半天,发现是css的问题   layui-show的多添加 算是把首页内容的任务解决了至于c ...

  7. requests--发送请求

    前戏 使用python做接口自动化,必须用到requests这个库,功能非常的强大,能满足我们大部分的需求. 官网:https://2.python-requests.org//zh_CN/lates ...

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

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

  9. alarm()函数的使用总结

    alarm()函数说明 1.引用头文件:#include <unistd.h>; 2.函数标准式:unsigned int alarm(unsigned int seconds); 3.功 ...

  10. C语言实现五子棋

    可以称得上史上最简单的五子棋版本了. 可以使用curses库来改进页面和下棋方式. 并且对于输入的坐标没有进行鉴别,如果输入的坐标超过棋盘大小,就会段错误退出. 我改进了一点,但是还是没有完全避免这个 ...