import os import cv2 import numpy as np def make_image(input_img): #画像のサイズ img_size=input_img.shape filter_one=np.ones((3,3)) #回転用 mat1=cv2.getRotationMatrix2D(tuple(np.array(input_img.shape[:2])/2),23,1) mat2=cv2.getRotationMatrix2D(tuple(np.array(input_img.shape[:2])/2),144,0.8) #水増しメソッドに使う関数です fake_method_array=np.array([ lambda image:cv2.warpAffine(image,mat1,image.shape[:2]), lambda image:cv2.warpAffine(image,mat2,image.shape[:2]), lambda image:cv2.threshold(image,100,255,cv2.THRESH_TOZERO)[1], lambda image:cv2.GaussianBlur(image,(5,5),0), lambda image:cv2.resize(cv2.resize(image,(img_size[1]//5,img_size[0]//5)),(img_size[1],img_size[0])), lambda image:cv2.erode(image,filter_one), lambda image:cv2.flip(image,1), ]) #画像変換処理を行います。 images=[] for method in fake_method_array: faked_img=method(input_img) images.append(faked_img) return images #画像を読み込む target_img=cv2.imread("IMG_1565.JPG") #画像を水増しする fake_images=make_image(target_img) #画像を保存するフォルダを作成します。 if not os.path.exists("fake_images"): os.mkdir("fake_images") for number,img in enumerate(fake_images): #まず保存先のディレクトリ"fake_images/"を指定して番号を付けて保存します。 cv2.imwrite("fake_images/"+ str(number) + ".jpg",img) ---------------------------------------------------------------------------------------------------------------------------------------------- ls fake_images 0.jpg 1.jpg 2.jpg 3.jpg 4.jpg 5.jpg 6.jpg ---------------------------------------------------------------------------------------------------------------------------------------------- import numpy as np import cv2 import matplotlib.pyplot as plt import os #列の数を設定します NUM_COLUMNS=4 #行 ROWS_COUNT=len(fake_images)%NUM_COLUMNS #列 COLUMS_COUNT=NUM_COLUMNS #グラフオブジェクト保存用 subfig=[] #figureオブジェクト作成サイズを決めます fig=plt.figure(figsize=(12,9)) # for i in range(1,len(fake_images)+1): #順序i番目のsubfig追加 subfig.append(fig.add_subplot(ROWS_COUNT,COLUMS_COUNT,i)) print(os.listdir('fake_images/')) print(os.path.abspath('fake_images/'+str(i-1)+'.jpg')) img_bgr=cv2.imread('fake_images/'+str(i-1)+'.jpg') img_rgb=cv2.cvtColor(img_bgr,cv2.COLOR_BGR2RGB) subfig[i-1].imshow(img_rgb) #グラフ間の横と縦の隙間の調整 fig.subplots_adjust(wspace=0.3,hspace=0.3) plt.show() /content/fake_images/0.jpg --------------------------------------------------------------------------- error Traceback (most recent call last) <ipython-input-39-2a2a9073e3b0> in <module>() 24 print(os.path.abspath('fake_images/'+str(i-1)+'.jpg')) 25 img_bgr=cv2.imread('fake_images/'+str(i-1)+'.jpg') ---> 26 img_rgb=cv2.cvtColor(img_bgr,cv2.COLOR_BGR2RGB) 27 subfig[i-1].imshow(img_rgb) 28 error: OpenCV(4.1.2) /io/opencv/modules/imgproc/src/color.cpp:182: error: (-215:Assertion failed) !_src.empty() in function 'cvtColor'
まず、一つの画像に輪郭抽出や回転などの処理を加えて、水増しのコードを実行しました。上記のコードを実行したとき、fake_imagesというディレクトリに7つの画像が入っているはずだったのですが、結果としてfake_imagesというディレクトリには画像ファイルが入っていないということがわかりました。上記で示した通り、[ls fake_images]で確認したときは、7つのファイルがあると表示されるのですが、確認してみるとディレクトリには1つもファイルが存在しませんでした。
回答1件
あなたの回答
tips
プレビュー