uc伯克利人工分割图像.seg文件解析
之前看到
http://www.eecs.berkeley.edu/Research/Projects/CS/vision/grouping/segbench/
提供的人工图像分割的.seg格式的文件,他们提供了linux系统下面的matlab代码,什么的,但是我们要在windows平台下面用就比较麻烦,就心血来潮写一个试试,还请大牛们指点一二啊,嘿嘿嘿
下面是SegHuman.h
/*
// # Reload me!
//
// SEGMENTATION FILE FORMAT
// David Martin
// 8/2/2001
//
// This document describes the segmentation file format. Segmentation
// files end in ".seg".
//
// The overall structure of the file is as follows:
//
// <header>
// data
// <data>
//
// The first part of the file is the header. The header is ascii text,
// and can contain comments. The comment character is '#'. The header
// is separated from the data with a line containing the literal text
// "data".
//
// The header can contain the following information, in any order:
//
// format {*ascii|binary} {*cr|map}
// date <date string>
// image <int> # image ID number
// user <int> # user ID number
// width <int> # width of image
// height <int> # height of image
// segments <int> # number of segments
// gray {*0|1} # image presented in grayscale?
// invert {*0|1} # image presented with pixel values inverted?
// flipflop {*0|1} # image presented upside-down and backwards?
//
// The {width,height,segments} lines are required. All others lines are
// optional. Default values are marked with a '*'.
//
// The format line describes the format of the data section of the file.
// The default and recommended format is 'ascii cr' (cr = compressed
// row). This document does not describe the other formats, as they are
// probably superfluous.
//
// The 'ascii cr' format is designed to be very easy to parse; it is not
// optimized for space. Use gzip if you want smaller files! Each line
// in the data section contains 4 integers:
//
// <s> <r> <c1> <c2>
//
// All values start counting at 0. <s> is the segment number; <r> is the
// row; <c1> and <c2> are column numbers. The line means that columns
// [<c1>..<c2>] of row <r> belong to segment <s>. Lines of this sort can
// appear in any order, and can be reordered without harm. The only
// restriction is that each pixel must be named exactly once.
//
// END
//
//
*/ #ifndef SEG_HUMAN
#define SEG_HUMAN #include "stdafx.h"
#include "stdio.h"
#include <map>
#include <vector>
#include <queue>
#include <set>
#include <string>
#include <list> #include <iostream>
using namespace std; struct SEG
{
int segment_number;
int row;
int column_number1;
int column_number2;
}; class SegHuman
{
public:
SegHuman(const char* path);
bool LoadSEG(const char* path); private:
string name;
int image_index;
int segments_index;
int height;
int width;
int gray;
vector<SEG> MySeg;
}; #endif // SEGHMAN
下面是:SegHuman.cpp
#include "stdafx.h"
#include "SegHuman.h" #include <iostream>
using namespace std; SegHuman::SegHuman(const char* path)
{
LoadSEG(path);
} bool SegHuman::LoadSEG(const char* path)
{
int st = 0;
FILE* pfile = fopen(path, "r");
if (pfile)
{
fseek(pfile,0,SEEK_END);
int dwsize = ftell(pfile);
rewind(pfile); char* filebuffer = new char[dwsize];
fread(filebuffer, 1, dwsize, pfile); char* pBegin = filebuffer;
char* pEnd = strchr(filebuffer, '\n');
int uiIndex = 1; int st = 0; while (pEnd != NULL)
{ std::string strbuff;
strbuff.insert(0, pBegin, pEnd-pBegin);
if (strbuff.empty())
{
return false;
} if (st==0)
{
if (1 == sscanf(strbuff.c_str(),"image %d",&image_index)) st=1;
}
else if (st==1)
{
if (1 == sscanf(strbuff.c_str(),"width %d",&width)) st=2;
}
else if (st==2)
{
if (1 == sscanf(strbuff.c_str(),"height %d",&height)) st=3;
}
else if (st==3)
{
if (1 == sscanf(strbuff.c_str(),"segments %d",&segments_index)) st=4;
}
else if (st==4)
{
if (1 == sscanf(strbuff.c_str(),"gray %d",&gray)) st=5;
}
else if (st==5)
{
if (0==strcmp(strbuff.c_str(),"data")) st=6;
}
else if (st==6)
{
SEG temp = { -1, -1, -1, -1};
if (4 == sscanf(strbuff.c_str(),"%d %d %d %d",&temp.segment_number, &temp.row, &temp.column_number1 , &temp.column_number2))
{
++uiIndex;
MySeg.push_back(temp); }
} pBegin = pEnd + 1;
pEnd = strchr(pEnd + 1, '\n'); }
delete[] filebuffer;
fclose(pfile); vector<SEG>::iterator iter = MySeg.begin();
for (;iter !=MySeg.end(); ++iter)
{
cout<<iter->segment_number<<' ';
cout<<iter->row<<' ';
cout<<iter->column_number1 <<' ';
cout<<iter->column_number2<<' ';
cout<<endl; }
getchar(); return true;
} return false;
}
下面的任务就是修改代码,把它用在OpenCV中,来显示人工分割的图像啦!
uc伯克利人工分割图像.seg文件解析的更多相关文章
- 图片像素对比OpenCV实现,实现人工分割跟算法分割图像结果的对比
图片对比,计算不同像素个数,已经比率.实现人工分割跟算法分割图像结果的对比,但是只能用灰度图像作为输入 // imageMaskComparison.cpp : 定义控制台应用程序的入口点. // / ...
- 细粒度语义分割:ICCV2019论文解析
细粒度语义分割:ICCV2019论文解析 Fine-Grained Segmentation Networks: Self-Supervised Segmentation for Improved L ...
- 全景分割:CVPR2019论文解析
全景分割:CVPR2019论文解析 Panoptic Segmentation 论文链接: http://openaccess.thecvf.com/content_CVPR_2019/papers/ ...
- (转)AVI文件格式解析+AVI文件解析工具
AVI文件解析工具下载地址:http://download.csdn.net/detail/zjq634359531/7556659 AVI(Audio Video Interleaved的缩写)是一 ...
- Dicom格式文件解析器[转]
Dicom格式文件解析器 Dicom全称是医学数字图像与通讯,这里讲的暂不涉及通讯那方面的问题 只讲*.dcm 也就是diocm格式文件的读取,读取本身是没啥难度的 无非就是字节码数据流处理.只不 ...
- Android中measure过程、WRAP_CONTENT详解以及 xml布局文件解析流程浅析
转自:http://www.uml.org.cn/mobiledev/201211221.asp 今天,我着重讲解下如下三个内容: measure过程 WRAP_CONTENT.MATCH_PAREN ...
- kitti数据集标定文件解析
1.kitti数据采集平台 KITTI数据集的数据采集平台装配有2个灰度摄像机,2个彩色摄像机,一个Velodyne64线3D激光雷达,4个光学镜头,以及1个GPS导航系统.图示为传感器的配置平面图, ...
- NIPS 2018 | 程序翻译新突破:UC伯克利提出树到树的程序翻译神经网络
NIPS 2018 | 程序翻译新突破:UC伯克利提出树到树的程序翻译神经网络 机器之心 已认证的官方帐号 49 人赞同了该文章 选自arXiv,作者:Xinyun Chen.Chang Liu. ...
- 转载:AAC文件解析及解码
转自:http://blog.csdn.net/wlsfling/article/details/5876016 http://www.cnblogs.com/gaozehua/archive/201 ...
随机推荐
- PyCharm 开发Django ,错误汇总
近期略微接触了一下Django.在学习的过程中可谓是坎坎坷坷,遇到了很多的问题. 下面就来谈一谈我对Django的一点点的见解. Django项目的创建 使用PyCharm来开发Django项目是非常 ...
- XML命名规则
XML = Extensible Markup Language,可扩展标记语言 XML 标签对大小写敏感,XML 标签对大小写敏感.在XML 中,标签 <Letter> 与标签 < ...
- Spark技术内幕之任务调度:从SparkContext开始
SparkContext是开发Spark应用的入口,它负责和整个集群的交互,包括创建RDD,accumulators and broadcast variables.理解Spark的架构,需要从这个入 ...
- 应付模块的R12 TRACE 和 FND Debug 文件 / FND 日志 调试
取得R12 TRACE: 1. 导航职责: 系统管理员> 配置文件> 系统> 查找 用户: 用户提交报表 配置: 初始化 SQL 语句 - 自定义 2. 点击用户栏位-编辑区域 ...
- octave installation on RHEL6.4
octave installation on RHEL6.4 rhel6.4上安装octave GNU Octave 是一种高级语言,主要设计用来进行数值计算,它是 MathWorks 出品的 Mat ...
- AndroidStudio如何快速制作.so
之前写过一篇Eclipse制作.so的文章,http://blog.csdn.net/baiyuliang2013/article/details/44306921使用的是GNUstep模拟Linux ...
- java设计模式---访问者模式
Java深入到一定程度,就不可避免的碰到设计模式这一概念,了解设计模式,将使自 己对java中的接口或抽象类应用有更深的理解.设计模式在java的中型系统中应用广 泛,遵循一定的编程模式,才能使自 ...
- Dubbo粗浅记录
这篇博客只是我自己的学习记录,对各位高手怕是没有什么太大的帮助,望高手不吝赐教. 项目的截图如下: 我们使用的主要就是红框里面的. 这里我主要分析两个xml /DubboTest/src/main/r ...
- Android官方命令深入分析之etc1tool
etc1tool是一个命令行工具,可以将PNG图像压缩为etc1标准,并且可以进行解压缩. 用法: etc1tool infile [--help | --encode | --encodeNoHea ...
- [C++学习历程]基础部分 C++中的函数学习
本文地址:http://blog.csdn.net/sushengmiyan/article/details/20305815 作者:sushengmiyan 一.静态变量: 局部变量是线程到达定义的 ...