2017-07-07 13 views
0

ガウスフィルタを作成するために、画像の配列の周りでカーネルを移動しようとしています。私はIndexErrorとIdkを取得しています。これはコードです:34行目のエラーIndex of bounds/IndexError

import numpy as np 
import scipy 
from scipy import misc 
import matplotlib.pyplot as plt 

imagen_nueva = np.empty((1931, 1282)) 

imagen = scipy.misc.imread("C:\\Users\\Reymi\\Downloads\\imagen.png") 

imagen_real = scipy.pad(array=imagen, pad_width=[1, 1], mode='constant', 
constant_values=0) 

(dim_x,dim_y)=np.shape(imagen_real) 
print((dim_x,dim_y)) 

ker1 = np.array([[1/16, 1/8, 1/16], 
      [1/8, 1/4, 1/8], 
      [1/16, 1/8, 1/16]]) 

def multiplicar_entero(): 
    global imagen_nueva 
    for i in range(1,dim_x+1): 
    for j in range(1,dim_y+1): 
     matriz_elemento = np.array([[imagen_real[i + 1, j - 1], 
imagen_real[i + 1, j], imagen_real[i + 1, j - 1]], 
         [imagen_real[i, j - 1], imagen_real[i, j], 
imagen_real[i, j + 1]], 
         [imagen_real[i - 1, j - 1], imagen_real[i - 1, j], 
imagen_real[i - 1, j + 1]]]) 
     valor = np.sum(matriz_elemento*ker1) 
     imagen_real[i, j] = valor 
     imagen_nueva = np.append(imagen[i, j], (1931, 1282)) 

is、jsの混乱している行列については、配列の各要素の行列3x3です。

+2

あなたの行が番号付けされていないと我々はエラーを知らない...あなたはでそのエラーを編集することができますか? –

+1

python 2またはpython 3? –

+1

'multiplicar_entero()'では、2番目の 'for'-loopの字下げが正しくないので、それが正しいかどうかは疑問です。 –

答えて

1

インデントの修正やオープンソースイメージの使用など、コードのマイナーな変更を加えてもエラーは発生しません。だから、インデントの誤りのように思える。

以下の作業のコードを参照してください:

import numpy as np 
import scipy 
from scipy import misc 
import matplotlib.pyplot as plt 

imagen_nueva = np.empty((1931, 1282)) 

imagen = scipy.resize(misc.ascent(), (1931, 1282)) 

imagen_real = scipy.pad(array=imagen, pad_width=[1, 1], mode='constant', 
         constant_values=0) 

(dim_x, dim_y) = np.shape(imagen_real) 
print((dim_x, dim_y)) 

ker1 = np.array([[1/16, 1/8, 1/16], 
       [1/8, 1/4, 1/8], 
       [1/16, 1/8, 1/16]]) 


def multiplicar_entero(): 
    global imagen_nueva 
    for i in range(1, dim_x + 1): 
     for j in range(1, dim_y + 1): 
      matriz_elemento = np.array([[imagen_real[i + 1, j - 1], imagen_real[i + 1, j], imagen_real[i + 1, j - 1]], 
             [imagen_real[i, j - 1], imagen_real[i, j], imagen_real[i, j + 1]], 
             [imagen_real[i - 1, j - 1], imagen_real[i - 1, j], imagen_real[i - 1, j + 1]]]) 

      valor = np.sum(matriz_elemento*ker1) 
      imagen_real[i, j] = valor 
      imagen_nueva = np.append(imagen[i, j], (1931, 1282)) 
関連する問題