サンプルコード
以下のサンプルコードでは、scikit-imageのthreshold_otsu/threshold_isodataでしきい値を求め、それぞれのアルゴリズムで2値化のRGB版と白黒版の動画を出力しています。from moviepy.editor import *
from skimage.filters import *
from skimage.color import *
def process_threshold_otsu(image):
threshold = threshold_otsu(image)
return (image > threshold)*255
def process_threshold_otsu_gray(image):
gray = rgb2gray(image)
threshold = threshold_otsu(gray)
return gray2rgb((gray > threshold)*255)
def process_threshold_iso(image):
threshold = threshold_isodata(image)
return (image > threshold)*255
def process_threshold_iso_gray(image):
gray = rgb2gray(image)
threshold = threshold_isodata(gray)
return gray2rgb((gray > threshold)*255)
clip1 = VideoFileClip("hydrangea.mp4")
clip1t = clip1.fl_image(process_threshold_otsu)
clip1t.write_videofile("process_threshold_otsu.mp4")
clip1t = clip1.fl_image(process_threshold_otsu_gray)
clip1t.write_videofile("process_threshold_otsu_gray.mp4")
clip1t = clip1.fl_image(process_threshold_iso)
clip1t.write_videofile("process_threshold_iso.mp4")
clip1t = clip1.fl_image(process_threshold_iso_gray)
clip1t.write_videofile("process_threshold_iso_gray.mp4")
〇元動画の画面
data:image/s3,"s3://crabby-images/18a4f/18a4fd66009b9429c4326a290095faab0dd33678" alt=""
〇出力動画の画面(threshold_otsu)
data:image/s3,"s3://crabby-images/22675/22675bbf8138d781f67d5266827cce2cfd0e2148" alt=""
〇出力動画の画面(rgb2grayとthreshold_otsu)
data:image/s3,"s3://crabby-images/e0053/e0053aec5015bf899b4c19336b51cd3abd3f9355" alt=""
〇出力動画の画面(threshold_isodata)
data:image/s3,"s3://crabby-images/5468e/5468e6fe7ee62651cc70cc58ef6b702fb9dea034" alt=""
〇出力動画の画面(rgb2grayとthreshold_isodata)
data:image/s3,"s3://crabby-images/a6831/a68315aa8c2e2a7048b86c3fe8cc2010bd827da2" alt=""
〇scikit-imageインストール
MoviePyの他、仮想環境のフォルダに移動して以下のコマンドを実行します。
pipenv install scikit-image
関連情報
・MoviePyのまとめ・moviepyのホームページ
https://zulko.github.io/moviepy/
0 件のコメント:
コメントを投稿