Skip to main content

stereo_msgs.flex

// ROS is available under the BSD license Copyright (C) 2009, Willow Garage, Inc.  
// Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 
//   - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 
//   - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 
//   - Neither the names of Willow Garage, Inc. nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. 
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 
// BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 
// GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
module ROS::Common::v1.stereo_msgs

import ROS::Common::v1.std_msgs (Header)
import ROS::Common::v1.sensor_msgs (Image, RegionOfInterest)


// Separate header for compatibility with current TimeSynchronizer. Likely to be removed in a later release,
// use image.header instead.
message struct DisparityImage {
    header: Header;
    // Floating point disparity image. The disparities are pre-adjusted for any x-offset between the principal
    // points of the two cameras (in the case that they are verged). That is: d = x_l - x_r - (cx_l - cx_r)
    image: Image;
    // Stereo geometry. For disparity d, the depth from the camera is Z = fT/d.
    f: float32;
    // Baseline, world units
    T: float32;
    // Subwindow of (potentially) valid disparity values.
    valid_window: RegionOfInterest;
    // The range of disparities searched. In the disparity image, any disparity less than min_disparity is invalid.
    // The disparity search range defines the horopter, or 3D volume that the stereo algorithm can "see". Points
    // with Z outside of: Z_min = fT / max_disparity Z_max = fT / min_disparity could not be found.
    min_disparity: float32;
    max_disparity: float32;
    // Smallest allowed disparity increment. The smallest achievable depth range resolution is delta_Z = (Z^2/fT)*delta_d.
    delta_d: float32;
}