mirror of
https://github.com/opencv/opencv_contrib.git
synced 2025-10-17 07:04:18 +08:00

Add FastCV DSP Initialization, QcAllocator and FastCV DSP Extension APIs #3931 Merge with https://github.com/opencv/opencv/pull/27290 **Detailed Description** This PR introduces FastCV DSP Extension APIs within the '**cv::fastcv::dsp**' namespace. The following APIs have been added: 1. **fcvdspinit**: Initializes the FastCV DSP environment. 2. **fcvdspdeinit**: Deinitializes the FastCV DSP environment. 3. **sumOfAbsoluteDiffs**: Computes the sum of absolute differences of an image against an 8x8 template. 4. **thresholdOtsu**: Binarizes a grayscale image using Otsu's method. 5. **FFT**: Computes the 1D or 2D Fast Fourier Transform of a real-valued matrix. 6. **IFFT**: Computes the 1D or 2D Inverse Fast Fourier Transform of a complex-valued matrix. 7. **canny**: Applies the Canny edge detector to an 8-bit grayscale image. 8. **filter2D**: Applies a generic 2D filter to an image. The **QcAllocator** has been added to manage memory allocations on Qualcomm's Chipsets. This allocator ensures that matrices are allocated using the Qualcomm hardware memory allocator, providing efficient DSP operations. Requires updated binary from: https://github.com/opencv/opencv_3rdparty/pull/97 Requires binary from https://github.com/opencv/opencv_3rdparty/pull/95 Lib Hash Update: https://github.com/opencv/opencv/pull/27403 ### Pull Request Readiness Checklist See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [ ] The PR is proposed to the proper branch - [ ] There is a reference to the original bug report and related work - [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [ ] The feature is well documented and sample code can be built with the project CMake
74 lines
1.8 KiB
C++
74 lines
1.8 KiB
C++
/*
|
|
* Copyright (c) 2025 Qualcomm Innovation Center, Inc. All rights reserved.
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include "perf_precomp.hpp"
|
|
|
|
namespace opencv_test {
|
|
|
|
typedef perf::TestBaseWithParam<tuple<Size, int, int>> Filter2DPerfTest_DSP;
|
|
|
|
PERF_TEST_P(Filter2DPerfTest_DSP, run,
|
|
::testing::Combine(::testing::Values(perf::szVGA, perf::sz720p), // image size
|
|
::testing::Values(CV_8U,CV_16S,CV_32F), // dst image depth
|
|
::testing::Values(3, 5, 7) // kernel size
|
|
)
|
|
)
|
|
{
|
|
applyTestTag(CV_TEST_TAG_FASTCV_SKIP_DSP);
|
|
|
|
//Initialize DSP
|
|
int initStatus = cv::fastcv::dsp::fcvdspinit();
|
|
ASSERT_EQ(initStatus, 0) << "Failed to initialize FastCV DSP";
|
|
|
|
cv::Size srcSize = get<0>(GetParam());
|
|
int ddepth = get<1>(GetParam());
|
|
int ksize = get<2>(GetParam());
|
|
|
|
cv::Mat src;
|
|
src.allocator = cv::fastcv::getQcAllocator();
|
|
src.create(srcSize, CV_8U);
|
|
|
|
cv::Mat kernel;
|
|
cv::Mat dst;
|
|
kernel.allocator = cv::fastcv::getQcAllocator();
|
|
dst.allocator = cv::fastcv::getQcAllocator();
|
|
|
|
switch (ddepth)
|
|
{
|
|
case CV_8U:
|
|
case CV_16S:
|
|
{
|
|
kernel.create(ksize,ksize,CV_8S);
|
|
break;
|
|
}
|
|
case CV_32F:
|
|
{
|
|
kernel.create(ksize,ksize,CV_32F);
|
|
break;
|
|
}
|
|
default:
|
|
break;
|
|
}
|
|
|
|
cv::randu(src, 0, 256);
|
|
cv::randu(kernel, INT8_MIN, INT8_MAX);
|
|
RNG& rng = cv::theRNG();
|
|
cvtest::randUni(rng, src, Scalar::all(0), Scalar::all(255));
|
|
|
|
while (next())
|
|
{
|
|
startTimer();
|
|
cv::fastcv::dsp::filter2D(src, dst, ddepth, kernel);
|
|
stopTimer();
|
|
}
|
|
|
|
//De-Initialize DSP
|
|
cv::fastcv::dsp::fcvdspdeinit();
|
|
|
|
SANITY_CHECK_NOTHING();
|
|
}
|
|
|
|
} // namespace
|