Commit 7c0a4788 authored by Vladislav Samsonov's avatar Vladislav Samsonov

Preserve edges

parent 1417dc65
...@@ -41,9 +41,7 @@ ...@@ -41,9 +41,7 @@
//M*/ //M*/
#include "precomp.hpp" #include "precomp.hpp"
//#include <iostream> #include "opencv2/ximgproc/edge_filter.hpp"
// using std::cout;
// using std::endl;
namespace cv namespace cv
{ {
...@@ -325,6 +323,8 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl ...@@ -325,6 +323,8 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl
CV_Assert( from.channels() == 1 ); CV_Assert( from.channels() == 1 );
CV_Assert( to.channels() == 1 ); CV_Assert( to.channels() == 1 );
const Mat fromOrig = from.clone();
applyCLAHE( from ); applyCLAHE( from );
applyCLAHE( to ); applyCLAHE( to );
...@@ -332,13 +332,8 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl ...@@ -332,13 +332,8 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl
findSparseFeatures( from, to, features, predictedFeatures ); findSparseFeatures( from, to, features, predictedFeatures );
removeOcclusions( from, to, features, predictedFeatures ); removeOcclusions( from, to, features, predictedFeatures );
// from.convertTo( from, CV_32F );
// to.convertTo( to, CV_32F );
flowOut.create( size, CV_32FC2 ); flowOut.create( size, CV_32FC2 );
Mat flow = flowOut.getMat(); Mat flow = flowOut.getMat();
// for ( size_t i = 0; i < features.size(); ++i )
// flow.at<Point2f>( features[i].y, features[i].x ) = /*Point2f(10,10);*/ predictedFeatures[i] - features[i];
Mat A, b1, b2, w1, w2; Mat A, b1, b2, w1, w2;
getSystem( A, b1, b2, features, predictedFeatures, size ); getSystem( A, b1, b2, features, predictedFeatures, size );
...@@ -346,9 +341,10 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl ...@@ -346,9 +341,10 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl
// solve( A2, b2, w2, DECOMP_CHOLESKY | DECOMP_NORMAL ); // solve( A2, b2, w2, DECOMP_CHOLESKY | DECOMP_NORMAL );
solveLSQR( A, b1, w1, dampingFactor * size.area() ); solveLSQR( A, b1, w1, dampingFactor * size.area() );
solveLSQR( A, b2, w2, dampingFactor * size.area() ); solveLSQR( A, b2, w2, dampingFactor * size.area() );
Mat flowSmall( basisSize * 16, CV_32FC2 ); Mat flowSmall( (size / 8) * 2, CV_32FC2 );
reduceToFlow( w1, w2, flowSmall, basisSize ); reduceToFlow( w1, w2, flowSmall, basisSize );
resize( flowSmall, flow, size, 0, 0, INTER_LINEAR ); resize( flowSmall, flow, size, 0, 0, INTER_LINEAR );
ximgproc::fastGlobalSmootherFilter(fromOrig, flow, flow, 500, 2);
} }
void OpticalFlowPCAFlow::collectGarbage() {} void OpticalFlowPCAFlow::collectGarbage() {}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment