3

Python vlfeat.py で vlfeat.org の SIFT 実装を使用しています。

インデックスが多すぎるというエラーが発生し続け、行番号は、read_features_from_file()実行時にエラーが発生したことを示しています。

また、 features1.siftファイルが空であることにも気付きましたexecuting process_image()

コード スニペット:

from PIL import Image
from pylab import *
import vlfeat as vlf

vlf.process_image('semper1.jpg','features1.sift', params="--edge-thresh 10 --peak-thresh 5")
l1,d1 = vlf.read_features_from_file('features1.sift')
image = array(Image.open('semper1.jpg'))

vlf.process_image('semper2.jpg','features2.sift', params="--edge-thresh 10 --peak-thresh 5")
l2,d2 = vlf.read_features_from_file('feautures2.sift')
image2 = array(Image.open('semper2.jpg'))   

matches = vlf.match(d1,d2)

imshow(image)

for k in xrange(len(matches)):
    if matches[k] > 0:
        plot(l1[k, 0], l1[k, 1], 'r.')
        plot([l1[k,0], l2[matches[k,0],0]], [l1[k,1], l2[matches[k,0],1]], 'b-')

show()

process_image は次のようになります。

def process_image(imagename,resultname,params="--edge-thresh 10 --peak-thresh 5"): 
""" process an image and save the results in a file""" 
if imagename[-3:] != 'pgm': 
    #create a pgm file 
    im = Image.open(imagename).convert('L') 
    im.save('tmp.pgm') 
    imagename = 'tmp.pgm' 
    cmmd = str("sift "+imagename+" --output="+resultname+ " "+params) 
    os.system(cmmd) 
    print 'processed', imagename, 'to', resultname
4

3 に答える 3

0

SIFT がメインの opencv リポジトリの一部として利用できるようになりました (SIFT の特許は期限切れです)。

opencv の最新バージョン (現在は 4.4) で確認できます。以下のコードを使用してふるいにかけてみてください。

cv2.SIFT_create()
于 2020-10-06T07:54:59.527 に答える