Per una classe di elaborazione immagine, eseguo operazioni punto su immagini monocromatiche. I pixel sono uint8 [0,255].numpy soluzione di avvolgimento pixel uint8
numpy uint8 verrà completato. Ad esempio, 235 + 30 = 9. Ho bisogno dei pixel per saturare (max = 255) o troncare (min = 0) invece di avvolgere.
La mia soluzione utilizza int32 pixel per il punto matematico, quindi converte in uint8 per salvare l'immagine.
È questo il modo migliore? O c'è un modo più veloce? immagine
#!/usr/bin/python
import sys
import numpy as np
import Image
def to_uint8(data) :
# maximum pixel
latch = np.zeros_like(data)
latch[:] = 255
# minimum pixel
zeros = np.zeros_like(data)
# unrolled to illustrate steps
d = np.maximum(zeros, data)
d = np.minimum(latch, d)
# cast to uint8
return np.asarray(d, dtype="uint8")
infilename=sys.argv[1]
img = Image.open(infilename)
data32 = np.asarray(img, dtype="int32")
data32 += 30
data_u8 = to_uint8(data32)
outimg = Image.fromarray(data_u8, "L")
outimg.save("out.png")
ingresso: immagine
uscita:
np.clip() è esattamente quello che ho avuto bisogno. Grazie! Mi leggerò anche su ImageEnhance. I compiti riguardavano il fare noi stessi, ma sarebbe bello imparare altri modi. –