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 ...
随机推荐
- iOS开发之Xcode8推出的WKWebView与UIWebView的使用
一.整体介绍 UIWebView自iOS2就有,WKWebView从iOS8才有,毫无疑问WKWebView将逐步取代笨重的UIWebView.通过简单的测试即可发现UIWebView占用过多内存,且 ...
- 关于MT8127中sdk的编译出错问题
今天在看MTK提供的SDK编译文档,按照步骤做,结果出错了,文档如下: 2- Building an SDK for MacOS and Linux ------------------------- ...
- Spark 1.0 开发环境构建:maven/sbt/idea
因为我原来对maven和sbt都不熟悉,因此使用两种方法都编译了一下.下面记录一下编译时候遇到的问题.然后介绍一下如果使用IntelliJ IDEA 13.1构建开发环境. 首先准备java环境和sc ...
- Android的oom详解
Android的oom原因 1.资源对象没关闭造成的内存泄露,try catch finally中将资源回收放到finally语句可以有效避免OOM.资源性对象比如: 1-1,Cursor 1-2,调 ...
- 06_NoSQL数据库之Redis数据库:Redis的高级应用之登录授权和主从复制
Redis高级实用特征 安全性(登录授权和登录后使用auth授权) 设置客户端连接后进行任何其他指定前需要使用的密码. 警告:因为redis速度相当快,所以在一台比较好的服务器下,一个外部的用户 ...
- mxgraph进阶(三)Web绘图——mxGraph项目实战(精华篇)
Web绘图--mxGraph项目实战(精华篇) 声明 本文部分内容所属论文现已发表,请慎重对待. 需求 由于小论文实验需求,需要实现根据用户日志提取出行为序列,然后根据行为序列生成有向图的形式 ...
- 用 Freemarker 生成 word 文档
阅读目录 添加图片 自定义载入模板 1. 用word写一个需要导出的word模板,然后存为xml格式. 2. 将xml中需要动态修改内容的地方,换成freemarker的 ...
- pig函数以及关键字 的一些实例应用的总结(来自pig笔记)
http://wenku.baidu.com/link?url=yb7KnpSj9nHxWk_MsEVUezvB24evRf9wR87FX0dTT77pGXNXi6k3o_kTmAkBrpIHTqo6 ...
- Oracle开发环境搭建
一.软件准备 地址:oracle官网 安装包:因为个人学习用,所以就安装服务器端就可以了,不需要客户端. 一共两个压缩文件,解压时一起解压到到一个文件夹. 本人使用的:win32_11gR2_data ...
- java设计模式---调停者模式
中介者模式(Mediator):用一个中介对象来封装一系列的对象交互.中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 通用类图: 举例:在一个公司里面 ...