Commit 1764f924 authored by Vladislav Samsonov's avatar Vladislav Samsonov

Fixed OpenCL check behavior

parent 55f093a4
...@@ -100,6 +100,7 @@ protected: ...@@ -100,6 +100,7 @@ protected:
const float occlusionsThreshold; const float occlusionsThreshold;
const float dampingFactor; const float dampingFactor;
const float claheClip; const float claheClip;
bool useOpenCL;
public: public:
OpticalFlowPCAFlow( Ptr<const PCAPrior> _prior = Ptr<const PCAPrior>(), const Size _basisSize = Size( 18, 14 ), OpticalFlowPCAFlow( Ptr<const PCAPrior> _prior = Ptr<const PCAPrior>(), const Size _basisSize = Size( 18, 14 ),
......
...@@ -283,7 +283,12 @@ int main( int argc, char** argv ) ...@@ -283,7 +283,12 @@ int main( int argc, char** argv )
double startTick, time; double startTick, time;
startTick = (double) getTickCount(); // measure time startTick = (double) getTickCount(); // measure time
if (useGpu)
algorithm->calc(i1, i2, flow.getUMat(ACCESS_RW));
else
algorithm->calc(i1, i2, flow); algorithm->calc(i1, i2, flow);
time = ((double) getTickCount() - startTick) / getTickFrequency(); time = ((double) getTickCount() - startTick) / getTickFrequency();
printf("\nTime [s]: %.3f\n", time); printf("\nTime [s]: %.3f\n", time);
if(display_images) if(display_images)
......
...@@ -321,7 +321,7 @@ void OpticalFlowPCAFlow::getSystem( OutputArray AOut, OutputArray b1Out, OutputA ...@@ -321,7 +321,7 @@ void OpticalFlowPCAFlow::getSystem( OutputArray AOut, OutputArray b1Out, OutputA
AOut.create( features.size(), basisSize.area(), CV_32F ); AOut.create( features.size(), basisSize.area(), CV_32F );
b1Out.create( features.size(), 1, CV_32F ); b1Out.create( features.size(), 1, CV_32F );
b2Out.create( features.size(), 1, CV_32F ); b2Out.create( features.size(), 1, CV_32F );
if ( ocl::useOpenCL() ) if ( useOpenCL )
{ {
UMat A = AOut.getUMat(); UMat A = AOut.getUMat();
Mat b1 = b1Out.getMat(); Mat b1 = b1Out.getMat();
...@@ -369,7 +369,7 @@ void OpticalFlowPCAFlow::getSystem( OutputArray A1Out, OutputArray A2Out, Output ...@@ -369,7 +369,7 @@ void OpticalFlowPCAFlow::getSystem( OutputArray A1Out, OutputArray A2Out, Output
b1Out.create( features.size() + prior->getPadding(), 1, CV_32F ); b1Out.create( features.size() + prior->getPadding(), 1, CV_32F );
b2Out.create( features.size() + prior->getPadding(), 1, CV_32F ); b2Out.create( features.size() + prior->getPadding(), 1, CV_32F );
if ( ocl::useOpenCL() ) if ( useOpenCL )
{ {
UMat A = A1Out.getUMat(); UMat A = A1Out.getUMat();
Mat b1 = b1Out.getMat(); Mat b1 = b1Out.getMat();
...@@ -444,6 +444,7 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl ...@@ -444,6 +444,7 @@ void OpticalFlowPCAFlow::calc( InputArray I0, InputArray I1, InputOutputArray fl
CV_Assert( to.channels() == 1 ); CV_Assert( to.channels() == 1 );
const Mat fromOrig = from.getMat( ACCESS_READ ).clone(); const Mat fromOrig = from.getMat( ACCESS_READ ).clone();
useOpenCL = flowOut.isUMat() && ocl::useOpenCL();
applyCLAHE( from, claheClip ); applyCLAHE( from, claheClip );
applyCLAHE( to, claheClip ); applyCLAHE( to, claheClip );
...@@ -481,7 +482,7 @@ OpticalFlowPCAFlow::OpticalFlowPCAFlow( Ptr<const PCAPrior> _prior, const Size _ ...@@ -481,7 +482,7 @@ OpticalFlowPCAFlow::OpticalFlowPCAFlow( Ptr<const PCAPrior> _prior, const Size _
float _dampingFactor, float _claheClip ) float _dampingFactor, float _claheClip )
: prior( _prior ), basisSize( _basisSize ), sparseRate( _sparseRate ), : prior( _prior ), basisSize( _basisSize ), sparseRate( _sparseRate ),
retainedCornersFraction( _retainedCornersFraction ), occlusionsThreshold( _occlusionsThreshold ), retainedCornersFraction( _retainedCornersFraction ), occlusionsThreshold( _occlusionsThreshold ),
dampingFactor( _dampingFactor ), claheClip( _claheClip ) dampingFactor( _dampingFactor ), claheClip( _claheClip ), useOpenCL( false )
{ {
CV_Assert( sparseRate > 0 && sparseRate <= 0.1 ); CV_Assert( sparseRate > 0 && sparseRate <= 0.1 );
CV_Assert( retainedCornersFraction >= 0 && retainedCornersFraction <= 1.0 ); CV_Assert( retainedCornersFraction >= 0 && retainedCornersFraction <= 1.0 );
......
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