私のシステムは Mac OS X v10.8.2 です。2560x500 の非圧縮 16 ビット TIFF イメージ (グレースケール、符号なし 16 ビット整数) がいくつかあります。最初に PIL (Homebrew、バージョン 1.7.8 経由でインストール) を使用してそれらをロードしようとします。
from PIL import Image
import numpy as np
filename = 'Rocks_2ptCal_750KHz_20ms_1ma_120KV_2013-03-06_20-02-12.tif'
img = Image.open(filename)
# >>> img
# <PIL.TiffImagePlugin.TiffImageFile image mode=I;16B size=2560x500 at 0x10A383C68>
img.show()
# almost all pixels displayed as white. Not correct.
# MatLab, EZ-draw, even Mac Preview show correct images in grayscale.
imgdata = list(img.getdata())
# most values negative:
# >>> imgdata[0:10]
# [-26588, -24079, -27822, -26045, -27245, -25368, -26139, -28454, -30675, -28455]
imgarray = np.asarray(imgdata, dtype=np.uint16)
# values now correct
# >>> imgarray
# array([38948, 41457, 37714, ..., 61922, 59565, 60035], dtype=uint16)
負の値は 65,536 ずれています...おそらく偶然ではありません。
ピクセルを変更するふりをして、PIL 経由で TIFF 画像に戻すと (配列を画像として戻すだけで):
newimg = Image.fromarray(imgarray)
エラーが発生します:
File "/usr/local/lib/python2.7/site-packages/PIL/Image.py", line 1884, in fromarray
raise TypeError("Cannot handle this data type")
TypeError: Cannot handle this data type
Image.fromarray()
PILのドキュメントでは見つかりません。経由でロードしようとしましImage.fromstring()
たが、PIL ドキュメントが理解できず、例がほとんどありません。
上記のコードに示されているように、PIL はデータを として「検出」しているようI;16B
です。PILドキュメントからわかることから、モードI
は次のとおりです。
*I* (32-bit signed integer pixels)
明らかに、それは正しくありません。
PIL が 16 ビット イメージをサポートしていないことを示唆する SX に関する多くの投稿を見つけました。pylibtiff を使用するための提案を見つけましたが、それは Windows のみだと思いますか?
Python でこれらの TIFF 画像を操作する「軽量」な方法を探しています。こんなに難しいことに驚いており、それが問題が他の人にとって明らかであると信じさせてくれます。