Skip to content

Commit dfe2825

Browse files
committed
refactor loading
1 parent 963d6f1 commit dfe2825

File tree

6 files changed

+86
-198
lines changed

6 files changed

+86
-198
lines changed
Lines changed: 79 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,79 @@
1+
/*
2+
* Copyright (C) Photon Vision.
3+
*
4+
* This program is free software: you can redistribute it and/or modify
5+
* it under the terms of the GNU General Public License as published by
6+
* the Free Software Foundation, either version 3 of the License, or
7+
* (at your option) any later version.
8+
*
9+
* This program is distributed in the hope that it will be useful,
10+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12+
* GNU General Public License for more details.
13+
*
14+
* You should have received a copy of the GNU General Public License
15+
* along with this program. If not, see <https://www.gnu.org/licenses/>.
16+
*/
17+
18+
package org.photonvision.common;
19+
20+
import edu.wpi.first.util.CombinedRuntimeLoader;
21+
import java.io.IOException;
22+
import org.photonvision.jni.LibraryLoader;
23+
24+
public class LoadJNI {
25+
public enum JNITypes {
26+
RUBIK_DETECTOR(false),
27+
RKNN_DETECTOR(false),
28+
MRCAL(false),
29+
LIBCAMERA(false);
30+
31+
private volatile boolean hasLoaded;
32+
33+
JNITypes(boolean hasLoaded) {
34+
this.hasLoaded = hasLoaded;
35+
}
36+
37+
public boolean hasLoaded() {
38+
return hasLoaded;
39+
}
40+
41+
public void setHasLoaded(boolean loaded) {
42+
this.hasLoaded = loaded;
43+
}
44+
}
45+
46+
public static synchronized void forceLoad(JNITypes type) throws IOException {
47+
loadLibraries();
48+
49+
if (type.hasLoaded()) {
50+
return;
51+
}
52+
53+
switch (type) {
54+
case RUBIK_DETECTOR:
55+
CombinedRuntimeLoader.loadLibraries(
56+
LoadJNI.class, "tensorflowlite", "tensorflowlite_c", "external_delegate", "rubik_jni");
57+
type.setHasLoaded(true);
58+
break;
59+
case RKNN_DETECTOR:
60+
CombinedRuntimeLoader.loadLibraries(LoadJNI.class, "rga", "rknnrt", "rknn_jni");
61+
type.setHasLoaded(true);
62+
break;
63+
case MRCAL:
64+
CombinedRuntimeLoader.loadLibraries(LoadJNI.class, "mrcal_jni");
65+
type.setHasLoaded(true);
66+
break;
67+
case LIBCAMERA:
68+
CombinedRuntimeLoader.loadLibraries(LoadJNI.class, "photonlibcamera");
69+
type.setHasLoaded(true);
70+
break;
71+
default:
72+
throw new IOException("Unknown JNI type: " + type);
73+
}
74+
}
75+
76+
public static boolean loadLibraries() {
77+
return LibraryLoader.loadWpiLibraries() && LibraryLoader.loadTargeting();
78+
}
79+
}

photon-core/src/main/java/org/photonvision/common/util/TestUtils.java

Lines changed: 0 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -20,41 +20,17 @@
2020
import com.fasterxml.jackson.databind.ObjectMapper;
2121
import edu.wpi.first.math.geometry.Translation2d;
2222
import edu.wpi.first.math.util.Units;
23-
import edu.wpi.first.util.CombinedRuntimeLoader;
2423
import java.awt.HeadlessException;
2524
import java.io.File;
2625
import java.io.IOException;
2726
import java.nio.file.Path;
2827
import org.opencv.core.Mat;
2928
import org.opencv.highgui.HighGui;
30-
import org.photonvision.jni.LibraryLoader;
3129
import org.photonvision.vision.calibration.CameraCalibrationCoefficients;
3230
import org.photonvision.vision.pipeline.result.CVPipelineResult;
3331
import org.photonvision.vision.target.TrackedTarget;
3432

3533
public class TestUtils {
36-
private static boolean hasMrcalLoaded = false;
37-
38-
public static boolean loadLibraries() {
39-
return LibraryLoader.loadWpiLibraries() && LibraryLoader.loadTargeting();
40-
}
41-
42-
public static boolean loadMrcal() {
43-
if (hasMrcalLoaded) return true;
44-
try {
45-
CombinedRuntimeLoader.loadLibraries(TestUtils.class, "mrcal_jni");
46-
hasMrcalLoaded = true;
47-
} catch (IOException e) {
48-
e.printStackTrace();
49-
hasMrcalLoaded = false;
50-
}
51-
return hasMrcalLoaded;
52-
}
53-
54-
public static boolean isMrcalLoaded() {
55-
return hasMrcalLoaded;
56-
}
57-
5834
@SuppressWarnings("unused")
5935
public enum WPI2019Image {
6036
kCargoAngledDark48in(1.2192),

photon-core/src/main/java/org/photonvision/jni/RknnDetectorJNI.java

Lines changed: 0 additions & 51 deletions
This file was deleted.

photon-core/src/main/java/org/photonvision/jni/RubikDetectorJNI.java

Lines changed: 0 additions & 56 deletions
This file was deleted.

photon-core/src/main/java/org/photonvision/raspi/LibCameraJNILoader.java

Lines changed: 0 additions & 49 deletions
This file was deleted.

photon-server/src/main/java/org/photonvision/Main.java

Lines changed: 7 additions & 18 deletions
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,7 @@
2323
import java.util.ArrayList;
2424
import java.util.List;
2525
import org.apache.commons.cli.*;
26+
import org.photonvision.common.LoadJNI;
2627
import org.photonvision.common.configuration.CameraConfiguration;
2728
import org.photonvision.common.configuration.ConfigManager;
2829
import org.photonvision.common.configuration.NeuralNetworkModelManager;
@@ -38,9 +39,6 @@
3839
import org.photonvision.common.logging.PvCSCoreLogger;
3940
import org.photonvision.common.networking.NetworkManager;
4041
import org.photonvision.common.util.TestUtils;
41-
import org.photonvision.jni.RknnDetectorJNI;
42-
import org.photonvision.jni.RubikDetectorJNI;
43-
import org.photonvision.raspi.LibCameraJNILoader;
4442
import org.photonvision.server.Server;
4543
import org.photonvision.vision.apriltag.AprilTagFamily;
4644
import org.photonvision.vision.camera.PVCameraInfo;
@@ -194,7 +192,7 @@ public static void main(String[] args) {
194192
}
195193

196194
try {
197-
boolean success = TestUtils.loadLibraries();
195+
boolean success = LoadJNI.loadLibraries();
198196

199197
if (!success) {
200198
logger.error("Failed to load native libraries! Giving up :(");
@@ -213,19 +211,14 @@ public static void main(String[] args) {
213211

214212
try {
215213
if (Platform.isRaspberryPi()) {
216-
LibCameraJNILoader.forceLoad();
214+
LoadJNI.forceLoad(LoadJNI.JNITypes.LIBCAMERA);
217215
}
218216
} catch (IOException e) {
219217
logger.error("Failed to load libcamera-JNI!", e);
220218
}
221219
try {
222220
if (Platform.isRK3588()) {
223-
RknnDetectorJNI.forceLoad();
224-
if (RknnDetectorJNI.getInstance().isLoaded()) {
225-
logger.info("RknnDetectorJNI loaded successfully.");
226-
} else {
227-
logger.error("Failed to load RknnDetectorJNI!");
228-
}
221+
LoadJNI.forceLoad(LoadJNI.JNITypes.RKNN_DETECTOR);
229222
} else {
230223
logger.error("Platform does not support RKNN based machine learning!");
231224
}
@@ -234,20 +227,16 @@ public static void main(String[] args) {
234227
}
235228
try {
236229
if (Platform.isQCS6490()) {
237-
RubikDetectorJNI.forceLoad();
238-
if (RubikDetectorJNI.getInstance().isLoaded()) {
239-
logger.info("RubikDetectorJNI loaded successfully.");
240-
} else {
241-
logger.error("Failed to load RubikDetectorJNI!");
242-
}
230+
LoadJNI.forceLoad(LoadJNI.JNITypes.RUBIK_DETECTOR);
243231
} else {
244232
logger.error("Platform does not support Rubik based machine learning!");
245233
}
246234
} catch (IOException e) {
247235
logger.error("Failed to load rubik-JNI!", e);
248236
}
249237
try {
250-
TestUtils.loadMrcal();
238+
LoadJNI.forceLoad(LoadJNI.JNITypes.MRCAL);
239+
logger.info("mrcal-JNI loaded successfully.");
251240
} catch (Exception e) {
252241
logger.warn(
253242
"Failed to load mrcal-JNI! Camera calibration will fall back to opencv\n"

0 commit comments

Comments
 (0)