前提・実現したいこと
pythonでpcカメラで動画を撮影し、縦横16pxごとに区切って、勾配計算をした画像(laplacian)と背景差分計算をした画像(fgmask)を作っています。背景は黒くマスクしてエッジを赤くするプログラムを作っています。
自分が手をつけたのはfgmask = fgbg.apply(frame)以降なので、そのどこかに間違いがあるはずですが、エラーメッセージが下記のものが表示されてしまいます。
発生している問題・エラーメッセージ
rows, cols, channels = frame.shape AttributeError: 'NoneType' object has no attribute 'shape'
該当のソースコード
python
1import numpy as np 2import cv2 3 4REGION_WIDTH=16 5REGION_HIGH=16 6 7cap = cv2.VideoCapture(0) 8cap.set(cv2.CAP_PROP_FRAME_WIDTH, 640) 9cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 480) 10fgbg = cv2.createBackgroundSubtractorMOG2(history=500, varThreshold=16, detectShadows=True) 11red_mask = np.full((1, 1, 3), (0,0,255), dtype=np.uint8) 12white_mask = np.full((REGION_HIGH, REGION_WIDTH, 3), (255,255,255), dtype=np.uint8) 13 14while(True): 15 ret, frame = cap.read() 16 rows, cols, channels = frame.shape#この行がエラーメッセージで表示されます 17 # maskを定義 18 laplacian_mask = np.zeros((rows, cols, channels), dtype=np.uint8) 19 fgmask_mask = np.zeros((rows, cols, channels), dtype=np.uint8) 20 21 frame_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) 22 laplacian = cv2.Laplacian(frame_gray, cv2.CV_64F) 23 for y in range(rows): 24 for x in range(cols): 25 if laplacian[y,x] > 10: 26 laplacian_mask[y,x] = np.copy(red_mask) 27 28 #ここから自分が手をつけました 29 fgmask = fgbg.apply(frame) 30 fgmask_sum = np.zeros((30,40)) 31 for i in range(int(rows/REGION_HIGH)): 32 for j in range(int(cols/REGION_WIDTH)): 33 for y in range(REGION_HIGH): 34 for x in range(REGION_WIDTH): 35 if (fgmask[i*16+y][j*16+x]==255): 36 fgmask_sum[y,x] += 1 37 fgmask_mean = np.sum(fgmask_sum)/30*40 38 for y in range(int(rows/REGION_HIGH)): 39 for x in range(int(cols/REGION_WIDTH)): 40 if fgmask_sum[x][y] >= fgmask_mean: 41 fgmask_mask[16*y:16*y+16,16*x:16*x+16] = np.copy(white_mask) 42 #ここまでの自分が手をつけた部分を消すとエラーは発生しません 43 44 mask_or = cv2.bitwise_or(laplacian_mask, fgmask_mask) 45 masked_frame = cv2.bitwise_and(frame, mask_or) 46 cv2.imshow('frame', masked_frame) 47 48 k = cv2.waitKey(30) & 0xff 49 if k == 27: 50 break # 'ESC' key is pressed 51cap.release() 52cv2.destroyAllWindows()
回答1件
あなたの回答
tips
プレビュー