FC2ブログ
にわとり遊び
PC関連とエンコードの覚書き
スポンサーサイト
上記の広告は1ヶ月以上更新のないブログに表示されています。
新しい記事を書く事で広告が消せます。

2つのソースからノイズの無い部分を選んでブレンドする (FlexibleMerge) その3
merge.png
FlexibleMerge3(clip1,clip2,right=6)

clip1_20150429202259bb6.pngclip2_2015042920225787e.png
左からclip1,clip2

show2.png
show=2


function FlexibleMerge3 (clip clip1,clip clip2,float "weight",float "weight2",int "top",int "bottom",int "left",int "right",float "thr",int "nexc",float "nmax",int "show") {
thr=default(thr,10)
weight=default(weight,0.5)
weight2=default(weight2,0.9)
show=default(show,0)
nexc=default(nexc,3)
nmax=default(nmax,30)

top=default(top,0)
bottom=default(bottom,0)
left=default(left,0)
right=default(right,0)

blank1=BlankClip(clip1,color=$ffffff).Letterbox(top,bottom,left,right).mt_binarize()

Mask1=CombMask(clip1, thY1 = thr, thY2 = thr)
Mask2=CombMask(clip2, thY1 = thr, thY2 = thr)
nmask1=mt_logic(blank1,mt_invert(mask2),mode="and")#clip2がきれい
nmask2=mt_logic(blank1,mt_logic(mask2,mask1,mode="andn"),mode="and")#clip1にノイズ、clip2はきれい

clip1=(show==0) ? clip1 : clip1.subtitle("clip1",size=48)
clip2=(show==0) ? clip2 : clip2.subtitle("clip2",size=48,y=50)
clip3=Merge(clip1,clip2,weight)
clip4=Merge(clip1,clip2,weight2)
clip=mt_merge(clip1,clip3,nmask1,luma=true)
clip=mt_merge(clip,clip4,nmask2,luma=true)

#nexc
global global_nmax=nmax
Mask1_Mask2=Interleave(Mask1,Mask2)
SelectClip=ConditionalFilter(Mask1_Mask2,clip1,clip2,"AverageLuma(SelectEven)","<","AverageLuma(SelectOdd)")
SelectClip=Select(nexc,clip,clip1,clip2,selectclip)
SelectClip=ConditionalFilter(Mask1_Mask2,clip,SelectClip,"Abs(AverageLuma(SelectEven)-AverageLuma(SelectOdd))","<","global_nmax")
clip=(nexc==0) ? clip : SelectClip

#show
show1=Combcheck(clip)
show2=StackHorizontal(Combcheck(clip1),Combcheck(clip2)).ReduceBy2.StackVertical(ReduceBy2(Combcheck(clip)).AddBorders(clip.width/4,0,clip.width/4,0))
show3=ConditionalFilter(Mask1_Mask2,clip,SelectClip,"Abs(AverageLuma(SelectEven)-AverageLuma(SelectOdd))","<","global_nmax",show=true)
clip=Select(show,clip,show1,show2,show3)
return clip
}


clip1 - ベースとなるクリップ
clip2 - サブクリップ
weight - [default=0.5] clip1とclip2の両方にノイズがない、または両方にノイズがある部分に merge(clip1,clip2,weight) を適用する
weigth2 - [default=0.9] clip1にノイズがあり、clip2にノイズがない部分に merge(clip1,clip2,weight2) を適用する
top,bottom,left,right - [default=0] clip2の外周にマスクをかけ、mergeから除外する
thr - [default=10] CombMaskの閾値
nexc - [default=3,0-3] clip1,clip2のノイズの量に応じて出力クリップを選択する
0.ノイズに関わりなくmergeしたクリップを返す
1.clip1,clip2のノイズ量の差がnmax以上のときclip1を返す
2.clip1,clip2のノイズ量の差がnmax以上のときclip2を返す
3.clip1,clip2のノイズ量の差がnmax以上のときノイズ量の少ないクリップを返す
nmax - [default=30] nexcの閾値
show - [default=0, 0-3] FlexibleMergeの働きを視覚化する
1.出力クリップにCombcheckを適用する
2.入力クリップと出力クリップにCombcheckを適用し並べる
3.入力クリップのノイズ差を表示する
スポンサーサイト

コメント

コメントの投稿














管理者にだけ表示を許可する


トラックバック
トラックバック URL
http://sasamisi.blog24.fc2.com/tb.php/315-ad10afc4
この記事にトラックバックする(FC2ブログユーザー)

上記広告は1ヶ月以上更新のないブログに表示されています。新しい記事を書くことで広告を消せます。