Middlebury是每个研究立体匹配算法的人不可能不使用的网站,Middlebury提供了许多标准的测试库,这极大地推进了立体匹配算法的进展。Middlebury提供的标准库,其计算出的视差保存在后缀名为.pfm的文件中,Middlebury本身也提供了读取.pfm文件中C++源码和Matlab源码。尽管如此,将源码写成与OpenCV结合的形式是我们更期望的,以下我写的读写.pfm文件的源码。相对于Middlebury给定的源码,更简洁易懂。

#include "CCC/COMCV.h"
#include <fstream>

void writPFM(Mat_<float> &disp, float &scale, string path)
{
    ofstream out(path, ios_base::binary);

    out << "Pf" << endl << disp.cols << " " << disp.rows << endl << scale << endl;
    ; i >= ; i--)//因为存储是从最后行开始存储的
        ; j < disp.cols; j++)
            out.write((const char*)(&disp(i, j)), sizeof(float));

    out.close();
}
void readPFM(Mat_<float> &disp, float &scale, string path)
{
    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 calcXYZ(Mat_<float> &disp, float f, float cx, float cy, float doffs, float baseline, Mat_<Vec3f> xyz)
{
    ; i < disp.rows; i++)
        ; j < disp.cols; j++)
        {
            float x = baseline*(j - cx) / (disp(i, j) + doffs);
            float y = baseline*(i - cy) / (disp(i, j) + doffs);
            float z = baseline*f / (disp(i, j) + doffs);
            xyz(i, j) = Vec3f(x, y, z);
        }
}
void writPLY(Mat_<Vec3f> &xyz, Mat_<Vec3b> &img,string path)
{
    ofstream out(path);
    out << "ply";
    out << endl << "format ascii 1.0";
    out << endl << "element vertex " << xyz.total();
    out << endl << "property float32 x";
    out << endl << "property float32 y";
    out << endl << "property float32 z";    out << endl << "property uchar red";     out << endl << "property uchar green";     out << endl << "property uchar blue";
    out << endl << "end_header";

    ; i < xyz.rows; i++)
        ; j < xyz.cols; j++)
            ] << ] << ] << " " << (int)img(i, j)[2] << " " << (int)img(i, j)[1] << " " << (int)img(i,j)[0];
    out.close();
}

void PFM2XML(string pfmpath, string xmlpath)
{
    Mat_<float> pfm;
    float scale;
    readPFM(pfm, scale, pfmpath);
    saveXML(xmlpath, pfm);
    writPFM(pfm, scale, pfmpath + "_verify.pfm");
}
void PFM2PLY(string pfmpath, string calibpath, string imgpath, string plypath)
{
    Mat_<float> pfm;
    float scale;
    readPFM(pfm, scale, pfmpath);

    ifstream in(calibpath);
    string cxstr, cystr, fstr, doffsstr, baselinestr, tmp;
    in >> fstr >> tmp >> cxstr >> tmp >> tmp >> cystr >> tmp >> tmp >> tmp;
    in >> tmp >> tmp >> tmp >> tmp >> tmp >> tmp >> tmp >> tmp >> tmp;
    in >> doffsstr >> baselinestr;
    in.close();

    //cout << endl << fstr << endl << cxstr << endl << cystr << endl << doffsstr << endl << baselinestr;
    ).c_str());
    , cxstr.length() - ).c_str());
    , cystr.length() - ).c_str());
    ).c_str());
    ).c_str());
    //cout << endl << f << endl << cx << endl << cy << endl << doffs << endl << baseline;getchar();

    Mat_<Vec3f> xyz(pfm.rows, pfm.cols);
    calcXYZ(pfm, f, cx, cy, doffs, baseline, xyz);    Mat_<Vec3b> img = imread(imgpath,1);
    writPLY(xyz, img, plypath);
}

void PFM2XM2LPLY_DIR()
{
    string dir = "./../TestData";
    vector<string> dirs = cv_GetListFolders(dir);
    ; k < dirs.size(); k++)
    {
        string pfmpath = dirs[k] + "/disp0GT.pfm";
        string xmlpath = dirs[k] + "/disp0GT.xml";
        string calibpath = dirs[k] + "/calib.txt";        string imgpath = dirs[k] + "/im0.png";
        string plypath = dirs[k] + "/0xyz.ply";
        PFM2XML(pfmpath, xmlpath);
        PFM2PLY(pfmpath, calibpath, imgpath, plypath);
    }
}

立体匹配:关于OpenCV读写middlebury网站的给定的视差并恢复三维场景的代码的更多相关文章

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

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

  2. OpenCV读写视频文件解析(二)

    OpenCV读写视频文件解析(二) VideoCapture::set 设置视频捕获中的属性. C++:bool VideoCapture::set(int propId, double value) ...

  3. OpenCV读写图像文件解析

    OpenCV读写图像文件解析 imdecode 从内存中的缓冲区读取图像. C++:Mat imdecode(InputArray buf, int flags) C++:Mat imdecode(I ...

  4. OpenCV读写视频文件解析

    OpenCV读写视频文件解析 一.视频读写类 视频处理的是运动图像,而不是静止图像.视频资源可以是一个专用摄像机.网络摄像头.视频文件或图像文件序列. 在 OpenCV 中,VideoCapture ...

  5. 如何在一个网站或者一个页面,去书写你的JS代码

    // JavaScript Document //如何在一个网站或者一个页面,去书写你的JS代码: //1.js的分层(功能) : jquery(tools) 组件(ui) 应用(app), mvc( ...

  6. 立体匹配:关于用OpenCV彩色化middlebury网站给定的视差

    #include "XYZ.h" void readPFM(Mat_<float> &disp, float &scale, string path) ...

  7. 立体匹配:关于理解middlebury提供的立体匹配代码后的精减

    Middlebury立体匹配源码总结 优化方法 图像可否预处理 代价计算可否采用BT方式 可选代价计算方法 可否代价聚合 可否MinFilter优化原始代价 WTA-Box 可以 可以 AD/SD 可 ...

  8. Python文件读写及网站显示

    一.关于文件读写的笔记 (一) 文件概述 文件是一个存储在辅助存储器上的数据序列,可以包含任何数据内容 文件都是按照2进制进行存储的,但在表现形式上有2种:文本文件和二进制文件. 1. 文本文件 文本 ...

  9. 【VS开发】【计算机视觉】OpenCV读写xml文件《C版本》

    一些简单的XML读写操作,记之于笔记以备忘 主要功能: 1. 创建XML 2. 向XML中存储或者是读取Int float型基本数据 3. 通过创建XML元素,存取复杂的结构如:结构体.矩阵 代码如下 ...

随机推荐

  1. 1134 铺地毯【2011年NOIP全国联赛提高组】

    http://codevs.cn/problem/1134/ 题目描述 Description 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地 ...

  2. 【转】图解CSS的padding,margin,border属性(详细介绍及举例说明)

    W3C组织建议把所有网页上的对像都放在一个盒(box)中,设计师可以通过创建定义来控制这个盒的属性,这些对像包括段落.列表.标题.图片以及层.盒模型主要定义四个区域:内容(content).边框距(p ...

  3. Oboe 提升web 用户体验以及性能

    Oboe  地址:http://oboejs.com/ 1.安装  bower bower  install oboe 2.使用,ajax 模式 oboe('/myapp/things.json') ...

  4. Oracle translate 函数的用法, 以及和replace的区别

     translate 是用来替换字符的函数 语法:  translate(char, from_str,to_str)   其中,char是待处理的字符串. from_str是按顺序排列若干个要被替换 ...

  5. 共享锁【S锁】 排他锁【X锁】

    排它锁又称为写锁((eXclusive lock,简记为X锁)),若事务T对数据对象A加上X锁,则只允许T读取和修改A,其它任何事务都不能再对A加任何类型的锁,直到T释放A上的锁.它防止任何其它事务获 ...

  6. 读取Config文件工具类 PropertiesConfig.java

    package com.util; import java.io.BufferedInputStream; import java.io.FileInputStream; import java.io ...

  7. [extjs] ExtJS4 treepanel 子节点选中父节点自动选中,选中父节点 子节点自动全部选中

    ExtJS4 treepanel 主要添加viewConfig重的代码: xtype:'treepanel', store: menuStore, id:'menuTreePanel', viewCo ...

  8. 【linux】man和--help

    man和--help都是获取命令帮助的指令. man 格式: man [命令] [root@andon tmp]# man pwd --help 命令 --help [root@andon tmp]# ...

  9. css3 文字闪动效果

    <div id="container"> 这里查看“<span class="blink">闪烁效果</span>”,ENj ...

  10. 样本方差:为嘛分母是n-1

    在样本方差计算式中,我们使用Xbar代替随机变量均值μ. 容易证明(参考随便一本会讲述样本方差的教材),只要Xbar不等于μ,sigma(Xi-Xbar)2必定小于sigma(Xi-μ)2. 然而,要 ...