0

javaCV を使用して単純な顔認識コードを実装しようとしています。エラーが発生し、理由がわかりません。

すべての .so ファイルをほぼすべてのディレクトリにコピーしました -> app/libs/armeabi および app/src/main/jniLibs また、javacpp.jar および javacv.jar を app/libs ディレクトリにコピーします

エラーは次のとおりです。

原因: java.lang.UnsatisfiedLinkError: dlopen に失敗しました: "libjniopencv_contrib.so" が必要とするライブラリ "libopencv_contrib.so" を読み込めませんでした。「libopencv_contrib.so」に必要なライブラリ「../../lib/libopencv_legacy.so」を読み込めなかったことが原因です。com の java.lang.System.load(System.java:511) の java.lang.Runtime.load(Runtime.java:330) にライブラリ "../../lib/libopencv_legacy.so" が見つからないことが原因です.googlecode.javacpp.Loader.loadLibrary(Loader.java:700) で com.googlecode.javacpp.Loader.load(Loader.java:586) で com.googlecode.javacpp.Loader.load(Loader.java:540) でcom.googlecode.javacv.cpp.opencv_contrib.(opencv_contrib.java:97) com.ifta.face.OpenCVFaceRecognizer.recognise(OpenCVFaceRecognizer.java:

私が使用しているJava関数は次​​のとおりです。

public static void recognise(Context context, File sampleDir, File testFile) {

    // DEBUG-1
    if(sampleDir!=null)
        log(context, "1. sampleDir OK. " + testFile.getAbsolutePath());
    else {
        log(context, "1. sampleDir is Null");
        return;
    }


    FilenameFilter pngFilter = new FilenameFilter() {
        public boolean accept(File dir, String name) {
            return name.toLowerCase().endsWith(".png");
        }
    };

    File[] imageFiles = sampleDir.listFiles(pngFilter);

    // DEBUG-2
    if(imageFiles!=null) {
        log(context, "2. ImageFile OK, Files :");
        for(File imageFile : imageFiles)
            log(context, "File : " + imageFile.getAbsolutePath() );
    }
    else {
        log(context, "2. ImageFile Array Null");
        return;
    }

    // DEBUG-.5
    if(testFile!=null)
        log(context, "2.5. testFile OK. " + testFile.getAbsolutePath());
    else {
        log(context, "2.5. testFile is Null");
        return;
    }

    IplImage testImage = cvLoadImage(testFile.getAbsolutePath());
    // DEBUG-3
    if(imageFiles!=null)
        log(context, "3. testImageIpl OK");
    else {
        log(context, "3. testImageIpl is Null");
        return;
    }

    MatVector images = new MatVector(imageFiles.length);

    int[] labels = new int[imageFiles.length];

    int counter = 0;
    int label;

    IplImage img;
    IplImage grayImg;

    for (File image : imageFiles) {
        // Get image and label:
        img = cvLoadImage(image.getAbsolutePath());
        label = Integer.parseInt(image.getName().split("\\-")[0]);

        // Convert image to gray scale:
        grayImg = IplImage.create(img.width(), img.height(), IPL_DEPTH_8U, 1);
        cvCvtColor(img, grayImg, CV_BGR2GRAY);
        // Append it in the image list:
        images.put(counter, grayImg);
        // And in the labels list:
        labels[counter] = label;
        // Increase counter for next image:
        counter++;
    }

    //FaceRecognizer faceRecognizer = createFisherFaceRecognizer();
    FaceRecognizer faceRecognizer = createEigenFaceRecognizer();
    // FaceRecognizer faceRecognizer = createLBPHFaceRecognizer();

    faceRecognizer.train(images, labels);

    // Load the test image:
    IplImage greyTestImage = IplImage.create(testImage.width(), testImage.height(), IPL_DEPTH_8U, 1);
    cvCvtColor(testImage, greyTestImage, CV_BGR2GRAY);

    // And get a prediction:
    //int predictedLabel = faceRecognizer.predict(greyTestImage);
    //System.out.println("Predicted label: " + predictedLabel);

    int[] imageLabels = new int[1];
    double[] confidences = new double[1];

    faceRecognizer.predict(greyTestImage, imageLabels, confidences);

    log(context, "Result : Label - " + imageLabels[0] + "  Conf - " + confidences[0]);


}
4

1 に答える 1

0

2日後にこれを解決しました...ライブラリを手動でロードすることになっていました。数行追加しました

    System.load("/data/data/com.ifta.face/lib/libopencv_photo.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_flann.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_features2d.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_calib3d.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_ml.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_video.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_legacy.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_objdetect.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_gpu.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_nonfree.so");
    System.load("/data/data/com.ifta.face/lib/libopencv_contrib.so");

そして、「libjni*.so」という名前のライブラリは自動的にロードされ、「libopencv_*.so」などのライブラリは手動でロードする必要があることがわかりました。また、ライブラリは以前のライブラリに依存しているため、ロード シーケンスは上記のようにする必要があります。なぜこれが起こっているのか知っている人はいますか?

于 2015-06-03T02:10:57.323 に答える