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 ...
随机推荐
- maven的UnsupportedClassVersionError
问题描述 我安装了maven3.3.3,配置好了M2_HOME和path环境变量之后,执行mvn -v报错:java.lang.UnsupportedClassVersionError: -. : U ...
- hadoop端口使用配置总结(非常好的总结)
转自http://www.aboutyun.com/thread-7513-1-1.html Hadoop集群的各部分一般都会使用到多个端口,有些是daemon之间进行交互之用,有些是用于RPC访问以 ...
- Android开发学习之路--MAC下Android Studio开发环境搭建
自从毕业开始到现在还没有系统地学习android应用的开发,之前一直都是做些底层的驱动,以及linux上的c开发.虽然写过几个简单的app,也对android4.0.3的源代码做过部分的分析,也算入门 ...
- 01-Git简介和仓库创建
Git简介 Linus的第二个伟大作品.2005年由于BitKeeper软件公司对Linux社区停止了免费使用权.Linus迫不得己自己开发了一个分布式版本控制工具,从而Git诞生了. 目前使用Git ...
- vbox centos安装增强工具
就是虚拟机识别不了宿主机的usb接口,这个虚拟机有没有图形界面,看看怎么装. 一个是依赖包问题,另一个就是挂了安装包,但是我怎么找到它并安装上去的问题. 虚拟机是centos6.6哈 vbox4.3. ...
- iOS中 常用的mac终端指令汇总 技术分享
通常情况下,只有高端用户才会经常用到终端应用.这并不意味着命令行非常难学,有的时候命令行可以轻松.快速的解决问题.相信所有Mac用户都尝试过命令行,今天为大家带来9个非常实用的命令行操作.一些命令行需 ...
- Linux的资源管理器
说是资源管理器,其实就是使用命令来对Linux运行系统的参数的查看.下面就一起看一看怎么像在windows下查看资源管理器吧. 1.查看进程(额,自然是电脑上正在运行的进程咯) ps aux 其中a ...
- 类装载器DexClassLoader (android内核剖析)
在java环境中,有个概念叫做"类装载器",其作用是动态装载Class文件.标准的java SDK中有一个ClassLoader类,借助它可以装载 想要的Class文件,每个Cla ...
- 开放源码的安卓天气应用-android学习之旅(73)
我在github上面发布了简易的天气应用,能够简单显示全国各个省市县市的天气 效果图片如下 源代码我放在github上了.我希望大家可以去下载,修改以后在上传维护,我的代码很简单.算是抛砖引玉,希望大 ...
- Guava 教程(3):Java 的函数式编程,通过 Google Collections 过滤和调用
原文出处: oschina 在本系列博客的第一.二部分,我介绍了非常优秀的Google Collections和Guava包.本篇博客中我们来看看如何使用Google Collections来做到过滤 ...