-
Notifications
You must be signed in to change notification settings - Fork 5.8k
ximgproc: optimize guidedfilter function for ARM64 using NEON intrinsics #3979
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: 4.x
Are you sure you want to change the base?
Conversation
07d31f6
to
ac1d06d
Compare
inline bool CPU_SUPPORT_NEON() | ||
{ | ||
static const bool is_supported = cv::checkHardwareSupport(CV_CPU_NEON); | ||
return is_supported; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The checkHardwareSupport
function is very simple:
bool checkHardwareSupport(int feature)
{
CV_DbgAssert( 0 <= feature && feature <= CV_HARDWARE_MAX_FEATURE );
return currentFeatures->have[feature];
}
No need to add static field for caching.
} | ||
} | ||
#elif CV_NEON | ||
if (CPU_SUPPORT_NEON()) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is CV_CPU_HAS_SUPPORT_NEON
macro for this:
include/opencv2/core/cv_cpu_helper.h:411:# define CV_CPU_HAS_SUPPORT_NEON (cv::checkHardwareSupport(CV_CPU_NEON))
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @asmorkalov ,
I’ve removed the custom CPU_SUPPORT_NEON() helper and updated the code to use the existing CV_CPU_HAS_SUPPORT_NEON macro instead.
|
Pull Request Readiness Checklist
See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request
I agree to contribute to the project under Apache 2 License.
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
This PR introduces an ARM64-specific optimization for the add_mul function in edgeaware_filters_common.cpp using NEON intrinsics.
The optimization is applied only when CV_NEON is defined and the runtime NEON check (cv::checkHardwareSupport(CV_CPU_NEON)) passes.
The SIMD implementation leverages NEON instructions (vld1q_f32, vmulq_f32, vaddq_f32, vst1q_f32) to accelerate the fused multiply-add operation on 4-element float vectors.
This brings parity with existing x64 SIMD optimizations using SSE1.
The addition of the ARM64 NEON optimization for the add_mul function in edgeaware_filters_common.cpp has led to performance improvements in some tests of GuidedFilter function.