立体匹配:关于用OpenCV彩色化middlebury网站给定的视差
#include "XYZ.h"
void readPFM(Mat_<float> &disp, float &scale, string path)
{ //关于将Mat见我的另外一篇博客:
ifstream in(path, ios_base::binary);
int cols;
int rows;
];
, '\n'); in.get();//文件头
, ' '); in.get(); cols = atoi(tmp);//列数
, '\n'); in.get(); rows = atoi(tmp); //行数
, '\n'); in.get(); scale = atof(tmp);//缩放因子
disp.create(rows, cols);
; i >= ; i--)//因为存储是从最后行开始存储的
; j < disp.cols; j++)
in.read((char*)(&disp(i, j)), sizeof(float));
in.close();
}
void dyeDisp_core(Mat_<Vec3b> &colordisp, Mat_<float> &disp, float mindisp, float maxdisp)
{
float scale = 1.0 / (maxdisp - mindisp);
; i < disp.rows; i++)
; j < disp.cols; j++)
{
Vec3b *xxx = &colordisp(i, j);
float x = disp(i, j);
if ((x != INFINITY) && (x != -INFINITY))
{
x = scale * (x - mindisp);
x = x / 1.15 + 0.1; // use slightly asymmetric range to avoid darkest shades of blue.
(*xxx)[] = __max(, __min(, ( * ( * fabs(x - .))))));
(*xxx)[] = __max(, __min(, ( * ( * fabs(x - .))))));
(*xxx)[] = __max(, __min(, ( * ( * fabs(x - .))))));
}
else
(*xxx) = Vec3b(, , );
}
}
void dyeDisp_one(string dir)
{
string calibpath = dir + "/calib.txt";
string disppath = dir + "/disp0GT.pfm";
string colordisppath = dir + "/disp0GT.png";
//1.读取极值视差
;
;
];
float f;
FILE *fp = fopen(calibpath.c_str(), "r");
while (fgets(line, sizeof line, fp) != NULL)
{
) dmin = f;
) dmax = f;
}
fclose(fp);
//2.读取视差图像
float scale;
Mat_<float> disp;
readPFM(disp, scale, disppath);
//FileStorage fs(disppath, FileStorage::READ);
//fs["mat"] >> disp;
//3.计算彩色视差
Mat_<Vec3b> colordisp(disp.rows, disp.cols);
dyeDisp_core(colordisp, disp, dmin, dmax);
//4.保存结果
imwrite(colordisppath, colordisp);
}
void dyeDisp_dir()
{
vector<string> dirs = cv_GetListFolders("./../TestData");
; i < dirs.size(); i++)
dyeDisp_one(dirs[i]);
}
void main()
{
dyeDisp_dir();
}
立体匹配:关于用OpenCV彩色化middlebury网站给定的视差的更多相关文章
- 光流算法:关于OpenCV读写middlebury网站给定的光流的代码
Middlebury是每个研究光流算法的人不可能不使用的网站,Middlebury提供了许多标准的测试库,这极大地推进了光流算法的进展.Middlebury提供的标准库,其计算出的光流保存在后缀名为. ...
- 立体匹配:关于OpenCV读写middlebury网站的给定的视差并恢复三维场景的代码
Middlebury是每个研究立体匹配算法的人不可能不使用的网站,Middlebury提供了许多标准的测试库,这极大地推进了立体匹配算法的进展.Middlebury提供的标准库,其计算出的视差保存在后 ...
- opencv 彩色图像分割(inrange)
灰度图像大多通过算子寻找边缘和区域生长融合来分割图像. 彩色图像增加了色彩信息,可以通过不同的色彩值来分割图像,常用彩色空间HSV/HSI, RGB, LAB等都可以用于分割! 笔者主要介绍inran ...
- OpenCV定制化创建角点检测子
定制化创建角点检测子 目标 在这个教程中我们将涉及: 使用 OpenCV 函数 cornerEigenValsAndVecs 来计算像素对应的本征值和本征向量来确定其是否是角点. 使用OpenCV 函 ...
- OpenCV阈值化处理
图像的阈值化就是利用图像像素点分布规律,设定阈值进行像素点分割,进而得到图像的二值图像.图像阈值化操作有多种方法,常用方法有经典的OTSU.固定阈值.自适应阈值.双阈值及半阈值化操作.这里对各种阈值化 ...
- OpenCV灰度化图像
OpenCV2版本号非常多函数发生了变化.比如二值化,其演示样例: void CmyMFC2Dlg::OnBnClickedButton1() { // TODO: Add your control ...
- opencv 彩色图像亮度、对比度调节 直方图均衡化
直接上代码: #include <Windows.h> #include <iostream>// for stand I/O #include <string> ...
- Jenkins(9)- 汉化 Jenkins 网站
如果想从头学起Jenkins的话,可以看看这一系列的文章哦 https://www.cnblogs.com/poloyy/category/1645399.html 下载插件 安装这两个插件,然后重启 ...
- OpenCV——阈值化
上述五种结合CV_THRESH_OTSU(自适应阈值),写成:THRESH_BINARY | CV_THRESH_OTSU
随机推荐
- require.js的使用
RequireJS是一个非常小巧的JavaScript模块载入框架,是AMD规范最好的实现者之一.最新版本的RequireJS压缩后只有14K,堪称非常轻量.它还同时可以和其他的框架协同工作,使用Re ...
- 关于PDF文件无法打印的问题的解决办法
在这里用到一个软件 PDFSpliter可以直接在网上下载.下载安装完之后 1:打开软件 2,点击 PDF合并 按钮 3,找到无法打印的文件 4,单击开始,文件另存为 5,另存为后的文件就可以打 ...
- 在服务器端将XML转换成HTML
以下是在服务器上转换XML文件所需要的简单源代码: <% 'Load the XML set xml = Server.CreateObject("Microsoft.XMLDOM&q ...
- jetty和tomcat启动项目
首先jetty和tomcat区别,不全面说,只说我理解的.jetty架构比tomcat更为简单.jetty是基于Handler来实现的,易于拓展,因此更适合于同时处理且长时间保持连接:tomcat的架 ...
- Android webservice的用法详细讲解
Android webservice的用法详细讲解 看到有很多朋友对WebService还不是很了解,在此就详细的讲讲WebService,争取说得明白吧.此文章采用的项目是我毕业设计的webserv ...
- oracle查看当前用户权限
查看用户和默认表空间的关系select username,default_tablespace from dba_users;--查看当前用户能访问的表select * from user_table ...
- Ubuntu中安装eclipse ,双击eclipse出现invalid configuration location问题
ubuntu invalid configuration location 标签: myeclipse for ubuntu ubuntu myeclipse ubuntu安装myecli ...
- exec函数族,守护进程,线程同步和互斥
2015.3.2 进程和程序有三点不同:1,存在位置不同,程序:硬盘,磁盘.进程:内存2. 程序是静态的,进程是动态的 执行./a.out -->bash->bash程序调用fork()- ...
- 标准IO的简单应用,动静态库,读取系统时间并打印,模拟ls -l功能
2015.2.27星期五,小雨 标准IO实现的复制功能: #include <stdio.h>#include <errno.h> #define N 64 int main( ...
- HDU 5358 尺取法+枚举
题意:给一个数列,按如下公式求和. 分析:场上做的时候,傻傻以为是线段树,也没想出题者为啥出log2,就是S(i,j) 的二进制表示的位数.只能说我做题依旧太死板,让求和就按规矩求和,多考虑一下就能发 ...