react-native-executorch 0.4.8 → 0.5.0

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.
Files changed (1013) hide show
  1. package/android/CMakeLists.txt +17 -0
  2. package/android/build.gradle +76 -13
  3. package/android/libs/classes.jar +0 -0
  4. package/android/src/main/cpp/CMakeLists.txt +73 -0
  5. package/android/src/main/cpp/ETInstallerModule.cpp +76 -0
  6. package/android/src/main/cpp/ETInstallerModule.h +43 -0
  7. package/android/src/main/java/com/swmansion/rnexecutorch/ETInstaller.kt +66 -0
  8. package/android/src/main/java/com/swmansion/rnexecutorch/LLM.kt +3 -3
  9. package/android/src/main/java/com/swmansion/rnexecutorch/RnExecutorchPackage.kt +7 -113
  10. package/common/ada/ada.cpp +17406 -0
  11. package/common/ada/ada.h +10274 -0
  12. package/common/pfft/pfft.c +2205 -0
  13. package/common/pfft/pfft.h +185 -0
  14. package/common/rnexecutorch/Log.h +489 -0
  15. package/common/rnexecutorch/RnExecutorchInstaller.cpp +78 -0
  16. package/common/rnexecutorch/RnExecutorchInstaller.h +112 -0
  17. package/common/rnexecutorch/TokenizerModule.cpp +52 -0
  18. package/common/rnexecutorch/TokenizerModule.h +26 -0
  19. package/common/rnexecutorch/data_processing/FFT.cpp +21 -0
  20. package/common/rnexecutorch/data_processing/FFT.h +23 -0
  21. package/common/rnexecutorch/data_processing/FileUtils.h +30 -0
  22. package/common/rnexecutorch/data_processing/ImageProcessing.cpp +240 -0
  23. package/common/rnexecutorch/data_processing/ImageProcessing.h +55 -0
  24. package/common/rnexecutorch/data_processing/Numerical.cpp +82 -0
  25. package/common/rnexecutorch/data_processing/Numerical.h +23 -0
  26. package/common/rnexecutorch/data_processing/base64.cpp +110 -0
  27. package/common/rnexecutorch/data_processing/base64.h +46 -0
  28. package/common/rnexecutorch/data_processing/dsp.cpp +65 -0
  29. package/common/rnexecutorch/data_processing/dsp.h +12 -0
  30. package/common/rnexecutorch/host_objects/JSTensorViewIn.h +12 -0
  31. package/common/rnexecutorch/host_objects/JSTensorViewOut.h +22 -0
  32. package/common/rnexecutorch/host_objects/JsiConversions.h +410 -0
  33. package/common/rnexecutorch/host_objects/ModelHostObject.h +239 -0
  34. package/common/rnexecutorch/jsi/JsiHostObject.cpp +108 -0
  35. package/common/rnexecutorch/jsi/JsiHostObject.h +87 -0
  36. package/common/rnexecutorch/jsi/OwningArrayBuffer.h +40 -0
  37. package/common/rnexecutorch/jsi/Promise.cpp +20 -0
  38. package/common/rnexecutorch/jsi/Promise.h +69 -0
  39. package/common/rnexecutorch/jsi/RuntimeAwareCache.h +58 -0
  40. package/common/rnexecutorch/jsi/RuntimeLifecycleMonitor.cpp +53 -0
  41. package/common/rnexecutorch/jsi/RuntimeLifecycleMonitor.h +35 -0
  42. package/common/rnexecutorch/metaprogramming/ConstructorHelpers.h +131 -0
  43. package/common/rnexecutorch/metaprogramming/FunctionHelpers.h +50 -0
  44. package/common/rnexecutorch/metaprogramming/TypeConcepts.h +37 -0
  45. package/common/rnexecutorch/models/BaseModel.cpp +181 -0
  46. package/common/rnexecutorch/models/BaseModel.h +47 -0
  47. package/common/rnexecutorch/models/EncoderDecoderBase.cpp +21 -0
  48. package/common/rnexecutorch/models/EncoderDecoderBase.h +31 -0
  49. package/common/rnexecutorch/models/classification/Classification.cpp +72 -0
  50. package/common/rnexecutorch/models/classification/Classification.h +26 -0
  51. package/{ios/RnExecutorch/models/classification/Constants.mm → common/rnexecutorch/models/classification/Constants.h} +7 -2
  52. package/common/rnexecutorch/models/embeddings/BaseEmbeddings.cpp +27 -0
  53. package/common/rnexecutorch/models/embeddings/BaseEmbeddings.h +17 -0
  54. package/common/rnexecutorch/models/embeddings/image/ImageEmbeddings.cpp +45 -0
  55. package/common/rnexecutorch/models/embeddings/image/ImageEmbeddings.h +23 -0
  56. package/common/rnexecutorch/models/embeddings/text/TextEmbeddings.cpp +61 -0
  57. package/common/rnexecutorch/models/embeddings/text/TextEmbeddings.h +26 -0
  58. package/{ios/RnExecutorch/models/image_segmentation/Constants.mm → common/rnexecutorch/models/image_segmentation/Constants.h} +7 -2
  59. package/common/rnexecutorch/models/image_segmentation/ImageSegmentation.cpp +173 -0
  60. package/common/rnexecutorch/models/image_segmentation/ImageSegmentation.h +43 -0
  61. package/{ios/RnExecutorch/utils/Constants.mm → common/rnexecutorch/models/object_detection/Constants.h} +9 -2
  62. package/common/rnexecutorch/models/object_detection/ObjectDetection.cpp +82 -0
  63. package/common/rnexecutorch/models/object_detection/ObjectDetection.h +31 -0
  64. package/{ios/RnExecutorch/utils/ObjectDetectionUtils.mm → common/rnexecutorch/models/object_detection/Utils.cpp} +10 -30
  65. package/common/rnexecutorch/models/object_detection/Utils.h +17 -0
  66. package/common/rnexecutorch/models/ocr/CTCLabelConverter.cpp +88 -0
  67. package/common/rnexecutorch/models/ocr/CTCLabelConverter.h +29 -0
  68. package/common/rnexecutorch/models/ocr/Constants.h +34 -0
  69. package/common/rnexecutorch/models/ocr/Detector.cpp +102 -0
  70. package/common/rnexecutorch/models/ocr/Detector.h +30 -0
  71. package/common/rnexecutorch/models/ocr/DetectorUtils.cpp +703 -0
  72. package/common/rnexecutorch/models/ocr/DetectorUtils.h +80 -0
  73. package/common/rnexecutorch/models/ocr/OCR.cpp +52 -0
  74. package/common/rnexecutorch/models/ocr/OCR.h +36 -0
  75. package/common/rnexecutorch/models/ocr/RecognitionHandler.cpp +107 -0
  76. package/common/rnexecutorch/models/ocr/RecognitionHandler.h +40 -0
  77. package/common/rnexecutorch/models/ocr/RecognitionHandlerUtils.cpp +153 -0
  78. package/common/rnexecutorch/models/ocr/RecognitionHandlerUtils.h +72 -0
  79. package/common/rnexecutorch/models/ocr/Recognizer.cpp +80 -0
  80. package/common/rnexecutorch/models/ocr/Recognizer.h +36 -0
  81. package/common/rnexecutorch/models/ocr/RecognizerUtils.cpp +202 -0
  82. package/common/rnexecutorch/models/ocr/RecognizerUtils.h +70 -0
  83. package/common/rnexecutorch/models/ocr/Types.h +37 -0
  84. package/common/rnexecutorch/models/speech_to_text/SpeechToText.cpp +64 -0
  85. package/common/rnexecutorch/models/speech_to_text/SpeechToText.h +31 -0
  86. package/common/rnexecutorch/models/speech_to_text/SpeechToTextStrategy.h +27 -0
  87. package/common/rnexecutorch/models/speech_to_text/WhisperStrategy.cpp +50 -0
  88. package/common/rnexecutorch/models/speech_to_text/WhisperStrategy.h +25 -0
  89. package/common/rnexecutorch/models/style_transfer/StyleTransfer.cpp +55 -0
  90. package/common/rnexecutorch/models/style_transfer/StyleTransfer.h +29 -0
  91. package/common/rnexecutorch/models/vertical_ocr/VerticalDetector.cpp +92 -0
  92. package/common/rnexecutorch/models/vertical_ocr/VerticalDetector.h +49 -0
  93. package/common/rnexecutorch/models/vertical_ocr/VerticalOCR.cpp +180 -0
  94. package/common/rnexecutorch/models/vertical_ocr/VerticalOCR.h +78 -0
  95. package/common/rnexecutorch/tests/LogTest.cpp +530 -0
  96. package/common/rnexecutorch/tests/README.md +20 -0
  97. package/common/rnexecutorch/tests/run_all_tests.sh +14 -0
  98. package/common/rnexecutorch/tests/run_test.sh +18 -0
  99. package/ios/ExecutorchLib.xcframework/Info.plist +4 -4
  100. package/ios/ExecutorchLib.xcframework/ios-arm64/ExecutorchLib.framework/ExecutorchLib +0 -0
  101. package/ios/ExecutorchLib.xcframework/ios-arm64/ExecutorchLib.framework/Info.plist +0 -0
  102. package/ios/ExecutorchLib.xcframework/ios-arm64-simulator/ExecutorchLib.framework/ExecutorchLib +0 -0
  103. package/ios/ExecutorchLib.xcframework/ios-arm64-simulator/ExecutorchLib.framework/Info.plist +0 -0
  104. package/ios/RnExecutorch/ETInstaller.h +8 -0
  105. package/ios/RnExecutorch/ETInstaller.mm +56 -0
  106. package/ios/RnExecutorch/utils/Conversions.h +8 -9
  107. package/ios/RnExecutorch/utils/Numerical.h +2 -0
  108. package/ios/RnExecutorch.xcodeproj/project.pbxproj +73 -0
  109. package/lib/module/Error.js +2 -0
  110. package/lib/module/Error.js.map +1 -1
  111. package/lib/module/common/Logger.js +23 -0
  112. package/lib/module/common/Logger.js.map +1 -0
  113. package/lib/module/constants/llmDefaults.js +8 -0
  114. package/lib/module/constants/llmDefaults.js.map +1 -1
  115. package/lib/module/constants/modelUrls.js +328 -84
  116. package/lib/module/constants/modelUrls.js.map +1 -1
  117. package/lib/module/constants/ocr/models.js +181 -286
  118. package/lib/module/constants/ocr/models.js.map +1 -1
  119. package/lib/module/constants/ocr/symbols.js +63 -63
  120. package/lib/module/controllers/LLMController.js +17 -11
  121. package/lib/module/controllers/LLMController.js.map +1 -1
  122. package/lib/module/controllers/OCRController.js +16 -9
  123. package/lib/module/controllers/OCRController.js.map +1 -1
  124. package/lib/module/controllers/VerticalOCRController.js +16 -9
  125. package/lib/module/controllers/VerticalOCRController.js.map +1 -1
  126. package/lib/module/hooks/computer_vision/useClassification.js +5 -5
  127. package/lib/module/hooks/computer_vision/useClassification.js.map +1 -1
  128. package/lib/module/hooks/computer_vision/useImageEmbeddings.js +13 -0
  129. package/lib/module/hooks/computer_vision/useImageEmbeddings.js.map +1 -0
  130. package/lib/module/hooks/computer_vision/useImageSegmentation.js +4 -4
  131. package/lib/module/hooks/computer_vision/useImageSegmentation.js.map +1 -1
  132. package/lib/module/hooks/computer_vision/useOCR.js +14 -15
  133. package/lib/module/hooks/computer_vision/useOCR.js.map +1 -1
  134. package/lib/module/hooks/computer_vision/useObjectDetection.js +5 -5
  135. package/lib/module/hooks/computer_vision/useObjectDetection.js.map +1 -1
  136. package/lib/module/hooks/computer_vision/useStyleTransfer.js +5 -5
  137. package/lib/module/hooks/computer_vision/useStyleTransfer.js.map +1 -1
  138. package/lib/module/hooks/computer_vision/useVerticalOCR.js +16 -17
  139. package/lib/module/hooks/computer_vision/useVerticalOCR.js.map +1 -1
  140. package/lib/module/hooks/general/useExecutorchModule.js +5 -3
  141. package/lib/module/hooks/general/useExecutorchModule.js.map +1 -1
  142. package/lib/module/hooks/natural_language_processing/useLLM.js +22 -25
  143. package/lib/module/hooks/natural_language_processing/useLLM.js.map +1 -1
  144. package/lib/module/hooks/natural_language_processing/useSpeechToText.js +72 -33
  145. package/lib/module/hooks/natural_language_processing/useSpeechToText.js.map +1 -1
  146. package/lib/module/hooks/natural_language_processing/useTextEmbeddings.js +4 -5
  147. package/lib/module/hooks/natural_language_processing/useTextEmbeddings.js.map +1 -1
  148. package/lib/module/hooks/natural_language_processing/useTokenizer.js +20 -19
  149. package/lib/module/hooks/natural_language_processing/useTokenizer.js.map +1 -1
  150. package/lib/module/hooks/useNonStaticModule.js +52 -0
  151. package/lib/module/hooks/useNonStaticModule.js.map +1 -0
  152. package/lib/module/index.js +15 -4
  153. package/lib/module/index.js.map +1 -1
  154. package/lib/module/modules/BaseModule.js +6 -3
  155. package/lib/module/modules/BaseModule.js.map +1 -1
  156. package/lib/module/modules/BaseNonStaticModule.js +17 -0
  157. package/lib/module/modules/BaseNonStaticModule.js.map +1 -0
  158. package/lib/module/modules/computer_vision/ClassificationModule.js +13 -8
  159. package/lib/module/modules/computer_vision/ClassificationModule.js.map +1 -1
  160. package/lib/module/modules/computer_vision/ImageEmbeddingsModule.js +19 -0
  161. package/lib/module/modules/computer_vision/ImageEmbeddingsModule.js.map +1 -0
  162. package/lib/module/modules/computer_vision/ImageSegmentationModule.js +21 -19
  163. package/lib/module/modules/computer_vision/ImageSegmentationModule.js.map +1 -1
  164. package/lib/module/modules/computer_vision/OCRModule.js +13 -10
  165. package/lib/module/modules/computer_vision/OCRModule.js.map +1 -1
  166. package/lib/module/modules/computer_vision/ObjectDetectionModule.js +13 -8
  167. package/lib/module/modules/computer_vision/ObjectDetectionModule.js.map +1 -1
  168. package/lib/module/modules/computer_vision/StyleTransferModule.js +13 -8
  169. package/lib/module/modules/computer_vision/StyleTransferModule.js.map +1 -1
  170. package/lib/module/modules/computer_vision/VerticalOCRModule.js +15 -10
  171. package/lib/module/modules/computer_vision/VerticalOCRModule.js.map +1 -1
  172. package/lib/module/modules/general/ExecutorchModule.js +10 -36
  173. package/lib/module/modules/general/ExecutorchModule.js.map +1 -1
  174. package/lib/module/modules/natural_language_processing/LLMModule.js +18 -22
  175. package/lib/module/modules/natural_language_processing/LLMModule.js.map +1 -1
  176. package/lib/module/modules/natural_language_processing/SpeechToTextModule.js +79 -27
  177. package/lib/module/modules/natural_language_processing/SpeechToTextModule.js.map +1 -1
  178. package/lib/module/modules/natural_language_processing/TextEmbeddingsModule.js +15 -8
  179. package/lib/module/modules/natural_language_processing/TextEmbeddingsModule.js.map +1 -1
  180. package/lib/module/modules/natural_language_processing/TokenizerModule.js +20 -14
  181. package/lib/module/modules/natural_language_processing/TokenizerModule.js.map +1 -1
  182. package/lib/module/native/NativeETInstaller.js +5 -0
  183. package/lib/module/native/NativeETInstaller.js.map +1 -0
  184. package/lib/module/native/RnExecutorchModules.js +2 -11
  185. package/lib/module/native/RnExecutorchModules.js.map +1 -1
  186. package/lib/module/types/common.js +25 -8
  187. package/lib/module/types/common.js.map +1 -1
  188. package/lib/module/types/stt.js +1 -79
  189. package/lib/module/types/stt.js.map +1 -1
  190. package/lib/module/utils/ResourceFetcher.js +276 -114
  191. package/lib/module/utils/ResourceFetcher.js.map +1 -1
  192. package/lib/module/utils/ResourceFetcherUtils.js +155 -0
  193. package/lib/module/utils/ResourceFetcherUtils.js.map +1 -0
  194. package/lib/module/utils/SpeechToTextModule/ASR.js +191 -0
  195. package/lib/module/utils/SpeechToTextModule/ASR.js.map +1 -0
  196. package/lib/module/utils/SpeechToTextModule/OnlineProcessor.js +73 -0
  197. package/lib/module/utils/SpeechToTextModule/OnlineProcessor.js.map +1 -0
  198. package/lib/module/utils/SpeechToTextModule/hypothesisBuffer.js +56 -0
  199. package/lib/module/utils/SpeechToTextModule/hypothesisBuffer.js.map +1 -0
  200. package/lib/module/utils/llm.js +41 -1
  201. package/lib/module/utils/llm.js.map +1 -1
  202. package/lib/typescript/Error.d.ts +2 -0
  203. package/lib/typescript/Error.d.ts.map +1 -1
  204. package/lib/typescript/common/Logger.d.ts +9 -0
  205. package/lib/typescript/common/Logger.d.ts.map +1 -0
  206. package/lib/typescript/constants/llmDefaults.d.ts +1 -0
  207. package/lib/typescript/constants/llmDefaults.d.ts.map +1 -1
  208. package/lib/typescript/constants/modelUrls.d.ts +240 -79
  209. package/lib/typescript/constants/modelUrls.d.ts.map +1 -1
  210. package/lib/typescript/constants/ocr/models.d.ts +882 -284
  211. package/lib/typescript/constants/ocr/models.d.ts.map +1 -1
  212. package/lib/typescript/controllers/LLMController.d.ts +3 -4
  213. package/lib/typescript/controllers/LLMController.d.ts.map +1 -1
  214. package/lib/typescript/controllers/OCRController.d.ts +5 -6
  215. package/lib/typescript/controllers/OCRController.d.ts.map +1 -1
  216. package/lib/typescript/controllers/VerticalOCRController.d.ts +5 -6
  217. package/lib/typescript/controllers/VerticalOCRController.d.ts.map +1 -1
  218. package/lib/typescript/hooks/computer_vision/useClassification.d.ts +8 -6
  219. package/lib/typescript/hooks/computer_vision/useClassification.d.ts.map +1 -1
  220. package/lib/typescript/hooks/computer_vision/useImageEmbeddings.d.ts +16 -0
  221. package/lib/typescript/hooks/computer_vision/useImageEmbeddings.d.ts.map +1 -0
  222. package/lib/typescript/hooks/computer_vision/useImageSegmentation.d.ts +5 -3
  223. package/lib/typescript/hooks/computer_vision/useImageSegmentation.d.ts.map +1 -1
  224. package/lib/typescript/hooks/computer_vision/useOCR.d.ts +4 -4
  225. package/lib/typescript/hooks/computer_vision/useOCR.d.ts.map +1 -1
  226. package/lib/typescript/hooks/computer_vision/useObjectDetection.d.ts +5 -3
  227. package/lib/typescript/hooks/computer_vision/useObjectDetection.d.ts.map +1 -1
  228. package/lib/typescript/hooks/computer_vision/useStyleTransfer.d.ts +5 -3
  229. package/lib/typescript/hooks/computer_vision/useStyleTransfer.d.ts.map +1 -1
  230. package/lib/typescript/hooks/computer_vision/useVerticalOCR.d.ts +3 -5
  231. package/lib/typescript/hooks/computer_vision/useVerticalOCR.d.ts.map +1 -1
  232. package/lib/typescript/hooks/general/useExecutorchModule.d.ts +1 -1
  233. package/lib/typescript/hooks/natural_language_processing/useLLM.d.ts +6 -4
  234. package/lib/typescript/hooks/natural_language_processing/useLLM.d.ts.map +1 -1
  235. package/lib/typescript/hooks/natural_language_processing/useSpeechToText.d.ts +15 -22
  236. package/lib/typescript/hooks/natural_language_processing/useSpeechToText.d.ts.map +1 -1
  237. package/lib/typescript/hooks/natural_language_processing/useTextEmbeddings.d.ts +9 -5
  238. package/lib/typescript/hooks/natural_language_processing/useTextEmbeddings.d.ts.map +1 -1
  239. package/lib/typescript/hooks/natural_language_processing/useTokenizer.d.ts +6 -4
  240. package/lib/typescript/hooks/natural_language_processing/useTokenizer.d.ts.map +1 -1
  241. package/lib/typescript/hooks/useNonStaticModule.d.ts +21 -0
  242. package/lib/typescript/hooks/useNonStaticModule.d.ts.map +1 -0
  243. package/lib/typescript/index.d.ts +17 -4
  244. package/lib/typescript/index.d.ts.map +1 -1
  245. package/lib/typescript/modules/BaseModule.d.ts +1 -1
  246. package/lib/typescript/modules/BaseModule.d.ts.map +1 -1
  247. package/lib/typescript/modules/BaseNonStaticModule.d.ts +10 -0
  248. package/lib/typescript/modules/BaseNonStaticModule.d.ts.map +1 -0
  249. package/lib/typescript/modules/computer_vision/ClassificationModule.d.ts +6 -6
  250. package/lib/typescript/modules/computer_vision/ClassificationModule.d.ts.map +1 -1
  251. package/lib/typescript/modules/computer_vision/ImageEmbeddingsModule.d.ts +9 -0
  252. package/lib/typescript/modules/computer_vision/ImageEmbeddingsModule.d.ts.map +1 -0
  253. package/lib/typescript/modules/computer_vision/ImageSegmentationModule.d.ts +8 -28
  254. package/lib/typescript/modules/computer_vision/ImageSegmentationModule.d.ts.map +1 -1
  255. package/lib/typescript/modules/computer_vision/OCRModule.d.ts +8 -7
  256. package/lib/typescript/modules/computer_vision/OCRModule.d.ts.map +1 -1
  257. package/lib/typescript/modules/computer_vision/ObjectDetectionModule.d.ts +7 -5
  258. package/lib/typescript/modules/computer_vision/ObjectDetectionModule.d.ts.map +1 -1
  259. package/lib/typescript/modules/computer_vision/StyleTransferModule.d.ts +6 -5
  260. package/lib/typescript/modules/computer_vision/StyleTransferModule.d.ts.map +1 -1
  261. package/lib/typescript/modules/computer_vision/VerticalOCRModule.d.ts +7 -8
  262. package/lib/typescript/modules/computer_vision/VerticalOCRModule.d.ts.map +1 -1
  263. package/lib/typescript/modules/general/ExecutorchModule.d.ts +5 -8
  264. package/lib/typescript/modules/general/ExecutorchModule.d.ts.map +1 -1
  265. package/lib/typescript/modules/natural_language_processing/LLMModule.d.ts +16 -16
  266. package/lib/typescript/modules/natural_language_processing/LLMModule.d.ts.map +1 -1
  267. package/lib/typescript/modules/natural_language_processing/SpeechToTextModule.d.ts +20 -13
  268. package/lib/typescript/modules/natural_language_processing/SpeechToTextModule.d.ts.map +1 -1
  269. package/lib/typescript/modules/natural_language_processing/TextEmbeddingsModule.d.ts +7 -5
  270. package/lib/typescript/modules/natural_language_processing/TextEmbeddingsModule.d.ts.map +1 -1
  271. package/lib/typescript/modules/natural_language_processing/TokenizerModule.d.ts +10 -9
  272. package/lib/typescript/modules/natural_language_processing/TokenizerModule.d.ts.map +1 -1
  273. package/lib/typescript/native/{NativeStyleTransfer.d.ts → NativeETInstaller.d.ts} +2 -3
  274. package/lib/typescript/native/NativeETInstaller.d.ts.map +1 -0
  275. package/lib/typescript/native/RnExecutorchModules.d.ts +3 -21
  276. package/lib/typescript/native/RnExecutorchModules.d.ts.map +1 -1
  277. package/lib/typescript/types/common.d.ts +30 -2
  278. package/lib/typescript/types/common.d.ts.map +1 -1
  279. package/lib/typescript/types/stt.d.ts +18 -88
  280. package/lib/typescript/types/stt.d.ts.map +1 -1
  281. package/lib/typescript/utils/ResourceFetcher.d.ts +18 -10
  282. package/lib/typescript/utils/ResourceFetcher.d.ts.map +1 -1
  283. package/lib/typescript/utils/ResourceFetcherUtils.d.ts +55 -0
  284. package/lib/typescript/utils/ResourceFetcherUtils.d.ts.map +1 -0
  285. package/lib/typescript/utils/SpeechToTextModule/ASR.d.ts +27 -0
  286. package/lib/typescript/utils/SpeechToTextModule/ASR.d.ts.map +1 -0
  287. package/lib/typescript/utils/SpeechToTextModule/OnlineProcessor.d.ts +23 -0
  288. package/lib/typescript/utils/SpeechToTextModule/OnlineProcessor.d.ts.map +1 -0
  289. package/lib/typescript/utils/SpeechToTextModule/hypothesisBuffer.d.ts +13 -0
  290. package/lib/typescript/utils/SpeechToTextModule/hypothesisBuffer.d.ts.map +1 -0
  291. package/lib/typescript/utils/llm.d.ts +4 -0
  292. package/lib/typescript/utils/llm.d.ts.map +1 -1
  293. package/package.json +23 -65
  294. package/react-native-executorch.podspec +75 -3
  295. package/src/Error.ts +2 -0
  296. package/src/common/Logger.ts +25 -0
  297. package/src/constants/llmDefaults.ts +11 -0
  298. package/src/constants/modelUrls.ts +401 -168
  299. package/src/constants/ocr/models.ts +826 -395
  300. package/src/constants/ocr/symbols.ts +63 -63
  301. package/src/controllers/LLMController.ts +28 -18
  302. package/src/controllers/OCRController.ts +24 -15
  303. package/src/controllers/VerticalOCRController.ts +24 -14
  304. package/src/hooks/computer_vision/useClassification.ts +10 -11
  305. package/src/hooks/computer_vision/useImageEmbeddings.ts +15 -0
  306. package/src/hooks/computer_vision/useImageSegmentation.ts +5 -8
  307. package/src/hooks/computer_vision/useOCR.ts +29 -21
  308. package/src/hooks/computer_vision/useObjectDetection.ts +6 -9
  309. package/src/hooks/computer_vision/useStyleTransfer.ts +6 -6
  310. package/src/hooks/computer_vision/useVerticalOCR.ts +30 -27
  311. package/src/hooks/general/useExecutorchModule.ts +3 -3
  312. package/src/hooks/natural_language_processing/useLLM.ts +38 -28
  313. package/src/hooks/natural_language_processing/useSpeechToText.ts +91 -88
  314. package/src/hooks/natural_language_processing/useTextEmbeddings.ts +11 -11
  315. package/src/hooks/natural_language_processing/useTokenizer.ts +22 -22
  316. package/src/hooks/useNonStaticModule.ts +74 -0
  317. package/src/index.ts +100 -0
  318. package/src/modules/BaseModule.ts +9 -3
  319. package/src/modules/BaseNonStaticModule.ts +26 -0
  320. package/src/modules/computer_vision/ClassificationModule.ts +20 -11
  321. package/src/modules/computer_vision/ImageEmbeddingsModule.ts +26 -0
  322. package/src/modules/computer_vision/ImageSegmentationModule.ts +35 -27
  323. package/src/modules/computer_vision/OCRModule.ts +23 -15
  324. package/src/modules/computer_vision/ObjectDetectionModule.ts +24 -11
  325. package/src/modules/computer_vision/StyleTransferModule.ts +20 -11
  326. package/src/modules/computer_vision/VerticalOCRModule.ts +25 -21
  327. package/src/modules/general/ExecutorchModule.ts +18 -48
  328. package/src/modules/natural_language_processing/LLMModule.ts +27 -30
  329. package/src/modules/natural_language_processing/SpeechToTextModule.ts +85 -68
  330. package/src/modules/natural_language_processing/TextEmbeddingsModule.ts +27 -12
  331. package/src/modules/natural_language_processing/TokenizerModule.ts +27 -17
  332. package/src/native/NativeETInstaller.ts +8 -0
  333. package/src/native/RnExecutorchModules.ts +4 -46
  334. package/src/types/common.ts +40 -12
  335. package/src/types/stt.ts +98 -89
  336. package/src/utils/ResourceFetcher.ts +338 -119
  337. package/src/utils/ResourceFetcherUtils.ts +186 -0
  338. package/src/utils/SpeechToTextModule/ASR.ts +303 -0
  339. package/src/utils/SpeechToTextModule/OnlineProcessor.ts +87 -0
  340. package/src/utils/SpeechToTextModule/hypothesisBuffer.ts +79 -0
  341. package/src/utils/llm.ts +65 -1
  342. package/third-party/android/libs/executorch/arm64-v8a/libexecutorch.so +0 -0
  343. package/third-party/android/libs/executorch/x86_64/libexecutorch.so +0 -0
  344. package/third-party/android/libs/opencv/arm64-v8a/libopencv_core.a +0 -0
  345. package/third-party/android/libs/opencv/arm64-v8a/libopencv_features2d.a +0 -0
  346. package/third-party/android/libs/opencv/arm64-v8a/libopencv_highgui.a +0 -0
  347. package/third-party/android/libs/opencv/arm64-v8a/libopencv_imgproc.a +0 -0
  348. package/third-party/android/libs/opencv/arm64-v8a/libopencv_photo.a +0 -0
  349. package/third-party/android/libs/opencv/arm64-v8a/libopencv_video.a +0 -0
  350. package/third-party/android/libs/opencv/x86_64/libopencv_core.a +0 -0
  351. package/third-party/android/libs/opencv/x86_64/libopencv_features2d.a +0 -0
  352. package/third-party/android/libs/opencv/x86_64/libopencv_highgui.a +0 -0
  353. package/third-party/android/libs/opencv/x86_64/libopencv_imgproc.a +0 -0
  354. package/third-party/android/libs/opencv/x86_64/libopencv_photo.a +0 -0
  355. package/third-party/android/libs/opencv/x86_64/libopencv_video.a +0 -0
  356. package/third-party/android/libs/opencv-third-party/arm64-v8a/libkleidicv.a +0 -0
  357. package/third-party/android/libs/opencv-third-party/arm64-v8a/libkleidicv_hal.a +0 -0
  358. package/third-party/android/libs/opencv-third-party/arm64-v8a/libkleidicv_thread.a +0 -0
  359. package/third-party/include/c10/macros/Export.h +163 -0
  360. package/third-party/include/c10/macros/Macros.h +497 -0
  361. package/third-party/include/c10/util/BFloat16-inl.h +342 -0
  362. package/third-party/include/c10/util/BFloat16-math.h +266 -0
  363. package/third-party/include/c10/util/BFloat16.h +125 -0
  364. package/third-party/include/c10/util/Half-inl.h +347 -0
  365. package/third-party/include/c10/util/Half.h +416 -0
  366. package/third-party/include/c10/util/TypeSafeSignMath.h +133 -0
  367. package/third-party/include/c10/util/bit_cast.h +43 -0
  368. package/third-party/include/c10/util/floating_point_utils.h +33 -0
  369. package/third-party/include/c10/util/irange.h +107 -0
  370. package/third-party/include/executorch/ExecuTorch.h +13 -0
  371. package/third-party/include/executorch/ExecuTorchError.h +16 -0
  372. package/third-party/include/executorch/ExecuTorchLog.h +76 -0
  373. package/third-party/include/executorch/ExecuTorchModule.h +286 -0
  374. package/third-party/include/executorch/ExecuTorchTensor.h +742 -0
  375. package/third-party/include/executorch/ExecuTorchValue.h +219 -0
  376. package/third-party/include/executorch/extension/module/module.h +492 -0
  377. package/third-party/include/executorch/extension/tensor/tensor.h +13 -0
  378. package/third-party/include/executorch/extension/tensor/tensor_accessor.h +190 -0
  379. package/third-party/include/executorch/extension/tensor/tensor_ptr.h +347 -0
  380. package/third-party/include/executorch/extension/tensor/tensor_ptr_maker.h +653 -0
  381. package/third-party/include/executorch/runtime/backend/backend_execution_context.h +71 -0
  382. package/third-party/include/executorch/runtime/backend/backend_init_context.h +72 -0
  383. package/third-party/include/executorch/runtime/backend/interface.h +166 -0
  384. package/third-party/include/executorch/runtime/core/array_ref.h +235 -0
  385. package/third-party/include/executorch/runtime/core/data_loader.h +136 -0
  386. package/third-party/include/executorch/runtime/core/defines.h +20 -0
  387. package/third-party/include/executorch/runtime/core/error.h +229 -0
  388. package/third-party/include/executorch/runtime/core/evalue.h +521 -0
  389. package/third-party/include/executorch/runtime/core/event_tracer.h +565 -0
  390. package/third-party/include/executorch/runtime/core/event_tracer_hooks.h +323 -0
  391. package/third-party/include/executorch/runtime/core/event_tracer_hooks_delegate.h +197 -0
  392. package/third-party/include/executorch/runtime/core/exec_aten/exec_aten.h +147 -0
  393. package/third-party/include/executorch/runtime/core/exec_aten/util/dim_order_util.h +263 -0
  394. package/third-party/include/executorch/runtime/core/exec_aten/util/scalar_type_util.h +1331 -0
  395. package/third-party/include/executorch/runtime/core/exec_aten/util/tensor_dimension_limit.h +21 -0
  396. package/third-party/include/executorch/runtime/core/exec_aten/util/tensor_shape_to_c_string.h +69 -0
  397. package/third-party/include/executorch/runtime/core/exec_aten/util/tensor_util.h +1250 -0
  398. package/third-party/include/executorch/runtime/core/freeable_buffer.h +107 -0
  399. package/third-party/include/executorch/runtime/core/hierarchical_allocator.h +107 -0
  400. package/third-party/include/executorch/runtime/core/memory_allocator.h +198 -0
  401. package/third-party/include/executorch/runtime/core/named_data_map.h +86 -0
  402. package/third-party/include/executorch/runtime/core/portable_type/bfloat16.h +27 -0
  403. package/third-party/include/executorch/runtime/core/portable_type/bfloat16_math.h +14 -0
  404. package/third-party/include/executorch/runtime/core/portable_type/bits_types.h +83 -0
  405. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/macros/Export.h +163 -0
  406. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/macros/Macros.h +497 -0
  407. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/BFloat16-inl.h +342 -0
  408. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/BFloat16-math.h +266 -0
  409. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/BFloat16.h +125 -0
  410. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/Half-inl.h +347 -0
  411. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/Half.h +416 -0
  412. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/TypeSafeSignMath.h +133 -0
  413. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/bit_cast.h +43 -0
  414. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/floating_point_utils.h +33 -0
  415. package/third-party/include/executorch/runtime/core/portable_type/c10/c10/util/irange.h +107 -0
  416. package/third-party/include/executorch/runtime/core/portable_type/complex.h +44 -0
  417. package/third-party/include/executorch/runtime/core/portable_type/device.h +70 -0
  418. package/third-party/include/executorch/runtime/core/portable_type/half.h +27 -0
  419. package/third-party/include/executorch/runtime/core/portable_type/optional.h +36 -0
  420. package/third-party/include/executorch/runtime/core/portable_type/qint_types.h +83 -0
  421. package/third-party/include/executorch/runtime/core/portable_type/scalar.h +110 -0
  422. package/third-party/include/executorch/runtime/core/portable_type/scalar_type.h +154 -0
  423. package/third-party/include/executorch/runtime/core/portable_type/string_view.h +29 -0
  424. package/third-party/include/executorch/runtime/core/portable_type/tensor.h +142 -0
  425. package/third-party/include/executorch/runtime/core/portable_type/tensor_impl.h +261 -0
  426. package/third-party/include/executorch/runtime/core/portable_type/tensor_options.h +60 -0
  427. package/third-party/include/executorch/runtime/core/result.h +258 -0
  428. package/third-party/include/executorch/runtime/core/span.h +93 -0
  429. package/third-party/include/executorch/runtime/core/tag.h +71 -0
  430. package/third-party/include/executorch/runtime/core/tensor_layout.h +79 -0
  431. package/third-party/include/executorch/runtime/core/tensor_shape_dynamism.h +39 -0
  432. package/third-party/include/executorch/runtime/executor/memory_manager.h +113 -0
  433. package/third-party/include/executorch/runtime/executor/method.h +387 -0
  434. package/third-party/include/executorch/runtime/executor/method_meta.h +251 -0
  435. package/third-party/include/executorch/runtime/executor/program.h +320 -0
  436. package/third-party/include/executorch/runtime/executor/pte_data_map.h +144 -0
  437. package/third-party/include/executorch/runtime/executor/tensor_parser.h +156 -0
  438. package/third-party/include/executorch/runtime/kernel/kernel_runtime_context.h +122 -0
  439. package/third-party/include/executorch/runtime/kernel/operator_registry.h +278 -0
  440. package/third-party/include/executorch/runtime/platform/abort.h +36 -0
  441. package/third-party/include/executorch/runtime/platform/assert.h +119 -0
  442. package/third-party/include/executorch/runtime/platform/clock.h +43 -0
  443. package/third-party/include/executorch/runtime/platform/compat_unistd.h +75 -0
  444. package/third-party/include/executorch/runtime/platform/compiler.h +191 -0
  445. package/third-party/include/executorch/runtime/platform/log.h +177 -0
  446. package/third-party/include/executorch/runtime/platform/platform.h +133 -0
  447. package/third-party/include/executorch/runtime/platform/profiler.h +292 -0
  448. package/third-party/include/executorch/runtime/platform/runtime.h +35 -0
  449. package/third-party/include/executorch/runtime/platform/system.h +49 -0
  450. package/third-party/include/executorch/runtime/platform/types.h +24 -0
  451. package/third-party/include/executorch/schema/extended_header.h +76 -0
  452. package/third-party/include/opencv2/core/affine.hpp +676 -0
  453. package/third-party/include/opencv2/core/async.hpp +107 -0
  454. package/third-party/include/opencv2/core/base.hpp +735 -0
  455. package/third-party/include/opencv2/core/bindings_utils.hpp +279 -0
  456. package/third-party/include/opencv2/core/bufferpool.hpp +39 -0
  457. package/third-party/include/opencv2/core/check.hpp +231 -0
  458. package/third-party/include/opencv2/core/core.hpp +55 -0
  459. package/third-party/include/opencv2/core/core_c.h +3261 -0
  460. package/third-party/include/opencv2/core/cv_cpu_dispatch.h +404 -0
  461. package/third-party/include/opencv2/core/cv_cpu_helper.h +856 -0
  462. package/third-party/include/opencv2/core/cvdef.h +1003 -0
  463. package/third-party/include/opencv2/core/cvstd.hpp +196 -0
  464. package/third-party/include/opencv2/core/cvstd.inl.hpp +188 -0
  465. package/third-party/include/opencv2/core/cvstd_wrapper.hpp +187 -0
  466. package/third-party/include/opencv2/core/detail/async_promise.hpp +73 -0
  467. package/third-party/include/opencv2/core/detail/dispatch_helper.impl.hpp +48 -0
  468. package/third-party/include/opencv2/core/detail/exception_ptr.hpp +24 -0
  469. package/third-party/include/opencv2/core/dualquaternion.hpp +1054 -0
  470. package/third-party/include/opencv2/core/dualquaternion.inl.hpp +464 -0
  471. package/third-party/include/opencv2/core/eigen.hpp +405 -0
  472. package/third-party/include/opencv2/core/fast_math.hpp +433 -0
  473. package/third-party/include/opencv2/core/hal/hal.hpp +451 -0
  474. package/third-party/include/opencv2/core/hal/interface.h +191 -0
  475. package/third-party/include/opencv2/core/hal/intrin.hpp +1222 -0
  476. package/third-party/include/opencv2/core/hal/intrin_avx.hpp +3378 -0
  477. package/third-party/include/opencv2/core/hal/intrin_avx512.hpp +3688 -0
  478. package/third-party/include/opencv2/core/hal/intrin_cpp.hpp +3446 -0
  479. package/third-party/include/opencv2/core/hal/intrin_forward.hpp +195 -0
  480. package/third-party/include/opencv2/core/hal/intrin_lasx.hpp +3243 -0
  481. package/third-party/include/opencv2/core/hal/intrin_lsx.hpp +2671 -0
  482. package/third-party/include/opencv2/core/hal/intrin_math.hpp +772 -0
  483. package/third-party/include/opencv2/core/hal/intrin_msa.hpp +1973 -0
  484. package/third-party/include/opencv2/core/hal/intrin_neon.hpp +2710 -0
  485. package/third-party/include/opencv2/core/hal/intrin_rvv071.hpp +3452 -0
  486. package/third-party/include/opencv2/core/hal/intrin_rvv_scalable.hpp +2559 -0
  487. package/third-party/include/opencv2/core/hal/intrin_sse.hpp +3528 -0
  488. package/third-party/include/opencv2/core/hal/intrin_sse_em.hpp +175 -0
  489. package/third-party/include/opencv2/core/hal/intrin_vsx.hpp +1756 -0
  490. package/third-party/include/opencv2/core/hal/intrin_wasm.hpp +2911 -0
  491. package/third-party/include/opencv2/core/hal/msa_macros.h +2079 -0
  492. package/third-party/include/opencv2/core/hal/simd_utils.impl.hpp +313 -0
  493. package/third-party/include/opencv2/core/mat.hpp +3842 -0
  494. package/third-party/include/opencv2/core/mat.inl.hpp +2753 -0
  495. package/third-party/include/opencv2/core/matx.hpp +603 -0
  496. package/third-party/include/opencv2/core/matx.inl.hpp +1132 -0
  497. package/third-party/include/opencv2/core/neon_utils.hpp +127 -0
  498. package/third-party/include/opencv2/core/operations.hpp +610 -0
  499. package/third-party/include/opencv2/core/optim.hpp +362 -0
  500. package/third-party/include/opencv2/core/parallel/backend/parallel_for.openmp.hpp +66 -0
  501. package/third-party/include/opencv2/core/parallel/backend/parallel_for.tbb.hpp +148 -0
  502. package/third-party/include/opencv2/core/parallel/parallel_backend.hpp +108 -0
  503. package/third-party/include/opencv2/core/persistence.hpp +1321 -0
  504. package/third-party/include/opencv2/core/quaternion.hpp +1889 -0
  505. package/third-party/include/opencv2/core/quaternion.inl.hpp +907 -0
  506. package/third-party/include/opencv2/core/saturate.hpp +347 -0
  507. package/third-party/include/opencv2/core/simd_intrinsics.hpp +90 -0
  508. package/third-party/include/opencv2/core/softfloat.hpp +657 -0
  509. package/third-party/include/opencv2/core/sse_utils.hpp +861 -0
  510. package/third-party/include/opencv2/core/traits.hpp +417 -0
  511. package/third-party/include/opencv2/core/types.hpp +2368 -0
  512. package/third-party/include/opencv2/core/types_c.h +2064 -0
  513. package/third-party/include/opencv2/core/utility.hpp +1296 -0
  514. package/third-party/include/opencv2/core/utils/allocator_stats.hpp +31 -0
  515. package/third-party/include/opencv2/core/utils/allocator_stats.impl.hpp +111 -0
  516. package/third-party/include/opencv2/core/utils/filesystem.hpp +91 -0
  517. package/third-party/include/opencv2/core/utils/fp_control_utils.hpp +70 -0
  518. package/third-party/include/opencv2/core/utils/instrumentation.hpp +127 -0
  519. package/third-party/include/opencv2/core/utils/logger.defines.hpp +50 -0
  520. package/third-party/include/opencv2/core/utils/logger.hpp +258 -0
  521. package/third-party/include/opencv2/core/utils/logtag.hpp +27 -0
  522. package/third-party/include/opencv2/core/utils/tls.hpp +230 -0
  523. package/third-party/include/opencv2/core/utils/trace.hpp +281 -0
  524. package/third-party/include/opencv2/core/version.hpp +29 -0
  525. package/third-party/include/opencv2/core/vsx_utils.hpp +1115 -0
  526. package/third-party/include/opencv2/core.hpp +3699 -0
  527. package/third-party/include/opencv2/cvconfig.h +155 -0
  528. package/third-party/include/opencv2/dnn/dnn.hpp +51 -0
  529. package/third-party/include/opencv2/dnn.hpp +17 -0
  530. package/third-party/include/opencv2/features2d/features2d.hpp +55 -0
  531. package/third-party/include/opencv2/features2d/hal/interface.h +32 -0
  532. package/third-party/include/opencv2/features2d.hpp +1756 -0
  533. package/third-party/include/opencv2/highgui/highgui.hpp +113 -0
  534. package/third-party/include/opencv2/highgui.hpp +17 -0
  535. package/third-party/include/opencv2/imgproc/bindings.hpp +34 -0
  536. package/third-party/include/opencv2/imgproc/detail/gcgraph.hpp +355 -0
  537. package/third-party/include/opencv2/imgproc/detail/legacy.hpp +35 -0
  538. package/third-party/include/opencv2/imgproc/hal/hal.hpp +246 -0
  539. package/third-party/include/opencv2/imgproc/hal/interface.h +52 -0
  540. package/third-party/include/opencv2/imgproc/imgproc.hpp +55 -0
  541. package/third-party/include/opencv2/imgproc/imgproc_c.h +1261 -0
  542. package/third-party/include/opencv2/imgproc/segmentation.hpp +168 -0
  543. package/third-party/include/opencv2/imgproc/types_c.h +632 -0
  544. package/third-party/include/opencv2/imgproc.hpp +5956 -0
  545. package/third-party/include/opencv2/opencv.hpp +102 -0
  546. package/third-party/include/opencv2/opencv_modules.hpp +19 -0
  547. package/third-party/include/opencv2/photo/legacy/constants_c.h +10 -0
  548. package/third-party/include/opencv2/photo/photo.hpp +55 -0
  549. package/third-party/include/opencv2/photo.hpp +975 -0
  550. package/third-party/include/opencv2/video/background_segm.hpp +341 -0
  551. package/third-party/include/opencv2/video/detail/tracking.detail.hpp +435 -0
  552. package/third-party/include/opencv2/video/legacy/constants_c.h +15 -0
  553. package/third-party/include/opencv2/video/tracking.hpp +1014 -0
  554. package/third-party/include/opencv2/video/video.hpp +55 -0
  555. package/third-party/include/opencv2/video.hpp +65 -0
  556. package/third-party/include/tokenizers-cpp/tokenizers_c.h +61 -0
  557. package/third-party/include/tokenizers-cpp/tokenizers_cpp.h +118 -0
  558. package/third-party/ios/ExecutorchLib/ExecutorchLib/Exported/ETModel.h +27 -0
  559. package/third-party/ios/ExecutorchLib/ExecutorchLib/Exported/ETModel.mm +249 -0
  560. package/third-party/ios/ExecutorchLib/ExecutorchLib/Exported/HuggingFaceTokenizer.h +14 -0
  561. package/third-party/ios/ExecutorchLib/ExecutorchLib/Exported/HuggingFaceTokenizer.mm +80 -0
  562. package/third-party/ios/ExecutorchLib/ExecutorchLib/Exported/LLaMARunner.h +32 -0
  563. package/third-party/ios/ExecutorchLib/ExecutorchLib/Exported/LLaMARunner.mm +95 -0
  564. package/third-party/ios/ExecutorchLib/ExecutorchLib/InputType.h +12 -0
  565. package/third-party/ios/ExecutorchLib/ExecutorchLib/Utils.hpp +217 -0
  566. package/third-party/ios/ExecutorchLib/ExecutorchLib/model/Model.cpp +11 -0
  567. package/third-party/ios/ExecutorchLib/ExecutorchLib/model/Model.h +11 -0
  568. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/irunner.h +48 -0
  569. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/runner.cpp +278 -0
  570. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/runner.h +67 -0
  571. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/stats.h +164 -0
  572. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/text_decoder_runner.cpp +65 -0
  573. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/text_decoder_runner.h +105 -0
  574. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/text_prefiller.cpp +91 -0
  575. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/text_prefiller.h +51 -0
  576. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/text_token_generator.h +162 -0
  577. package/third-party/ios/ExecutorchLib/ExecutorchLib/runner/util.h +108 -0
  578. package/third-party/ios/ExecutorchLib/ExecutorchLib/sampler/sampler.cpp +193 -0
  579. package/third-party/ios/ExecutorchLib/ExecutorchLib/sampler/sampler.h +64 -0
  580. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/base64.h +202 -0
  581. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/bpe_tokenizer.cpp +313 -0
  582. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/bpe_tokenizer.h +57 -0
  583. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/llama_tiktoken.cpp +78 -0
  584. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/llama_tiktoken.h +23 -0
  585. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/tiktoken.cpp +427 -0
  586. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/tiktoken.h +87 -0
  587. package/third-party/ios/ExecutorchLib/ExecutorchLib/tokenizer/tokenizer.h +76 -0
  588. package/third-party/ios/ExecutorchLib/ExecutorchLib.xcodeproj/project.pbxproj +683 -0
  589. package/third-party/ios/ExecutorchLib/build.sh +44 -0
  590. package/third-party/ios/ExecutorchLib/frameworks/backend_coreml.xcframework/Info.plist +43 -0
  591. package/third-party/ios/ExecutorchLib/frameworks/backend_coreml.xcframework/ios-arm64/libbackend_coreml_ios.a +0 -0
  592. package/third-party/ios/ExecutorchLib/frameworks/backend_coreml.xcframework/ios-arm64-simulator/libbackend_coreml_simulator.a +0 -0
  593. package/third-party/ios/ExecutorchLib/frameworks/backend_mps.xcframework/Info.plist +43 -0
  594. package/third-party/ios/ExecutorchLib/frameworks/backend_mps.xcframework/ios-arm64/libbackend_mps_ios.a +0 -0
  595. package/third-party/ios/ExecutorchLib/frameworks/backend_mps.xcframework/ios-arm64-simulator/libbackend_mps_simulator.a +0 -0
  596. package/third-party/ios/ExecutorchLib/frameworks/backend_xnnpack.xcframework/Info.plist +43 -0
  597. package/third-party/ios/ExecutorchLib/frameworks/backend_xnnpack.xcframework/ios-arm64/libbackend_xnnpack_ios.a +0 -0
  598. package/third-party/ios/ExecutorchLib/frameworks/backend_xnnpack.xcframework/ios-arm64-simulator/libbackend_xnnpack_simulator.a +0 -0
  599. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/Info.plist +47 -0
  600. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/macros/Export.h +163 -0
  601. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/macros/Macros.h +497 -0
  602. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/BFloat16-inl.h +342 -0
  603. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/BFloat16-math.h +266 -0
  604. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/BFloat16.h +125 -0
  605. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/Half-inl.h +347 -0
  606. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/Half.h +416 -0
  607. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/TypeSafeSignMath.h +133 -0
  608. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/bit_cast.h +43 -0
  609. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/floating_point_utils.h +33 -0
  610. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/c10/util/irange.h +107 -0
  611. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/ExecuTorch.h +13 -0
  612. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/ExecuTorchError.h +16 -0
  613. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/ExecuTorchLog.h +76 -0
  614. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/ExecuTorchModule.h +286 -0
  615. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/ExecuTorchTensor.h +742 -0
  616. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/ExecuTorchValue.h +219 -0
  617. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/extension/module/module.h +492 -0
  618. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/extension/tensor/tensor.h +13 -0
  619. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/extension/tensor/tensor_accessor.h +190 -0
  620. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/extension/tensor/tensor_ptr.h +347 -0
  621. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/extension/tensor/tensor_ptr_maker.h +653 -0
  622. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/backend/backend_execution_context.h +71 -0
  623. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/backend/backend_init_context.h +72 -0
  624. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/backend/interface.h +166 -0
  625. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/array_ref.h +235 -0
  626. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/data_loader.h +136 -0
  627. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/defines.h +20 -0
  628. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/error.h +229 -0
  629. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/evalue.h +521 -0
  630. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/event_tracer.h +565 -0
  631. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/event_tracer_hooks.h +323 -0
  632. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/event_tracer_hooks_delegate.h +197 -0
  633. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/exec_aten/exec_aten.h +147 -0
  634. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/exec_aten/util/dim_order_util.h +263 -0
  635. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/exec_aten/util/scalar_type_util.h +1331 -0
  636. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/exec_aten/util/tensor_dimension_limit.h +21 -0
  637. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/exec_aten/util/tensor_shape_to_c_string.h +69 -0
  638. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/exec_aten/util/tensor_util.h +1250 -0
  639. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/freeable_buffer.h +107 -0
  640. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/hierarchical_allocator.h +107 -0
  641. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/memory_allocator.h +198 -0
  642. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/named_data_map.h +86 -0
  643. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/bfloat16.h +27 -0
  644. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/bfloat16_math.h +14 -0
  645. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/bits_types.h +83 -0
  646. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/macros/Export.h +163 -0
  647. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/macros/Macros.h +497 -0
  648. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/BFloat16-inl.h +342 -0
  649. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/BFloat16-math.h +266 -0
  650. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/BFloat16.h +125 -0
  651. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/Half-inl.h +347 -0
  652. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/Half.h +416 -0
  653. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/TypeSafeSignMath.h +133 -0
  654. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/bit_cast.h +43 -0
  655. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/floating_point_utils.h +33 -0
  656. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/c10/c10/util/irange.h +107 -0
  657. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/complex.h +44 -0
  658. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/device.h +70 -0
  659. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/half.h +27 -0
  660. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/optional.h +36 -0
  661. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/qint_types.h +83 -0
  662. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/scalar.h +110 -0
  663. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/scalar_type.h +154 -0
  664. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/string_view.h +29 -0
  665. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/tensor.h +142 -0
  666. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/tensor_impl.h +261 -0
  667. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/portable_type/tensor_options.h +60 -0
  668. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/result.h +258 -0
  669. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/span.h +93 -0
  670. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/tag.h +71 -0
  671. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/tensor_layout.h +79 -0
  672. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/core/tensor_shape_dynamism.h +39 -0
  673. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/executor/memory_manager.h +113 -0
  674. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/executor/method.h +387 -0
  675. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/executor/method_meta.h +251 -0
  676. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/executor/program.h +320 -0
  677. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/executor/pte_data_map.h +144 -0
  678. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/executor/tensor_parser.h +156 -0
  679. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/kernel/kernel_runtime_context.h +122 -0
  680. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/kernel/operator_registry.h +278 -0
  681. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/abort.h +36 -0
  682. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/assert.h +119 -0
  683. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/clock.h +43 -0
  684. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/compat_unistd.h +75 -0
  685. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/compiler.h +191 -0
  686. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/log.h +177 -0
  687. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/platform.h +133 -0
  688. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/profiler.h +292 -0
  689. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/runtime.h +35 -0
  690. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/system.h +49 -0
  691. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/runtime/platform/types.h +24 -0
  692. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/executorch/schema/extended_header.h +76 -0
  693. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/Headers/module.modulemap +5 -0
  694. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64/libexecutorch_ios.a +0 -0
  695. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/macros/Export.h +163 -0
  696. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/macros/Macros.h +497 -0
  697. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/BFloat16-inl.h +342 -0
  698. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/BFloat16-math.h +266 -0
  699. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/BFloat16.h +125 -0
  700. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/Half-inl.h +347 -0
  701. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/Half.h +416 -0
  702. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/TypeSafeSignMath.h +133 -0
  703. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/bit_cast.h +43 -0
  704. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/floating_point_utils.h +33 -0
  705. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/c10/util/irange.h +107 -0
  706. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/ExecuTorch.h +13 -0
  707. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/ExecuTorchError.h +16 -0
  708. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/ExecuTorchLog.h +76 -0
  709. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/ExecuTorchModule.h +286 -0
  710. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/ExecuTorchTensor.h +742 -0
  711. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/ExecuTorchValue.h +219 -0
  712. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/extension/module/module.h +492 -0
  713. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/extension/tensor/tensor.h +13 -0
  714. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/extension/tensor/tensor_accessor.h +190 -0
  715. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/extension/tensor/tensor_ptr.h +347 -0
  716. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/extension/tensor/tensor_ptr_maker.h +653 -0
  717. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/backend/backend_execution_context.h +71 -0
  718. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/backend/backend_init_context.h +72 -0
  719. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/backend/interface.h +166 -0
  720. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/array_ref.h +235 -0
  721. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/data_loader.h +136 -0
  722. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/defines.h +20 -0
  723. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/error.h +229 -0
  724. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/evalue.h +521 -0
  725. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/event_tracer.h +565 -0
  726. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/event_tracer_hooks.h +323 -0
  727. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/event_tracer_hooks_delegate.h +197 -0
  728. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/exec_aten/exec_aten.h +147 -0
  729. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/exec_aten/util/dim_order_util.h +263 -0
  730. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/exec_aten/util/scalar_type_util.h +1331 -0
  731. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/exec_aten/util/tensor_dimension_limit.h +21 -0
  732. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/exec_aten/util/tensor_shape_to_c_string.h +69 -0
  733. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/exec_aten/util/tensor_util.h +1250 -0
  734. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/freeable_buffer.h +107 -0
  735. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/hierarchical_allocator.h +107 -0
  736. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/memory_allocator.h +198 -0
  737. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/named_data_map.h +86 -0
  738. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/bfloat16.h +27 -0
  739. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/bfloat16_math.h +14 -0
  740. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/bits_types.h +83 -0
  741. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/macros/Export.h +163 -0
  742. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/macros/Macros.h +497 -0
  743. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/BFloat16-inl.h +342 -0
  744. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/BFloat16-math.h +266 -0
  745. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/BFloat16.h +125 -0
  746. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/Half-inl.h +347 -0
  747. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/Half.h +416 -0
  748. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/TypeSafeSignMath.h +133 -0
  749. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/bit_cast.h +43 -0
  750. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/floating_point_utils.h +33 -0
  751. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/c10/c10/util/irange.h +107 -0
  752. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/complex.h +44 -0
  753. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/device.h +70 -0
  754. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/half.h +27 -0
  755. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/optional.h +36 -0
  756. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/qint_types.h +83 -0
  757. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/scalar.h +110 -0
  758. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/scalar_type.h +154 -0
  759. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/string_view.h +29 -0
  760. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/tensor.h +142 -0
  761. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/tensor_impl.h +261 -0
  762. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/portable_type/tensor_options.h +60 -0
  763. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/result.h +258 -0
  764. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/span.h +93 -0
  765. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/tag.h +71 -0
  766. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/tensor_layout.h +79 -0
  767. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/core/tensor_shape_dynamism.h +39 -0
  768. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/executor/memory_manager.h +113 -0
  769. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/executor/method.h +387 -0
  770. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/executor/method_meta.h +251 -0
  771. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/executor/program.h +320 -0
  772. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/executor/pte_data_map.h +144 -0
  773. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/executor/tensor_parser.h +156 -0
  774. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/kernel/kernel_runtime_context.h +122 -0
  775. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/kernel/operator_registry.h +278 -0
  776. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/abort.h +36 -0
  777. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/assert.h +119 -0
  778. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/clock.h +43 -0
  779. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/compat_unistd.h +75 -0
  780. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/compiler.h +191 -0
  781. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/log.h +177 -0
  782. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/platform.h +133 -0
  783. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/profiler.h +292 -0
  784. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/runtime.h +35 -0
  785. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/system.h +49 -0
  786. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/runtime/platform/types.h +24 -0
  787. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/executorch/schema/extended_header.h +76 -0
  788. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/Headers/module.modulemap +5 -0
  789. package/third-party/ios/ExecutorchLib/frameworks/executorch.xcframework/ios-arm64-simulator/libexecutorch_simulator.a +0 -0
  790. package/third-party/ios/ExecutorchLib/frameworks/kernels_custom.xcframework/Info.plist +43 -0
  791. package/third-party/ios/ExecutorchLib/frameworks/kernels_custom.xcframework/ios-arm64/libkernels_custom_ios.a +0 -0
  792. package/third-party/ios/ExecutorchLib/frameworks/kernels_custom.xcframework/ios-arm64-simulator/libkernels_custom_simulator.a +0 -0
  793. package/third-party/ios/ExecutorchLib/frameworks/kernels_optimized.xcframework/Info.plist +43 -0
  794. package/third-party/ios/ExecutorchLib/frameworks/kernels_optimized.xcframework/ios-arm64/libkernels_optimized_ios.a +0 -0
  795. package/third-party/ios/ExecutorchLib/frameworks/kernels_optimized.xcframework/ios-arm64-simulator/libkernels_optimized_simulator.a +0 -0
  796. package/third-party/ios/ExecutorchLib/frameworks/kernels_portable.xcframework/Info.plist +43 -0
  797. package/third-party/ios/ExecutorchLib/frameworks/kernels_portable.xcframework/ios-arm64/libkernels_portable_ios.a +0 -0
  798. package/third-party/ios/ExecutorchLib/frameworks/kernels_portable.xcframework/ios-arm64-simulator/libkernels_portable_simulator.a +0 -0
  799. package/third-party/ios/ExecutorchLib/frameworks/kernels_quantized.xcframework/Info.plist +43 -0
  800. package/third-party/ios/ExecutorchLib/frameworks/kernels_quantized.xcframework/ios-arm64/libkernels_quantized_ios.a +0 -0
  801. package/third-party/ios/ExecutorchLib/frameworks/kernels_quantized.xcframework/ios-arm64-simulator/libkernels_quantized_simulator.a +0 -0
  802. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/Info.plist +43 -0
  803. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/bitmap256.h +82 -0
  804. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/filtered_re2.h +111 -0
  805. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/pod_array.h +43 -0
  806. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/prefilter.h +130 -0
  807. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/prefilter_tree.h +139 -0
  808. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/prog.h +483 -0
  809. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/re2.h +994 -0
  810. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/regexp.h +692 -0
  811. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/set.h +85 -0
  812. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/sparse_array.h +367 -0
  813. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/sparse_set.h +241 -0
  814. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/stringpiece.h +205 -0
  815. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/unicode_casefold.h +78 -0
  816. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/unicode_groups.h +64 -0
  817. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Headers/walker-inl.h +235 -0
  818. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/Info.plist +26 -0
  819. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64/re2.framework/re2 +0 -0
  820. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/bitmap256.h +82 -0
  821. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/filtered_re2.h +111 -0
  822. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/pod_array.h +43 -0
  823. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/prefilter.h +130 -0
  824. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/prefilter_tree.h +139 -0
  825. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/prog.h +483 -0
  826. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/re2.h +994 -0
  827. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/regexp.h +692 -0
  828. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/set.h +85 -0
  829. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/sparse_array.h +367 -0
  830. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/sparse_set.h +241 -0
  831. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/stringpiece.h +205 -0
  832. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/unicode_casefold.h +78 -0
  833. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/unicode_groups.h +64 -0
  834. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Headers/walker-inl.h +235 -0
  835. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/Info.plist +26 -0
  836. package/third-party/ios/ExecutorchLib/frameworks/re2.xcframework/ios-arm64-simulator/re2.framework/re2 +0 -0
  837. package/third-party/ios/ios.toolchain.cmake +1122 -0
  838. package/LICENSE +0 -79
  839. package/README.md +0 -148
  840. package/android/src/main/java/com/swmansion/rnexecutorch/Classification.kt +0 -64
  841. package/android/src/main/java/com/swmansion/rnexecutorch/ETModule.kt +0 -90
  842. package/android/src/main/java/com/swmansion/rnexecutorch/ImageSegmentation.kt +0 -58
  843. package/android/src/main/java/com/swmansion/rnexecutorch/OCR.kt +0 -90
  844. package/android/src/main/java/com/swmansion/rnexecutorch/ObjectDetection.kt +0 -64
  845. package/android/src/main/java/com/swmansion/rnexecutorch/SpeechToText.kt +0 -91
  846. package/android/src/main/java/com/swmansion/rnexecutorch/StyleTransfer.kt +0 -54
  847. package/android/src/main/java/com/swmansion/rnexecutorch/TextEmbeddings.kt +0 -51
  848. package/android/src/main/java/com/swmansion/rnexecutorch/Tokenizer.kt +0 -86
  849. package/android/src/main/java/com/swmansion/rnexecutorch/VerticalOCR.kt +0 -179
  850. package/android/src/main/java/com/swmansion/rnexecutorch/models/BaseModel.kt +0 -54
  851. package/android/src/main/java/com/swmansion/rnexecutorch/models/TextEmbeddings/TextEmbeddingsModel.kt +0 -48
  852. package/android/src/main/java/com/swmansion/rnexecutorch/models/TextEmbeddings/TextEmbeddingsUtils.kt +0 -37
  853. package/android/src/main/java/com/swmansion/rnexecutorch/models/classification/ClassificationModel.kt +0 -46
  854. package/android/src/main/java/com/swmansion/rnexecutorch/models/classification/Constants.kt +0 -1005
  855. package/android/src/main/java/com/swmansion/rnexecutorch/models/imageSegmentation/Constants.kt +0 -26
  856. package/android/src/main/java/com/swmansion/rnexecutorch/models/imageSegmentation/ImageSegmentationModel.kt +0 -142
  857. package/android/src/main/java/com/swmansion/rnexecutorch/models/objectDetection/SSDLiteLargeModel.kt +0 -74
  858. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/Detector.kt +0 -82
  859. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/RecognitionHandler.kt +0 -117
  860. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/Recognizer.kt +0 -51
  861. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/VerticalDetector.kt +0 -89
  862. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/utils/CTCLabelConverter.kt +0 -58
  863. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/utils/Constants.kt +0 -31
  864. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/utils/DetectorUtils.kt +0 -608
  865. package/android/src/main/java/com/swmansion/rnexecutorch/models/ocr/utils/RecognizerUtils.kt +0 -430
  866. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/BaseS2TDecoder.kt +0 -39
  867. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/BaseS2TModule.kt +0 -43
  868. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/Moonshine.kt +0 -16
  869. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/MoonshineDecoder.kt +0 -23
  870. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/MoonshineEncoder.kt +0 -20
  871. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/Whisper.kt +0 -16
  872. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/WhisperDecoder.kt +0 -22
  873. package/android/src/main/java/com/swmansion/rnexecutorch/models/speechToText/WhisperEncoder.kt +0 -29
  874. package/android/src/main/java/com/swmansion/rnexecutorch/models/styleTransfer/StyleTransferModel.kt +0 -43
  875. package/android/src/main/java/com/swmansion/rnexecutorch/utils/ArrayUtils.kt +0 -87
  876. package/android/src/main/java/com/swmansion/rnexecutorch/utils/ETError.kt +0 -34
  877. package/android/src/main/java/com/swmansion/rnexecutorch/utils/ImageProcessor.kt +0 -237
  878. package/android/src/main/java/com/swmansion/rnexecutorch/utils/Numerical.kt +0 -8
  879. package/android/src/main/java/com/swmansion/rnexecutorch/utils/ObjectDetectionUtils.kt +0 -201
  880. package/android/src/main/java/com/swmansion/rnexecutorch/utils/STFT.kt +0 -50
  881. package/android/src/main/java/com/swmansion/rnexecutorch/utils/TensorUtils.kt +0 -103
  882. package/ios/RnExecutorch/Classification.h +0 -5
  883. package/ios/RnExecutorch/Classification.mm +0 -54
  884. package/ios/RnExecutorch/ETModule.h +0 -5
  885. package/ios/RnExecutorch/ETModule.mm +0 -75
  886. package/ios/RnExecutorch/ImageSegmentation.h +0 -5
  887. package/ios/RnExecutorch/ImageSegmentation.mm +0 -60
  888. package/ios/RnExecutorch/OCR.h +0 -5
  889. package/ios/RnExecutorch/OCR.mm +0 -96
  890. package/ios/RnExecutorch/ObjectDetection.h +0 -5
  891. package/ios/RnExecutorch/ObjectDetection.mm +0 -56
  892. package/ios/RnExecutorch/SpeechToText.h +0 -5
  893. package/ios/RnExecutorch/SpeechToText.mm +0 -125
  894. package/ios/RnExecutorch/StyleTransfer.h +0 -5
  895. package/ios/RnExecutorch/StyleTransfer.mm +0 -55
  896. package/ios/RnExecutorch/TextEmbeddings.h +0 -5
  897. package/ios/RnExecutorch/TextEmbeddings.mm +0 -62
  898. package/ios/RnExecutorch/Tokenizer.h +0 -5
  899. package/ios/RnExecutorch/Tokenizer.mm +0 -83
  900. package/ios/RnExecutorch/VerticalOCR.h +0 -5
  901. package/ios/RnExecutorch/VerticalOCR.mm +0 -183
  902. package/ios/RnExecutorch/models/BaseModel.h +0 -21
  903. package/ios/RnExecutorch/models/BaseModel.mm +0 -43
  904. package/ios/RnExecutorch/models/classification/ClassificationModel.h +0 -10
  905. package/ios/RnExecutorch/models/classification/ClassificationModel.mm +0 -53
  906. package/ios/RnExecutorch/models/classification/Constants.h +0 -3
  907. package/ios/RnExecutorch/models/image_segmentation/Constants.h +0 -4
  908. package/ios/RnExecutorch/models/image_segmentation/ImageSegmentationModel.h +0 -10
  909. package/ios/RnExecutorch/models/image_segmentation/ImageSegmentationModel.mm +0 -146
  910. package/ios/RnExecutorch/models/object_detection/SSDLiteLargeModel.hpp +0 -11
  911. package/ios/RnExecutorch/models/object_detection/SSDLiteLargeModel.mm +0 -64
  912. package/ios/RnExecutorch/models/ocr/Detector.h +0 -9
  913. package/ios/RnExecutorch/models/ocr/Detector.mm +0 -101
  914. package/ios/RnExecutorch/models/ocr/RecognitionHandler.h +0 -16
  915. package/ios/RnExecutorch/models/ocr/RecognitionHandler.mm +0 -135
  916. package/ios/RnExecutorch/models/ocr/Recognizer.h +0 -8
  917. package/ios/RnExecutorch/models/ocr/Recognizer.mm +0 -77
  918. package/ios/RnExecutorch/models/ocr/VerticalDetector.h +0 -10
  919. package/ios/RnExecutorch/models/ocr/VerticalDetector.mm +0 -118
  920. package/ios/RnExecutorch/models/ocr/utils/CTCLabelConverter.h +0 -16
  921. package/ios/RnExecutorch/models/ocr/utils/CTCLabelConverter.mm +0 -80
  922. package/ios/RnExecutorch/models/ocr/utils/Constants.h +0 -26
  923. package/ios/RnExecutorch/models/ocr/utils/DetectorUtils.h +0 -31
  924. package/ios/RnExecutorch/models/ocr/utils/DetectorUtils.mm +0 -754
  925. package/ios/RnExecutorch/models/ocr/utils/OCRUtils.h +0 -10
  926. package/ios/RnExecutorch/models/ocr/utils/OCRUtils.mm +0 -67
  927. package/ios/RnExecutorch/models/ocr/utils/RecognizerUtils.h +0 -35
  928. package/ios/RnExecutorch/models/ocr/utils/RecognizerUtils.mm +0 -331
  929. package/ios/RnExecutorch/models/stt/Moonshine.hpp +0 -13
  930. package/ios/RnExecutorch/models/stt/Moonshine.mm +0 -64
  931. package/ios/RnExecutorch/models/stt/MoonshineDecoder.hpp +0 -16
  932. package/ios/RnExecutorch/models/stt/MoonshineDecoder.mm +0 -24
  933. package/ios/RnExecutorch/models/stt/MoonshineEncoder.hpp +0 -15
  934. package/ios/RnExecutorch/models/stt/MoonshineEncoder.mm +0 -18
  935. package/ios/RnExecutorch/models/stt/SpeechToTextBaseModel.hpp +0 -26
  936. package/ios/RnExecutorch/models/stt/SpeechToTextBaseModel.mm +0 -19
  937. package/ios/RnExecutorch/models/stt/Whisper.hpp +0 -12
  938. package/ios/RnExecutorch/models/stt/Whisper.mm +0 -68
  939. package/ios/RnExecutorch/models/stt/WhisperDecoder.hpp +0 -16
  940. package/ios/RnExecutorch/models/stt/WhisperDecoder.mm +0 -22
  941. package/ios/RnExecutorch/models/stt/WhisperEncoder.hpp +0 -15
  942. package/ios/RnExecutorch/models/stt/WhisperEncoder.mm +0 -21
  943. package/ios/RnExecutorch/models/style_transfer/StyleTransferModel.h +0 -11
  944. package/ios/RnExecutorch/models/style_transfer/StyleTransferModel.mm +0 -50
  945. package/ios/RnExecutorch/models/text_embeddings/TextEmbeddingsModel.h +0 -15
  946. package/ios/RnExecutorch/models/text_embeddings/TextEmbeddingsModel.mm +0 -45
  947. package/ios/RnExecutorch/models/text_embeddings/TextEmbeddingsUtils.h +0 -8
  948. package/ios/RnExecutorch/models/text_embeddings/TextEmbeddingsUtils.mm +0 -49
  949. package/ios/RnExecutorch/utils/Constants.h +0 -8
  950. package/ios/RnExecutorch/utils/ObjectDetectionUtils.hpp +0 -23
  951. package/ios/RnExecutorch/utils/SFFT.hpp +0 -13
  952. package/ios/RnExecutorch/utils/SFFT.mm +0 -71
  953. package/lib/module/constants/sttDefaults.js +0 -72
  954. package/lib/module/constants/sttDefaults.js.map +0 -1
  955. package/lib/module/controllers/SpeechToTextController.js +0 -307
  956. package/lib/module/controllers/SpeechToTextController.js.map +0 -1
  957. package/lib/module/native/NativeClassification.js +0 -5
  958. package/lib/module/native/NativeClassification.js.map +0 -1
  959. package/lib/module/native/NativeETModule.js +0 -5
  960. package/lib/module/native/NativeETModule.js.map +0 -1
  961. package/lib/module/native/NativeImageSegmentation.js +0 -5
  962. package/lib/module/native/NativeImageSegmentation.js.map +0 -1
  963. package/lib/module/native/NativeOCR.js +0 -5
  964. package/lib/module/native/NativeOCR.js.map +0 -1
  965. package/lib/module/native/NativeObjectDetection.js +0 -5
  966. package/lib/module/native/NativeObjectDetection.js.map +0 -1
  967. package/lib/module/native/NativeSpeechToText.js +0 -5
  968. package/lib/module/native/NativeSpeechToText.js.map +0 -1
  969. package/lib/module/native/NativeStyleTransfer.js +0 -5
  970. package/lib/module/native/NativeStyleTransfer.js.map +0 -1
  971. package/lib/module/native/NativeTextEmbeddings.js +0 -5
  972. package/lib/module/native/NativeTextEmbeddings.js.map +0 -1
  973. package/lib/module/native/NativeTokenizer.js +0 -5
  974. package/lib/module/native/NativeTokenizer.js.map +0 -1
  975. package/lib/module/native/NativeVerticalOCR.js +0 -5
  976. package/lib/module/native/NativeVerticalOCR.js.map +0 -1
  977. package/lib/module/package.json +0 -1
  978. package/lib/typescript/constants/sttDefaults.d.ts +0 -28
  979. package/lib/typescript/constants/sttDefaults.d.ts.map +0 -1
  980. package/lib/typescript/controllers/SpeechToTextController.d.ts +0 -52
  981. package/lib/typescript/controllers/SpeechToTextController.d.ts.map +0 -1
  982. package/lib/typescript/native/NativeClassification.d.ts +0 -10
  983. package/lib/typescript/native/NativeClassification.d.ts.map +0 -1
  984. package/lib/typescript/native/NativeETModule.d.ts +0 -9
  985. package/lib/typescript/native/NativeETModule.d.ts.map +0 -1
  986. package/lib/typescript/native/NativeImageSegmentation.d.ts +0 -10
  987. package/lib/typescript/native/NativeImageSegmentation.d.ts.map +0 -1
  988. package/lib/typescript/native/NativeOCR.d.ts +0 -9
  989. package/lib/typescript/native/NativeOCR.d.ts.map +0 -1
  990. package/lib/typescript/native/NativeObjectDetection.d.ts +0 -9
  991. package/lib/typescript/native/NativeObjectDetection.d.ts.map +0 -1
  992. package/lib/typescript/native/NativeSpeechToText.d.ts +0 -12
  993. package/lib/typescript/native/NativeSpeechToText.d.ts.map +0 -1
  994. package/lib/typescript/native/NativeStyleTransfer.d.ts.map +0 -1
  995. package/lib/typescript/native/NativeTextEmbeddings.d.ts +0 -8
  996. package/lib/typescript/native/NativeTextEmbeddings.d.ts.map +0 -1
  997. package/lib/typescript/native/NativeTokenizer.d.ts +0 -12
  998. package/lib/typescript/native/NativeTokenizer.d.ts.map +0 -1
  999. package/lib/typescript/native/NativeVerticalOCR.d.ts +0 -9
  1000. package/lib/typescript/native/NativeVerticalOCR.d.ts.map +0 -1
  1001. package/src/constants/sttDefaults.ts +0 -86
  1002. package/src/controllers/SpeechToTextController.ts +0 -458
  1003. package/src/index.tsx +0 -47
  1004. package/src/native/NativeClassification.ts +0 -9
  1005. package/src/native/NativeETModule.ts +0 -14
  1006. package/src/native/NativeImageSegmentation.ts +0 -14
  1007. package/src/native/NativeOCR.ts +0 -16
  1008. package/src/native/NativeObjectDetection.ts +0 -10
  1009. package/src/native/NativeSpeechToText.ts +0 -17
  1010. package/src/native/NativeStyleTransfer.ts +0 -10
  1011. package/src/native/NativeTextEmbeddings.ts +0 -9
  1012. package/src/native/NativeTokenizer.ts +0 -13
  1013. package/src/native/NativeVerticalOCR.ts +0 -16
@@ -0,0 +1,1756 @@
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
6
+ license.
7
+ // If you do not agree to this license, do not download, install,
8
+ // copy or use the software.
9
+ //
10
+ //
11
+ // License Agreement
12
+ // For Open Source Computer Vision Library
13
+ //
14
+ // Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
15
+ // Copyright (C) 2009, Willow Garage Inc., all rights reserved.
16
+ // Third party copyrights are property of their respective owners.
17
+ //
18
+ // Redistribution and use in source and binary forms, with or without
19
+ 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
26
+ notice,
27
+ // this list of conditions and the following disclaimer in the documentation
28
+ // and/or other materials provided with the distribution.
29
+ //
30
+ // * The name of the copyright holders may not be used to endorse or promote
31
+ products
32
+ // derived from this software without specific prior written permission.
33
+ //
34
+ // This software is provided by the copyright holders and contributors "as is"
35
+ and
36
+ // any express or implied warranties, including, but not limited to, the implied
37
+ // warranties of merchantability and fitness for a particular purpose are
38
+ disclaimed.
39
+ // In no event shall the Intel Corporation or contributors be liable for any
40
+ direct,
41
+ // indirect, incidental, special, exemplary, or consequential damages
42
+ // (including, but not limited to, procurement of substitute goods or services;
43
+ // loss of use, data, or profits; or business interruption) however caused
44
+ // and on any theory of liability, whether in contract, strict liability,
45
+ // or tort (including negligence or otherwise) arising in any way out of
46
+ // the use of this software, even if advised of the possibility of such damage.
47
+ //
48
+ //M*/
49
+
50
+ #ifndef OPENCV_FEATURES_2D_HPP
51
+ #define OPENCV_FEATURES_2D_HPP
52
+
53
+ #include "opencv2/core.hpp"
54
+ #include "opencv2/opencv_modules.hpp"
55
+
56
+ #ifdef HAVE_OPENCV_FLANN
57
+ #include "opencv2/flann/miniflann.hpp"
58
+ #endif
59
+
60
+ /**
61
+ @defgroup features2d 2D Features Framework
62
+ @{
63
+ @defgroup features2d_main Feature Detection and Description
64
+ @defgroup features2d_match Descriptor Matchers
65
+
66
+ Matchers of keypoint descriptors in OpenCV have wrappers with a common
67
+ interface that enables you to easily switch between different algorithms
68
+ solving the same problem. This section is devoted to matching descriptors that
69
+ are represented as vectors in a multidimensional space. All objects that
70
+ implement vector descriptor matchers inherit the DescriptorMatcher interface.
71
+
72
+ @defgroup features2d_draw Drawing Function of Keypoints and Matches
73
+ @defgroup features2d_category Object Categorization
74
+
75
+ This section describes approaches based on local 2D features and used to
76
+ categorize objects.
77
+
78
+ @defgroup feature2d_hal Hardware Acceleration Layer
79
+ @{
80
+ @defgroup features2d_hal_interface Interface
81
+ @}
82
+ @}
83
+ */
84
+
85
+ namespace cv {
86
+
87
+ //! @addtogroup features2d_main
88
+ //! @{
89
+
90
+ // //! writes vector of keypoints to the file storage
91
+ // CV_EXPORTS void write(FileStorage& fs, const String& name, const
92
+ // std::vector<KeyPoint>& keypoints);
93
+ // //! reads vector of keypoints from the specified file storage node
94
+ // CV_EXPORTS void read(const FileNode& node, CV_OUT std::vector<KeyPoint>&
95
+ // keypoints);
96
+
97
+ /** @brief A class filters a vector of keypoints.
98
+
99
+ Because now it is difficult to provide a convenient interface for all usage
100
+ scenarios of the keypoints filter class, it has only several needed by now
101
+ static methods.
102
+ */
103
+ class CV_EXPORTS KeyPointsFilter {
104
+ public:
105
+ KeyPointsFilter() {}
106
+
107
+ /*
108
+ * Remove keypoints within borderPixels of an image edge.
109
+ */
110
+ static void runByImageBorder(std::vector<KeyPoint> &keypoints, Size imageSize,
111
+ int borderSize);
112
+ /*
113
+ * Remove keypoints of sizes out of range.
114
+ */
115
+ static void runByKeypointSize(std::vector<KeyPoint> &keypoints, float minSize,
116
+ float maxSize = FLT_MAX);
117
+ /*
118
+ * Remove keypoints from some image by mask for pixels of this image.
119
+ */
120
+ static void runByPixelsMask(std::vector<KeyPoint> &keypoints,
121
+ const Mat &mask);
122
+ /*
123
+ * Remove objects from some image and a vector of points by mask for pixels of
124
+ * this image
125
+ */
126
+ static void
127
+ runByPixelsMask2VectorPoint(std::vector<KeyPoint> &keypoints,
128
+ std::vector<std::vector<Point>> &removeFrom,
129
+ const Mat &mask);
130
+ /*
131
+ * Remove duplicated keypoints.
132
+ */
133
+ static void removeDuplicated(std::vector<KeyPoint> &keypoints);
134
+ /*
135
+ * Remove duplicated keypoints and sort the remaining keypoints
136
+ */
137
+ static void removeDuplicatedSorted(std::vector<KeyPoint> &keypoints);
138
+
139
+ /*
140
+ * Retain the specified number of the best keypoints (according to the
141
+ * response)
142
+ */
143
+ static void retainBest(std::vector<KeyPoint> &keypoints, int npoints);
144
+ };
145
+
146
+ /************************************ Base Classes
147
+ * ************************************/
148
+
149
+ /** @brief Abstract base class for 2D image feature detectors and descriptor
150
+ * extractors
151
+ */
152
+ #ifdef __EMSCRIPTEN__
153
+ class CV_EXPORTS_W Feature2D : public Algorithm
154
+ #else
155
+ class CV_EXPORTS_W Feature2D : public virtual Algorithm
156
+ #endif
157
+ {
158
+ public:
159
+ virtual ~Feature2D();
160
+
161
+ /** @brief Detects keypoints in an image (first variant) or image set (second
162
+ variant).
163
+
164
+ @param image Image.
165
+ @param keypoints The detected keypoints. In the second variant of the method
166
+ keypoints[i] is a set of keypoints detected in images[i] .
167
+ @param mask Mask specifying where to look for keypoints (optional). It must be
168
+ a 8-bit integer matrix with non-zero values in the region of interest.
169
+ */
170
+ CV_WRAP virtual void detect(InputArray image,
171
+ CV_OUT std::vector<KeyPoint> &keypoints,
172
+ InputArray mask = noArray());
173
+
174
+ /** @overload
175
+ @param images Image set.
176
+ @param keypoints The detected keypoints. In the second variant of the method
177
+ keypoints[i] is a set of keypoints detected in images[i] .
178
+ @param masks Masks for each input image specifying where to look for keypoints
179
+ (optional). masks[i] is a mask for images[i].
180
+ */
181
+ CV_WRAP virtual void
182
+ detect(InputArrayOfArrays images,
183
+ CV_OUT std::vector<std::vector<KeyPoint>> &keypoints,
184
+ InputArrayOfArrays masks = noArray());
185
+
186
+ /** @brief Computes the descriptors for a set of keypoints detected in an
187
+ image (first variant) or image set (second variant).
188
+
189
+ @param image Image.
190
+ @param keypoints Input collection of keypoints. Keypoints for which a
191
+ descriptor cannot be computed are removed. Sometimes new keypoints can be
192
+ added, for example: SIFT duplicates keypoint with several dominant
193
+ orientations (for each orientation).
194
+ @param descriptors Computed descriptors. In the second variant of the method
195
+ descriptors[i] are descriptors computed for a keypoints[i]. Row j is the
196
+ keypoints (or keypoints[i]) is the descriptor for keypoint j-th keypoint.
197
+ */
198
+ CV_WRAP virtual void
199
+ compute(InputArray image, CV_OUT CV_IN_OUT std::vector<KeyPoint> &keypoints,
200
+ OutputArray descriptors);
201
+
202
+ /** @overload
203
+
204
+ @param images Image set.
205
+ @param keypoints Input collection of keypoints. Keypoints for which a
206
+ descriptor cannot be computed are removed. Sometimes new keypoints can be
207
+ added, for example: SIFT duplicates keypoint with several dominant
208
+ orientations (for each orientation).
209
+ @param descriptors Computed descriptors. In the second variant of the method
210
+ descriptors[i] are descriptors computed for a keypoints[i]. Row j is the
211
+ keypoints (or keypoints[i]) is the descriptor for keypoint j-th keypoint.
212
+ */
213
+ CV_WRAP virtual void
214
+ compute(InputArrayOfArrays images,
215
+ CV_OUT CV_IN_OUT std::vector<std::vector<KeyPoint>> &keypoints,
216
+ OutputArrayOfArrays descriptors);
217
+
218
+ /** Detects keypoints and computes the descriptors */
219
+ CV_WRAP virtual void detectAndCompute(InputArray image, InputArray mask,
220
+ CV_OUT std::vector<KeyPoint> &keypoints,
221
+ OutputArray descriptors,
222
+ bool useProvidedKeypoints = false);
223
+
224
+ CV_WRAP virtual int descriptorSize() const;
225
+ CV_WRAP virtual int descriptorType() const;
226
+ CV_WRAP virtual int defaultNorm() const;
227
+
228
+ CV_WRAP void write(const String &fileName) const;
229
+
230
+ CV_WRAP void read(const String &fileName);
231
+
232
+ virtual void write(FileStorage &) const CV_OVERRIDE;
233
+
234
+ // see corresponding cv::Algorithm method
235
+ CV_WRAP virtual void read(const FileNode &) CV_OVERRIDE;
236
+
237
+ //! Return true if detector object is empty
238
+ CV_WRAP virtual bool empty() const CV_OVERRIDE;
239
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
240
+
241
+ // see corresponding cv::Algorithm method
242
+ CV_WRAP inline void write(FileStorage &fs, const String &name) const {
243
+ Algorithm::write(fs, name);
244
+ }
245
+ #if CV_VERSION_MAJOR < 5
246
+ inline void write(const Ptr<FileStorage> &fs, const String &name) const {
247
+ CV_Assert(fs);
248
+ Algorithm::write(*fs, name);
249
+ }
250
+ #endif
251
+ };
252
+
253
+ /** Feature detectors in OpenCV have wrappers with a common interface that
254
+ enables you to easily switch between different algorithms solving the same
255
+ problem. All objects that implement keypoint detectors inherit the
256
+ FeatureDetector interface. */
257
+ typedef Feature2D FeatureDetector;
258
+
259
+ /** Extractors of keypoint descriptors in OpenCV have wrappers with a common
260
+ interface that enables you to easily switch between different algorithms solving
261
+ the same problem. This section is devoted to computing descriptors represented
262
+ as vectors in a multidimensional space. All objects that implement the vector
263
+ descriptor extractors inherit the DescriptorExtractor interface.
264
+ */
265
+ typedef Feature2D DescriptorExtractor;
266
+
267
+ /** @brief Class for implementing the wrapper which makes detectors and
268
+ extractors to be affine invariant, described as ASIFT in @cite YM11 .
269
+ */
270
+ class CV_EXPORTS_W AffineFeature : public Feature2D {
271
+ public:
272
+ /**
273
+ @param backend The detector/extractor you want to use as backend.
274
+ @param maxTilt The highest power index of tilt factor. 5 is used in the paper
275
+ as tilt sampling range n.
276
+ @param minTilt The lowest power index of tilt factor. 0 is used in the paper.
277
+ @param tiltStep Tilt sampling step \f$\delta_t\f$ in Algorithm 1 in the paper.
278
+ @param rotateStepBase Rotation sampling step factor b in Algorithm 1 in the
279
+ paper.
280
+ */
281
+ CV_WRAP static Ptr<AffineFeature> create(const Ptr<Feature2D> &backend,
282
+ int maxTilt = 5, int minTilt = 0,
283
+ float tiltStep = 1.4142135623730951f,
284
+ float rotateStepBase = 72);
285
+
286
+ CV_WRAP virtual void setViewParams(const std::vector<float> &tilts,
287
+ const std::vector<float> &rolls) = 0;
288
+ CV_WRAP virtual void getViewParams(std::vector<float> &tilts,
289
+ std::vector<float> &rolls) const = 0;
290
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
291
+ };
292
+
293
+ typedef AffineFeature AffineFeatureDetector;
294
+ typedef AffineFeature AffineDescriptorExtractor;
295
+
296
+ /** @brief Class for extracting keypoints and computing descriptors using the
297
+ Scale Invariant Feature Transform (SIFT) algorithm by D. Lowe @cite Lowe04 .
298
+ */
299
+ class CV_EXPORTS_W SIFT : public Feature2D {
300
+ public:
301
+ /**
302
+ @param nfeatures The number of best features to retain. The features are
303
+ ranked by their scores (measured in SIFT algorithm as the local contrast)
304
+
305
+ @param nOctaveLayers The number of layers in each octave. 3 is the value used
306
+ in D. Lowe paper. The number of octaves is computed automatically from the
307
+ image resolution.
308
+
309
+ @param contrastThreshold The contrast threshold used to filter out weak
310
+ features in semi-uniform (low-contrast) regions. The larger the threshold, the
311
+ less features are produced by the detector.
312
+
313
+ @note The contrast threshold will be divided by nOctaveLayers when the
314
+ filtering is applied. When nOctaveLayers is set to default and if you want to
315
+ use the value used in D. Lowe paper, 0.03, set this argument to 0.09.
316
+
317
+ @param edgeThreshold The threshold used to filter out edge-like features. Note
318
+ that the its meaning is different from the contrastThreshold, i.e. the larger
319
+ the edgeThreshold, the less features are filtered out (more features are
320
+ retained).
321
+
322
+ @param sigma The sigma of the Gaussian applied to the input image at the
323
+ octave \#0. If your image is captured with a weak camera with soft lenses, you
324
+ might want to reduce the number.
325
+
326
+ @param enable_precise_upscale Whether to enable precise upscaling in the scale
327
+ pyramid, which maps index \f$\texttt{x}\f$ to \f$\texttt{2x}\f$. This prevents
328
+ localization bias. The option is disabled by default.
329
+ */
330
+ CV_WRAP static Ptr<SIFT> create(int nfeatures = 0, int nOctaveLayers = 3,
331
+ double contrastThreshold = 0.04,
332
+ double edgeThreshold = 10, double sigma = 1.6,
333
+ bool enable_precise_upscale = false);
334
+
335
+ /** @brief Create SIFT with specified descriptorType.
336
+ @param nfeatures The number of best features to retain. The features are
337
+ ranked by their scores (measured in SIFT algorithm as the local contrast)
338
+
339
+ @param nOctaveLayers The number of layers in each octave. 3 is the value used
340
+ in D. Lowe paper. The number of octaves is computed automatically from the
341
+ image resolution.
342
+
343
+ @param contrastThreshold The contrast threshold used to filter out weak
344
+ features in semi-uniform (low-contrast) regions. The larger the threshold, the
345
+ less features are produced by the detector.
346
+
347
+ @note The contrast threshold will be divided by nOctaveLayers when the
348
+ filtering is applied. When nOctaveLayers is set to default and if you want to
349
+ use the value used in D. Lowe paper, 0.03, set this argument to 0.09.
350
+
351
+ @param edgeThreshold The threshold used to filter out edge-like features. Note
352
+ that the its meaning is different from the contrastThreshold, i.e. the larger
353
+ the edgeThreshold, the less features are filtered out (more features are
354
+ retained).
355
+
356
+ @param sigma The sigma of the Gaussian applied to the input image at the
357
+ octave \#0. If your image is captured with a weak camera with soft lenses, you
358
+ might want to reduce the number.
359
+
360
+ @param descriptorType The type of descriptors. Only CV_32F and CV_8U are
361
+ supported.
362
+
363
+ @param enable_precise_upscale Whether to enable precise upscaling in the scale
364
+ pyramid, which maps index \f$\texttt{x}\f$ to \f$\texttt{2x}\f$. This prevents
365
+ localization bias. The option is disabled by default.
366
+ */
367
+ CV_WRAP static Ptr<SIFT> create(int nfeatures, int nOctaveLayers,
368
+ double contrastThreshold,
369
+ double edgeThreshold, double sigma,
370
+ int descriptorType,
371
+ bool enable_precise_upscale = false);
372
+
373
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
374
+
375
+ CV_WRAP virtual void setNFeatures(int maxFeatures) = 0;
376
+ CV_WRAP virtual int getNFeatures() const = 0;
377
+
378
+ CV_WRAP virtual void setNOctaveLayers(int nOctaveLayers) = 0;
379
+ CV_WRAP virtual int getNOctaveLayers() const = 0;
380
+
381
+ CV_WRAP virtual void setContrastThreshold(double contrastThreshold) = 0;
382
+ CV_WRAP virtual double getContrastThreshold() const = 0;
383
+
384
+ CV_WRAP virtual void setEdgeThreshold(double edgeThreshold) = 0;
385
+ CV_WRAP virtual double getEdgeThreshold() const = 0;
386
+
387
+ CV_WRAP virtual void setSigma(double sigma) = 0;
388
+ CV_WRAP virtual double getSigma() const = 0;
389
+ };
390
+
391
+ typedef SIFT SiftFeatureDetector;
392
+ typedef SIFT SiftDescriptorExtractor;
393
+
394
+ /** @brief Class implementing the BRISK keypoint detector and descriptor
395
+ * extractor, described in @cite LCS11 .
396
+ */
397
+ class CV_EXPORTS_W BRISK : public Feature2D {
398
+ public:
399
+ /** @brief The BRISK constructor
400
+
401
+ @param thresh AGAST detection threshold score.
402
+ @param octaves detection octaves. Use 0 to do single scale.
403
+ @param patternScale apply this scale to the pattern used for sampling the
404
+ neighbourhood of a keypoint.
405
+ */
406
+ CV_WRAP static Ptr<BRISK> create(int thresh = 30, int octaves = 3,
407
+ float patternScale = 1.0f);
408
+
409
+ /** @brief The BRISK constructor for a custom pattern
410
+
411
+ @param radiusList defines the radii (in pixels) where the samples around a
412
+ keypoint are taken (for keypoint scale 1).
413
+ @param numberList defines the number of sampling points on the sampling
414
+ circle. Must be the same size as radiusList..
415
+ @param dMax threshold for the short pairings used for descriptor formation (in
416
+ pixels for keypoint scale 1).
417
+ @param dMin threshold for the long pairings used for orientation determination
418
+ (in pixels for keypoint scale 1).
419
+ @param indexChange index remapping of the bits. */
420
+ CV_WRAP static Ptr<BRISK>
421
+ create(const std::vector<float> &radiusList,
422
+ const std::vector<int> &numberList, float dMax = 5.85f,
423
+ float dMin = 8.2f,
424
+ const std::vector<int> &indexChange = std::vector<int>());
425
+
426
+ /** @brief The BRISK constructor for a custom pattern, detection threshold and
427
+ octaves
428
+
429
+ @param thresh AGAST detection threshold score.
430
+ @param octaves detection octaves. Use 0 to do single scale.
431
+ @param radiusList defines the radii (in pixels) where the samples around a
432
+ keypoint are taken (for keypoint scale 1).
433
+ @param numberList defines the number of sampling points on the sampling
434
+ circle. Must be the same size as radiusList..
435
+ @param dMax threshold for the short pairings used for descriptor formation (in
436
+ pixels for keypoint scale 1).
437
+ @param dMin threshold for the long pairings used for orientation determination
438
+ (in pixels for keypoint scale 1).
439
+ @param indexChange index remapping of the bits. */
440
+ CV_WRAP static Ptr<BRISK>
441
+ create(int thresh, int octaves, const std::vector<float> &radiusList,
442
+ const std::vector<int> &numberList, float dMax = 5.85f,
443
+ float dMin = 8.2f,
444
+ const std::vector<int> &indexChange = std::vector<int>());
445
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
446
+
447
+ /** @brief Set detection threshold.
448
+ @param threshold AGAST detection threshold score.
449
+ */
450
+ CV_WRAP virtual void setThreshold(int threshold) = 0;
451
+ CV_WRAP virtual int getThreshold() const = 0;
452
+
453
+ /** @brief Set detection octaves.
454
+ @param octaves detection octaves. Use 0 to do single scale.
455
+ */
456
+ CV_WRAP virtual void setOctaves(int octaves) = 0;
457
+ CV_WRAP virtual int getOctaves() const = 0;
458
+ /** @brief Set detection patternScale.
459
+ @param patternScale apply this scale to the pattern used for sampling the
460
+ neighbourhood of a keypoint.
461
+ */
462
+ CV_WRAP virtual void setPatternScale(float patternScale) = 0;
463
+ CV_WRAP virtual float getPatternScale() const = 0;
464
+ };
465
+
466
+ /** @brief Class implementing the ORB (*oriented BRIEF*) keypoint detector and
467
+ descriptor extractor
468
+
469
+ described in @cite RRKB11 . The algorithm uses FAST in pyramids to detect stable
470
+ keypoints, selects the strongest features using FAST or Harris response, finds
471
+ their orientation using first-order moments and computes the descriptors using
472
+ BRIEF (where the coordinates of random point pairs (or k-tuples) are rotated
473
+ according to the measured orientation).
474
+ */
475
+ class CV_EXPORTS_W ORB : public Feature2D {
476
+ public:
477
+ enum ScoreType { HARRIS_SCORE = 0, FAST_SCORE = 1 };
478
+ static const int kBytes = 32;
479
+
480
+ /** @brief The ORB constructor
481
+
482
+ @param nfeatures The maximum number of features to retain.
483
+ @param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2
484
+ means the classical pyramid, where each next level has 4x less pixels than the
485
+ previous, but such a big scale factor will degrade feature matching scores
486
+ dramatically. On the other hand, too close to 1 scale factor will mean that to
487
+ cover certain scale range you will need more pyramid levels and so the speed
488
+ will suffer.
489
+ @param nlevels The number of pyramid levels. The smallest level will have
490
+ linear size equal to input_image_linear_size/pow(scaleFactor, nlevels -
491
+ firstLevel).
492
+ @param edgeThreshold This is size of the border where the features are not
493
+ detected. It should roughly match the patchSize parameter.
494
+ @param firstLevel The level of pyramid to put source image to. Previous layers
495
+ are filled with upscaled source image.
496
+ @param WTA_K The number of points that produce each element of the oriented
497
+ BRIEF descriptor. The default value 2 means the BRIEF where we take a random
498
+ point pair and compare their brightnesses, so we get 0/1 response. Other
499
+ possible values are 3 and 4. For example, 3 means that we take 3 random points
500
+ (of course, those point coordinates are random, but they are generated from
501
+ the pre-defined seed, so each element of BRIEF descriptor is computed
502
+ deterministically from the pixel rectangle), find point of maximum brightness
503
+ and output index of the winner (0, 1 or 2). Such output will occupy 2 bits,
504
+ and therefore it will need a special variant of Hamming distance, denoted as
505
+ NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to
506
+ compute each bin (that will also occupy 2 bits with possible values 0, 1, 2 or
507
+ 3).
508
+ @param scoreType The default HARRIS_SCORE means that Harris algorithm is used
509
+ to rank features (the score is written to KeyPoint::score and is used to
510
+ retain best nfeatures features); FAST_SCORE is alternative value of the
511
+ parameter that produces slightly less stable keypoints, but it is a little
512
+ faster to compute.
513
+ @param patchSize size of the patch used by the oriented BRIEF descriptor. Of
514
+ course, on smaller pyramid layers the perceived image area covered by a
515
+ feature will be larger.
516
+ @param fastThreshold the fast threshold
517
+ */
518
+ CV_WRAP static Ptr<ORB> create(int nfeatures = 500, float scaleFactor = 1.2f,
519
+ int nlevels = 8, int edgeThreshold = 31,
520
+ int firstLevel = 0, int WTA_K = 2,
521
+ ORB::ScoreType scoreType = ORB::HARRIS_SCORE,
522
+ int patchSize = 31, int fastThreshold = 20);
523
+
524
+ CV_WRAP virtual void setMaxFeatures(int maxFeatures) = 0;
525
+ CV_WRAP virtual int getMaxFeatures() const = 0;
526
+
527
+ CV_WRAP virtual void setScaleFactor(double scaleFactor) = 0;
528
+ CV_WRAP virtual double getScaleFactor() const = 0;
529
+
530
+ CV_WRAP virtual void setNLevels(int nlevels) = 0;
531
+ CV_WRAP virtual int getNLevels() const = 0;
532
+
533
+ CV_WRAP virtual void setEdgeThreshold(int edgeThreshold) = 0;
534
+ CV_WRAP virtual int getEdgeThreshold() const = 0;
535
+
536
+ CV_WRAP virtual void setFirstLevel(int firstLevel) = 0;
537
+ CV_WRAP virtual int getFirstLevel() const = 0;
538
+
539
+ CV_WRAP virtual void setWTA_K(int wta_k) = 0;
540
+ CV_WRAP virtual int getWTA_K() const = 0;
541
+
542
+ CV_WRAP virtual void setScoreType(ORB::ScoreType scoreType) = 0;
543
+ CV_WRAP virtual ORB::ScoreType getScoreType() const = 0;
544
+
545
+ CV_WRAP virtual void setPatchSize(int patchSize) = 0;
546
+ CV_WRAP virtual int getPatchSize() const = 0;
547
+
548
+ CV_WRAP virtual void setFastThreshold(int fastThreshold) = 0;
549
+ CV_WRAP virtual int getFastThreshold() const = 0;
550
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
551
+ };
552
+
553
+ /** @brief Maximally stable extremal region extractor
554
+
555
+ The class encapsulates all the parameters of the %MSER extraction algorithm (see
556
+ [wiki article](http://en.wikipedia.org/wiki/Maximally_stable_extremal_regions)).
557
+
558
+ - there are two different implementation of %MSER: one for grey image, one for
559
+ color image
560
+
561
+ - the grey image algorithm is taken from: @cite nister2008linear ; the paper
562
+ claims to be faster than union-find method; it actually get 1.5~2m/s on my
563
+ centrino L7200 1.2GHz laptop.
564
+
565
+ - the color image algorithm is taken from: @cite forssen2007maximally ; it
566
+ should be much slower than grey image method ( 3~4 times )
567
+
568
+ - (Python) A complete example showing the use of the %MSER detector can be found
569
+ at samples/python/mser.py
570
+ */
571
+ class CV_EXPORTS_W MSER : public Feature2D {
572
+ public:
573
+ /** @brief Full constructor for %MSER detector
574
+
575
+ @param delta it compares \f$(size_{i}-size_{i-delta})/size_{i-delta}\f$
576
+ @param min_area prune the area which smaller than minArea
577
+ @param max_area prune the area which bigger than maxArea
578
+ @param max_variation prune the area have similar size to its children
579
+ @param min_diversity for color image, trace back to cut off mser with
580
+ diversity less than min_diversity
581
+ @param max_evolution for color image, the evolution steps
582
+ @param area_threshold for color image, the area threshold to cause
583
+ re-initialize
584
+ @param min_margin for color image, ignore too small margin
585
+ @param edge_blur_size for color image, the aperture size for edge blur
586
+ */
587
+ CV_WRAP static Ptr<MSER>
588
+ create(int delta = 5, int min_area = 60, int max_area = 14400,
589
+ double max_variation = 0.25, double min_diversity = .2,
590
+ int max_evolution = 200, double area_threshold = 1.01,
591
+ double min_margin = 0.003, int edge_blur_size = 5);
592
+
593
+ /** @brief Detect %MSER regions
594
+
595
+ @param image input image (8UC1, 8UC3 or 8UC4, must be greater or equal than
596
+ 3x3)
597
+ @param msers resulting list of point sets
598
+ @param bboxes resulting bounding boxes
599
+ */
600
+ CV_WRAP virtual void
601
+ detectRegions(InputArray image, CV_OUT std::vector<std::vector<Point>> &msers,
602
+ CV_OUT std::vector<Rect> &bboxes) = 0;
603
+
604
+ CV_WRAP virtual void setDelta(int delta) = 0;
605
+ CV_WRAP virtual int getDelta() const = 0;
606
+
607
+ CV_WRAP virtual void setMinArea(int minArea) = 0;
608
+ CV_WRAP virtual int getMinArea() const = 0;
609
+
610
+ CV_WRAP virtual void setMaxArea(int maxArea) = 0;
611
+ CV_WRAP virtual int getMaxArea() const = 0;
612
+
613
+ CV_WRAP virtual void setMaxVariation(double maxVariation) = 0;
614
+ CV_WRAP virtual double getMaxVariation() const = 0;
615
+
616
+ CV_WRAP virtual void setMinDiversity(double minDiversity) = 0;
617
+ CV_WRAP virtual double getMinDiversity() const = 0;
618
+
619
+ CV_WRAP virtual void setMaxEvolution(int maxEvolution) = 0;
620
+ CV_WRAP virtual int getMaxEvolution() const = 0;
621
+
622
+ CV_WRAP virtual void setAreaThreshold(double areaThreshold) = 0;
623
+ CV_WRAP virtual double getAreaThreshold() const = 0;
624
+
625
+ CV_WRAP virtual void setMinMargin(double min_margin) = 0;
626
+ CV_WRAP virtual double getMinMargin() const = 0;
627
+
628
+ CV_WRAP virtual void setEdgeBlurSize(int edge_blur_size) = 0;
629
+ CV_WRAP virtual int getEdgeBlurSize() const = 0;
630
+
631
+ CV_WRAP virtual void setPass2Only(bool f) = 0;
632
+ CV_WRAP virtual bool getPass2Only() const = 0;
633
+
634
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
635
+ };
636
+
637
+ /** @brief Wrapping class for feature detection using the FAST method. :
638
+ */
639
+ class CV_EXPORTS_W FastFeatureDetector : public Feature2D {
640
+ public:
641
+ enum DetectorType { TYPE_5_8 = 0, TYPE_7_12 = 1, TYPE_9_16 = 2 };
642
+ enum { THRESHOLD = 10000, NONMAX_SUPPRESSION = 10001, FAST_N = 10002 };
643
+
644
+ CV_WRAP static Ptr<FastFeatureDetector> create(
645
+ int threshold = 10, bool nonmaxSuppression = true,
646
+ FastFeatureDetector::DetectorType type = FastFeatureDetector::TYPE_9_16);
647
+
648
+ CV_WRAP virtual void setThreshold(int threshold) = 0;
649
+ CV_WRAP virtual int getThreshold() const = 0;
650
+
651
+ CV_WRAP virtual void setNonmaxSuppression(bool f) = 0;
652
+ CV_WRAP virtual bool getNonmaxSuppression() const = 0;
653
+
654
+ CV_WRAP virtual void setType(FastFeatureDetector::DetectorType type) = 0;
655
+ CV_WRAP virtual FastFeatureDetector::DetectorType getType() const = 0;
656
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
657
+ };
658
+
659
+ /** @overload */
660
+ CV_EXPORTS void FAST(InputArray image, CV_OUT std::vector<KeyPoint> &keypoints,
661
+ int threshold, bool nonmaxSuppression = true);
662
+
663
+ /** @brief Detects corners using the FAST algorithm
664
+
665
+ @param image grayscale image where keypoints (corners) are detected.
666
+ @param keypoints keypoints detected on the image.
667
+ @param threshold threshold on difference between intensity of the central pixel
668
+ and pixels of a circle around this pixel.
669
+ @param nonmaxSuppression if true, non-maximum suppression is applied to detected
670
+ corners (keypoints).
671
+ @param type one of the three neighborhoods as defined in the paper:
672
+ FastFeatureDetector::TYPE_9_16, FastFeatureDetector::TYPE_7_12,
673
+ FastFeatureDetector::TYPE_5_8
674
+
675
+ Detects corners using the FAST algorithm by @cite Rosten06 .
676
+
677
+ @note In Python API, types are given as cv.FAST_FEATURE_DETECTOR_TYPE_5_8,
678
+ cv.FAST_FEATURE_DETECTOR_TYPE_7_12 and cv.FAST_FEATURE_DETECTOR_TYPE_9_16. For
679
+ corner detection, use cv.FAST.detect() method.
680
+ */
681
+ CV_EXPORTS void FAST(InputArray image, CV_OUT std::vector<KeyPoint> &keypoints,
682
+ int threshold, bool nonmaxSuppression,
683
+ FastFeatureDetector::DetectorType type);
684
+
685
+ /** @brief Wrapping class for feature detection using the AGAST method. :
686
+ */
687
+ class CV_EXPORTS_W AgastFeatureDetector : public Feature2D {
688
+ public:
689
+ enum DetectorType {
690
+ AGAST_5_8 = 0,
691
+ AGAST_7_12d = 1,
692
+ AGAST_7_12s = 2,
693
+ OAST_9_16 = 3,
694
+ };
695
+
696
+ enum {
697
+ THRESHOLD = 10000,
698
+ NONMAX_SUPPRESSION = 10001,
699
+ };
700
+
701
+ CV_WRAP static Ptr<AgastFeatureDetector>
702
+ create(int threshold = 10, bool nonmaxSuppression = true,
703
+ AgastFeatureDetector::DetectorType type =
704
+ AgastFeatureDetector::OAST_9_16);
705
+
706
+ CV_WRAP virtual void setThreshold(int threshold) = 0;
707
+ CV_WRAP virtual int getThreshold() const = 0;
708
+
709
+ CV_WRAP virtual void setNonmaxSuppression(bool f) = 0;
710
+ CV_WRAP virtual bool getNonmaxSuppression() const = 0;
711
+
712
+ CV_WRAP virtual void setType(AgastFeatureDetector::DetectorType type) = 0;
713
+ CV_WRAP virtual AgastFeatureDetector::DetectorType getType() const = 0;
714
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
715
+ };
716
+
717
+ /** @overload */
718
+ CV_EXPORTS void AGAST(InputArray image, CV_OUT std::vector<KeyPoint> &keypoints,
719
+ int threshold, bool nonmaxSuppression = true);
720
+
721
+ /** @brief Detects corners using the AGAST algorithm
722
+
723
+ @param image grayscale image where keypoints (corners) are detected.
724
+ @param keypoints keypoints detected on the image.
725
+ @param threshold threshold on difference between intensity of the central pixel
726
+ and pixels of a circle around this pixel.
727
+ @param nonmaxSuppression if true, non-maximum suppression is applied to detected
728
+ corners (keypoints).
729
+ @param type one of the four neighborhoods as defined in the paper:
730
+ AgastFeatureDetector::AGAST_5_8, AgastFeatureDetector::AGAST_7_12d,
731
+ AgastFeatureDetector::AGAST_7_12s, AgastFeatureDetector::OAST_9_16
732
+
733
+ For non-Intel platforms, there is a tree optimised variant of AGAST with same
734
+ numerical results. The 32-bit binary tree tables were generated automatically
735
+ from original code using perl script. The perl script and examples of tree
736
+ generation are placed in features2d/doc folder. Detects corners using the AGAST
737
+ algorithm by @cite mair2010_agast .
738
+
739
+ */
740
+ CV_EXPORTS void AGAST(InputArray image, CV_OUT std::vector<KeyPoint> &keypoints,
741
+ int threshold, bool nonmaxSuppression,
742
+ AgastFeatureDetector::DetectorType type);
743
+
744
+ /** @brief Wrapping class for feature detection using the goodFeaturesToTrack
745
+ * function. :
746
+ */
747
+ class CV_EXPORTS_W GFTTDetector : public Feature2D {
748
+ public:
749
+ CV_WRAP static Ptr<GFTTDetector>
750
+ create(int maxCorners = 1000, double qualityLevel = 0.01,
751
+ double minDistance = 1, int blockSize = 3,
752
+ bool useHarrisDetector = false, double k = 0.04);
753
+ CV_WRAP static Ptr<GFTTDetector>
754
+ create(int maxCorners, double qualityLevel, double minDistance, int blockSize,
755
+ int gradiantSize, bool useHarrisDetector = false, double k = 0.04);
756
+ CV_WRAP virtual void setMaxFeatures(int maxFeatures) = 0;
757
+ CV_WRAP virtual int getMaxFeatures() const = 0;
758
+
759
+ CV_WRAP virtual void setQualityLevel(double qlevel) = 0;
760
+ CV_WRAP virtual double getQualityLevel() const = 0;
761
+
762
+ CV_WRAP virtual void setMinDistance(double minDistance) = 0;
763
+ CV_WRAP virtual double getMinDistance() const = 0;
764
+
765
+ CV_WRAP virtual void setBlockSize(int blockSize) = 0;
766
+ CV_WRAP virtual int getBlockSize() const = 0;
767
+
768
+ CV_WRAP virtual void setGradientSize(int gradientSize_) = 0;
769
+ CV_WRAP virtual int getGradientSize() = 0;
770
+
771
+ CV_WRAP virtual void setHarrisDetector(bool val) = 0;
772
+ CV_WRAP virtual bool getHarrisDetector() const = 0;
773
+
774
+ CV_WRAP virtual void setK(double k) = 0;
775
+ CV_WRAP virtual double getK() const = 0;
776
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
777
+ };
778
+
779
+ /** @brief Class for extracting blobs from an image. :
780
+
781
+ The class implements a simple algorithm for extracting blobs from an image:
782
+
783
+ 1. Convert the source image to binary images by applying thresholding with
784
+ several thresholds from minThreshold (inclusive) to maxThreshold (exclusive)
785
+ with distance thresholdStep between neighboring thresholds.
786
+ 2. Extract connected components from every binary image by findContours and
787
+ calculate their centers.
788
+ 3. Group centers from several binary images by their coordinates. Close centers
789
+ form one group that corresponds to one blob, which is controlled by the
790
+ minDistBetweenBlobs parameter.
791
+ 4. From the groups, estimate final centers of blobs and their radiuses and
792
+ return as locations and sizes of keypoints.
793
+
794
+ This class performs several filtrations of returned blobs. You should set
795
+ filterBy\* to true/false to turn on/off corresponding filtration. Available
796
+ filtrations:
797
+
798
+ - **By color**. This filter compares the intensity of a binary image at the
799
+ center of a blob to blobColor. If they differ, the blob is filtered out. Use
800
+ blobColor = 0 to extract dark blobs and blobColor = 255 to extract light blobs.
801
+ - **By area**. Extracted blobs have an area between minArea (inclusive) and
802
+ maxArea (exclusive).
803
+ - **By circularity**. Extracted blobs have circularity
804
+ (\f$\frac{4*\pi*Area}{perimeter * perimeter}\f$) between minCircularity
805
+ (inclusive) and maxCircularity (exclusive).
806
+ - **By ratio of the minimum inertia to maximum inertia**. Extracted blobs have
807
+ this ratio between minInertiaRatio (inclusive) and maxInertiaRatio (exclusive).
808
+ - **By convexity**. Extracted blobs have convexity (area / area of blob convex
809
+ hull) between minConvexity (inclusive) and maxConvexity (exclusive).
810
+
811
+ Default values of parameters are tuned to extract dark circular blobs.
812
+ */
813
+ class CV_EXPORTS_W SimpleBlobDetector : public Feature2D {
814
+ public:
815
+ struct CV_EXPORTS_W_SIMPLE Params {
816
+ CV_WRAP Params();
817
+ CV_PROP_RW float thresholdStep;
818
+ CV_PROP_RW float minThreshold;
819
+ CV_PROP_RW float maxThreshold;
820
+ CV_PROP_RW size_t minRepeatability;
821
+ CV_PROP_RW float minDistBetweenBlobs;
822
+
823
+ CV_PROP_RW bool filterByColor;
824
+ CV_PROP_RW uchar blobColor;
825
+
826
+ CV_PROP_RW bool filterByArea;
827
+ CV_PROP_RW float minArea, maxArea;
828
+
829
+ CV_PROP_RW bool filterByCircularity;
830
+ CV_PROP_RW float minCircularity, maxCircularity;
831
+
832
+ CV_PROP_RW bool filterByInertia;
833
+ CV_PROP_RW float minInertiaRatio, maxInertiaRatio;
834
+
835
+ CV_PROP_RW bool filterByConvexity;
836
+ CV_PROP_RW float minConvexity, maxConvexity;
837
+
838
+ CV_PROP_RW bool collectContours;
839
+
840
+ void read(const FileNode &fn);
841
+ void write(FileStorage &fs) const;
842
+ };
843
+
844
+ CV_WRAP static Ptr<SimpleBlobDetector>
845
+ create(const SimpleBlobDetector::Params &parameters =
846
+ SimpleBlobDetector::Params());
847
+
848
+ CV_WRAP virtual void setParams(const SimpleBlobDetector::Params &params) = 0;
849
+ CV_WRAP virtual SimpleBlobDetector::Params getParams() const = 0;
850
+
851
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
852
+ CV_WRAP virtual const std::vector<std::vector<cv::Point>> &
853
+ getBlobContours() const;
854
+ };
855
+
856
+ /** @brief Class implementing the KAZE keypoint detector and descriptor
857
+ extractor, described in @cite ABD12 .
858
+
859
+ @note AKAZE descriptor can only be used with KAZE or AKAZE keypoints .. [ABD12]
860
+ KAZE Features. Pablo F. Alcantarilla, Adrien Bartoli and Andrew J. Davison. In
861
+ European Conference on Computer Vision (ECCV), Fiorenze, Italy, October 2012.
862
+ */
863
+ class CV_EXPORTS_W KAZE : public Feature2D {
864
+ public:
865
+ enum DiffusivityType {
866
+ DIFF_PM_G1 = 0,
867
+ DIFF_PM_G2 = 1,
868
+ DIFF_WEICKERT = 2,
869
+ DIFF_CHARBONNIER = 3
870
+ };
871
+
872
+ /** @brief The KAZE constructor
873
+
874
+ @param extended Set to enable extraction of extended (128-byte) descriptor.
875
+ @param upright Set to enable use of upright descriptors (non
876
+ rotation-invariant).
877
+ @param threshold Detector response threshold to accept point
878
+ @param nOctaves Maximum octave evolution of the image
879
+ @param nOctaveLayers Default number of sublevels per scale level
880
+ @param diffusivity Diffusivity type. DIFF_PM_G1, DIFF_PM_G2, DIFF_WEICKERT or
881
+ DIFF_CHARBONNIER
882
+ */
883
+ CV_WRAP static Ptr<KAZE>
884
+ create(bool extended = false, bool upright = false, float threshold = 0.001f,
885
+ int nOctaves = 4, int nOctaveLayers = 4,
886
+ KAZE::DiffusivityType diffusivity = KAZE::DIFF_PM_G2);
887
+
888
+ CV_WRAP virtual void setExtended(bool extended) = 0;
889
+ CV_WRAP virtual bool getExtended() const = 0;
890
+
891
+ CV_WRAP virtual void setUpright(bool upright) = 0;
892
+ CV_WRAP virtual bool getUpright() const = 0;
893
+
894
+ CV_WRAP virtual void setThreshold(double threshold) = 0;
895
+ CV_WRAP virtual double getThreshold() const = 0;
896
+
897
+ CV_WRAP virtual void setNOctaves(int octaves) = 0;
898
+ CV_WRAP virtual int getNOctaves() const = 0;
899
+
900
+ CV_WRAP virtual void setNOctaveLayers(int octaveLayers) = 0;
901
+ CV_WRAP virtual int getNOctaveLayers() const = 0;
902
+
903
+ CV_WRAP virtual void setDiffusivity(KAZE::DiffusivityType diff) = 0;
904
+ CV_WRAP virtual KAZE::DiffusivityType getDiffusivity() const = 0;
905
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
906
+ };
907
+
908
+ /** @brief Class implementing the AKAZE keypoint detector and descriptor
909
+ extractor, described in @cite ANB13.
910
+
911
+ @details AKAZE descriptors can only be used with KAZE or AKAZE keypoints. This
912
+ class is thread-safe.
913
+
914
+ @note When you need descriptors use Feature2D::detectAndCompute, which
915
+ provides better performance. When using Feature2D::detect followed by
916
+ Feature2D::compute scale space pyramid is computed twice.
917
+
918
+ @note AKAZE implements T-API. When image is passed as UMat some parts of the
919
+ algorithm will use OpenCL.
920
+
921
+ @note [ANB13] Fast Explicit Diffusion for Accelerated Features in Nonlinear
922
+ Scale Spaces. Pablo F. Alcantarilla, Jesús Nuevo and Adrien Bartoli. In
923
+ British Machine Vision Conference (BMVC), Bristol, UK, September 2013.
924
+
925
+ */
926
+ class CV_EXPORTS_W AKAZE : public Feature2D {
927
+ public:
928
+ // AKAZE descriptor type
929
+ enum DescriptorType {
930
+ DESCRIPTOR_KAZE_UPRIGHT =
931
+ 2, ///< Upright descriptors, not invariant to rotation
932
+ DESCRIPTOR_KAZE = 3,
933
+ DESCRIPTOR_MLDB_UPRIGHT =
934
+ 4, ///< Upright descriptors, not invariant to rotation
935
+ DESCRIPTOR_MLDB = 5
936
+ };
937
+
938
+ /** @brief The AKAZE constructor
939
+
940
+ @param descriptor_type Type of the extracted descriptor: DESCRIPTOR_KAZE,
941
+ DESCRIPTOR_KAZE_UPRIGHT, DESCRIPTOR_MLDB or DESCRIPTOR_MLDB_UPRIGHT.
942
+ @param descriptor_size Size of the descriptor in bits. 0 -\> Full size
943
+ @param descriptor_channels Number of channels in the descriptor (1, 2, 3)
944
+ @param threshold Detector response threshold to accept point
945
+ @param nOctaves Maximum octave evolution of the image
946
+ @param nOctaveLayers Default number of sublevels per scale level
947
+ @param diffusivity Diffusivity type. DIFF_PM_G1, DIFF_PM_G2, DIFF_WEICKERT or
948
+ DIFF_CHARBONNIER
949
+ @param max_points Maximum amount of returned points. In case if image contains
950
+ more features, then the features with highest response are returned.
951
+ Negative value means no limitation.
952
+ */
953
+ CV_WRAP static Ptr<AKAZE>
954
+ create(AKAZE::DescriptorType descriptor_type = AKAZE::DESCRIPTOR_MLDB,
955
+ int descriptor_size = 0, int descriptor_channels = 3,
956
+ float threshold = 0.001f, int nOctaves = 4, int nOctaveLayers = 4,
957
+ KAZE::DiffusivityType diffusivity = KAZE::DIFF_PM_G2,
958
+ int max_points = -1);
959
+
960
+ CV_WRAP virtual void setDescriptorType(AKAZE::DescriptorType dtype) = 0;
961
+ CV_WRAP virtual AKAZE::DescriptorType getDescriptorType() const = 0;
962
+
963
+ CV_WRAP virtual void setDescriptorSize(int dsize) = 0;
964
+ CV_WRAP virtual int getDescriptorSize() const = 0;
965
+
966
+ CV_WRAP virtual void setDescriptorChannels(int dch) = 0;
967
+ CV_WRAP virtual int getDescriptorChannels() const = 0;
968
+
969
+ CV_WRAP virtual void setThreshold(double threshold) = 0;
970
+ CV_WRAP virtual double getThreshold() const = 0;
971
+
972
+ CV_WRAP virtual void setNOctaves(int octaves) = 0;
973
+ CV_WRAP virtual int getNOctaves() const = 0;
974
+
975
+ CV_WRAP virtual void setNOctaveLayers(int octaveLayers) = 0;
976
+ CV_WRAP virtual int getNOctaveLayers() const = 0;
977
+
978
+ CV_WRAP virtual void setDiffusivity(KAZE::DiffusivityType diff) = 0;
979
+ CV_WRAP virtual KAZE::DiffusivityType getDiffusivity() const = 0;
980
+ CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
981
+
982
+ CV_WRAP virtual void setMaxPoints(int max_points) = 0;
983
+ CV_WRAP virtual int getMaxPoints() const = 0;
984
+ };
985
+
986
+ /****************************************************************************************\
987
+ * Distance *
988
+ \****************************************************************************************/
989
+
990
+ template <typename T> struct CV_EXPORTS Accumulator {
991
+ typedef T Type;
992
+ };
993
+
994
+ template <> struct Accumulator<unsigned char> {
995
+ typedef float Type;
996
+ };
997
+ template <> struct Accumulator<unsigned short> {
998
+ typedef float Type;
999
+ };
1000
+ template <> struct Accumulator<char> {
1001
+ typedef float Type;
1002
+ };
1003
+ template <> struct Accumulator<short> {
1004
+ typedef float Type;
1005
+ };
1006
+
1007
+ /*
1008
+ * Squared Euclidean distance functor
1009
+ */
1010
+ template <class T> struct CV_EXPORTS SL2 {
1011
+ static const NormTypes normType = NORM_L2SQR;
1012
+ typedef T ValueType;
1013
+ typedef typename Accumulator<T>::Type ResultType;
1014
+
1015
+ ResultType operator()(const T *a, const T *b, int size) const {
1016
+ return normL2Sqr<ValueType, ResultType>(a, b, size);
1017
+ }
1018
+ };
1019
+
1020
+ /*
1021
+ * Euclidean distance functor
1022
+ */
1023
+ template <class T> struct L2 {
1024
+ static const NormTypes normType = NORM_L2;
1025
+ typedef T ValueType;
1026
+ typedef typename Accumulator<T>::Type ResultType;
1027
+
1028
+ ResultType operator()(const T *a, const T *b, int size) const {
1029
+ return (ResultType)std::sqrt(
1030
+ (double)normL2Sqr<ValueType, ResultType>(a, b, size));
1031
+ }
1032
+ };
1033
+
1034
+ /*
1035
+ * Manhattan distance (city block distance) functor
1036
+ */
1037
+ template <class T> struct L1 {
1038
+ static const NormTypes normType = NORM_L1;
1039
+ typedef T ValueType;
1040
+ typedef typename Accumulator<T>::Type ResultType;
1041
+
1042
+ ResultType operator()(const T *a, const T *b, int size) const {
1043
+ return normL1<ValueType, ResultType>(a, b, size);
1044
+ }
1045
+ };
1046
+
1047
+ //! @} features2d_main
1048
+
1049
+ /****************************************************************************************\
1050
+ * DescriptorMatcher *
1051
+ \****************************************************************************************/
1052
+
1053
+ //! @addtogroup features2d_match
1054
+ //! @{
1055
+
1056
+ /** @brief Abstract base class for matching keypoint descriptors.
1057
+
1058
+ It has two groups of match methods: for matching descriptors of an image with
1059
+ another image or with an image set.
1060
+ */
1061
+ class CV_EXPORTS_W DescriptorMatcher : public Algorithm {
1062
+ public:
1063
+ enum MatcherType {
1064
+ FLANNBASED = 1,
1065
+ BRUTEFORCE = 2,
1066
+ BRUTEFORCE_L1 = 3,
1067
+ BRUTEFORCE_HAMMING = 4,
1068
+ BRUTEFORCE_HAMMINGLUT = 5,
1069
+ BRUTEFORCE_SL2 = 6
1070
+ };
1071
+
1072
+ virtual ~DescriptorMatcher();
1073
+
1074
+ /** @brief Adds descriptors to train a CPU(trainDescCollectionis) or
1075
+ GPU(utrainDescCollectionis) descriptor collection.
1076
+
1077
+ If the collection is not empty, the new descriptors are added to existing
1078
+ train descriptors.
1079
+
1080
+ @param descriptors Descriptors to add. Each descriptors[i] is a set of
1081
+ descriptors from the same train image.
1082
+ */
1083
+ CV_WRAP virtual void add(InputArrayOfArrays descriptors);
1084
+
1085
+ /** @brief Returns a constant link to the train descriptor collection
1086
+ * trainDescCollection .
1087
+ */
1088
+ CV_WRAP const std::vector<Mat> &getTrainDescriptors() const;
1089
+
1090
+ /** @brief Clears the train descriptor collections.
1091
+ */
1092
+ CV_WRAP virtual void clear() CV_OVERRIDE;
1093
+
1094
+ /** @brief Returns true if there are no train descriptors in the both
1095
+ * collections.
1096
+ */
1097
+ CV_WRAP virtual bool empty() const CV_OVERRIDE;
1098
+
1099
+ /** @brief Returns true if the descriptor matcher supports masking permissible
1100
+ * matches.
1101
+ */
1102
+ CV_WRAP virtual bool isMaskSupported() const = 0;
1103
+
1104
+ /** @brief Trains a descriptor matcher
1105
+
1106
+ Trains a descriptor matcher (for example, the flann index). In all methods to
1107
+ match, the method train() is run every time before matching. Some descriptor
1108
+ matchers (for example, BruteForceMatcher) have an empty implementation of this
1109
+ method. Other matchers really train their inner structures (for example,
1110
+ FlannBasedMatcher trains flann::Index ).
1111
+ */
1112
+ CV_WRAP virtual void train();
1113
+
1114
+ /** @brief Finds the best match for each descriptor from a query set.
1115
+
1116
+ @param queryDescriptors Query set of descriptors.
1117
+ @param trainDescriptors Train set of descriptors. This set is not added to the
1118
+ train descriptors collection stored in the class object.
1119
+ @param matches Matches. If a query descriptor is masked out in mask , no match
1120
+ is added for this descriptor. So, matches size may be smaller than the query
1121
+ descriptors count.
1122
+ @param mask Mask specifying permissible matches between an input query and
1123
+ train matrices of descriptors.
1124
+
1125
+ In the first variant of this method, the train descriptors are passed as an
1126
+ input argument. In the second variant of the method, train descriptors
1127
+ collection that was set by DescriptorMatcher::add is used. Optional mask (or
1128
+ masks) can be passed to specify which query and training descriptors can be
1129
+ matched. Namely, queryDescriptors[i] can be matched with trainDescriptors[j]
1130
+ only if mask.at\<uchar\>(i,j) is non-zero.
1131
+ */
1132
+ CV_WRAP void match(InputArray queryDescriptors, InputArray trainDescriptors,
1133
+ CV_OUT std::vector<DMatch> &matches,
1134
+ InputArray mask = noArray()) const;
1135
+
1136
+ /** @brief Finds the k best matches for each descriptor from a query set.
1137
+
1138
+ @param queryDescriptors Query set of descriptors.
1139
+ @param trainDescriptors Train set of descriptors. This set is not added to the
1140
+ train descriptors collection stored in the class object.
1141
+ @param mask Mask specifying permissible matches between an input query and
1142
+ train matrices of descriptors.
1143
+ @param matches Matches. Each matches[i] is k or less matches for the same
1144
+ query descriptor.
1145
+ @param k Count of best matches found per each query descriptor or less if a
1146
+ query descriptor has less than k possible matches in total.
1147
+ @param compactResult Parameter used when the mask (or masks) is not empty. If
1148
+ compactResult is false, the matches vector has the same size as
1149
+ queryDescriptors rows. If compactResult is true, the matches vector does not
1150
+ contain matches for fully masked-out query descriptors.
1151
+
1152
+ These extended variants of DescriptorMatcher::match methods find several best
1153
+ matches for each query descriptor. The matches are returned in the distance
1154
+ increasing order. See DescriptorMatcher::match for the details about query and
1155
+ train descriptors.
1156
+ */
1157
+ CV_WRAP void knnMatch(InputArray queryDescriptors,
1158
+ InputArray trainDescriptors,
1159
+ CV_OUT std::vector<std::vector<DMatch>> &matches, int k,
1160
+ InputArray mask = noArray(),
1161
+ bool compactResult = false) const;
1162
+
1163
+ /** @brief For each query descriptor, finds the training descriptors not
1164
+ farther than the specified distance.
1165
+
1166
+ @param queryDescriptors Query set of descriptors.
1167
+ @param trainDescriptors Train set of descriptors. This set is not added to the
1168
+ train descriptors collection stored in the class object.
1169
+ @param matches Found matches.
1170
+ @param compactResult Parameter used when the mask (or masks) is not empty. If
1171
+ compactResult is false, the matches vector has the same size as
1172
+ queryDescriptors rows. If compactResult is true, the matches vector does not
1173
+ contain matches for fully masked-out query descriptors.
1174
+ @param maxDistance Threshold for the distance between matched descriptors.
1175
+ Distance means here metric distance (e.g. Hamming distance), not the distance
1176
+ between coordinates (which is measured in Pixels)!
1177
+ @param mask Mask specifying permissible matches between an input query and
1178
+ train matrices of descriptors.
1179
+
1180
+ For each query descriptor, the methods find such training descriptors that the
1181
+ distance between the query descriptor and the training descriptor is equal or
1182
+ smaller than maxDistance. Found matches are returned in the distance
1183
+ increasing order.
1184
+ */
1185
+ CV_WRAP void radiusMatch(InputArray queryDescriptors,
1186
+ InputArray trainDescriptors,
1187
+ CV_OUT std::vector<std::vector<DMatch>> &matches,
1188
+ float maxDistance, InputArray mask = noArray(),
1189
+ bool compactResult = false) const;
1190
+
1191
+ /** @overload
1192
+ @param queryDescriptors Query set of descriptors.
1193
+ @param matches Matches. If a query descriptor is masked out in mask , no match
1194
+ is added for this descriptor. So, matches size may be smaller than the query
1195
+ descriptors count.
1196
+ @param masks Set of masks. Each masks[i] specifies permissible matches between
1197
+ the input query descriptors and stored train descriptors from the i-th image
1198
+ trainDescCollection[i].
1199
+ */
1200
+ CV_WRAP void match(InputArray queryDescriptors,
1201
+ CV_OUT std::vector<DMatch> &matches,
1202
+ InputArrayOfArrays masks = noArray());
1203
+ /** @overload
1204
+ @param queryDescriptors Query set of descriptors.
1205
+ @param matches Matches. Each matches[i] is k or less matches for the same
1206
+ query descriptor.
1207
+ @param k Count of best matches found per each query descriptor or less if a
1208
+ query descriptor has less than k possible matches in total.
1209
+ @param masks Set of masks. Each masks[i] specifies permissible matches between
1210
+ the input query descriptors and stored train descriptors from the i-th image
1211
+ trainDescCollection[i].
1212
+ @param compactResult Parameter used when the mask (or masks) is not empty. If
1213
+ compactResult is false, the matches vector has the same size as
1214
+ queryDescriptors rows. If compactResult is true, the matches vector does not
1215
+ contain matches for fully masked-out query descriptors.
1216
+ */
1217
+ CV_WRAP void knnMatch(InputArray queryDescriptors,
1218
+ CV_OUT std::vector<std::vector<DMatch>> &matches, int k,
1219
+ InputArrayOfArrays masks = noArray(),
1220
+ bool compactResult = false);
1221
+ /** @overload
1222
+ @param queryDescriptors Query set of descriptors.
1223
+ @param matches Found matches.
1224
+ @param maxDistance Threshold for the distance between matched descriptors.
1225
+ Distance means here metric distance (e.g. Hamming distance), not the distance
1226
+ between coordinates (which is measured in Pixels)!
1227
+ @param masks Set of masks. Each masks[i] specifies permissible matches between
1228
+ the input query descriptors and stored train descriptors from the i-th image
1229
+ trainDescCollection[i].
1230
+ @param compactResult Parameter used when the mask (or masks) is not empty. If
1231
+ compactResult is false, the matches vector has the same size as
1232
+ queryDescriptors rows. If compactResult is true, the matches vector does not
1233
+ contain matches for fully masked-out query descriptors.
1234
+ */
1235
+ CV_WRAP void radiusMatch(InputArray queryDescriptors,
1236
+ CV_OUT std::vector<std::vector<DMatch>> &matches,
1237
+ float maxDistance,
1238
+ InputArrayOfArrays masks = noArray(),
1239
+ bool compactResult = false);
1240
+
1241
+ CV_WRAP void write(const String &fileName) const {
1242
+ FileStorage fs(fileName, FileStorage::WRITE);
1243
+ write(fs);
1244
+ }
1245
+
1246
+ CV_WRAP void read(const String &fileName) {
1247
+ FileStorage fs(fileName, FileStorage::READ);
1248
+ read(fs.root());
1249
+ }
1250
+ // Reads matcher object from a file node
1251
+ // see corresponding cv::Algorithm method
1252
+ CV_WRAP virtual void read(const FileNode &) CV_OVERRIDE;
1253
+ // Writes matcher object to a file storage
1254
+ virtual void write(FileStorage &) const CV_OVERRIDE;
1255
+
1256
+ /** @brief Clones the matcher.
1257
+
1258
+ @param emptyTrainData If emptyTrainData is false, the method creates a deep
1259
+ copy of the object, that is, copies both parameters and train data. If
1260
+ emptyTrainData is true, the method creates an object copy with the current
1261
+ parameters but with empty train data.
1262
+ */
1263
+ CV_WRAP CV_NODISCARD_STD virtual Ptr<DescriptorMatcher>
1264
+ clone(bool emptyTrainData = false) const = 0;
1265
+
1266
+ /** @brief Creates a descriptor matcher of a given type with the default
1267
+ parameters (using default constructor).
1268
+
1269
+ @param descriptorMatcherType Descriptor matcher type. Now the following
1270
+ matcher types are supported:
1271
+ - `BruteForce` (it uses L2 )
1272
+ - `BruteForce-L1`
1273
+ - `BruteForce-Hamming`
1274
+ - `BruteForce-Hamming(2)`
1275
+ - `FlannBased`
1276
+ */
1277
+ CV_WRAP static Ptr<DescriptorMatcher>
1278
+ create(const String &descriptorMatcherType);
1279
+
1280
+ CV_WRAP static Ptr<DescriptorMatcher>
1281
+ create(const DescriptorMatcher::MatcherType &matcherType);
1282
+
1283
+ // see corresponding cv::Algorithm method
1284
+ CV_WRAP inline void write(FileStorage &fs, const String &name) const {
1285
+ Algorithm::write(fs, name);
1286
+ }
1287
+ #if CV_VERSION_MAJOR < 5
1288
+ inline void write(const Ptr<FileStorage> &fs, const String &name) const {
1289
+ CV_Assert(fs);
1290
+ Algorithm::write(*fs, name);
1291
+ }
1292
+ #endif
1293
+
1294
+ protected:
1295
+ /**
1296
+ * Class to work with descriptors from several images as with one merged
1297
+ * matrix. It is used e.g. in FlannBasedMatcher.
1298
+ */
1299
+ class CV_EXPORTS DescriptorCollection {
1300
+ public:
1301
+ DescriptorCollection();
1302
+ DescriptorCollection(const DescriptorCollection &collection);
1303
+ virtual ~DescriptorCollection();
1304
+
1305
+ // Vector of matrices "descriptors" will be merged to one matrix
1306
+ // "mergedDescriptors" here.
1307
+ void set(const std::vector<Mat> &descriptors);
1308
+ virtual void clear();
1309
+
1310
+ const Mat &getDescriptors() const;
1311
+ Mat getDescriptor(int imgIdx, int localDescIdx) const;
1312
+ Mat getDescriptor(int globalDescIdx) const;
1313
+ void getLocalIdx(int globalDescIdx, int &imgIdx, int &localDescIdx) const;
1314
+
1315
+ int size() const;
1316
+
1317
+ protected:
1318
+ Mat mergedDescriptors;
1319
+ std::vector<int> startIdxs;
1320
+ };
1321
+
1322
+ //! In fact the matching is implemented only by the following two methods.
1323
+ //! These methods suppose that the class object has been trained already.
1324
+ //! Public match methods call these methods after calling train().
1325
+ virtual void knnMatchImpl(InputArray queryDescriptors,
1326
+ std::vector<std::vector<DMatch>> &matches, int k,
1327
+ InputArrayOfArrays masks = noArray(),
1328
+ bool compactResult = false) = 0;
1329
+ virtual void radiusMatchImpl(InputArray queryDescriptors,
1330
+ std::vector<std::vector<DMatch>> &matches,
1331
+ float maxDistance,
1332
+ InputArrayOfArrays masks = noArray(),
1333
+ bool compactResult = false) = 0;
1334
+
1335
+ static bool isPossibleMatch(InputArray mask, int queryIdx, int trainIdx);
1336
+ static bool isMaskedOut(InputArrayOfArrays masks, int queryIdx);
1337
+
1338
+ CV_NODISCARD_STD static Mat clone_op(Mat m) { return m.clone(); }
1339
+ void checkMasks(InputArrayOfArrays masks, int queryDescriptorsCount) const;
1340
+
1341
+ //! Collection of descriptors from train images.
1342
+ std::vector<Mat> trainDescCollection;
1343
+ };
1344
+
1345
+ /** @brief Brute-force descriptor matcher.
1346
+
1347
+ For each descriptor in the first set, this matcher finds the closest descriptor
1348
+ in the second set by trying each one. This descriptor matcher supports masking
1349
+ permissible matches of descriptor sets.
1350
+ */
1351
+ class CV_EXPORTS_W BFMatcher : public DescriptorMatcher {
1352
+ public:
1353
+ /** @brief Brute-force matcher constructor (obsolete). Please use
1354
+ * BFMatcher.create()
1355
+ *
1356
+ *
1357
+ */
1358
+ CV_WRAP BFMatcher(int normType = NORM_L2, bool crossCheck = false);
1359
+
1360
+ virtual ~BFMatcher() {}
1361
+
1362
+ virtual bool isMaskSupported() const CV_OVERRIDE { return true; }
1363
+
1364
+ /** @brief Brute-force matcher create method.
1365
+ @param normType One of NORM_L1, NORM_L2, NORM_HAMMING, NORM_HAMMING2. L1 and
1366
+ L2 norms are preferable choices for SIFT and SURF descriptors, NORM_HAMMING
1367
+ should be used with ORB, BRISK and BRIEF, NORM_HAMMING2 should be used with
1368
+ ORB when WTA_K==3 or 4 (see ORB::ORB constructor description).
1369
+ @param crossCheck If it is false, this is will be default BFMatcher behaviour
1370
+ when it finds the k nearest neighbors for each query descriptor. If
1371
+ crossCheck==true, then the knnMatch() method with k=1 will only return pairs
1372
+ (i,j) such that for i-th query descriptor the j-th descriptor in the matcher's
1373
+ collection is the nearest and vice versa, i.e. the BFMatcher will only return
1374
+ consistent pairs. Such technique usually produces best results with minimal
1375
+ number of outliers when there are enough matches. This is alternative to the
1376
+ ratio test, used by D. Lowe in SIFT paper.
1377
+ */
1378
+ CV_WRAP static Ptr<BFMatcher> create(int normType = NORM_L2,
1379
+ bool crossCheck = false);
1380
+
1381
+ CV_NODISCARD_STD virtual Ptr<DescriptorMatcher>
1382
+ clone(bool emptyTrainData = false) const CV_OVERRIDE;
1383
+
1384
+ protected:
1385
+ virtual void knnMatchImpl(InputArray queryDescriptors,
1386
+ std::vector<std::vector<DMatch>> &matches, int k,
1387
+ InputArrayOfArrays masks = noArray(),
1388
+ bool compactResult = false) CV_OVERRIDE;
1389
+ virtual void radiusMatchImpl(InputArray queryDescriptors,
1390
+ std::vector<std::vector<DMatch>> &matches,
1391
+ float maxDistance,
1392
+ InputArrayOfArrays masks = noArray(),
1393
+ bool compactResult = false) CV_OVERRIDE;
1394
+
1395
+ int normType;
1396
+ bool crossCheck;
1397
+ };
1398
+
1399
+ #if defined(HAVE_OPENCV_FLANN) || defined(CV_DOXYGEN)
1400
+
1401
+ /** @brief Flann-based descriptor matcher.
1402
+
1403
+ This matcher trains cv::flann::Index on a train descriptor collection and calls
1404
+ its nearest search methods to find the best matches. So, this matcher may be
1405
+ faster when matching a large train collection than the brute force matcher.
1406
+ FlannBasedMatcher does not support masking permissible matches of descriptor
1407
+ sets because flann::Index does not support this. :
1408
+ */
1409
+ class CV_EXPORTS_W FlannBasedMatcher : public DescriptorMatcher {
1410
+ public:
1411
+ CV_WRAP FlannBasedMatcher(const Ptr<flann::IndexParams> &indexParams =
1412
+ makePtr<flann::KDTreeIndexParams>(),
1413
+ const Ptr<flann::SearchParams> &searchParams =
1414
+ makePtr<flann::SearchParams>());
1415
+
1416
+ virtual void add(InputArrayOfArrays descriptors) CV_OVERRIDE;
1417
+ virtual void clear() CV_OVERRIDE;
1418
+
1419
+ // Reads matcher object from a file node
1420
+ virtual void read(const FileNode &) CV_OVERRIDE;
1421
+ // Writes matcher object to a file storage
1422
+ virtual void write(FileStorage &) const CV_OVERRIDE;
1423
+
1424
+ virtual void train() CV_OVERRIDE;
1425
+ virtual bool isMaskSupported() const CV_OVERRIDE;
1426
+
1427
+ CV_WRAP static Ptr<FlannBasedMatcher> create();
1428
+
1429
+ CV_NODISCARD_STD virtual Ptr<DescriptorMatcher>
1430
+ clone(bool emptyTrainData = false) const CV_OVERRIDE;
1431
+
1432
+ protected:
1433
+ static void convertToDMatches(const DescriptorCollection &descriptors,
1434
+ const Mat &indices, const Mat &distances,
1435
+ std::vector<std::vector<DMatch>> &matches);
1436
+
1437
+ virtual void knnMatchImpl(InputArray queryDescriptors,
1438
+ std::vector<std::vector<DMatch>> &matches, int k,
1439
+ InputArrayOfArrays masks = noArray(),
1440
+ bool compactResult = false) CV_OVERRIDE;
1441
+ virtual void radiusMatchImpl(InputArray queryDescriptors,
1442
+ std::vector<std::vector<DMatch>> &matches,
1443
+ float maxDistance,
1444
+ InputArrayOfArrays masks = noArray(),
1445
+ bool compactResult = false) CV_OVERRIDE;
1446
+
1447
+ Ptr<flann::IndexParams> indexParams;
1448
+ Ptr<flann::SearchParams> searchParams;
1449
+ Ptr<flann::Index> flannIndex;
1450
+
1451
+ DescriptorCollection mergedDescriptors;
1452
+ int addedDescCount;
1453
+ };
1454
+
1455
+ #endif
1456
+
1457
+ //! @} features2d_match
1458
+
1459
+ /****************************************************************************************\
1460
+ * Drawing functions *
1461
+ \****************************************************************************************/
1462
+
1463
+ //! @addtogroup features2d_draw
1464
+ //! @{
1465
+
1466
+ enum struct DrawMatchesFlags {
1467
+ DEFAULT =
1468
+ 0, //!< Output image matrix will be created (Mat::create),
1469
+ //!< i.e. existing memory of output image may be reused.
1470
+ //!< Two source image, matches and single keypoints will be drawn.
1471
+ //!< For each keypoint only the center point will be drawn (without
1472
+ //!< the circle around keypoint with keypoint size and orientation).
1473
+ DRAW_OVER_OUTIMG =
1474
+ 1, //!< Output image matrix will not be created (Mat::create).
1475
+ //!< Matches will be drawn on existing content of output image.
1476
+ NOT_DRAW_SINGLE_POINTS = 2, //!< Single keypoints will not be drawn.
1477
+ DRAW_RICH_KEYPOINTS = 4 //!< For each keypoint the circle around keypoint with
1478
+ //!< keypoint size and orientation will be drawn.
1479
+ };
1480
+ CV_ENUM_FLAGS(DrawMatchesFlags)
1481
+
1482
+ /** @brief Draws keypoints.
1483
+
1484
+ @param image Source image.
1485
+ @param keypoints Keypoints from the source image.
1486
+ @param outImage Output image. Its content depends on the flags value defining
1487
+ what is drawn in the output image. See possible flags bit values below.
1488
+ @param color Color of keypoints.
1489
+ @param flags Flags setting drawing features. Possible flags bit values are
1490
+ defined by DrawMatchesFlags. See details above in drawMatches .
1491
+
1492
+ @note
1493
+ For Python API, flags are modified as cv.DRAW_MATCHES_FLAGS_DEFAULT,
1494
+ cv.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS,
1495
+ cv.DRAW_MATCHES_FLAGS_DRAW_OVER_OUTIMG,
1496
+ cv.DRAW_MATCHES_FLAGS_NOT_DRAW_SINGLE_POINTS
1497
+ */
1498
+ CV_EXPORTS_W void
1499
+ drawKeypoints(InputArray image, const std::vector<KeyPoint> &keypoints,
1500
+ InputOutputArray outImage, const Scalar &color = Scalar::all(-1),
1501
+ DrawMatchesFlags flags = DrawMatchesFlags::DEFAULT);
1502
+
1503
+ /** @brief Draws the found matches of keypoints from two images.
1504
+
1505
+ @param img1 First source image.
1506
+ @param keypoints1 Keypoints from the first source image.
1507
+ @param img2 Second source image.
1508
+ @param keypoints2 Keypoints from the second source image.
1509
+ @param matches1to2 Matches from the first image to the second one, which means
1510
+ that keypoints1[i] has a corresponding point in keypoints2[matches[i]] .
1511
+ @param outImg Output image. Its content depends on the flags value defining what
1512
+ is drawn in the output image. See possible flags bit values below.
1513
+ @param matchColor Color of matches (lines and connected keypoints). If
1514
+ matchColor==Scalar::all(-1) , the color is generated randomly.
1515
+ @param singlePointColor Color of single keypoints (circles), which means that
1516
+ keypoints do not have the matches. If singlePointColor==Scalar::all(-1) , the
1517
+ color is generated randomly.
1518
+ @param matchesMask Mask determining which matches are drawn. If the mask is
1519
+ empty, all matches are drawn.
1520
+ @param flags Flags setting drawing features. Possible flags bit values are
1521
+ defined by DrawMatchesFlags.
1522
+
1523
+ This function draws matches of keypoints from two images in the output image.
1524
+ Match is a line connecting two keypoints (circles). See cv::DrawMatchesFlags.
1525
+ */
1526
+ CV_EXPORTS_W void
1527
+ drawMatches(InputArray img1, const std::vector<KeyPoint> &keypoints1,
1528
+ InputArray img2, const std::vector<KeyPoint> &keypoints2,
1529
+ const std::vector<DMatch> &matches1to2, InputOutputArray outImg,
1530
+ const Scalar &matchColor = Scalar::all(-1),
1531
+ const Scalar &singlePointColor = Scalar::all(-1),
1532
+ const std::vector<char> &matchesMask = std::vector<char>(),
1533
+ DrawMatchesFlags flags = DrawMatchesFlags::DEFAULT);
1534
+
1535
+ /** @overload */
1536
+ CV_EXPORTS_W void
1537
+ drawMatches(InputArray img1, const std::vector<KeyPoint> &keypoints1,
1538
+ InputArray img2, const std::vector<KeyPoint> &keypoints2,
1539
+ const std::vector<DMatch> &matches1to2, InputOutputArray outImg,
1540
+ const int matchesThickness,
1541
+ const Scalar &matchColor = Scalar::all(-1),
1542
+ const Scalar &singlePointColor = Scalar::all(-1),
1543
+ const std::vector<char> &matchesMask = std::vector<char>(),
1544
+ DrawMatchesFlags flags = DrawMatchesFlags::DEFAULT);
1545
+
1546
+ CV_EXPORTS_AS(drawMatchesKnn)
1547
+ void drawMatches(InputArray img1, const std::vector<KeyPoint> &keypoints1,
1548
+ InputArray img2, const std::vector<KeyPoint> &keypoints2,
1549
+ const std::vector<std::vector<DMatch>> &matches1to2,
1550
+ InputOutputArray outImg,
1551
+ const Scalar &matchColor = Scalar::all(-1),
1552
+ const Scalar &singlePointColor = Scalar::all(-1),
1553
+ const std::vector<std::vector<char>> &matchesMask =
1554
+ std::vector<std::vector<char>>(),
1555
+ DrawMatchesFlags flags = DrawMatchesFlags::DEFAULT);
1556
+
1557
+ //! @} features2d_draw
1558
+
1559
+ /****************************************************************************************\
1560
+ * Functions to evaluate the feature detectors and [generic] descriptor
1561
+ extractors *
1562
+ \****************************************************************************************/
1563
+
1564
+ //! @addtogroup features2d_main
1565
+ //! @{
1566
+
1567
+ CV_EXPORTS void evaluateFeatureDetector(
1568
+ const Mat &img1, const Mat &img2, const Mat &H1to2,
1569
+ std::vector<KeyPoint> *keypoints1, std::vector<KeyPoint> *keypoints2,
1570
+ float &repeatability, int &correspCount,
1571
+ const Ptr<FeatureDetector> &fdetector = Ptr<FeatureDetector>());
1572
+
1573
+ CV_EXPORTS void computeRecallPrecisionCurve(
1574
+ const std::vector<std::vector<DMatch>> &matches1to2,
1575
+ const std::vector<std::vector<uchar>> &correctMatches1to2Mask,
1576
+ std::vector<Point2f> &recallPrecisionCurve);
1577
+
1578
+ CV_EXPORTS float getRecall(const std::vector<Point2f> &recallPrecisionCurve,
1579
+ float l_precision);
1580
+ CV_EXPORTS int getNearestPoint(const std::vector<Point2f> &recallPrecisionCurve,
1581
+ float l_precision);
1582
+
1583
+ //! @}
1584
+
1585
+ /****************************************************************************************\
1586
+ * Bag of visual words *
1587
+ \****************************************************************************************/
1588
+
1589
+ //! @addtogroup features2d_category
1590
+ //! @{
1591
+
1592
+ /** @brief Abstract base class for training the *bag of visual words* vocabulary
1593
+ from a set of descriptors.
1594
+
1595
+ For details, see, for example, *Visual Categorization with Bags of Keypoints* by
1596
+ Gabriella Csurka, Christopher R. Dance, Lixin Fan, Jutta Willamowski, Cedric
1597
+ Bray, 2004. :
1598
+ */
1599
+ class CV_EXPORTS_W BOWTrainer {
1600
+ public:
1601
+ BOWTrainer();
1602
+ virtual ~BOWTrainer();
1603
+
1604
+ /** @brief Adds descriptors to a training set.
1605
+
1606
+ @param descriptors Descriptors to add to a training set. Each row of the
1607
+ descriptors matrix is a descriptor.
1608
+
1609
+ The training set is clustered using clustermethod to construct the vocabulary.
1610
+ */
1611
+ CV_WRAP void add(const Mat &descriptors);
1612
+
1613
+ /** @brief Returns a training set of descriptors.
1614
+ */
1615
+ CV_WRAP const std::vector<Mat> &getDescriptors() const;
1616
+
1617
+ /** @brief Returns the count of all descriptors stored in the training set.
1618
+ */
1619
+ CV_WRAP int descriptorsCount() const;
1620
+
1621
+ CV_WRAP virtual void clear();
1622
+
1623
+ /** @overload */
1624
+ CV_WRAP virtual Mat cluster() const = 0;
1625
+
1626
+ /** @brief Clusters train descriptors.
1627
+
1628
+ @param descriptors Descriptors to cluster. Each row of the descriptors matrix
1629
+ is a descriptor. Descriptors are not added to the inner train descriptor set.
1630
+
1631
+ The vocabulary consists of cluster centers. So, this method returns the
1632
+ vocabulary. In the first variant of the method, train descriptors stored in
1633
+ the object are clustered. In the second variant, input descriptors are
1634
+ clustered.
1635
+ */
1636
+ CV_WRAP virtual Mat cluster(const Mat &descriptors) const = 0;
1637
+
1638
+ protected:
1639
+ std::vector<Mat> descriptors;
1640
+ int size;
1641
+ };
1642
+
1643
+ /** @brief kmeans -based class to train visual vocabulary using the *bag of
1644
+ * visual words* approach. :
1645
+ */
1646
+ class CV_EXPORTS_W BOWKMeansTrainer : public BOWTrainer {
1647
+ public:
1648
+ /** @brief The constructor.
1649
+
1650
+ @see cv::kmeans
1651
+ */
1652
+ CV_WRAP BOWKMeansTrainer(int clusterCount,
1653
+ const TermCriteria &termcrit = TermCriteria(),
1654
+ int attempts = 3, int flags = KMEANS_PP_CENTERS);
1655
+ virtual ~BOWKMeansTrainer();
1656
+
1657
+ // Returns trained vocabulary (i.e. cluster centers).
1658
+ CV_WRAP virtual Mat cluster() const CV_OVERRIDE;
1659
+ CV_WRAP virtual Mat cluster(const Mat &descriptors) const CV_OVERRIDE;
1660
+
1661
+ protected:
1662
+ int clusterCount;
1663
+ TermCriteria termcrit;
1664
+ int attempts;
1665
+ int flags;
1666
+ };
1667
+
1668
+ /** @brief Class to compute an image descriptor using the *bag of visual words*.
1669
+
1670
+ Such a computation consists of the following steps:
1671
+
1672
+ 1. Compute descriptors for a given image and its keypoints set.
1673
+ 2. Find the nearest visual words from the vocabulary for each keypoint
1674
+ descriptor.
1675
+ 3. Compute the bag-of-words image descriptor as is a normalized histogram of
1676
+ vocabulary words encountered in the image. The i-th bin of the histogram is a
1677
+ frequency of i-th word of the vocabulary in the given image.
1678
+ */
1679
+ class CV_EXPORTS_W BOWImgDescriptorExtractor {
1680
+ public:
1681
+ /** @brief The constructor.
1682
+
1683
+ @param dextractor Descriptor extractor that is used to compute descriptors for
1684
+ an input image and its keypoints.
1685
+ @param dmatcher Descriptor matcher that is used to find the nearest word of
1686
+ the trained vocabulary for each keypoint descriptor of the image.
1687
+ */
1688
+ CV_WRAP BOWImgDescriptorExtractor(const Ptr<Feature2D> &dextractor,
1689
+ const Ptr<DescriptorMatcher> &dmatcher);
1690
+ /** @overload */
1691
+ BOWImgDescriptorExtractor(const Ptr<DescriptorMatcher> &dmatcher);
1692
+ virtual ~BOWImgDescriptorExtractor();
1693
+
1694
+ /** @brief Sets a visual vocabulary.
1695
+
1696
+ @param vocabulary Vocabulary (can be trained using the inheritor of BOWTrainer
1697
+ ). Each row of the vocabulary is a visual word (cluster center).
1698
+ */
1699
+ CV_WRAP void setVocabulary(const Mat &vocabulary);
1700
+
1701
+ /** @brief Returns the set vocabulary.
1702
+ */
1703
+ CV_WRAP const Mat &getVocabulary() const;
1704
+
1705
+ /** @brief Computes an image descriptor using the set visual vocabulary.
1706
+
1707
+ @param image Image, for which the descriptor is computed.
1708
+ @param keypoints Keypoints detected in the input image.
1709
+ @param imgDescriptor Computed output image descriptor.
1710
+ @param pointIdxsOfClusters Indices of keypoints that belong to the cluster.
1711
+ This means that pointIdxsOfClusters[i] are keypoint indices that belong to the
1712
+ i -th cluster (word of vocabulary) returned if it is non-zero.
1713
+ @param descriptors Descriptors of the image keypoints that are returned if
1714
+ they are non-zero.
1715
+ */
1716
+ void compute(InputArray image, std::vector<KeyPoint> &keypoints,
1717
+ OutputArray imgDescriptor,
1718
+ std::vector<std::vector<int>> *pointIdxsOfClusters = 0,
1719
+ Mat *descriptors = 0);
1720
+ /** @overload
1721
+ @param keypointDescriptors Computed descriptors to match with vocabulary.
1722
+ @param imgDescriptor Computed output image descriptor.
1723
+ @param pointIdxsOfClusters Indices of keypoints that belong to the cluster.
1724
+ This means that pointIdxsOfClusters[i] are keypoint indices that belong to the
1725
+ i -th cluster (word of vocabulary) returned if it is non-zero.
1726
+ */
1727
+ void compute(InputArray keypointDescriptors, OutputArray imgDescriptor,
1728
+ std::vector<std::vector<int>> *pointIdxsOfClusters = 0);
1729
+ // compute() is not constant because DescriptorMatcher::match is not constant
1730
+
1731
+ CV_WRAP_AS(compute)
1732
+ void compute2(const Mat &image, std::vector<KeyPoint> &keypoints,
1733
+ CV_OUT Mat &imgDescriptor) {
1734
+ compute(image, keypoints, imgDescriptor);
1735
+ }
1736
+
1737
+ /** @brief Returns an image descriptor size if the vocabulary is set.
1738
+ * Otherwise, it returns 0.
1739
+ */
1740
+ CV_WRAP int descriptorSize() const;
1741
+
1742
+ /** @brief Returns an image descriptor type.
1743
+ */
1744
+ CV_WRAP int descriptorType() const;
1745
+
1746
+ protected:
1747
+ Mat vocabulary;
1748
+ Ptr<DescriptorExtractor> dextractor;
1749
+ Ptr<DescriptorMatcher> dmatcher;
1750
+ };
1751
+
1752
+ //! @} features2d_category
1753
+
1754
+ } /* namespace cv */
1755
+
1756
+ #endif