react-native-yolo 0.0.5 → 0.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/android/src/main/java/com/yolo/HybridYolo.kt +12 -235
- package/android/src/main/java/com/yolo/HybridYoloModel.kt +212 -0
- package/android/src/main/java/com/yolo/utils/BitmapOrientationFixer.kt +8 -1
- package/lib/commonjs/index.js +4 -3
- package/lib/commonjs/index.js.map +1 -1
- package/lib/module/index.js +4 -3
- package/lib/module/index.js.map +1 -1
- package/lib/typescript/src/index.d.ts +12 -3
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/specs/yolo.nitro.d.ts +10 -6
- package/lib/typescript/src/specs/yolo.nitro.d.ts.map +1 -1
- package/nitrogen/generated/android/Yolo+autolinking.cmake +2 -0
- package/nitrogen/generated/android/YoloOnLoad.cpp +2 -0
- package/nitrogen/generated/android/c++/JHybridYoloModelSpec.cpp +78 -0
- package/nitrogen/generated/android/c++/JHybridYoloModelSpec.hpp +64 -0
- package/nitrogen/generated/android/c++/JHybridYoloSpec.cpp +9 -32
- package/nitrogen/generated/android/c++/JHybridYoloSpec.hpp +1 -3
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/yolo/HybridYoloModelSpec.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/yolo/HybridYoloSpec.kt +1 -9
- package/nitrogen/generated/ios/Yolo-Swift-Cxx-Bridge.cpp +17 -0
- package/nitrogen/generated/ios/Yolo-Swift-Cxx-Bridge.hpp +48 -31
- package/nitrogen/generated/ios/Yolo-Swift-Cxx-Umbrella.hpp +5 -0
- package/nitrogen/generated/ios/c++/HybridYoloModelSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridYoloModelSpecSwift.hpp +97 -0
- package/nitrogen/generated/ios/c++/HybridYoloSpecSwift.hpp +6 -24
- package/nitrogen/generated/ios/swift/HybridYoloModelSpec.swift +57 -0
- package/nitrogen/generated/ios/swift/HybridYoloModelSpec_cxx.swift +160 -0
- package/nitrogen/generated/ios/swift/HybridYoloSpec.swift +1 -3
- package/nitrogen/generated/ios/swift/HybridYoloSpec_cxx.swift +8 -38
- package/nitrogen/generated/shared/c++/HybridYoloModelSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridYoloModelSpec.hpp +69 -0
- package/nitrogen/generated/shared/c++/HybridYoloSpec.cpp +0 -2
- package/nitrogen/generated/shared/c++/HybridYoloSpec.hpp +5 -8
- package/package.json +1 -1
- package/src/index.ts +14 -4
- package/src/specs/yolo.nitro.ts +12 -3
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JHybridYoloModelSpec.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "JHybridYoloModelSpec.hpp"
|
|
9
|
+
|
|
10
|
+
// Forward declaration of `Detection` to properly resolve imports.
|
|
11
|
+
namespace margelo::nitro::yolo { struct Detection; }
|
|
12
|
+
// Forward declaration of `BoundingBox` to properly resolve imports.
|
|
13
|
+
namespace margelo::nitro::yolo { struct BoundingBox; }
|
|
14
|
+
// Forward declaration of `HybridFrameSpec` to properly resolve imports.
|
|
15
|
+
namespace margelo::nitro::camera { class HybridFrameSpec; }
|
|
16
|
+
|
|
17
|
+
#include "Detection.hpp"
|
|
18
|
+
#include <vector>
|
|
19
|
+
#include "JDetection.hpp"
|
|
20
|
+
#include "BoundingBox.hpp"
|
|
21
|
+
#include "JBoundingBox.hpp"
|
|
22
|
+
#include <memory>
|
|
23
|
+
#include <VisionCamera/HybridFrameSpec.hpp>
|
|
24
|
+
#include <VisionCamera/JHybridFrameSpec.hpp>
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::yolo {
|
|
27
|
+
|
|
28
|
+
std::shared_ptr<JHybridYoloModelSpec> JHybridYoloModelSpec::JavaPart::getJHybridYoloModelSpec() {
|
|
29
|
+
auto hybridObject = JHybridObject::JavaPart::getJHybridObject();
|
|
30
|
+
auto castHybridObject = std::dynamic_pointer_cast<JHybridYoloModelSpec>(hybridObject);
|
|
31
|
+
if (castHybridObject == nullptr) [[unlikely]] {
|
|
32
|
+
throw std::runtime_error("Failed to downcast JHybridObject to JHybridYoloModelSpec!");
|
|
33
|
+
}
|
|
34
|
+
return castHybridObject;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
jni::local_ref<JHybridYoloModelSpec::CxxPart::jhybriddata> JHybridYoloModelSpec::CxxPart::initHybrid(jni::alias_ref<jhybridobject> jThis) {
|
|
38
|
+
return makeCxxInstance(jThis);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
std::shared_ptr<JHybridObject> JHybridYoloModelSpec::CxxPart::createHybridObject(const jni::local_ref<JHybridObject::JavaPart>& javaPart) {
|
|
42
|
+
auto castJavaPart = jni::dynamic_ref_cast<JHybridYoloModelSpec::JavaPart>(javaPart);
|
|
43
|
+
if (castJavaPart == nullptr) [[unlikely]] {
|
|
44
|
+
throw std::runtime_error("Failed to cast JHybridObject::JavaPart to JHybridYoloModelSpec::JavaPart!");
|
|
45
|
+
}
|
|
46
|
+
return std::make_shared<JHybridYoloModelSpec>(castJavaPart);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
void JHybridYoloModelSpec::CxxPart::registerNatives() {
|
|
50
|
+
registerHybrid({
|
|
51
|
+
makeNativeMethod("initHybrid", JHybridYoloModelSpec::CxxPart::initHybrid),
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// Properties
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
// Methods
|
|
59
|
+
std::vector<Detection> JHybridYoloModelSpec::detect(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) {
|
|
60
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<jni::JArrayClass<JDetection>>(jni::alias_ref<margelo::nitro::camera::JHybridFrameSpec::JavaPart> /* frame */)>("detect");
|
|
61
|
+
auto __result = method(_javaPart, std::dynamic_pointer_cast<margelo::nitro::camera::JHybridFrameSpec>(frame)->getJavaPart());
|
|
62
|
+
return [&](auto&& __input) {
|
|
63
|
+
size_t __size = __input->size();
|
|
64
|
+
std::vector<Detection> __vector;
|
|
65
|
+
__vector.reserve(__size);
|
|
66
|
+
for (size_t __i = 0; __i < __size; __i++) {
|
|
67
|
+
auto __element = __input->getElement(__i);
|
|
68
|
+
__vector.push_back(__element->toCpp());
|
|
69
|
+
}
|
|
70
|
+
return __vector;
|
|
71
|
+
}(__result);
|
|
72
|
+
}
|
|
73
|
+
void JHybridYoloModelSpec::close() {
|
|
74
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<void()>("close");
|
|
75
|
+
method(_javaPart);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
} // namespace margelo::nitro::yolo
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridYoloModelSpec.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include <NitroModules/JHybridObject.hpp>
|
|
11
|
+
#include <fbjni/fbjni.h>
|
|
12
|
+
#include "HybridYoloModelSpec.hpp"
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
namespace margelo::nitro::yolo {
|
|
18
|
+
|
|
19
|
+
using namespace facebook;
|
|
20
|
+
|
|
21
|
+
class JHybridYoloModelSpec: public virtual HybridYoloModelSpec, public virtual JHybridObject {
|
|
22
|
+
public:
|
|
23
|
+
struct JavaPart: public jni::JavaClass<JavaPart, JHybridObject::JavaPart> {
|
|
24
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/yolo/HybridYoloModelSpec;";
|
|
25
|
+
std::shared_ptr<JHybridYoloModelSpec> getJHybridYoloModelSpec();
|
|
26
|
+
};
|
|
27
|
+
struct CxxPart: public jni::HybridClass<CxxPart, JHybridObject::CxxPart> {
|
|
28
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/yolo/HybridYoloModelSpec$CxxPart;";
|
|
29
|
+
static jni::local_ref<jhybriddata> initHybrid(jni::alias_ref<jhybridobject> jThis);
|
|
30
|
+
static void registerNatives();
|
|
31
|
+
using HybridBase::HybridBase;
|
|
32
|
+
protected:
|
|
33
|
+
std::shared_ptr<JHybridObject> createHybridObject(const jni::local_ref<JHybridObject::JavaPart>& javaPart) override;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
public:
|
|
37
|
+
explicit JHybridYoloModelSpec(const jni::local_ref<JHybridYoloModelSpec::JavaPart>& javaPart):
|
|
38
|
+
HybridObject(HybridYoloModelSpec::TAG),
|
|
39
|
+
JHybridObject(javaPart),
|
|
40
|
+
_javaPart(jni::make_global(javaPart)) {}
|
|
41
|
+
~JHybridYoloModelSpec() override {
|
|
42
|
+
// Hermes GC can destroy JS objects on a non-JNI Thread.
|
|
43
|
+
jni::ThreadScope::WithClassLoader([&] { _javaPart.reset(); });
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
public:
|
|
47
|
+
inline const jni::global_ref<JHybridYoloModelSpec::JavaPart>& getJavaPart() const noexcept {
|
|
48
|
+
return _javaPart;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public:
|
|
52
|
+
// Properties
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
public:
|
|
56
|
+
// Methods
|
|
57
|
+
std::vector<Detection> detect(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) override;
|
|
58
|
+
void close() override;
|
|
59
|
+
|
|
60
|
+
private:
|
|
61
|
+
jni::global_ref<JHybridYoloModelSpec::JavaPart> _javaPart;
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
} // namespace margelo::nitro::yolo
|
|
@@ -7,20 +7,15 @@
|
|
|
7
7
|
|
|
8
8
|
#include "JHybridYoloSpec.hpp"
|
|
9
9
|
|
|
10
|
-
// Forward declaration of `
|
|
11
|
-
namespace margelo::nitro::yolo {
|
|
12
|
-
// Forward declaration of `BoundingBox` to properly resolve imports.
|
|
13
|
-
namespace margelo::nitro::yolo { struct BoundingBox; }
|
|
10
|
+
// Forward declaration of `HybridYoloModelSpec` to properly resolve imports.
|
|
11
|
+
namespace margelo::nitro::yolo { class HybridYoloModelSpec; }
|
|
14
12
|
// Forward declaration of `HybridFrameSpec` to properly resolve imports.
|
|
15
13
|
namespace margelo::nitro::camera { class HybridFrameSpec; }
|
|
16
14
|
|
|
17
|
-
#include <string>
|
|
18
|
-
#include "Detection.hpp"
|
|
19
|
-
#include <vector>
|
|
20
|
-
#include "JDetection.hpp"
|
|
21
|
-
#include "BoundingBox.hpp"
|
|
22
|
-
#include "JBoundingBox.hpp"
|
|
23
15
|
#include <memory>
|
|
16
|
+
#include "HybridYoloModelSpec.hpp"
|
|
17
|
+
#include "JHybridYoloModelSpec.hpp"
|
|
18
|
+
#include <string>
|
|
24
19
|
#include <VisionCamera/HybridFrameSpec.hpp>
|
|
25
20
|
#include <VisionCamera/JHybridFrameSpec.hpp>
|
|
26
21
|
|
|
@@ -57,33 +52,15 @@ namespace margelo::nitro::yolo {
|
|
|
57
52
|
|
|
58
53
|
|
|
59
54
|
// Methods
|
|
60
|
-
|
|
61
|
-
static const auto method = _javaPart->javaClassStatic()->getMethod<
|
|
62
|
-
auto __result = method(_javaPart,
|
|
63
|
-
return __result;
|
|
64
|
-
}
|
|
65
|
-
void JHybridYoloSpec::loadModel(const std::string& modelPath) {
|
|
66
|
-
static const auto method = _javaPart->javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* modelPath */)>("loadModel");
|
|
67
|
-
method(_javaPart, jni::make_jstring(modelPath));
|
|
55
|
+
std::shared_ptr<HybridYoloModelSpec> JHybridYoloSpec::loadModel(const std::string& modelPath) {
|
|
56
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JHybridYoloModelSpec::JavaPart>(jni::alias_ref<jni::JString> /* modelPath */)>("loadModel");
|
|
57
|
+
auto __result = method(_javaPart, jni::make_jstring(modelPath));
|
|
58
|
+
return __result->getJHybridYoloModelSpec();
|
|
68
59
|
}
|
|
69
60
|
std::string JHybridYoloSpec::frameToBase64(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) {
|
|
70
61
|
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<jni::JString>(jni::alias_ref<margelo::nitro::camera::JHybridFrameSpec::JavaPart> /* frame */)>("frameToBase64");
|
|
71
62
|
auto __result = method(_javaPart, std::dynamic_pointer_cast<margelo::nitro::camera::JHybridFrameSpec>(frame)->getJavaPart());
|
|
72
63
|
return __result->toStdString();
|
|
73
64
|
}
|
|
74
|
-
std::vector<Detection> JHybridYoloSpec::detect(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) {
|
|
75
|
-
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<jni::JArrayClass<JDetection>>(jni::alias_ref<margelo::nitro::camera::JHybridFrameSpec::JavaPart> /* frame */)>("detect");
|
|
76
|
-
auto __result = method(_javaPart, std::dynamic_pointer_cast<margelo::nitro::camera::JHybridFrameSpec>(frame)->getJavaPart());
|
|
77
|
-
return [&](auto&& __input) {
|
|
78
|
-
size_t __size = __input->size();
|
|
79
|
-
std::vector<Detection> __vector;
|
|
80
|
-
__vector.reserve(__size);
|
|
81
|
-
for (size_t __i = 0; __i < __size; __i++) {
|
|
82
|
-
auto __element = __input->getElement(__i);
|
|
83
|
-
__vector.push_back(__element->toCpp());
|
|
84
|
-
}
|
|
85
|
-
return __vector;
|
|
86
|
-
}(__result);
|
|
87
|
-
}
|
|
88
65
|
|
|
89
66
|
} // namespace margelo::nitro::yolo
|
|
@@ -54,10 +54,8 @@ namespace margelo::nitro::yolo {
|
|
|
54
54
|
|
|
55
55
|
public:
|
|
56
56
|
// Methods
|
|
57
|
-
|
|
58
|
-
void loadModel(const std::string& modelPath) override;
|
|
57
|
+
std::shared_ptr<HybridYoloModelSpec> loadModel(const std::string& modelPath) override;
|
|
59
58
|
std::string frameToBase64(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) override;
|
|
60
|
-
std::vector<Detection> detect(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) override;
|
|
61
59
|
|
|
62
60
|
private:
|
|
63
61
|
jni::global_ref<JHybridYoloSpec::JavaPart> _javaPart;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridYoloModelSpec.kt
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
package com.margelo.nitro.yolo
|
|
9
|
+
|
|
10
|
+
import androidx.annotation.Keep
|
|
11
|
+
import com.facebook.jni.HybridData
|
|
12
|
+
import com.facebook.proguard.annotations.DoNotStrip
|
|
13
|
+
import com.margelo.nitro.camera.HybridFrameSpec
|
|
14
|
+
import com.margelo.nitro.core.HybridObject
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* A Kotlin class representing the YoloModel HybridObject.
|
|
18
|
+
* Implement this abstract class to create Kotlin-based instances of YoloModel.
|
|
19
|
+
*/
|
|
20
|
+
@DoNotStrip
|
|
21
|
+
@Keep
|
|
22
|
+
@Suppress(
|
|
23
|
+
"KotlinJniMissingFunction", "unused",
|
|
24
|
+
"RedundantSuppression", "RedundantUnitReturnType", "SimpleRedundantLet",
|
|
25
|
+
"LocalVariableName", "PropertyName", "PrivatePropertyName", "FunctionName"
|
|
26
|
+
)
|
|
27
|
+
abstract class HybridYoloModelSpec: HybridObject() {
|
|
28
|
+
// Properties
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
// Methods
|
|
32
|
+
@DoNotStrip
|
|
33
|
+
@Keep
|
|
34
|
+
abstract fun detect(frame: com.margelo.nitro.camera.HybridFrameSpec): Array<Detection>
|
|
35
|
+
|
|
36
|
+
@DoNotStrip
|
|
37
|
+
@Keep
|
|
38
|
+
abstract fun close(): Unit
|
|
39
|
+
|
|
40
|
+
// Default implementation of `HybridObject.toString()`
|
|
41
|
+
override fun toString(): String {
|
|
42
|
+
return "[HybridObject YoloModel]"
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// C++ backing class
|
|
46
|
+
@DoNotStrip
|
|
47
|
+
@Keep
|
|
48
|
+
protected open class CxxPart(javaPart: HybridYoloModelSpec): HybridObject.CxxPart(javaPart) {
|
|
49
|
+
// C++ JHybridYoloModelSpec::CxxPart::initHybrid(...)
|
|
50
|
+
external override fun initHybrid(): HybridData
|
|
51
|
+
}
|
|
52
|
+
override fun createCxxPart(): CxxPart {
|
|
53
|
+
return CxxPart(this)
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
companion object {
|
|
57
|
+
protected const val TAG = "HybridYoloModelSpec"
|
|
58
|
+
}
|
|
59
|
+
}
|
|
@@ -31,19 +31,11 @@ abstract class HybridYoloSpec: HybridObject() {
|
|
|
31
31
|
// Methods
|
|
32
32
|
@DoNotStrip
|
|
33
33
|
@Keep
|
|
34
|
-
abstract fun
|
|
35
|
-
|
|
36
|
-
@DoNotStrip
|
|
37
|
-
@Keep
|
|
38
|
-
abstract fun loadModel(modelPath: String): Unit
|
|
34
|
+
abstract fun loadModel(modelPath: String): HybridYoloModelSpec
|
|
39
35
|
|
|
40
36
|
@DoNotStrip
|
|
41
37
|
@Keep
|
|
42
38
|
abstract fun frameToBase64(frame: com.margelo.nitro.camera.HybridFrameSpec): String
|
|
43
|
-
|
|
44
|
-
@DoNotStrip
|
|
45
|
-
@Keep
|
|
46
|
-
abstract fun detect(frame: com.margelo.nitro.camera.HybridFrameSpec): Array<Detection>
|
|
47
39
|
|
|
48
40
|
// Default implementation of `HybridObject.toString()`
|
|
49
41
|
override fun toString(): String {
|
|
@@ -8,6 +8,7 @@
|
|
|
8
8
|
#include "Yolo-Swift-Cxx-Bridge.hpp"
|
|
9
9
|
|
|
10
10
|
// Include C++ implementation defined types
|
|
11
|
+
#include "HybridYoloModelSpecSwift.hpp"
|
|
11
12
|
#include "HybridYoloSpecSwift.hpp"
|
|
12
13
|
#include "Yolo-Swift-Cxx-Umbrella.hpp"
|
|
13
14
|
#include <NitroModules/NitroDefines.hpp>
|
|
@@ -25,6 +26,22 @@ namespace margelo::nitro::yolo::bridge::swift {
|
|
|
25
26
|
return margelo::nitro::camera::bridge::swift::get_std__shared_ptr_HybridFrameSpec_(cppType);
|
|
26
27
|
}
|
|
27
28
|
|
|
29
|
+
// pragma MARK: std::shared_ptr<HybridYoloModelSpec>
|
|
30
|
+
std::shared_ptr<HybridYoloModelSpec> create_std__shared_ptr_HybridYoloModelSpec_(void* NON_NULL swiftUnsafePointer) noexcept {
|
|
31
|
+
Yolo::HybridYoloModelSpec_cxx swiftPart = Yolo::HybridYoloModelSpec_cxx::fromUnsafe(swiftUnsafePointer);
|
|
32
|
+
return std::make_shared<margelo::nitro::yolo::HybridYoloModelSpecSwift>(swiftPart);
|
|
33
|
+
}
|
|
34
|
+
void* NON_NULL get_std__shared_ptr_HybridYoloModelSpec_(std__shared_ptr_HybridYoloModelSpec_ cppType) {
|
|
35
|
+
std::shared_ptr<margelo::nitro::yolo::HybridYoloModelSpecSwift> swiftWrapper = std::dynamic_pointer_cast<margelo::nitro::yolo::HybridYoloModelSpecSwift>(cppType);
|
|
36
|
+
#ifdef NITRO_DEBUG
|
|
37
|
+
if (swiftWrapper == nullptr) [[unlikely]] {
|
|
38
|
+
throw std::runtime_error("Class \"HybridYoloModelSpec\" is not implemented in Swift!");
|
|
39
|
+
}
|
|
40
|
+
#endif
|
|
41
|
+
Yolo::HybridYoloModelSpec_cxx& swiftPart = swiftWrapper->getSwiftPart();
|
|
42
|
+
return swiftPart.toUnsafe();
|
|
43
|
+
}
|
|
44
|
+
|
|
28
45
|
// pragma MARK: std::shared_ptr<HybridYoloSpec>
|
|
29
46
|
std::shared_ptr<HybridYoloSpec> create_std__shared_ptr_HybridYoloSpec_(void* NON_NULL swiftUnsafePointer) noexcept {
|
|
30
47
|
Yolo::HybridYoloSpec_cxx swiftPart = Yolo::HybridYoloSpec_cxx::fromUnsafe(swiftUnsafePointer);
|
|
@@ -14,18 +14,23 @@ namespace margelo::nitro::yolo { struct BoundingBox; }
|
|
|
14
14
|
namespace margelo::nitro::yolo { struct Detection; }
|
|
15
15
|
// Forward declaration of `HybridFrameSpec` to properly resolve imports.
|
|
16
16
|
namespace margelo::nitro::camera { class HybridFrameSpec; }
|
|
17
|
+
// Forward declaration of `HybridYoloModelSpec` to properly resolve imports.
|
|
18
|
+
namespace margelo::nitro::yolo { class HybridYoloModelSpec; }
|
|
17
19
|
// Forward declaration of `HybridYoloSpec` to properly resolve imports.
|
|
18
20
|
namespace margelo::nitro::yolo { class HybridYoloSpec; }
|
|
19
21
|
|
|
20
22
|
// Forward declarations of Swift defined types
|
|
21
23
|
// Forward declaration of `HybridFrameSpec_cxx` to properly resolve imports.
|
|
22
24
|
namespace VisionCamera { class HybridFrameSpec_cxx; }
|
|
25
|
+
// Forward declaration of `HybridYoloModelSpec_cxx` to properly resolve imports.
|
|
26
|
+
namespace Yolo { class HybridYoloModelSpec_cxx; }
|
|
23
27
|
// Forward declaration of `HybridYoloSpec_cxx` to properly resolve imports.
|
|
24
28
|
namespace Yolo { class HybridYoloSpec_cxx; }
|
|
25
29
|
|
|
26
30
|
// Include C++ defined types
|
|
27
31
|
#include "BoundingBox.hpp"
|
|
28
32
|
#include "Detection.hpp"
|
|
33
|
+
#include "HybridYoloModelSpec.hpp"
|
|
29
34
|
#include "HybridYoloSpec.hpp"
|
|
30
35
|
#include <NitroModules/Result.hpp>
|
|
31
36
|
#include <VisionCamera/HybridFrameSpec.hpp>
|
|
@@ -40,6 +45,17 @@ namespace Yolo { class HybridYoloSpec_cxx; }
|
|
|
40
45
|
*/
|
|
41
46
|
namespace margelo::nitro::yolo::bridge::swift {
|
|
42
47
|
|
|
48
|
+
// pragma MARK: std::vector<Detection>
|
|
49
|
+
/**
|
|
50
|
+
* Specialized version of `std::vector<Detection>`.
|
|
51
|
+
*/
|
|
52
|
+
using std__vector_Detection_ = std::vector<Detection>;
|
|
53
|
+
inline std::vector<Detection> create_std__vector_Detection_(size_t size) noexcept {
|
|
54
|
+
std::vector<Detection> vector;
|
|
55
|
+
vector.reserve(size);
|
|
56
|
+
return vector;
|
|
57
|
+
}
|
|
58
|
+
|
|
43
59
|
// pragma MARK: std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>
|
|
44
60
|
/**
|
|
45
61
|
* Specialized version of `std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>`.
|
|
@@ -52,15 +68,34 @@ namespace margelo::nitro::yolo::bridge::swift {
|
|
|
52
68
|
using std__weak_ptr_margelo__nitro__camera__HybridFrameSpec_ = std::weak_ptr<margelo::nitro::camera::HybridFrameSpec>;
|
|
53
69
|
inline std__weak_ptr_margelo__nitro__camera__HybridFrameSpec_ weakify_std__shared_ptr_margelo__nitro__camera__HybridFrameSpec_(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& strong) noexcept { return strong; }
|
|
54
70
|
|
|
55
|
-
// pragma MARK: std::
|
|
71
|
+
// pragma MARK: std::shared_ptr<HybridYoloModelSpec>
|
|
56
72
|
/**
|
|
57
|
-
* Specialized version of `std::
|
|
73
|
+
* Specialized version of `std::shared_ptr<HybridYoloModelSpec>`.
|
|
58
74
|
*/
|
|
59
|
-
using
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
75
|
+
using std__shared_ptr_HybridYoloModelSpec_ = std::shared_ptr<HybridYoloModelSpec>;
|
|
76
|
+
std::shared_ptr<HybridYoloModelSpec> create_std__shared_ptr_HybridYoloModelSpec_(void* NON_NULL swiftUnsafePointer) noexcept;
|
|
77
|
+
void* NON_NULL get_std__shared_ptr_HybridYoloModelSpec_(std__shared_ptr_HybridYoloModelSpec_ cppType);
|
|
78
|
+
|
|
79
|
+
// pragma MARK: std::weak_ptr<HybridYoloModelSpec>
|
|
80
|
+
using std__weak_ptr_HybridYoloModelSpec_ = std::weak_ptr<HybridYoloModelSpec>;
|
|
81
|
+
inline std__weak_ptr_HybridYoloModelSpec_ weakify_std__shared_ptr_HybridYoloModelSpec_(const std::shared_ptr<HybridYoloModelSpec>& strong) noexcept { return strong; }
|
|
82
|
+
|
|
83
|
+
// pragma MARK: Result<std::vector<Detection>>
|
|
84
|
+
using Result_std__vector_Detection__ = Result<std::vector<Detection>>;
|
|
85
|
+
inline Result_std__vector_Detection__ create_Result_std__vector_Detection__(const std::vector<Detection>& value) noexcept {
|
|
86
|
+
return Result<std::vector<Detection>>::withValue(value);
|
|
87
|
+
}
|
|
88
|
+
inline Result_std__vector_Detection__ create_Result_std__vector_Detection__(const std::exception_ptr& error) noexcept {
|
|
89
|
+
return Result<std::vector<Detection>>::withError(error);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
// pragma MARK: Result<void>
|
|
93
|
+
using Result_void_ = Result<void>;
|
|
94
|
+
inline Result_void_ create_Result_void_() noexcept {
|
|
95
|
+
return Result<void>::withValue();
|
|
96
|
+
}
|
|
97
|
+
inline Result_void_ create_Result_void_(const std::exception_ptr& error) noexcept {
|
|
98
|
+
return Result<void>::withError(error);
|
|
64
99
|
}
|
|
65
100
|
|
|
66
101
|
// pragma MARK: std::shared_ptr<HybridYoloSpec>
|
|
@@ -75,22 +110,13 @@ namespace margelo::nitro::yolo::bridge::swift {
|
|
|
75
110
|
using std__weak_ptr_HybridYoloSpec_ = std::weak_ptr<HybridYoloSpec>;
|
|
76
111
|
inline std__weak_ptr_HybridYoloSpec_ weakify_std__shared_ptr_HybridYoloSpec_(const std::shared_ptr<HybridYoloSpec>& strong) noexcept { return strong; }
|
|
77
112
|
|
|
78
|
-
// pragma MARK: Result<
|
|
79
|
-
using
|
|
80
|
-
inline
|
|
81
|
-
return Result<
|
|
113
|
+
// pragma MARK: Result<std::shared_ptr<HybridYoloModelSpec>>
|
|
114
|
+
using Result_std__shared_ptr_HybridYoloModelSpec__ = Result<std::shared_ptr<HybridYoloModelSpec>>;
|
|
115
|
+
inline Result_std__shared_ptr_HybridYoloModelSpec__ create_Result_std__shared_ptr_HybridYoloModelSpec__(const std::shared_ptr<HybridYoloModelSpec>& value) noexcept {
|
|
116
|
+
return Result<std::shared_ptr<HybridYoloModelSpec>>::withValue(value);
|
|
82
117
|
}
|
|
83
|
-
inline
|
|
84
|
-
return Result<
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
// pragma MARK: Result<void>
|
|
88
|
-
using Result_void_ = Result<void>;
|
|
89
|
-
inline Result_void_ create_Result_void_() noexcept {
|
|
90
|
-
return Result<void>::withValue();
|
|
91
|
-
}
|
|
92
|
-
inline Result_void_ create_Result_void_(const std::exception_ptr& error) noexcept {
|
|
93
|
-
return Result<void>::withError(error);
|
|
118
|
+
inline Result_std__shared_ptr_HybridYoloModelSpec__ create_Result_std__shared_ptr_HybridYoloModelSpec__(const std::exception_ptr& error) noexcept {
|
|
119
|
+
return Result<std::shared_ptr<HybridYoloModelSpec>>::withError(error);
|
|
94
120
|
}
|
|
95
121
|
|
|
96
122
|
// pragma MARK: Result<std::string>
|
|
@@ -101,14 +127,5 @@ namespace margelo::nitro::yolo::bridge::swift {
|
|
|
101
127
|
inline Result_std__string_ create_Result_std__string_(const std::exception_ptr& error) noexcept {
|
|
102
128
|
return Result<std::string>::withError(error);
|
|
103
129
|
}
|
|
104
|
-
|
|
105
|
-
// pragma MARK: Result<std::vector<Detection>>
|
|
106
|
-
using Result_std__vector_Detection__ = Result<std::vector<Detection>>;
|
|
107
|
-
inline Result_std__vector_Detection__ create_Result_std__vector_Detection__(const std::vector<Detection>& value) noexcept {
|
|
108
|
-
return Result<std::vector<Detection>>::withValue(value);
|
|
109
|
-
}
|
|
110
|
-
inline Result_std__vector_Detection__ create_Result_std__vector_Detection__(const std::exception_ptr& error) noexcept {
|
|
111
|
-
return Result<std::vector<Detection>>::withError(error);
|
|
112
|
-
}
|
|
113
130
|
|
|
114
131
|
} // namespace margelo::nitro::yolo::bridge::swift
|
|
@@ -14,12 +14,15 @@ namespace margelo::nitro::yolo { struct BoundingBox; }
|
|
|
14
14
|
namespace margelo::nitro::yolo { struct Detection; }
|
|
15
15
|
// Forward declaration of `HybridFrameSpec` to properly resolve imports.
|
|
16
16
|
namespace margelo::nitro::camera { class HybridFrameSpec; }
|
|
17
|
+
// Forward declaration of `HybridYoloModelSpec` to properly resolve imports.
|
|
18
|
+
namespace margelo::nitro::yolo { class HybridYoloModelSpec; }
|
|
17
19
|
// Forward declaration of `HybridYoloSpec` to properly resolve imports.
|
|
18
20
|
namespace margelo::nitro::yolo { class HybridYoloSpec; }
|
|
19
21
|
|
|
20
22
|
// Include C++ defined types
|
|
21
23
|
#include "BoundingBox.hpp"
|
|
22
24
|
#include "Detection.hpp"
|
|
25
|
+
#include "HybridYoloModelSpec.hpp"
|
|
23
26
|
#include "HybridYoloSpec.hpp"
|
|
24
27
|
#include <NitroModules/Result.hpp>
|
|
25
28
|
#include <VisionCamera/HybridFrameSpec.hpp>
|
|
@@ -40,6 +43,8 @@ namespace margelo::nitro::yolo { class HybridYoloSpec; }
|
|
|
40
43
|
// Forward declarations of Swift defined types
|
|
41
44
|
// Forward declaration of `HybridFrameSpec_cxx` to properly resolve imports.
|
|
42
45
|
namespace VisionCamera { class HybridFrameSpec_cxx; }
|
|
46
|
+
// Forward declaration of `HybridYoloModelSpec_cxx` to properly resolve imports.
|
|
47
|
+
namespace Yolo { class HybridYoloModelSpec_cxx; }
|
|
43
48
|
// Forward declaration of `HybridYoloSpec_cxx` to properly resolve imports.
|
|
44
49
|
namespace Yolo { class HybridYoloSpec_cxx; }
|
|
45
50
|
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridYoloModelSpecSwift.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridYoloModelSpecSwift.hpp"
|
|
9
|
+
|
|
10
|
+
namespace margelo::nitro::yolo {
|
|
11
|
+
} // namespace margelo::nitro::yolo
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridYoloModelSpecSwift.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include "HybridYoloModelSpec.hpp"
|
|
11
|
+
|
|
12
|
+
// Forward declaration of `HybridYoloModelSpec_cxx` to properly resolve imports.
|
|
13
|
+
namespace Yolo { class HybridYoloModelSpec_cxx; }
|
|
14
|
+
|
|
15
|
+
// Forward declaration of `Detection` to properly resolve imports.
|
|
16
|
+
namespace margelo::nitro::yolo { struct Detection; }
|
|
17
|
+
// Forward declaration of `BoundingBox` to properly resolve imports.
|
|
18
|
+
namespace margelo::nitro::yolo { struct BoundingBox; }
|
|
19
|
+
// Forward declaration of `HybridFrameSpec` to properly resolve imports.
|
|
20
|
+
namespace margelo::nitro::camera { class HybridFrameSpec; }
|
|
21
|
+
|
|
22
|
+
#include "Detection.hpp"
|
|
23
|
+
#include <vector>
|
|
24
|
+
#include "BoundingBox.hpp"
|
|
25
|
+
#include <memory>
|
|
26
|
+
#include <VisionCamera/HybridFrameSpec.hpp>
|
|
27
|
+
|
|
28
|
+
#include "Yolo-Swift-Cxx-Umbrella.hpp"
|
|
29
|
+
|
|
30
|
+
namespace margelo::nitro::yolo {
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* The C++ part of HybridYoloModelSpec_cxx.swift.
|
|
34
|
+
*
|
|
35
|
+
* HybridYoloModelSpecSwift (C++) accesses HybridYoloModelSpec_cxx (Swift), and might
|
|
36
|
+
* contain some additional bridging code for C++ <> Swift interop.
|
|
37
|
+
*
|
|
38
|
+
* Since this obviously introduces an overhead, I hope at some point in
|
|
39
|
+
* the future, HybridYoloModelSpec_cxx can directly inherit from the C++ class HybridYoloModelSpec
|
|
40
|
+
* to simplify the whole structure and memory management.
|
|
41
|
+
*/
|
|
42
|
+
class HybridYoloModelSpecSwift: public virtual HybridYoloModelSpec {
|
|
43
|
+
public:
|
|
44
|
+
// Constructor from a Swift instance
|
|
45
|
+
explicit HybridYoloModelSpecSwift(const Yolo::HybridYoloModelSpec_cxx& swiftPart):
|
|
46
|
+
HybridObject(HybridYoloModelSpec::TAG),
|
|
47
|
+
_swiftPart(swiftPart) { }
|
|
48
|
+
|
|
49
|
+
public:
|
|
50
|
+
// Get the Swift part
|
|
51
|
+
inline Yolo::HybridYoloModelSpec_cxx& getSwiftPart() noexcept {
|
|
52
|
+
return _swiftPart;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
public:
|
|
56
|
+
inline size_t getExternalMemorySize() noexcept override {
|
|
57
|
+
return _swiftPart.getMemorySize();
|
|
58
|
+
}
|
|
59
|
+
bool equals(const std::shared_ptr<HybridObject>& other) override {
|
|
60
|
+
if (auto otherCast = std::dynamic_pointer_cast<HybridYoloModelSpecSwift>(other)) {
|
|
61
|
+
return _swiftPart.equals(otherCast->_swiftPart);
|
|
62
|
+
}
|
|
63
|
+
return false;
|
|
64
|
+
}
|
|
65
|
+
void dispose() noexcept override {
|
|
66
|
+
_swiftPart.dispose();
|
|
67
|
+
}
|
|
68
|
+
std::string toString() override {
|
|
69
|
+
return _swiftPart.toString();
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
public:
|
|
73
|
+
// Properties
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
public:
|
|
77
|
+
// Methods
|
|
78
|
+
inline std::vector<Detection> detect(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) override {
|
|
79
|
+
auto __result = _swiftPart.detect(frame);
|
|
80
|
+
if (__result.hasError()) [[unlikely]] {
|
|
81
|
+
std::rethrow_exception(__result.error());
|
|
82
|
+
}
|
|
83
|
+
auto __value = std::move(__result.value());
|
|
84
|
+
return __value;
|
|
85
|
+
}
|
|
86
|
+
inline void close() override {
|
|
87
|
+
auto __result = _swiftPart.close();
|
|
88
|
+
if (__result.hasError()) [[unlikely]] {
|
|
89
|
+
std::rethrow_exception(__result.error());
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
private:
|
|
94
|
+
Yolo::HybridYoloModelSpec_cxx _swiftPart;
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
} // namespace margelo::nitro::yolo
|
|
@@ -12,19 +12,15 @@
|
|
|
12
12
|
// Forward declaration of `HybridYoloSpec_cxx` to properly resolve imports.
|
|
13
13
|
namespace Yolo { class HybridYoloSpec_cxx; }
|
|
14
14
|
|
|
15
|
+
// Forward declaration of `HybridYoloModelSpec` to properly resolve imports.
|
|
16
|
+
namespace margelo::nitro::yolo { class HybridYoloModelSpec; }
|
|
15
17
|
// Forward declaration of `HybridFrameSpec` to properly resolve imports.
|
|
16
18
|
namespace margelo::nitro::camera { class HybridFrameSpec; }
|
|
17
|
-
// Forward declaration of `Detection` to properly resolve imports.
|
|
18
|
-
namespace margelo::nitro::yolo { struct Detection; }
|
|
19
|
-
// Forward declaration of `BoundingBox` to properly resolve imports.
|
|
20
|
-
namespace margelo::nitro::yolo { struct BoundingBox; }
|
|
21
19
|
|
|
22
|
-
#include <string>
|
|
23
20
|
#include <memory>
|
|
21
|
+
#include "HybridYoloModelSpec.hpp"
|
|
22
|
+
#include <string>
|
|
24
23
|
#include <VisionCamera/HybridFrameSpec.hpp>
|
|
25
|
-
#include "Detection.hpp"
|
|
26
|
-
#include <vector>
|
|
27
|
-
#include "BoundingBox.hpp"
|
|
28
24
|
|
|
29
25
|
#include "Yolo-Swift-Cxx-Umbrella.hpp"
|
|
30
26
|
|
|
@@ -76,20 +72,14 @@ namespace margelo::nitro::yolo {
|
|
|
76
72
|
|
|
77
73
|
public:
|
|
78
74
|
// Methods
|
|
79
|
-
inline
|
|
80
|
-
auto __result = _swiftPart.
|
|
75
|
+
inline std::shared_ptr<HybridYoloModelSpec> loadModel(const std::string& modelPath) override {
|
|
76
|
+
auto __result = _swiftPart.loadModel(modelPath);
|
|
81
77
|
if (__result.hasError()) [[unlikely]] {
|
|
82
78
|
std::rethrow_exception(__result.error());
|
|
83
79
|
}
|
|
84
80
|
auto __value = std::move(__result.value());
|
|
85
81
|
return __value;
|
|
86
82
|
}
|
|
87
|
-
inline void loadModel(const std::string& modelPath) override {
|
|
88
|
-
auto __result = _swiftPart.loadModel(modelPath);
|
|
89
|
-
if (__result.hasError()) [[unlikely]] {
|
|
90
|
-
std::rethrow_exception(__result.error());
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
83
|
inline std::string frameToBase64(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) override {
|
|
94
84
|
auto __result = _swiftPart.frameToBase64(frame);
|
|
95
85
|
if (__result.hasError()) [[unlikely]] {
|
|
@@ -98,14 +88,6 @@ namespace margelo::nitro::yolo {
|
|
|
98
88
|
auto __value = std::move(__result.value());
|
|
99
89
|
return __value;
|
|
100
90
|
}
|
|
101
|
-
inline std::vector<Detection> detect(const std::shared_ptr<margelo::nitro::camera::HybridFrameSpec>& frame) override {
|
|
102
|
-
auto __result = _swiftPart.detect(frame);
|
|
103
|
-
if (__result.hasError()) [[unlikely]] {
|
|
104
|
-
std::rethrow_exception(__result.error());
|
|
105
|
-
}
|
|
106
|
-
auto __value = std::move(__result.value());
|
|
107
|
-
return __value;
|
|
108
|
-
}
|
|
109
91
|
|
|
110
92
|
private:
|
|
111
93
|
Yolo::HybridYoloSpec_cxx _swiftPart;
|