質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

520閲覧

pythonのこのプログラムを実行したいです

退会済みユーザー

退会済みユーザー

総合スコア0

OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/12/07 04:04

以前pythonのパス指定が間違っている時のエラーがわかりません。で質問したプログラムを使用したいのです。
というのが、今回の質問兼お願いです。
プログラムはこちらなのですが、環境を製作者に揃えたところ

error

1OpenCV(3.4.1) Error: Assertion failed (scn == 3 || scn == 4) in cvtColor, file /Users/travis/build/skvark/opencv-python/opencv/modules/imgproc/src/color.cpp, line 11180 2Traceback (most recent call last): 3 File "IAGCWD.py", line 89, in <module> 4 main() 5 File "IAGCWD.py", line 62, in main 6 YCrCb = cv2.cvtColor(img, cv2.COLOR_BGR2YCrCb) 7cv2.error: OpenCV(3.4.1) /Users/travis/build/skvark/opencv-python/opencv/modules/imgproc/src/color.cpp:11180: error: (-215) scn == 3 || scn == 4 in function cvtColor

となり、今自分が使用している環境だと

error

1$ python3 IAGCWD.py --input ./input --output ./output 2Traceback (most recent call last): 3 File "IAGCWD.py", line 89, in <module> 4 main() 5 File "IAGCWD.py", line 62, in main 6 YCrCb = cv2.cvtColor(img, cv2.COLOR_BGR2YCrCb) 7cv2.error: OpenCV(4.5.4-dev) /Users/runner/work/opencv-python/opencv-python/opencv/modules/imgproc/src/color.cpp:182: error: (-215:Assertion failed) !_src.empty() in function 'cvtColor'

となりました。
どちらもpathがうまくいっていないというエラーなのは調べたのですが、どこをどう直せばいいのかわかりません。
pathを解決できるのが一番なのですが、どなたからも前回のに回答をいただけていません。

なので、画像を1枚入力してそれを出力する最もスタンダードな形にしたいのですが、pathの関数が多くてどこをどう直せばいいのか、わからないで詰まっています。
どなたか教えてください。
お願い致します。

python

1import cv2 2import glob 3import argparse 4import numpy as np 5from matplotlib import pyplot as plt 6from scipy.linalg import fractional_matrix_power 7 8def image_agcwd(img, a=0.25, truncated_cdf=False): 9 h,w = img.shape[:2] 10 hist,bins = np.histogram(img.flatten(),256,[0,256]) 11 cdf = hist.cumsum() 12 cdf_normalized = cdf / cdf.max() 13 prob_normalized = hist / hist.sum() 14 15 unique_intensity = np.unique(img) 16 intensity_max = unique_intensity.max() 17 intensity_min = unique_intensity.min() 18 prob_min = prob_normalized.min() 19 prob_max = prob_normalized.max() 20 21 pn_temp = (prob_normalized - prob_min) / (prob_max - prob_min) 22 pn_temp[pn_temp>0] = prob_max * (pn_temp[pn_temp>0]**a) 23 pn_temp[pn_temp<0] = prob_max * (-((-pn_temp[pn_temp<0])**a)) 24 prob_normalized_wd = pn_temp / pn_temp.sum() # [0,1]に正規化 25 cdf_prob_normalized_wd = prob_normalized_wd.cumsum() 26 27 if truncated_cdf: 28 inverse_cdf = np.maximum(0.5,1 - cdf_prob_normalized_wd) 29 else: 30 inverse_cdf = 1 - cdf_prob_normalized_wd 31 32 img_new = img.copy() 33 for i in unique_intensity: 34 img_new[img==i] = np.round(255 * (i / 255)**inverse_cdf[i]) 35 36 return img_new 37 38def process_bright(img): 39 img_negative = 255 - img 40 agcwd = image_agcwd(img_negative, a=0.25, truncated_cdf=False) 41 reversed = 255 - agcwd 42 return reversed 43 44def process_dimmed(img): 45 agcwd = image_agcwd(img, a=0.75, truncated_cdf=True) 46 return agcwd 47 48def main(): 49 parser = argparse.ArgumentParser(description='IAGCWD') 50 parser.add_argument('--input', dest='input_dir', default='./input/', type=str, \ 51 help='Input directory for image(s)') 52 parser.add_argument('--output', dest='output_dir', default='./output/', type=str, \ 53 help='Output directory for image(s)') 54 args = parser.parse_args() 55 56 img_paths = glob.glob(args.input_dir+'*') 57 for path in img_paths: 58 img = cv2.imread(path, 1) 59 name = path.split('\')[-1].split('.')[0] 60 61 # 画像の強度成分を抽出 62 YCrCb = cv2.cvtColor(img, cv2.COLOR_BGR2YCrCb) 63 Y = YCrCb[:,:,0] 64 # 画像が明るいか暗いかを判断する 65 threshold = 0.3 66 exp_in = 112 # 予想されるグローバル平均強度 67 M,N = img.shape[:2] 68 mean_in = np.sum(Y/(M*N)) 69 t = (mean_in - exp_in)/ exp_in 70 71 # ガンマ補正のための画像処理 72 img_output = None 73 if t < -threshold: # 淡い色合いの画像 74 print (name + ": Dimmed") 75 result = process_dimmed(Y) 76 YCrCb[:,:,0] = result 77 img_output = cv2.cvtColor(YCrCb,cv2.COLOR_YCrCb2BGR) 78 elif t > threshold: 79 print (name + ": Bright Image") # 明るい画像 80 result = process_bright(Y) 81 YCrCb[:,:,0] = result 82 img_output = cv2.cvtColor(YCrCb,cv2.COLOR_YCrCb2BGR) 83 else: 84 img_output = img 85 86 cv2.imwrite(args.output_dir+name+'.jpg', img_output) 87 88if __name__ == '__main__': 89 main()

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

焦っていただけで、冷静になれば、できました。

python

1import cv2 2import glob 3import argparse 4import numpy as np 5from matplotlib import pyplot as plt 6from scipy.linalg import fractional_matrix_power 7 8def image_agcwd(img, a=0.25, truncated_cdf=False): 9 h,w = img.shape[:2] 10 hist,bins = np.histogram(img.flatten(),256,[0,256]) 11 cdf = hist.cumsum() 12 cdf_normalized = cdf / cdf.max() 13 prob_normalized = hist / hist.sum() 14 15 unique_intensity = np.unique(img) 16 intensity_max = unique_intensity.max() 17 intensity_min = unique_intensity.min() 18 prob_min = prob_normalized.min() 19 prob_max = prob_normalized.max() 20 21 pn_temp = (prob_normalized - prob_min) / (prob_max - prob_min) 22 pn_temp[pn_temp>0] = prob_max * (pn_temp[pn_temp>0]**a) 23 pn_temp[pn_temp<0] = prob_max * (-((-pn_temp[pn_temp<0])**a)) 24 prob_normalized_wd = pn_temp / pn_temp.sum() # [0,1]に正規化 25 cdf_prob_normalized_wd = prob_normalized_wd.cumsum() 26 27 if truncated_cdf: 28 inverse_cdf = np.maximum(0.5,1 - cdf_prob_normalized_wd) 29 else: 30 inverse_cdf = 1 - cdf_prob_normalized_wd 31 32 img_new = img.copy() 33 for i in unique_intensity: 34 img_new[img==i] = np.round(255 * (i / 255)**inverse_cdf[i]) 35 36 return img_new 37 38def process_bright(img): 39 img_negative = 255 - img 40 agcwd = image_agcwd(img_negative, a=0.25, truncated_cdf=False) 41 reversed = 255 - agcwd 42 return reversed 43 44def process_dimmed(img): 45 agcwd = image_agcwd(img, a=0.75, truncated_cdf=True) 46 return agcwd 47 48def main(): 49 img = cv2.imread('input/Desk.jpg') 50 51 # 画像の強度成分を抽出 52 YCrCb = cv2.cvtColor(img, cv2.COLOR_BGR2YCrCb) 53 Y = YCrCb[:,:,0] 54 # 画像が明るいか暗いかを判断する 55 threshold = 0.3 56 exp_in = 112 # 予想されるグローバル平均強度 57 M,N = img.shape[:2] 58 mean_in = np.sum(Y/(M*N)) 59 t = (mean_in - exp_in)/ exp_in 60 61 # ガンマ補正のための画像処理 62 img_output = None 63 if t < -threshold: # 淡い色合いの画像 64 result = process_dimmed(Y) 65 YCrCb[:,:,0] = result 66 img_output = cv2.cvtColor(YCrCb,cv2.COLOR_YCrCb2BGR) 67 elif t > threshold: # 明るい画像 68 result = process_bright(Y) 69 YCrCb[:,:,0] = result 70 img_output = cv2.cvtColor(YCrCb,cv2.COLOR_YCrCb2BGR) 71 else: 72 img_output = img 73 74 cv2.imwrite('output/Desk3.jpg', img_output) 75 76if __name__ == '__main__': 77 main() 78 79

投稿2021/12/07 04:13

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問