#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网站给定的视差的更多相关文章

  1. 光流算法:关于OpenCV读写middlebury网站给定的光流的代码

    Middlebury是每个研究光流算法的人不可能不使用的网站,Middlebury提供了许多标准的测试库,这极大地推进了光流算法的进展.Middlebury提供的标准库,其计算出的光流保存在后缀名为. ...

  2. 立体匹配:关于OpenCV读写middlebury网站的给定的视差并恢复三维场景的代码

    Middlebury是每个研究立体匹配算法的人不可能不使用的网站,Middlebury提供了许多标准的测试库,这极大地推进了立体匹配算法的进展.Middlebury提供的标准库,其计算出的视差保存在后 ...

  3. opencv 彩色图像分割(inrange)

    灰度图像大多通过算子寻找边缘和区域生长融合来分割图像. 彩色图像增加了色彩信息,可以通过不同的色彩值来分割图像,常用彩色空间HSV/HSI, RGB, LAB等都可以用于分割! 笔者主要介绍inran ...

  4. OpenCV定制化创建角点检测子

    定制化创建角点检测子 目标 在这个教程中我们将涉及: 使用 OpenCV 函数 cornerEigenValsAndVecs 来计算像素对应的本征值和本征向量来确定其是否是角点. 使用OpenCV 函 ...

  5. OpenCV阈值化处理

    图像的阈值化就是利用图像像素点分布规律,设定阈值进行像素点分割,进而得到图像的二值图像.图像阈值化操作有多种方法,常用方法有经典的OTSU.固定阈值.自适应阈值.双阈值及半阈值化操作.这里对各种阈值化 ...

  6. OpenCV灰度化图像

    OpenCV2版本号非常多函数发生了变化.比如二值化,其演示样例: void CmyMFC2Dlg::OnBnClickedButton1() { // TODO: Add your control ...

  7. opencv 彩色图像亮度、对比度调节 直方图均衡化

    直接上代码: #include <Windows.h> #include <iostream>// for stand I/O #include <string> ...

  8. Jenkins(9)- 汉化 Jenkins 网站

    如果想从头学起Jenkins的话,可以看看这一系列的文章哦 https://www.cnblogs.com/poloyy/category/1645399.html 下载插件 安装这两个插件,然后重启 ...

  9. OpenCV——阈值化

    上述五种结合CV_THRESH_OTSU(自适应阈值),写成:THRESH_BINARY | CV_THRESH_OTSU

随机推荐

  1. 编程技术●Python

    <Python语言入门> 2015-01-16 14:13 ★ 虽然书名叫入门.序里也写了说完全没有编程经验的都可以用这本书来学习入门.不过好像不太适合哦.书很好,内容也挺全面细致的.太好 ...

  2. jsonp 实现sso

    这几天用jsop实现了公司的sso. 这里面最重要的是对cookie的理解. cookie 就是一个网站存于本地的数据,zai下次请求同一个网站时,发送给服务器,服务器端可以进行AUD操作,这种操作后 ...

  3. Ubuntu中查看32还是64

    安装ubuntu在pc上,不推荐在32位pc安装64位操作系统,64位pc安装32位操作系统 方法/步骤   1 按ctrl+shift+t 快捷键,打开终端,输入sudo uname --m ,按下 ...

  4. cocos2dx 3.8版关于#include "GB2ShapeCache-x.h"

    关于coco2d-x 3.8版的PhysicsEditor.exe1.09版的GB2ShapeCache-x.h.cpp中有些方法更新了和容器的使用方法,还有就是头文件include "CC ...

  5. SSD固态硬盘使用注意事项

    SSD固态硬盘的结构和运行方式不同于传统硬盘,在购买以后强烈建议进行一些设置以达到最优的运行效能,延长SSD的使用寿命.以下第一部分是一些可以在网上找到的关于SSD硬盘相关的注意事项,已经介绍很多,这 ...

  6. Unity3D 发布无边框exe

    关于:Unity3D 发布无边框exe,Unity3D Build exe无边框 Unity发布windows版本 总是带着边框,很想给它去掉,笔者在网上查了一番,常见的有3中. 1:通过unity3 ...

  7. JS运动基础(三) 弹性运动

    加减速运动速度不断增加或减少速度减小到负值,会向反方向运动 弹性运动在目标点左边,加速:在目标点右边,减速根据距离,计算加速度 带摩擦力的弹性运动弹性运动+摩擦力 弹性:速度 += (目标点 - 当前 ...

  8. JDK各版本新特性!

    1.JDK1.5 新特性 1.自动装箱与拆箱:自动装箱的过程:每当需要一种类型的对象时,这种基本类型就自动地封装到与它相同类型的包装中.自动拆箱的过程:每当需要一个值时,被装箱对象中的值就被自动地提取 ...

  9. dedecms搜索框制作

    <form method=" name="kwtype"> <table width="> <tr> <td widt ...

  10. 《C与指针》第十章练习

    本章问题 1.成员和数组元素有什么区别? answer:Structure members can be all different types;they are accessed by name;a ...