node-native-win-utils 1.4.0 → 2.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +29 -82
- package/binding.gyp +2 -0
- package/dist/dirnameLocal.cjs +4 -0
- package/dist/dirnameLocal.d.cts +1 -0
- package/dist/dirnameLocal.d.mts +1 -0
- package/dist/dirnameLocal.mjs +2 -0
- package/dist/{index.js → index.cjs} +83 -16
- package/dist/{index.d.ts → index.d.cts} +68 -17
- package/dist/index.d.mts +230 -0
- package/dist/index.mjs +212 -0
- package/dist/keyCodes.d.mts +101 -0
- package/dist/keyCodes.mjs +201 -0
- package/node22.json +16 -0
- package/package.json +19 -9
- package/prebuilds/win32-x64/node-native-win-utils.node +0 -0
- package/src/cpp/keyboard.cpp +141 -140
- package/src/cpp/main.cpp +9 -3
- package/src/cpp/{capturewindow.cpp → screenshot.cpp} +174 -2
- package/src/dirnameLocal.mts +3 -0
- package/src/index.mts +455 -0
- package/src/keyCodes.mts +203 -0
- package/dllCopy.js +0 -14
- package/include/opencv2/core/affine.hpp +0 -678
- package/include/opencv2/core/async.hpp +0 -105
- package/include/opencv2/core/base.hpp +0 -664
- package/include/opencv2/core/bindings_utils.hpp +0 -325
- package/include/opencv2/core/bufferpool.hpp +0 -40
- package/include/opencv2/core/check.hpp +0 -170
- package/include/opencv2/core/core.hpp +0 -48
- package/include/opencv2/core/core_c.h +0 -3128
- package/include/opencv2/core/cuda/block.hpp +0 -211
- package/include/opencv2/core/cuda/border_interpolate.hpp +0 -722
- package/include/opencv2/core/cuda/color.hpp +0 -309
- package/include/opencv2/core/cuda/common.hpp +0 -131
- package/include/opencv2/core/cuda/datamov_utils.hpp +0 -113
- package/include/opencv2/core/cuda/detail/color_detail.hpp +0 -2018
- package/include/opencv2/core/cuda/detail/reduce.hpp +0 -365
- package/include/opencv2/core/cuda/detail/reduce_key_val.hpp +0 -502
- package/include/opencv2/core/cuda/detail/transform_detail.hpp +0 -392
- package/include/opencv2/core/cuda/detail/type_traits_detail.hpp +0 -191
- package/include/opencv2/core/cuda/detail/vec_distance_detail.hpp +0 -121
- package/include/opencv2/core/cuda/dynamic_smem.hpp +0 -88
- package/include/opencv2/core/cuda/emulation.hpp +0 -269
- package/include/opencv2/core/cuda/filters.hpp +0 -293
- package/include/opencv2/core/cuda/funcattrib.hpp +0 -79
- package/include/opencv2/core/cuda/functional.hpp +0 -805
- package/include/opencv2/core/cuda/limits.hpp +0 -128
- package/include/opencv2/core/cuda/reduce.hpp +0 -209
- package/include/opencv2/core/cuda/saturate_cast.hpp +0 -292
- package/include/opencv2/core/cuda/scan.hpp +0 -258
- package/include/opencv2/core/cuda/simd_functions.hpp +0 -869
- package/include/opencv2/core/cuda/transform.hpp +0 -75
- package/include/opencv2/core/cuda/type_traits.hpp +0 -90
- package/include/opencv2/core/cuda/utility.hpp +0 -230
- package/include/opencv2/core/cuda/vec_distance.hpp +0 -232
- package/include/opencv2/core/cuda/vec_math.hpp +0 -923
- package/include/opencv2/core/cuda/vec_traits.hpp +0 -288
- package/include/opencv2/core/cuda/warp.hpp +0 -139
- package/include/opencv2/core/cuda/warp_reduce.hpp +0 -76
- package/include/opencv2/core/cuda/warp_shuffle.hpp +0 -162
- package/include/opencv2/core/cuda.hpp +0 -1279
- package/include/opencv2/core/cuda.inl.hpp +0 -763
- package/include/opencv2/core/cuda_stream_accessor.hpp +0 -86
- package/include/opencv2/core/cuda_types.hpp +0 -144
- package/include/opencv2/core/cv_cpu_dispatch.h +0 -381
- package/include/opencv2/core/cv_cpu_helper.h +0 -550
- package/include/opencv2/core/cvdef.h +0 -973
- package/include/opencv2/core/cvstd.hpp +0 -190
- package/include/opencv2/core/cvstd.inl.hpp +0 -197
- package/include/opencv2/core/cvstd_wrapper.hpp +0 -154
- package/include/opencv2/core/detail/async_promise.hpp +0 -71
- package/include/opencv2/core/detail/dispatch_helper.impl.hpp +0 -49
- package/include/opencv2/core/detail/exception_ptr.hpp +0 -27
- package/include/opencv2/core/directx.hpp +0 -184
- package/include/opencv2/core/dualquaternion.hpp +0 -979
- package/include/opencv2/core/dualquaternion.inl.hpp +0 -487
- package/include/opencv2/core/eigen.hpp +0 -402
- package/include/opencv2/core/fast_math.hpp +0 -433
- package/include/opencv2/core/hal/hal.hpp +0 -256
- package/include/opencv2/core/hal/interface.h +0 -190
- package/include/opencv2/core/hal/intrin.hpp +0 -939
- package/include/opencv2/core/hal/intrin_avx.hpp +0 -3177
- package/include/opencv2/core/hal/intrin_avx512.hpp +0 -3090
- package/include/opencv2/core/hal/intrin_cpp.hpp +0 -3321
- package/include/opencv2/core/hal/intrin_forward.hpp +0 -191
- package/include/opencv2/core/hal/intrin_lasx.hpp +0 -3236
- package/include/opencv2/core/hal/intrin_msa.hpp +0 -1887
- package/include/opencv2/core/hal/intrin_neon.hpp +0 -2610
- package/include/opencv2/core/hal/intrin_rvv.hpp +0 -3320
- package/include/opencv2/core/hal/intrin_rvv071.hpp +0 -2545
- package/include/opencv2/core/hal/intrin_rvv_scalable.hpp +0 -2080
- package/include/opencv2/core/hal/intrin_sse.hpp +0 -3467
- package/include/opencv2/core/hal/intrin_sse_em.hpp +0 -180
- package/include/opencv2/core/hal/intrin_vsx.hpp +0 -1608
- package/include/opencv2/core/hal/intrin_wasm.hpp +0 -2782
- package/include/opencv2/core/hal/msa_macros.h +0 -1558
- package/include/opencv2/core/hal/simd_utils.impl.hpp +0 -186
- package/include/opencv2/core/llapi/llapi.h +0 -102
- package/include/opencv2/core/mat.hpp +0 -3775
- package/include/opencv2/core/mat.inl.hpp +0 -3422
- package/include/opencv2/core/matx.hpp +0 -1536
- package/include/opencv2/core/neon_utils.hpp +0 -128
- package/include/opencv2/core/ocl.hpp +0 -917
- package/include/opencv2/core/ocl_genbase.hpp +0 -69
- package/include/opencv2/core/opencl/ocl_defs.hpp +0 -82
- package/include/opencv2/core/opencl/opencl_info.hpp +0 -212
- package/include/opencv2/core/opencl/opencl_svm.hpp +0 -81
- package/include/opencv2/core/opencl/runtime/autogenerated/opencl_clblas.hpp +0 -602
- package/include/opencv2/core/opencl/runtime/autogenerated/opencl_clfft.hpp +0 -146
- package/include/opencv2/core/opencl/runtime/autogenerated/opencl_core.hpp +0 -371
- package/include/opencv2/core/opencl/runtime/autogenerated/opencl_core_wrappers.hpp +0 -272
- package/include/opencv2/core/opencl/runtime/autogenerated/opencl_gl.hpp +0 -62
- package/include/opencv2/core/opencl/runtime/autogenerated/opencl_gl_wrappers.hpp +0 -42
- package/include/opencv2/core/opencl/runtime/opencl_clblas.hpp +0 -53
- package/include/opencv2/core/opencl/runtime/opencl_clfft.hpp +0 -53
- package/include/opencv2/core/opencl/runtime/opencl_core.hpp +0 -84
- package/include/opencv2/core/opencl/runtime/opencl_core_wrappers.hpp +0 -47
- package/include/opencv2/core/opencl/runtime/opencl_gl.hpp +0 -53
- package/include/opencv2/core/opencl/runtime/opencl_gl_wrappers.hpp +0 -47
- package/include/opencv2/core/opencl/runtime/opencl_svm_20.hpp +0 -48
- package/include/opencv2/core/opencl/runtime/opencl_svm_definitions.hpp +0 -42
- package/include/opencv2/core/opencl/runtime/opencl_svm_hsa_extension.hpp +0 -166
- package/include/opencv2/core/opengl.hpp +0 -733
- package/include/opencv2/core/openvx/ovx_defs.hpp +0 -48
- package/include/opencv2/core/operations.hpp +0 -610
- package/include/opencv2/core/optim.hpp +0 -302
- package/include/opencv2/core/ovx.hpp +0 -28
- package/include/opencv2/core/parallel/backend/parallel_for.openmp.hpp +0 -72
- package/include/opencv2/core/parallel/backend/parallel_for.tbb.hpp +0 -153
- package/include/opencv2/core/parallel/parallel_backend.hpp +0 -90
- package/include/opencv2/core/persistence.hpp +0 -1350
- package/include/opencv2/core/private/cv_cpu_include_simd_declarations.hpp +0 -30
- package/include/opencv2/core/private.cuda.hpp +0 -169
- package/include/opencv2/core/private.hpp +0 -896
- package/include/opencv2/core/quaternion.hpp +0 -1696
- package/include/opencv2/core/quaternion.inl.hpp +0 -1063
- package/include/opencv2/core/saturate.hpp +0 -180
- package/include/opencv2/core/simd_intrinsics.hpp +0 -87
- package/include/opencv2/core/softfloat.hpp +0 -514
- package/include/opencv2/core/sse_utils.hpp +0 -652
- package/include/opencv2/core/traits.hpp +0 -417
- package/include/opencv2/core/types.hpp +0 -2457
- package/include/opencv2/core/types_c.h +0 -2126
- package/include/opencv2/core/utility.hpp +0 -1229
- package/include/opencv2/core/utils/allocator_stats.hpp +0 -29
- package/include/opencv2/core/utils/allocator_stats.impl.hpp +0 -158
- package/include/opencv2/core/utils/buffer_area.private.hpp +0 -136
- package/include/opencv2/core/utils/configuration.private.hpp +0 -22
- package/include/opencv2/core/utils/filesystem.hpp +0 -82
- package/include/opencv2/core/utils/filesystem.private.hpp +0 -66
- package/include/opencv2/core/utils/fp_control.private.hpp +0 -29
- package/include/opencv2/core/utils/fp_control_utils.hpp +0 -69
- package/include/opencv2/core/utils/instrumentation.hpp +0 -125
- package/include/opencv2/core/utils/lock.private.hpp +0 -119
- package/include/opencv2/core/utils/logger.defines.hpp +0 -42
- package/include/opencv2/core/utils/logger.hpp +0 -218
- package/include/opencv2/core/utils/logtag.hpp +0 -28
- package/include/opencv2/core/utils/plugin_loader.private.hpp +0 -165
- package/include/opencv2/core/utils/tls.hpp +0 -235
- package/include/opencv2/core/utils/trace.hpp +0 -252
- package/include/opencv2/core/utils/trace.private.hpp +0 -421
- package/include/opencv2/core/va_intel.hpp +0 -75
- package/include/opencv2/core/version.hpp +0 -26
- package/include/opencv2/core/vsx_utils.hpp +0 -1047
- package/include/opencv2/core.hpp +0 -3365
- package/include/opencv2/imgcodecs/imgcodecs.hpp +0 -48
- package/include/opencv2/imgcodecs/imgcodecs_c.h +0 -1
- package/include/opencv2/imgcodecs/ios.h +0 -59
- package/include/opencv2/imgcodecs/legacy/constants_c.h +0 -54
- package/include/opencv2/imgcodecs/macosx.h +0 -20
- package/include/opencv2/imgcodecs.hpp +0 -407
- package/include/opencv2/imgproc/bindings.hpp +0 -34
- package/include/opencv2/imgproc/detail/gcgraph.hpp +0 -395
- package/include/opencv2/imgproc/hal/hal.hpp +0 -246
- package/include/opencv2/imgproc/hal/interface.h +0 -46
- package/include/opencv2/imgproc/imgproc.hpp +0 -48
- package/include/opencv2/imgproc/imgproc_c.h +0 -1177
- package/include/opencv2/imgproc/segmentation.hpp +0 -141
- package/include/opencv2/imgproc/types_c.h +0 -659
- package/include/opencv2/imgproc.hpp +0 -5035
- package/include/opencv2/opencv_modules.hpp +0 -17
- package/include/tesseract/baseapi.h +0 -820
- package/include/tesseract/capi.h +0 -485
- package/include/tesseract/export.h +0 -37
- package/include/tesseract/ltrresultiterator.h +0 -235
- package/include/tesseract/ocrclass.h +0 -158
- package/include/tesseract/osdetect.h +0 -139
- package/include/tesseract/pageiterator.h +0 -364
- package/include/tesseract/publictypes.h +0 -281
- package/include/tesseract/renderer.h +0 -334
- package/include/tesseract/resultiterator.h +0 -250
- package/include/tesseract/tesseract.h +0 -40
- package/include/tesseract/unichar.h +0 -174
- package/include/tesseract/version.h +0 -34
- package/include/tesseract/version.h.in +0 -34
- package/libs/libjpeg-turbo.lib +0 -0
- package/libs/libpng.lib +0 -0
- package/libs/opencv_core470.lib +0 -0
- package/libs/opencv_imgcodecs470.lib +0 -0
- package/libs/opencv_imgproc470.lib +0 -0
- package/libs/tesseract.lib +0 -0
- package/libs/zlib.lib +0 -0
- /package/dist/{keyCodes.js → keyCodes.cjs} +0 -0
- /package/dist/{keyCodes.d.ts → keyCodes.d.cts} +0 -0
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
/*M///////////////////////////////////////////////////////////////////////////////////////
|
|
2
|
-
//
|
|
3
|
-
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
|
|
4
|
-
//
|
|
5
|
-
// By downloading, copying, installing or using the software you agree to this license.
|
|
6
|
-
// If you do not agree to this license, do not download, install,
|
|
7
|
-
// copy or use the software.
|
|
8
|
-
//
|
|
9
|
-
//
|
|
10
|
-
// License Agreement
|
|
11
|
-
// For Open Source Computer Vision Library
|
|
12
|
-
//
|
|
13
|
-
// Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
|
|
14
|
-
// Copyright (C) 2009, Willow Garage Inc., all rights reserved.
|
|
15
|
-
// Copyright (C) 2013, OpenCV Foundation, all rights reserved.
|
|
16
|
-
// Copyright (C) 2014, Itseez Inc., all rights reserved.
|
|
17
|
-
// Third party copyrights are property of their respective owners.
|
|
18
|
-
//
|
|
19
|
-
// Redistribution and use in source and binary forms, with or without modification,
|
|
20
|
-
// are permitted provided that the following conditions are met:
|
|
21
|
-
//
|
|
22
|
-
// * Redistribution's of source code must retain the above copyright notice,
|
|
23
|
-
// this list of conditions and the following disclaimer.
|
|
24
|
-
//
|
|
25
|
-
// * Redistribution's in binary form must reproduce the above copyright notice,
|
|
26
|
-
// this list of conditions and the following disclaimer in the documentation
|
|
27
|
-
// and/or other materials provided with the distribution.
|
|
28
|
-
//
|
|
29
|
-
// * The name of the copyright holders may not be used to endorse or promote products
|
|
30
|
-
// derived from this software without specific prior written permission.
|
|
31
|
-
//
|
|
32
|
-
// This software is provided by the copyright holders and contributors "as is" and
|
|
33
|
-
// any express or implied warranties, including, but not limited to, the implied
|
|
34
|
-
// warranties of merchantability and fitness for a particular purpose are disclaimed.
|
|
35
|
-
// In no event shall the Intel Corporation or contributors be liable for any direct,
|
|
36
|
-
// indirect, incidental, special, exemplary, or consequential damages
|
|
37
|
-
// (including, but not limited to, procurement of substitute goods or services;
|
|
38
|
-
// loss of use, data, or profits; or business interruption) however caused
|
|
39
|
-
// and on any theory of liability, whether in contract, strict liability,
|
|
40
|
-
// or tort (including negligence or otherwise) arising in any way out of
|
|
41
|
-
// the use of this software, even if advised of the possibility of such damage.
|
|
42
|
-
//
|
|
43
|
-
//M*/
|
|
44
|
-
|
|
45
|
-
#ifndef OPENCV_CORE_SATURATE_HPP
|
|
46
|
-
#define OPENCV_CORE_SATURATE_HPP
|
|
47
|
-
|
|
48
|
-
#include "opencv2/core/cvdef.h"
|
|
49
|
-
#include <climits>
|
|
50
|
-
#include "opencv2/core/fast_math.hpp"
|
|
51
|
-
|
|
52
|
-
namespace cv
|
|
53
|
-
{
|
|
54
|
-
|
|
55
|
-
//! @addtogroup core_utils
|
|
56
|
-
//! @{
|
|
57
|
-
|
|
58
|
-
/////////////// saturate_cast (used in image & signal processing) ///////////////////
|
|
59
|
-
|
|
60
|
-
/** @brief Template function for accurate conversion from one primitive type to another.
|
|
61
|
-
|
|
62
|
-
The function saturate_cast resembles the standard C++ cast operations, such as static_cast\<T\>()
|
|
63
|
-
and others. It perform an efficient and accurate conversion from one primitive type to another
|
|
64
|
-
(see the introduction chapter). saturate in the name means that when the input value v is out of the
|
|
65
|
-
range of the target type, the result is not formed just by taking low bits of the input, but instead
|
|
66
|
-
the value is clipped. For example:
|
|
67
|
-
@code
|
|
68
|
-
uchar a = saturate_cast<uchar>(-100); // a = 0 (UCHAR_MIN)
|
|
69
|
-
short b = saturate_cast<short>(33333.33333); // b = 32767 (SHRT_MAX)
|
|
70
|
-
@endcode
|
|
71
|
-
Such clipping is done when the target type is unsigned char , signed char , unsigned short or
|
|
72
|
-
signed short . For 32-bit integers, no clipping is done.
|
|
73
|
-
|
|
74
|
-
When the parameter is a floating-point value and the target type is an integer (8-, 16- or 32-bit),
|
|
75
|
-
the floating-point value is first rounded to the nearest integer and then clipped if needed (when
|
|
76
|
-
the target type is 8- or 16-bit).
|
|
77
|
-
|
|
78
|
-
@param v Function parameter.
|
|
79
|
-
@sa add, subtract, multiply, divide, Mat::convertTo
|
|
80
|
-
*/
|
|
81
|
-
template<typename _Tp> static inline _Tp saturate_cast(uchar v) { return _Tp(v); }
|
|
82
|
-
/** @overload */
|
|
83
|
-
template<typename _Tp> static inline _Tp saturate_cast(schar v) { return _Tp(v); }
|
|
84
|
-
/** @overload */
|
|
85
|
-
template<typename _Tp> static inline _Tp saturate_cast(ushort v) { return _Tp(v); }
|
|
86
|
-
/** @overload */
|
|
87
|
-
template<typename _Tp> static inline _Tp saturate_cast(short v) { return _Tp(v); }
|
|
88
|
-
/** @overload */
|
|
89
|
-
template<typename _Tp> static inline _Tp saturate_cast(unsigned v) { return _Tp(v); }
|
|
90
|
-
/** @overload */
|
|
91
|
-
template<typename _Tp> static inline _Tp saturate_cast(int v) { return _Tp(v); }
|
|
92
|
-
/** @overload */
|
|
93
|
-
template<typename _Tp> static inline _Tp saturate_cast(float v) { return _Tp(v); }
|
|
94
|
-
/** @overload */
|
|
95
|
-
template<typename _Tp> static inline _Tp saturate_cast(double v) { return _Tp(v); }
|
|
96
|
-
/** @overload */
|
|
97
|
-
template<typename _Tp> static inline _Tp saturate_cast(int64 v) { return _Tp(v); }
|
|
98
|
-
/** @overload */
|
|
99
|
-
template<typename _Tp> static inline _Tp saturate_cast(uint64 v) { return _Tp(v); }
|
|
100
|
-
|
|
101
|
-
template<> inline uchar saturate_cast<uchar>(schar v) { return (uchar)std::max((int)v, 0); }
|
|
102
|
-
template<> inline uchar saturate_cast<uchar>(ushort v) { return (uchar)std::min((unsigned)v, (unsigned)UCHAR_MAX); }
|
|
103
|
-
template<> inline uchar saturate_cast<uchar>(int v) { return (uchar)((unsigned)v <= UCHAR_MAX ? v : v > 0 ? UCHAR_MAX : 0); }
|
|
104
|
-
template<> inline uchar saturate_cast<uchar>(short v) { return saturate_cast<uchar>((int)v); }
|
|
105
|
-
template<> inline uchar saturate_cast<uchar>(unsigned v) { return (uchar)std::min(v, (unsigned)UCHAR_MAX); }
|
|
106
|
-
template<> inline uchar saturate_cast<uchar>(float v) { int iv = cvRound(v); return saturate_cast<uchar>(iv); }
|
|
107
|
-
template<> inline uchar saturate_cast<uchar>(double v) { int iv = cvRound(v); return saturate_cast<uchar>(iv); }
|
|
108
|
-
template<> inline uchar saturate_cast<uchar>(int64 v) { return (uchar)((uint64)v <= (uint64)UCHAR_MAX ? v : v > 0 ? UCHAR_MAX : 0); }
|
|
109
|
-
template<> inline uchar saturate_cast<uchar>(uint64 v) { return (uchar)std::min(v, (uint64)UCHAR_MAX); }
|
|
110
|
-
|
|
111
|
-
template<> inline schar saturate_cast<schar>(uchar v) { return (schar)std::min((int)v, SCHAR_MAX); }
|
|
112
|
-
template<> inline schar saturate_cast<schar>(ushort v) { return (schar)std::min((unsigned)v, (unsigned)SCHAR_MAX); }
|
|
113
|
-
template<> inline schar saturate_cast<schar>(int v) { return (schar)((unsigned)(v-SCHAR_MIN) <= (unsigned)UCHAR_MAX ? v : v > 0 ? SCHAR_MAX : SCHAR_MIN); }
|
|
114
|
-
template<> inline schar saturate_cast<schar>(short v) { return saturate_cast<schar>((int)v); }
|
|
115
|
-
template<> inline schar saturate_cast<schar>(unsigned v) { return (schar)std::min(v, (unsigned)SCHAR_MAX); }
|
|
116
|
-
template<> inline schar saturate_cast<schar>(float v) { int iv = cvRound(v); return saturate_cast<schar>(iv); }
|
|
117
|
-
template<> inline schar saturate_cast<schar>(double v) { int iv = cvRound(v); return saturate_cast<schar>(iv); }
|
|
118
|
-
template<> inline schar saturate_cast<schar>(int64 v) { return (schar)((uint64)((int64)v-SCHAR_MIN) <= (uint64)UCHAR_MAX ? v : v > 0 ? SCHAR_MAX : SCHAR_MIN); }
|
|
119
|
-
template<> inline schar saturate_cast<schar>(uint64 v) { return (schar)std::min(v, (uint64)SCHAR_MAX); }
|
|
120
|
-
|
|
121
|
-
template<> inline ushort saturate_cast<ushort>(schar v) { return (ushort)std::max((int)v, 0); }
|
|
122
|
-
template<> inline ushort saturate_cast<ushort>(short v) { return (ushort)std::max((int)v, 0); }
|
|
123
|
-
template<> inline ushort saturate_cast<ushort>(int v) { return (ushort)((unsigned)v <= (unsigned)USHRT_MAX ? v : v > 0 ? USHRT_MAX : 0); }
|
|
124
|
-
template<> inline ushort saturate_cast<ushort>(unsigned v) { return (ushort)std::min(v, (unsigned)USHRT_MAX); }
|
|
125
|
-
template<> inline ushort saturate_cast<ushort>(float v) { int iv = cvRound(v); return saturate_cast<ushort>(iv); }
|
|
126
|
-
template<> inline ushort saturate_cast<ushort>(double v) { int iv = cvRound(v); return saturate_cast<ushort>(iv); }
|
|
127
|
-
template<> inline ushort saturate_cast<ushort>(int64 v) { return (ushort)((uint64)v <= (uint64)USHRT_MAX ? v : v > 0 ? USHRT_MAX : 0); }
|
|
128
|
-
template<> inline ushort saturate_cast<ushort>(uint64 v) { return (ushort)std::min(v, (uint64)USHRT_MAX); }
|
|
129
|
-
|
|
130
|
-
template<> inline short saturate_cast<short>(ushort v) { return (short)std::min((int)v, SHRT_MAX); }
|
|
131
|
-
template<> inline short saturate_cast<short>(int v) { return (short)((unsigned)(v - SHRT_MIN) <= (unsigned)USHRT_MAX ? v : v > 0 ? SHRT_MAX : SHRT_MIN); }
|
|
132
|
-
template<> inline short saturate_cast<short>(unsigned v) { return (short)std::min(v, (unsigned)SHRT_MAX); }
|
|
133
|
-
template<> inline short saturate_cast<short>(float v) { int iv = cvRound(v); return saturate_cast<short>(iv); }
|
|
134
|
-
template<> inline short saturate_cast<short>(double v) { int iv = cvRound(v); return saturate_cast<short>(iv); }
|
|
135
|
-
template<> inline short saturate_cast<short>(int64 v) { return (short)((uint64)((int64)v - SHRT_MIN) <= (uint64)USHRT_MAX ? v : v > 0 ? SHRT_MAX : SHRT_MIN); }
|
|
136
|
-
template<> inline short saturate_cast<short>(uint64 v) { return (short)std::min(v, (uint64)SHRT_MAX); }
|
|
137
|
-
|
|
138
|
-
template<> inline int saturate_cast<int>(unsigned v) { return (int)std::min(v, (unsigned)INT_MAX); }
|
|
139
|
-
template<> inline int saturate_cast<int>(int64 v) { return (int)((uint64)(v - INT_MIN) <= (uint64)UINT_MAX ? v : v > 0 ? INT_MAX : INT_MIN); }
|
|
140
|
-
template<> inline int saturate_cast<int>(uint64 v) { return (int)std::min(v, (uint64)INT_MAX); }
|
|
141
|
-
template<> inline int saturate_cast<int>(float v) { return cvRound(v); }
|
|
142
|
-
template<> inline int saturate_cast<int>(double v) { return cvRound(v); }
|
|
143
|
-
|
|
144
|
-
template<> inline unsigned saturate_cast<unsigned>(schar v) { return (unsigned)std::max(v, (schar)0); }
|
|
145
|
-
template<> inline unsigned saturate_cast<unsigned>(short v) { return (unsigned)std::max(v, (short)0); }
|
|
146
|
-
template<> inline unsigned saturate_cast<unsigned>(int v) { return (unsigned)std::max(v, (int)0); }
|
|
147
|
-
template<> inline unsigned saturate_cast<unsigned>(int64 v) { return (unsigned)((uint64)v <= (uint64)UINT_MAX ? v : v > 0 ? UINT_MAX : 0); }
|
|
148
|
-
template<> inline unsigned saturate_cast<unsigned>(uint64 v) { return (unsigned)std::min(v, (uint64)UINT_MAX); }
|
|
149
|
-
// we intentionally do not clip negative numbers, to make -1 become 0xffffffff etc.
|
|
150
|
-
template<> inline unsigned saturate_cast<unsigned>(float v) { return static_cast<unsigned>(cvRound(v)); }
|
|
151
|
-
template<> inline unsigned saturate_cast<unsigned>(double v) { return static_cast<unsigned>(cvRound(v)); }
|
|
152
|
-
|
|
153
|
-
template<> inline uint64 saturate_cast<uint64>(schar v) { return (uint64)std::max(v, (schar)0); }
|
|
154
|
-
template<> inline uint64 saturate_cast<uint64>(short v) { return (uint64)std::max(v, (short)0); }
|
|
155
|
-
template<> inline uint64 saturate_cast<uint64>(int v) { return (uint64)std::max(v, (int)0); }
|
|
156
|
-
template<> inline uint64 saturate_cast<uint64>(int64 v) { return (uint64)std::max(v, (int64)0); }
|
|
157
|
-
|
|
158
|
-
template<> inline int64 saturate_cast<int64>(uint64 v) { return (int64)std::min(v, (uint64)LLONG_MAX); }
|
|
159
|
-
|
|
160
|
-
/** @overload */
|
|
161
|
-
template<typename _Tp> static inline _Tp saturate_cast(float16_t v) { return saturate_cast<_Tp>((float)v); }
|
|
162
|
-
|
|
163
|
-
// in theory, we could use a LUT for 8u/8s->16f conversion,
|
|
164
|
-
// but with hardware support for FP32->FP16 conversion the current approach is preferable
|
|
165
|
-
template<> inline float16_t saturate_cast<float16_t>(uchar v) { return float16_t((float)v); }
|
|
166
|
-
template<> inline float16_t saturate_cast<float16_t>(schar v) { return float16_t((float)v); }
|
|
167
|
-
template<> inline float16_t saturate_cast<float16_t>(ushort v) { return float16_t((float)v); }
|
|
168
|
-
template<> inline float16_t saturate_cast<float16_t>(short v) { return float16_t((float)v); }
|
|
169
|
-
template<> inline float16_t saturate_cast<float16_t>(unsigned v){ return float16_t((float)v); }
|
|
170
|
-
template<> inline float16_t saturate_cast<float16_t>(int v) { return float16_t((float)v); }
|
|
171
|
-
template<> inline float16_t saturate_cast<float16_t>(uint64 v) { return float16_t((float)v); }
|
|
172
|
-
template<> inline float16_t saturate_cast<float16_t>(int64 v) { return float16_t((float)v); }
|
|
173
|
-
template<> inline float16_t saturate_cast<float16_t>(float v) { return float16_t(v); }
|
|
174
|
-
template<> inline float16_t saturate_cast<float16_t>(double v) { return float16_t((float)v); }
|
|
175
|
-
|
|
176
|
-
//! @}
|
|
177
|
-
|
|
178
|
-
} // cv
|
|
179
|
-
|
|
180
|
-
#endif // OPENCV_CORE_SATURATE_HPP
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
// This file is part of OpenCV project.
|
|
2
|
-
// It is subject to the license terms in the LICENSE file found in the top-level directory
|
|
3
|
-
// of this distribution and at http://opencv.org/license.html.
|
|
4
|
-
|
|
5
|
-
#ifndef OPENCV_CORE_SIMD_INTRINSICS_HPP
|
|
6
|
-
#define OPENCV_CORE_SIMD_INTRINSICS_HPP
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
Helper header to support SIMD intrinsics (universal intrinsics) in user code.
|
|
10
|
-
Intrinsics documentation: https://docs.opencv.org/4.x/df/d91/group__core__hal__intrin.html
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
Checks of target CPU instruction set based on compiler definitions don't work well enough.
|
|
14
|
-
More reliable solutions require utilization of configuration systems (like CMake).
|
|
15
|
-
|
|
16
|
-
So, probably you need to specify your own configuration.
|
|
17
|
-
|
|
18
|
-
You can do that via CMake in this way:
|
|
19
|
-
add_definitions(/DOPENCV_SIMD_CONFIG_HEADER=opencv_simd_config_custom.hpp)
|
|
20
|
-
or
|
|
21
|
-
add_definitions(/DOPENCV_SIMD_CONFIG_INCLUDE_DIR=1)
|
|
22
|
-
|
|
23
|
-
Additionally you may need to add include directory to your files:
|
|
24
|
-
include_directories("${CMAKE_CURRENT_LIST_DIR}/opencv_config_${MYTARGET}")
|
|
25
|
-
|
|
26
|
-
These files can be pre-generated for target configurations of your application
|
|
27
|
-
or generated by CMake on the fly (use CMAKE_BINARY_DIR for that).
|
|
28
|
-
|
|
29
|
-
Notes:
|
|
30
|
-
- H/W capability checks are still responsibility of your application
|
|
31
|
-
- runtime dispatching is not covered by this helper header
|
|
32
|
-
*/
|
|
33
|
-
|
|
34
|
-
#ifdef __OPENCV_BUILD
|
|
35
|
-
#error "Use core/hal/intrin.hpp during OpenCV build"
|
|
36
|
-
#endif
|
|
37
|
-
|
|
38
|
-
#ifdef OPENCV_HAL_INTRIN_HPP
|
|
39
|
-
#error "core/simd_intrinsics.hpp must be included before core/hal/intrin.hpp"
|
|
40
|
-
#endif
|
|
41
|
-
|
|
42
|
-
#include "opencv2/core/cvdef.h"
|
|
43
|
-
|
|
44
|
-
#ifdef OPENCV_SIMD_CONFIG_HEADER
|
|
45
|
-
#include CVAUX_STR(OPENCV_SIMD_CONFIG_HEADER)
|
|
46
|
-
#elif defined(OPENCV_SIMD_CONFIG_INCLUDE_DIR)
|
|
47
|
-
#include "opencv_simd_config.hpp" // corresponding directory should be added via -I compiler parameter
|
|
48
|
-
#else // custom config headers
|
|
49
|
-
|
|
50
|
-
#if (!defined(CV_AVX_512F) || !CV_AVX_512F) && (defined(__AVX512__) || defined(__AVX512F__))
|
|
51
|
-
# include <immintrin.h>
|
|
52
|
-
# undef CV_AVX_512F
|
|
53
|
-
# define CV_AVX_512F 1
|
|
54
|
-
# ifndef OPENCV_SIMD_DONT_ASSUME_SKX // Skylake-X with AVX-512F/CD/BW/DQ/VL
|
|
55
|
-
# undef CV_AVX512_SKX
|
|
56
|
-
# define CV_AVX512_SKX 1
|
|
57
|
-
# undef CV_AVX_512CD
|
|
58
|
-
# define CV_AVX_512CD 1
|
|
59
|
-
# undef CV_AVX_512BW
|
|
60
|
-
# define CV_AVX_512BW 1
|
|
61
|
-
# undef CV_AVX_512DQ
|
|
62
|
-
# define CV_AVX_512DQ 1
|
|
63
|
-
# undef CV_AVX_512VL
|
|
64
|
-
# define CV_AVX_512VL 1
|
|
65
|
-
# endif
|
|
66
|
-
#endif // AVX512
|
|
67
|
-
|
|
68
|
-
// GCC/Clang: -mavx2
|
|
69
|
-
// MSVC: /arch:AVX2
|
|
70
|
-
#if defined __AVX2__
|
|
71
|
-
# include <immintrin.h>
|
|
72
|
-
# undef CV_AVX2
|
|
73
|
-
# define CV_AVX2 1
|
|
74
|
-
# if defined __F16C__
|
|
75
|
-
# undef CV_FP16
|
|
76
|
-
# define CV_FP16 1
|
|
77
|
-
# endif
|
|
78
|
-
#endif
|
|
79
|
-
|
|
80
|
-
#endif
|
|
81
|
-
|
|
82
|
-
// SSE / NEON / VSX is handled by cv_cpu_dispatch.h compatibility block
|
|
83
|
-
#include "cv_cpu_dispatch.h"
|
|
84
|
-
|
|
85
|
-
#include "hal/intrin.hpp"
|
|
86
|
-
|
|
87
|
-
#endif // OPENCV_CORE_SIMD_INTRINSICS_HPP
|