Skip to content
Snippets Groups Projects
Select Git revision
  • 261d20bf5ed58617c17e09eac22cb96608c870f4
  • master default protected
  • development
  • marco/aquacrop-fix-api-use
  • precompile-statements
  • precompile-tools
  • tmp-faster-loading
  • skylark
  • testsuite
  • code-review
  • v0.7.0
  • v0.6.1
  • v0.6.0
  • v0.5.5
  • v0.5.4
  • v0.5.3
  • v0.5.2
  • v0.2
  • v0.3.0
  • v0.4.1
  • v0.5
21 results

gis.html

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    np_opencv_converter.h 3.29 KiB
    /*
    This file is part of BGSLibrary.
    
    BGSLibrary is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.
    
    BGSLibrary is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
    
    You should have received a copy of the GNU General Public License
    along with BGSLibrary.  If not, see <http://www.gnu.org/licenses/>.
    */
    #pragma once
    
    #define BOOST_PYTHON_STATIC_LIB
    #include <boost/python.hpp>
    #include <boost/python/suite/indexing/vector_indexing_suite.hpp>
    
    #include "utils/template.h"
    #include "utils/container.h"
    #include "utils/conversion.h"
    
    #include <opencv2/opencv.hpp>
    
    namespace fs { namespace python {
    
    // TODO: Template these
    // Vec3f => cv::Mat
    struct Vec3f_to_mat {
      static PyObject* convert(const cv::Vec3f& v){
        NDArrayConverter cvt;
        PyObject* ret = cvt.toNDArray(cv::Mat(v));
        return ret;
      }
    };
    
    // cv::Point => cv::Mat
    struct Point_to_mat {
      static PyObject* convert(const cv::Point& v){
        NDArrayConverter cvt;
        PyObject* ret = cvt.toNDArray(cv::Mat(v));
        return ret;
      }
    };
    
    // cv::Point2f => cv::Mat
    struct Point2f_to_mat {
      static PyObject* convert(const cv::Point2f& v){
        NDArrayConverter cvt;
        PyObject* ret = cvt.toNDArray(cv::Mat(v));
        return ret;
      }
    };
    
    // cv::Point3f => cv::Mat
    struct Point3f_to_mat {
      static PyObject* convert(const cv::Point3f& v){
        NDArrayConverter cvt;
        PyObject* ret = cvt.toNDArray(cv::Mat(v));
        return ret;
      }
    };
    
    // cv::Mat_<T> => Numpy PyObject
    template <typename T>
    struct Mat_to_PyObject {
      static PyObject* convert(const T& mat){
        NDArrayConverter cvt;
        PyObject* ret = cvt.toNDArray(mat);
        return ret;
      }
    };
    
    // Generic templated cv::Mat <=> Numpy PyObject converter
    template <typename T>
    struct Mat_PyObject_converter
    {
      // Register from converter
      Mat_PyObject_converter() {
        boost::python::converter::registry::push_back(
            &convertible,
            &construct,
            boost::python::type_id<T>());
    
        // Register to converter
        py::to_python_converter<T, Mat_to_PyObject<T> >();
      }
    
      // Convert from type T to PyObject (numpy array)
      // Assume obj_ptr can be converted in a cv::Mat
      static void* convertible(PyObject* obj_ptr)
      {
        // Check validity? 
        assert(obj_ptr != 0); 
        return obj_ptr;
      }
    
      // Convert obj_ptr into a cv::Mat
      static void construct(PyObject* obj_ptr,
                            boost::python::converter::rvalue_from_python_stage1_data* data)
      {
        using namespace boost::python;
        typedef converter::rvalue_from_python_storage< T > storage_t;
    
        // Object is a borrowed reference, so create a handle indicating it is
        // borrowed for proper reference counting.
        boost::python::handle<> handle(boost::python::borrowed(obj_ptr));
    
        storage_t* the_storage = reinterpret_cast<storage_t*>( data );
        void* memory_chunk = the_storage->storage.bytes;
    
        NDArrayConverter cvt;
        T* newvec = new (memory_chunk) T(cvt.toMat(obj_ptr));
        data->convertible = memory_chunk;
    
        return;
      }
    };
    
    bool init_and_export_converters();
    
    } // namespace python
    } // namespace fs