質問編集履歴
4
文章の修正
title
CHANGED
File without changes
|
body
CHANGED
@@ -3,7 +3,9 @@
|
|
3
3
|
|
4
4
|
とありました。
|
5
5
|
そのまんまなのですが、明るい画像の場合の値の画像を反転し、暗い画像の場合と同様に処理してから、もう一度反転して、値の画像を使用している場合は再結合する方法がわかりません。
|
6
|
+
|
6
|
-
|
7
|
+
**今は再結合の方法がわかりません。**
|
8
|
+
|
7
9
|
どなたか教えてください。お願い致します。
|
8
10
|
```pyrhon
|
9
11
|
import cv2
|
@@ -50,9 +52,7 @@
|
|
50
52
|
|
51
53
|
とあるのですが、暗い画像と同様に処理した後、もう一度反転しました。
|
52
54
|
しかし、どこでどうやって再結合すればいいのかわかりません。
|
53
|
-
|
55
|
+
|
54
|
-
理由は、反転した後の値を合成しているのでそれを元に戻すだけなので、あっていると思います。
|
55
|
-
しかし、どこで再結合すればいいのかがわかりません。
|
56
56
|
```python
|
57
57
|
#色の反転
|
58
58
|
img = cv2.bitwise_not(img)
|
3
追記
title
CHANGED
File without changes
|
body
CHANGED
@@ -44,14 +44,21 @@
|
|
44
44
|
cv2.imwrite('lioncuddle1_gamma2.jpg', img_gamma2)
|
45
45
|
```
|
46
46
|
|
47
|
+
**追記**
|
48
|
+
プログラムを間違えており、サイトに載っているプログラムをそのまんま使用したらできたのですが、
|
47
|
-
|
49
|
+
> 暗い画像の場合と同様に処理してから、もう一度反転して、値の画像を使用している場合は再結合します。
|
50
|
+
|
51
|
+
とあるのですが、暗い画像と同様に処理した後、もう一度反転しました。
|
52
|
+
しかし、どこでどうやって再結合すればいいのかわかりません。
|
53
|
+
「新しい明度チャンネルを元の色相と彩度チャンネルに合成」の後に反転したのですが、ここであっているのかも不安です。
|
48
|
-
|
54
|
+
理由は、反転した後の値を合成しているのでそれを元に戻すだけなので、あっていると思います。
|
55
|
+
しかし、どこで再結合すればいいのかがわかりません。
|
49
56
|
```python
|
50
57
|
#色の反転
|
51
|
-
|
58
|
+
img = cv2.bitwise_not(img)
|
52
59
|
|
53
60
|
# imgをHSVに変換
|
54
|
-
hsv = cv2.cvtColor(
|
61
|
+
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
|
55
62
|
hue, sat, val = cv2.split(hsv)
|
56
63
|
|
57
64
|
# gammaの計算 = log(mid*255)/log(mean)
|
@@ -60,15 +67,18 @@
|
|
60
67
|
gamma = math.log(mid*255)/math.log(mean)
|
61
68
|
print(gamma)
|
62
69
|
|
63
|
-
|
70
|
+
#明度チャンネルにガンマ補正を行う
|
64
|
-
|
71
|
+
val_gamma = np.power(val, gamma).clip(0,255).astype(np.uint8)
|
72
|
+
|
65
73
|
|
66
|
-
#
|
74
|
+
#新しい明度チャンネルを元の色相と彩度チャンネルに合成します
|
67
|
-
|
75
|
+
hsv_gamma = cv2.merge([hue, sat, val_gamma])
|
76
|
+
img_gamma2 = cv2.cvtColor(hsv_gamma, cv2.COLOR_HSV2BGR)
|
68
77
|
|
69
78
|
#色の反転
|
70
|
-
|
79
|
+
img_gamma2 = cv2.bitwise_not(img_gamma2)
|
80
|
+
|
71
81
|
|
72
82
|
#書き込み
|
73
|
-
cv2.imwrite(sys.argv[2],
|
83
|
+
cv2.imwrite(sys.argv[2],img_gamma2)
|
74
84
|
```
|
2
やってみた
title
CHANGED
File without changes
|
body
CHANGED
@@ -5,8 +5,6 @@
|
|
5
5
|
そのまんまなのですが、明るい画像の場合の値の画像を反転し、暗い画像の場合と同様に処理してから、もう一度反転して、値の画像を使用している場合は再結合する方法がわかりません。
|
6
6
|
調べても、ネガポジ反転が出てきてしまい、どうすればいいのかわかりません。
|
7
7
|
どなたか教えてください。お願い致します。
|
8
|
-
|
9
|
-
[OpenCVで画像の色反転をしてみた](https://qiita.com/kenfukaya/items/245122eb312cdb6ba389)今は、こちらのサイトを試しています。
|
10
8
|
```pyrhon
|
11
9
|
import cv2
|
12
10
|
import numpy as np
|
@@ -44,4 +42,33 @@
|
|
44
42
|
|
45
43
|
# save results
|
46
44
|
cv2.imwrite('lioncuddle1_gamma2.jpg', img_gamma2)
|
45
|
+
```
|
46
|
+
|
47
|
+
[OpenCVで画像の色反転をしてみた](https://qiita.com/kenfukaya/items/245122eb312cdb6ba389)今は、こちらのサイトを試しています。
|
48
|
+
試した結果、以下の様なプログラムを組んだのですが、真っ黒な画像になってしまいました。
|
49
|
+
```python
|
50
|
+
#色の反転
|
51
|
+
image2 = cv2.bitwise_not(img)
|
52
|
+
|
53
|
+
# imgをHSVに変換
|
54
|
+
hsv = cv2.cvtColor(image2, cv2.COLOR_BGR2HSV)
|
55
|
+
hue, sat, val = cv2.split(hsv)
|
56
|
+
|
57
|
+
# gammaの計算 = log(mid*255)/log(mean)
|
58
|
+
mid = 0.5
|
59
|
+
mean = np.mean(val)
|
60
|
+
gamma = math.log(mid*255)/math.log(mean)
|
61
|
+
print(gamma)
|
62
|
+
|
63
|
+
x = np.arange(256)
|
64
|
+
y = (x / 255) ** gamma * 255
|
65
|
+
|
66
|
+
# 変換する。
|
67
|
+
image3 = cv2.LUT(image2, y)
|
68
|
+
|
69
|
+
#色の反転
|
70
|
+
dst1 = cv2.bitwise_not(image3)
|
71
|
+
|
72
|
+
#書き込み
|
73
|
+
cv2.imwrite(sys.argv[2],dst1)
|
47
74
|
```
|
1
やっていること
title
CHANGED
File without changes
|
body
CHANGED
@@ -5,6 +5,8 @@
|
|
5
5
|
そのまんまなのですが、明るい画像の場合の値の画像を反転し、暗い画像の場合と同様に処理してから、もう一度反転して、値の画像を使用している場合は再結合する方法がわかりません。
|
6
6
|
調べても、ネガポジ反転が出てきてしまい、どうすればいいのかわかりません。
|
7
7
|
どなたか教えてください。お願い致します。
|
8
|
+
|
9
|
+
[OpenCVで画像の色反転をしてみた](https://qiita.com/kenfukaya/items/245122eb312cdb6ba389)今は、こちらのサイトを試しています。
|
8
10
|
```pyrhon
|
9
11
|
import cv2
|
10
12
|
import numpy as np
|