VisualSFM使用记录1 unable to load libsiftgpu.so

官网:http://ccwu.me/vsfm/
(解决过程蓝色字,问题原因解决方法红色字)
SFM computer missing match阶段运行出现错误

More than 189MB of graphic memory may be allocated
under the default settings. If the program halts here,
adjust parameters to save memory and rerun the task:
    [Tools->Enable GPU->Set Maximum DIM]
Note some octaves may be automatically skipped
ERROR: unable to load  libsiftgpu.so
ERROR: unable to get function address
SIFT: 0000, 1080x1920,     ERROR1
ERROR: unable to locate sift binary.
FAQ at http://ccwu.me/vsfm/doc.html#errors

查看官方文档提示如下
1. "SiftGPU failed the detection test" or "ERROR: siftgpu doesn‘t work"
    This means SiftGPU feature detection did not work properly. Either your graphic driver
    is out-dated or your graphic card does not support SiftGPU at all. You should give
    it another try after updating the graphic driver. If it fails the same way, you may
    need to switch to CPU for feature detection or get a better GPU.

2. "ERROR1" + "ERROR: unable to locate sift binary"
    This means VisualSFM tried to use CPU feature detector but it could not find it.
    Under windows, it looks for .\SiftWin32.exe if param_use_vlfeat_or_lowe==0 or
    .\sift.exe otherwise. For other OS, it will look for ./sift

1.SiftGPU无法工作,可能是显卡驱动程序过时,或者显卡驱动不支持SiftGPU,可以更新显卡驱动进行尝试,如果依旧失败,可以转换用CPU进行特征检测或获取更好的GPU
2.找不到SIFT二进制文件,意味着VisualSFM试图使用CPU功能检测器,但找不到它。

Typical hardware requirements
1. The feature detection step requires a decent GPU (ATI/ nVidia / Intel)
   In particular, a large amount of GPU memory (1GB) is expected.
   Small GPU memory may cause problems for the feature detection: click here.
   The latest SiftGPU-V400 works for Intel graphic card in some platforms.
1.特征检测步骤需要一个合适的GPU(ATI/Nvidia/Intel)尤其需要大量的GPU内存(1GB)。小的GPU内存可能会导致功能检测出现问题:单击此处。最新的siftgpu-v400可在某些平台上的英特尔显卡上工作。

我的显卡驱动以及CUDA信息如下,硬件环境方面并没发现什么问题
NVIDIA-SMI 418.39       Driver Version: 418.39       CUDA Version: 10.1

尝试了以下操作:

1.对SiftGPU重新编译
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ make clean
rm -f build/*.o
rm -f bin/libsiftgpu.a
rm -f bin/libsiftgpu.so
rm -f bin/TestWinGlut
rm -f bin/SimpleSIFT
rm -f bin/speed
rm -f bin/server_siftgpu
rm -f bin/MultiThreadSIFT
rm -f ProgramCU.linkinfo
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ make -j12

cp /usr/lib64/libGLEW.so.2.1 ../../VisualSFM_linux_64bit/vsfm/bin/
cp /usr/lib64/libGLEW.so.2.1 ../../VisualSFM_linux_64bit/vsfm/bin/

2.将libsiftgpu.so拷贝至/usr/local/lib/目录

~/Documents/SFMSource/VisualSFM_linux_64bit/vsfm$sudo cp bin/libsiftgpu.so  /usr/local/lib/

~/Documents/SFMSource/VisualSFM_linux_64bit/vsfm$ bin/VisualSFM

失败

2.将正确的路径加入环境变量

~/Documents/SFMSource/VisualSFM_linux_64bit/vsfm$ export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:~/Documents/SFMSource/VisualSFM_linux_64bit/vsfm/bin

~/Documents/SFMSource/VisualSFM_linux_64bit/vsfm$ bin/VisualSFM
失败

3.进入/SiftGPU-V400/SiftGPU/bin 运行可执行文件SimpleSIFT,运行失败,查看依赖后进入程序源码/SiftGPU-V400/SiftGPU/src/TestWin/SimpleSIFT.cpp查找原因。

~/Documents/SFMSource/SiftGPU-V400/SiftGPU/bin$ ./SimpleSIFT
运行SimpleSIFT文件无结果显示。
~/Documents/SFMSource/SiftGPU-V400/SiftGPU/bin$ ldd ./SimpleSIFT
查看相关依赖正常
打开源码
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ vim src/TestWin/SimpleSIFT.cpp
在void * hsiftgpu = dlopen("libsiftgpu.so", RTLD_LAZY);处打印一些字符判断是否加载成功。
再执行
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ make
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ bin/SimpleSIFT

无结果显示,将路径加入环境变量再运行
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:~/Documents/SFMSource/SiftGPU-V400/SiftGPU/bin
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ bin/SimpleSIFT
打印结果说明.so文件依旧没有成功加载

------可忽略的系列尝试
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$export LD_LIBRARY_PATH=~/Documents/SFMSource/SiftGPU-V400/SiftGPU/bin
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ echo $LD_LIBRARY_PATH
/home/zsl/Documents/SFMSource/SiftGPU-V400/SiftGPU/bin
修改了路径变量再运行
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ bin/SimpleSIFT
hello?
还是不行,重新编译
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ make -j12
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ vim src/TestWin/SimpleSIFT.cpp
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ man dlopen
----------
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ vim src/TestWin/SimpleSIFT.cpp
4.根据 dlopen 命令的使用,
在SimpleSIFT.cpp中so载入异常出添加代码,使其打印加载so失败的错误原因
添加代码如下:       
 //void * hsiftgpu = dlopen("libsiftgpu.so", RTLD_LAZY);
        void * hsiftgpu = dlopen("/home/zsl/Documents/SFMSource/SiftGPU-V400/SiftGPU/bin/libsiftgpu.so", RTLD_LAZY);
    
     if (!hsiftgpu) {
               fprintf(stderr, "%s\n", dlerror());
               exit(EXIT_FAILURE);
           }

#endif

printf("hello?\n");
    if(hsiftgpu == NULL) return 0;

printf("hello\n");

编辑完成后,编译执行
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ make
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ bin/SimpleSIFT
libGLEW.so.2.1: cannot open shared object file: No such file or directory

返回了失败原因:因为加载libsiftgup.so需要加载libGLEW.so.2.1然而找不到该文件。说明该文件没有指明路径。找到该文件:
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ locate libGLEW.so.2.1
/home/zsl/Documents/SFMSource/glew-2.1.0/lib/libGLEW.so.2.1
/home/zsl/Documents/SFMSource/glew-2.1.0/lib/libGLEW.so.2.1.0
/usr/lib64/libGLEW.so.2.1
/usr/lib64/libGLEW.so.2.1.0

将libGLEW.so.2.1拷贝到SiftGPU-V400/SiftGPU/bin/目录下运行SimpleSIFT 出结果了。
~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ cp /usr/lib64/libGLEW.so.2.1 bin/

~/Documents/SFMSource/SiftGPU-V400/SiftGPU$ bin/SimpleSIFT
hello?
hello
[GPU VENDOR]:    NVIDIA Corporation 10404MB
TEXTURE:    32768

[SiftGPU Language]:    GLSL
Unable to open image [code = 1290]
Unable to open image [code = 1290]
[SiftMatchGPU]: GLSL

0 sift matches were found;

为使其找到libGLEW.so.2.1,将其拷贝到vsfm/bin/下
cp /usr/lib64/libGLEW.so.2.1 ../../VisualSFM_linux_64bit/vsfm/bin/

~/Documents/SFMSource/VisualSFM_linux_64bit/vsfm$ bin/VisualSFM

成功。

===========================
第二天开机使用又出现了一样的 unable to load  libsiftgpu.so
错误,而且/SiftGPU-V400/SiftGPU$ bin/SimpleSIFT 是有输出的。
然后我编译了几次都没有解决问题,最后到目录/VisualSFM_linux_64bit/vsfm下
$ sudo cp bin/libsiftgpu.so  /usr/local/lib

Computer Missing Matches成功

原文地址:https://www.cnblogs.com/2333333he-tui/p/10536716.html

时间: 2024-10-10 18:54:00

VisualSFM使用记录1 unable to load libsiftgpu.so的相关文章

[转]genymotion Unable to load VirtualBox engine 某种解决办法

genymotion Unable to load VirtualBox engine 某种解决办法 耳闻genymotion这款模拟器很强力.于是下下来试试看.我的机器上是有virtualbox的了,所以我就没选择带virtualbox的版本. 万万没想到..genymotion起不来了.网上找了一堆的解决办法,大多数是在说网卡的事情,但那已经是到模拟器那一步了,我这还没进去呢,完全没到创建设备的那一步.大家还说要不就重装了virtualBox吧.查了一下版本,发现我的virtualbox版本

关于cocos2dx 3.0升级崩溃报错(unable to load native library) 和(Fatal signal 11 (SIGSEGV) at 0x00000000)

最近一直在Windows平台开发cocos-2dx游戏,期间做了一次引擎升级,升级到了3.0正式版本.Windows平台上表现很正常,没有出现什么问题. 上周五准备发布一个安卓包,编译很轻松的就过了,没有花费多少时间,但是安装到手机后,发现运行就崩溃了.没办法只好用模拟机调试,再次吐槽Android的模拟器,真的太他妈慢了,不到万不得已我真的不想再去用它,google真的应该好好整一下了. 好不容易运行起来了,看到崩溃的时候logcat的报错是"unable to load native lib

Caused by: Unable to load configuration. - action - file:/C:/apache-tomcat-7.0.70/webapps/Structs/WEB-INF/classes/struts.xml:7:72 at com.opensymphony.xwork2.config.ConfigurationManager.getConfigurati

Unable to load configuration. - action - file:/C:/apache-tomcat-7.0.70/webapps/Structs/WEB-INF/classes/struts.xml:7:72 at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:431) at org.apache.struts2.dispatcher.ng.InitOperations.initDispat

Hadoop安装—— WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platf

今天在安装hadoop完成测试创建用户目录失败在网上找到了原因记录一下原文地址 http://blog.csdn.net/l1028386804/article/details/51538611 配置完hadoop启动运行的时候出现如下警告信息: WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applica

项目初始化以后出现:Unable to load script from assets 'index.android.bundle

Mac中真机测试React Native project时出现Unable to load script from assets 'index.android.bundle' 2018年01月21日 01:59:38 neuHenry 阅读数:1186 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010347226/article/details/79117940 刚接触学习React Native,在进行真机调试时,报错出现Unable

Hadoop 2.2.0 常见问题之:Ubuntu 64环境下“Unable to load native-hadoop library for your platform”问题”

问题 最近在学习Hadoop(2.2.0),打算写一个MapReduce的小程序在Ubuntu 64位的环境下测试一把,一切环境配置完毕后,执行的过程中,控制台输出下面的内容: WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable 原因 在网上搜索了一番,得出如下结论: "The reason

hadoop2.6.0实践:A02 问题处理 util.NativeCodeLoader: Unable to load native-hadoop library for your platform

############################################################# hadoop "util.NativeCodeLoader: Unable to load native-hadoop library for your platform" hadoop安装完以后,经常会提示以下警告: WARN util.NativeCodeLoader: Unable to load native-hadoop library for your

启动tomcat后struts框架报异常严重: Exception starting filter struts2 Unable to load configuration.

启动tomcat后struts框架报异常严重: Exception starting filter struts2 Unable to load configuration. 出现此异常是因为,struts.xml定义的版本和 struts2-core-2.1.6.jar里面的struts-default.xml版本不一致!! struts-default.xml文件里面定义的<!DOCTYPE ...>如下: <!DOCTYPE struts PUBLIC "-//Apach

Struts2中的Unable to load configuration错误的分析与解决方法

当我们遇到 Unable to load configuration. 这样的错误时,可以根据具体的错误提示找出错误的原因. Unable to load configuration. - interceptor-ref - file:/D:/Java/apache-tomcat-6.0.32/webapps/examquestions/WEB-INF/classes/struts.xml:28:49 at com.opensymphony.xwork2.config.Configuration