View difference between Paste ID: M1XYE3Jk and 0bKmyuV8
SHOW: | | - or go back to the newest paste.
1-
###### srestore v2.791 ######
1+
###### srestore v2.792 ######
2
# ==================================================================================================================================
3
# Change List
4
#
5
# 03/14/2018 AmjadSONY
6
# - Update v2.791 -> v2.792
7
#  native ReplaceStr using in avs+
8
#
9
# 11/22/2017 AmjadSONY
10
# - Update v2.78 -> v2.791
11
#  some edit in speed parameter (in avs26 or avs+ will get different result now)
12
#
13
# 06/15/2017 AmjadSONY
14
# - Update v2.77 -> v2.78
15
#  some fix
16
#
17
# 05/25/2017 AmjadSONY
18
# - Update v2.76 -> v2.77
19
#  fix high bit depth
20
#
21
# 03/31/2017 AmjadSONY
22
# - Update v2.75 -> v2.76
23
#  update to masktools 2.2.5
24
#
25
# 03/09/2017 AmjadSONY
26
# - Update v2.7i -> v2.75
27
#  now work with all high bit depth in avs+
28
#
29
# 02/09/2017 AmjadSONY
30
# - Update v2.7h -> v2.7i
31
#  clean up and add YUY2 and other format
32
#
33
# 03/23/2014 AmjadSONY
34
# - Update v2.7g -> v2.7h
35
#  update to use new Average by tp7
36
#
37
# 11/12/2013 martin53
38
# - Update v2.7f -> v2.7g
39
#  Refactored to use a single line ScriptClip() call like v2.7e - Neccessary to save AviSynth string heap space when RTE is called
40
#
41
# 10/28/2013 martin53
42
# - Update v2.7e -> v2.7f
43
# Callable more than once from the same script with help of unique global variables per instance.
44
# Moderate reformatting to re-establish readability with the new variable names.
45
# Needs GRunT plugin
46
#
47
# ==================================================================================================================================
48
49
function Srestore(clip sourceo, float "frate", "omode", float "speed", float "blocks", int "mode", float "thresh", int "cache", clip "dclip")
50
{
51
avs26=!(VersionNumber() < 2.6)
52
nonyuy2=avs26 && sourceo.isyuy2()
53
source=nonyuy2 ? sourceo.nonyuy2clipin(true) : sourceo
54
ssispmt   = Findstr(VersionString(), "AviSynth+") != 0 && Findstr(VersionString(), "r1576") == 0
55
sislumaonly = ssispmt ? sourceo.isy() : !avs26 ? false : sourceo.isy8()
56
sis444 = ssispmt ? sourceo.is444() : !avs26 ? false : sourceo.isyv24()
57
###### parameters & other necessary vars ######
58
	dm      = default(mode, 2)
59
     sisproslumonl = (!(dm<0) && avs26)
60
    srad  = sisproslumonl || sis444 || sislumaonly ? isfloat(speed) && abs(speed)>=1 ? sqrt(abs(speed)) : 9 : isfloat(speed) && abs(speed)>=1 ? sqrt(abs(speed))*4 : 12
61
    cache = default(cache, -1)
62
    irate = framerate(source)
63
    bsize = isfloat(speed) && speed>0 ? 16 : 32
64
65
	om      = default(omode, 6)
66
	bom     = isstring(om)
67
	thr     = abs(default(thresh, 16))+0.01
68
	frfac   = bom || abs(om-3)<2.5 ? 1 : isfloat(frate) ? frate*5<irate || frate>irate ? 1 :
69
			\ abs(frate)/irate : round(irate*10010)%30000==0 ? 1001./2400. : 480./1001.
70
71
	numr    = abs(frfac*1001-round(frfac*1001))<0.01 ? round(frfac*1001) :
72
			\ abs(1001/frfac-round(1001/frfac))<0.01 ? 1001 : round(frfac*9000)
73
	numr    = isfloat(frate) && abs(irate*numr/float(round(numr/frfac))-frate) >
74
			\ abs(irate*round(frate*100)/float(round(irate*100))-frate) ? round(frate*100) : numr
75
	denm    = round(numr/frfac)
76
77
	###### source preparation & lut ######
78
	out = source
79
	mec = abs(dm)<2 || bom ? nop() : mergeluma(mergechroma(out, out.trim(1, 0), 0.5), out.trim(1, 0), 0.5)
80
	det	= default(dclip, source).killaudio()
81
  	sis420  = ssispmt ? det.is420() : det.isyv12()
82
	det	= dm<0 || sislumaonly ? det : ssispmt ? det.converttoy() : avs26 ? det.converttoy8() : det.converttoyv12()
83
	det	= det.pointresize(sisproslumonl || sis444 || sislumaonly ? int(det.width/(sis420 ? (srad*1.77) : srad)) : srad==4 ? det.width : int(det.width/2/srad+4)*4, sisproslumonl || sis444 || sislumaonly ? int(det.width/(sis420 ? (srad*1.77) : srad)) : srad==4 ? det.height : int(det.height/2/srad+4)*4).trim(2, 0)
84
	det	= !sislumaonly && dm<0 && sis420 ? stackvertical(stackhorizontal(ssispmt ? det.ExtractU() : avs26 ? det.utoy8() : det.utoy(), ssispmt ? det.ExtractV() : avs26 ? det.vtoy8() : det.vtoy()), ssispmt ? det.converttoy() : avs26 ? det.converttoy8() : det) : det
85
	det	= !sislumaonly && dm<0 && !sis420 ? stackhorizontal(stackhorizontal(ssispmt ? det.ExtractU() : avs26 ? det.utoy8() : det.utoy(), ssispmt ? det.ExtractV() : avs26 ? det.vtoy8() : det.vtoy()), ssispmt ? det.converttoy() : avs26 ? det.converttoy8() : det) : det
86
	det = bom ? !avs26 ? det.mt_lut("x 0.5 * 64 +", y=3, u=1, v=1) : det.mt_lut("x 0.5 * 64 scalef +", y=3, u=1, v=1) : det
87
88
		code0   = !avs26 ? "x 128 - y 128 - * 0 > x 128 - abs y 128 - abs < x 128 - 128 x - * y 128 - 128 y - * ? x y + 256 - x y + 256 - * ? 0.25 * 128 +"
89
			  \	 : "x range_half - y range_half - * 0 > x range_half - abs y range_half - abs < x range_half - range_half x - * y range_half - range_half y - * ? x y + range_size - dup * ? 0.25 * range_half +"
90
		code1   = !avs26 ? "x y - 2 ^ 3 * x y + 256 - 2 ^ - 128 +" : "x y - dup * 3 * x y + range_size - 2 ^ - range_half +"
91
		diff 	= mt_makediff(det, det.trim(1, 0), y=3, u=1, v=1)
92
	bclp    = !bom ? mt_lutxy(diff, diff.trim(1, 0), expr=code0, y=3, u=1, v=1).bilinearresize(bsize, bsize) :
93
		       \ mt_lutxy(diff.trim(1, 0), mt_adddiff(diff, diff.trim(2, 0), y=3, u=1, v=1), expr=code1, y=3, u=1, v=1).bilinearresize(bsize, bsize)
94
	dclp    = !avs26 ? diff.trim(1, 0).mt_lut("x 128 - abs 1.1 ^ 1 -", y=3, u=1, v=1).bilinearresize(bsize, bsize)
95
		  \	 : diff.trim(1, 0).mt_lut("x range_half - abs 1.1 ^ 1 scalef -", y=3, u=1, v=1).bilinearresize(bsize, bsize)
96
97
	###### POSTPROCESSING ######
98
    unblend1    = bom ? average(out, 2.0, out.loop(2, 0, 0), -1.0) : nop()
99
    unblend2    = bom ? average(out.trim(2, 0), -1.0, out.trim(1, 0), 2.0) : nop()
100
101
    qmask1  = bom ? mt_makediff(unblend1.removegrain(mode=19, modeU=-1, modeV=-1), unblend1, y=3, u=1, v=1) : nop()
102
    qmask2  = bom ? mt_makediff(unblend2.removegrain(mode=19, modeU=-1, modeV=-1), unblend2, y=3, u=1, v=1) : nop()
103
    diffm   = bom ? mt_makediff(out.loop(2, 0, 0), out, y=3, u=1, v=1).mt_lut("x y - abs", y=3, u=1, v=1).mt_expand() : nop()
104
	# 10/28/2013 note: next UPN expression is buggy, but correct expression not known
105
    bmask	= bom ? !avs26 ? mt_lutxy(qmask1, qmask2, expr="x y - == 128 x 128 - 2 ^ x 128 - 2 ^ y 128 - 2 ^ + / 255 *", y=3, u=1, v=1)
106
			\      : mt_lutxy(qmask1, qmask2, expr="clamp_f_i8 x range_half - dup * dup y range_half - dup * + / range_max *", y=3, u=1, v=1) : nop()
107
    dmask	= bom ? !avs26 ? mt_lutxy(diffm, diffm.trim(2, 0), expr="x 2 * y < x 4 < & 0 y 2 * x < y 4 < & 255 x x y + / 200 * 28 + ? ?", y=3, u=1, v=1)
108
			\      : mt_lutxy(diffm, diffm.trim(2, 0), expr="x 2 * y < x 4 scalef < & 0 y 2 * x < y 4 scalef < & range_max x x y + / 200 scalef * 28 scalef + ? ?", y=3, u=1, v=1) : nop()
109
    pmask	= bom ? !avs26 ? mt_lutxy(dmask, bmask, expr="y 0 > y 255 < & x 0 == x 255 == | & x y ?", y=3, u=1, v=1)
110
			\      : mt_lutxy(dmask, bmask, expr="y 0 > y range_max < & x 0 == x range_max == | & x y ?", y=3, u=1, v=1) : nop()
111
112
    pp0 = bom ? average(out.trim(2, 0), -0.5, out.trim(1, 0), 1.0, out, 1.0, out.loop(2, 0, 0), -0.5) : nop()
113
    pp1 = bom ? mt_merge(unblend1, unblend2, dmask.removegrain(mode=12, modeU=-1, modeV=-1).greyscale(), y=3, u=sislumaonly ? 1 : 3, v=sislumaonly ? 1 : 3) : nop()
114
    pp2 = bom ? mt_merge(unblend1, unblend2, bmask.removegrain(mode=12, modeU=-1, modeV=-1), luma=!sislumaonly) : nop()
115
    pp3 = bom ? mt_merge(unblend1, unblend2, pmask.removegrain(mode=12, modeU=-1, modeV=-1), luma=!sislumaonly).removegrain(mode=0, modeU=12, modeV=12) : nop()
116
117
	fin  = bom ? eval(om) : nop()
118
119
	#######################################
120
    # Unique Identifier Definition
121
    #######################################
122
	Try { global Srestore_InstanceNumber = Srestore_InstanceNumber+1 } catch(err) { global Srestore_InstanceNumber = 1 }
123
124
	# Runtime Environment Preparation & Call
125
	Eval(StrReplace("""	#"
126
        #######################################
127
        # 1) Unique Global Variables Initialization
128
        #######################################
129
		global  Srestore_lfr%%%     = -100
130
		global  Srestore_offs%%%    = 0
131
		global  Srestore_ldet%%%    = -100
132
		global  Srestore_lpos%%%    = 0
133
134
        #######################################
135
        # 2) Unique Runtime Call
136
        #######################################
137
		###### evaluation call & output calculation ######
138
		ARGS = "dm, om, bom, thr, frfac, numr, denm, mec, det, bclp, dclp, fin, ssispmt"
139
		source
140
		GScriptClip("srestore_inside_%%%(last, dm, om, bom, thr, frfac, numr, denm, mec, det, bclp, dclp, fin, ssispmt)", local=true, args=ARGS)
141
142
		###### final decimation & caching ######
143
		nonyuy2 ? nonyuy2clipout(true) : last
144
		cache<0 ? last : last.RequestLinear(8, cache, 5, false, false)
145
146
		temp    = frameratenumerator(det)*float(numr)>2147483600. ? det.assumescaledfps(numr, denm) : nop()
147
		isclip(temp) ? last.changefps(temp, linear=true) : last.changefps(frameratenumerator(source)*numr, frameratedenominator(source)*denm, linear=true)
148
149
		return last
150
151
        #######################################
152
        # 3) Unique Runtime Function Definition
153
        #######################################
154
		function srestore_inside_%%%(clip source, dm, om, bom, thr, frfac, numr, denm, mec, det, bclp, dclp, fin, ssispmt) {
155
			ssIsVF  = ssispmt ? source.IsVideoFloat() : false
156
			shbdbpc = ssispmt ? source.BitsPerComponent() : 8
157
			sIshbd  = shbdbpc > 8
158
			sdoscal = !ssIsVF && sIshbd
159
			sscalva = sdoscal ? shbdbpc == 10 ? 4 : shbdbpc == 12 ? 8 : shbdbpc == 14 ? 64 : 256 : 1
160
				ssIsVF ? eval("
161
			v015625 = .0000612745098039
162
			vp125   = .0004901960784314
163
			vp01    = .0000392156862745
164
			vp45    = .0017647058823529
165
			vp55    = .002156862745098
166
			vp51    = .002
167
			vp35    = .0013725490196078
168
			v0p5    = 0.0019607843137255
169
			v1      = 0.003921568627451
170
			v125    = 0.4901960784313725
171
						") : \
172
							eval("
173
			v015625 = .015625
174
			vp125   = .125
175
			vp01    = .01
176
			vp45    = .45
177
			vp55    = .55
178
			vp51    = .51
179
			vp35    = .35
180
			v0p5    = 0.5
181
			v1      = 1
182
			v125    = sdoscal ? 125*sscalva : 125
183
								")
184
			svhalf  = ssIsVF ? 0.5 : sdoscal ? shbdbpc == 10 ? 512 : shbdbpc == 12 ? 1024 : shbdbpc == 14 ? 8192 : 32768 : 128
185
			thr     = ssIsVF ? thr/255 : sdoscal ? thr*sscalva : thr
186
187
			### preparation ###
188
			cfr = current_frame
189
			jmp = Srestore_lfr%%%+1==cfr
190
			cfo = (((cfr%denm)*numr*2+denm+(versionnumber()>2.575 ? numr : 0))%(2*denm))-denm
191
			bfo = cfo>-numr && cfo<=numr
192
193
			global	Srestore_lfr%%%     = cfr
194
			global	Srestore_offs%%%    = bfo && Srestore_offs%%%<=-4*numr
195
												\? Srestore_offs%%%+2*denm
196
												\: bfo && Srestore_offs%%%>=4*numr
197
													\? Srestore_offs%%%-2*denm
198
													\: Srestore_offs%%%
199
200
			pos = frfac==1 ? 0 : bfo ? -round((cfo+Srestore_offs%%%)/(2.*numr)) : Srestore_lpos%%%
201
			cof = cfo+Srestore_offs%%%+2*numr*pos
202
203
			global	Srestore_ldet%%%    = cfr+pos==Srestore_ldet%%% ? -1 : cfr+pos
204
205
			## diff value shifting ##
206
			d_v = yplanemax(dclp)+v015625
207
			Srestore_d43%%% = jmp ? Srestore_d32%%% : d_v
208
			global 	Srestore_d32%%% = jmp ? Srestore_d21%%% : d_v
209
			global	Srestore_d21%%% = jmp ? Srestore_d10%%% : d_v
210
			global	Srestore_d10%%% = jmp ? Srestore_d01%%% : d_v
211
			global	Srestore_d01%%% = jmp ? Srestore_d12%%% : d_v
212
			global	Srestore_d12%%% = jmp ? Srestore_d23%%% : d_v
213
			global	Srestore_d23%%% = jmp ? Srestore_d34%%% : d_v
214
			global  Srestore_d34%%% = d_v
215
216
			## diff value shifting ##
217
			m_v = isfloat(om) && abs(om)>5 ? lumadifference(det, det.trim(2, 0))+v015625 : v1
218
			Srestore_m53%%% = jmp ? Srestore_m42%%% : m_v
219
			global 	Srestore_m42%%% = jmp ? Srestore_m31%%% : m_v
220
			global  Srestore_m31%%% = jmp ? Srestore_m20%%% : m_v
221
			global	Srestore_m20%%% = jmp ? Srestore_m11%%% : m_v
222
			global	Srestore_m11%%% = jmp ? Srestore_m02%%% : m_v
223
			global	Srestore_m02%%% = jmp ? Srestore_m13%%% : m_v
224
			global	Srestore_m13%%% = jmp ? Srestore_m24%%% : m_v
225
			global  Srestore_m24%%% = m_v
226
227
			## get blend and clear values ##
228
			b_v = svhalf-yplanemin(bclp)
229
			b_v = b_v<v1 ? vp125 : b_v
230
			c_v = yplanemax(bclp)-svhalf
231
			c_v = c_v<v1 ? vp125 : c_v
232
233
			## blend value shifting ##
234
			Srestore_bp3%%% = jmp ? Srestore_bp2%%% : bom ? b_v-c_v : b_v
235
			global 	Srestore_bp2%%% = jmp ? Srestore_bp1%%% : Srestore_bp3%%%
236
			global	Srestore_bp1%%% = jmp ? Srestore_bn0%%% : Srestore_bp3%%%
237
			global	Srestore_bn0%%% = jmp ? Srestore_bn1%%% : Srestore_bp3%%%
238
			global	Srestore_bn1%%% = jmp ? Srestore_bn2%%% : Srestore_bp3%%%
239
			global	Srestore_bn2%%% = jmp ? Srestore_bn3%%% : Srestore_bp3%%%
240
			global	Srestore_bn3%%% = bom ? b_v-c_v : b_v
241
242
			## clear value shifting ##
243
			Srestore_cp3%%% = jmp ? Srestore_cp2%%% : c_v
244
			global	Srestore_cp2%%% = jmp ? Srestore_cp1%%% : c_v
245
			global	Srestore_cp1%%% = jmp ? Srestore_cn0%%% : c_v
246
			global	Srestore_cn0%%% = jmp ? Srestore_cn1%%% : c_v
247
			global	Srestore_cn1%%% = jmp ? Srestore_cn2%%% : c_v
248
			global	Srestore_cn2%%% = jmp ? Srestore_cn3%%% : c_v
249
			global	Srestore_cn3%%% = c_v
250
251
			## used detection values ##
252
			bb  = select(pos+2, Srestore_bp3%%%, Srestore_bp2%%%, Srestore_bp1%%%, Srestore_bn0%%%, Srestore_bn1%%%)
253
			bc  = select(pos+2, Srestore_bp2%%%, Srestore_bp1%%%, Srestore_bn0%%%, Srestore_bn1%%%, Srestore_bn2%%%)
254
			bn  = select(pos+2, Srestore_bp1%%%, Srestore_bn0%%%, Srestore_bn1%%%, Srestore_bn2%%%, Srestore_bn3%%%)
255
256
			cb  = select(pos+2, Srestore_cp3%%%, Srestore_cp2%%%, Srestore_cp1%%%, Srestore_cn0%%%, Srestore_cn1%%%)
257
			cc  = select(pos+2, Srestore_cp2%%%, Srestore_cp1%%%, Srestore_cn0%%%, Srestore_cn1%%%, Srestore_cn2%%%)
258
			cn  = select(pos+2, Srestore_cp1%%%, Srestore_cn0%%%, Srestore_cn1%%%, Srestore_cn2%%%, Srestore_cn3%%%)
259
260
			dbb = select(pos+2, Srestore_d43%%%, Srestore_d32%%%, Srestore_d21%%%, Srestore_d10%%%, Srestore_d01%%%)
261
			dbc = select(pos+2, Srestore_d32%%%, Srestore_d21%%%, Srestore_d10%%%, Srestore_d01%%%, Srestore_d12%%%)
262
			dcn = select(pos+2, Srestore_d21%%%, Srestore_d10%%%, Srestore_d01%%%, Srestore_d12%%%, Srestore_d23%%%)
263
			dnn = select(pos+2, Srestore_d10%%%, Srestore_d01%%%, Srestore_d12%%%, Srestore_d23%%%, Srestore_d34%%%)
264
			dn2 = select(pos+2, Srestore_d01%%%, Srestore_d12%%%, Srestore_d23%%%, Srestore_d34%%%, Srestore_d34%%%)
265
266
			mb1 = select(pos+2, Srestore_m53%%%, Srestore_m42%%%, Srestore_m31%%%, Srestore_m20%%%, Srestore_m11%%%)
267
			mb  = select(pos+2, Srestore_m42%%%, Srestore_m31%%%, Srestore_m20%%%, Srestore_m11%%%, Srestore_m02%%%)
268
			mc  = select(pos+2, Srestore_m31%%%, Srestore_m20%%%, Srestore_m11%%%, Srestore_m02%%%, Srestore_m13%%%)
269
			mn  = select(pos+2, Srestore_m20%%%, Srestore_m11%%%, Srestore_m02%%%, Srestore_m13%%%, Srestore_m24%%%)
270
			mn1 = select(pos+2, Srestore_m11%%%, Srestore_m02%%%, Srestore_m13%%%, Srestore_m24%%%, vp01)
271
272
273
			### basic calculation ###
274
			bbool   = .8*bc*cb>bb*cc && .8*bc*cn>bn*cc && bc*bc>cc
275
			blend   = bbool && bc*5>cc && dbc+dcn>1.5*thr && (dbb<7*dbc || dbb<8*dcn) && (dnn<8*dcn || dnn<7*dbc) &&
276
					\ (mb<mb1 && mb<mc || mn<mn1 && mn<mc || (dbb+dnn)*4<dbc+dcn || (bb*cc*5<bc*cb || mb>thr) && (bn*cc*5<bc*cn || mn>thr) && bc>thr)
277
278
			clear   = dbb+dbc>thr && dcn+dnn>thr && (bc<2*bb || bc<2*bn) && (dbb+dnn)*2>dbc+dcn && (mc<.96*mb && mc<.96*mn && (bb*2>cb || bn*2>cn) &&
279
					\ cc>cb && cc>cn || frfac>vp45 && frfac<vp55 && .8*mc>mb1 && .8*mc>mn1 && mb>.8*mn && mn>.8*mb)
280
281
			highd   = dcn>5*dbc && dcn>5*dnn && dcn>thr && dbc<thr && dnn<thr
282
283
			lowd    = dcn*5<dbc && dcn*5<dnn && dbc>thr && dnn>thr && dcn<thr && frfac>vp35 && (frfac<vp51 || dcn*5<dbb)
284
285
			res     = (Srestore_d43%%%<thr
286
					  \&& Srestore_d32%%%<thr
287
					  \&& Srestore_d21%%%<thr
288
					  \&& Srestore_d10%%%<thr
289
					  \&& Srestore_d01%%%<thr
290
					  \&& Srestore_d12%%%<thr
291
					  \&& Srestore_d23%%%<thr
292
					  \&& Srestore_d34%%%<thr)
293
					  \|| (dbc*4<dbb && dcn*4<dbb && dnn*4<dbb && dn2*4<dbb)
294
					  \|| (dcn*4<dbc && dnn*4<dbc && dn2*4<dbc)
295
296
297
			### offset calculation ###
298
			odm     = blend ? denm : clear ? 0 : highd ? denm-numr : lowd ? 2*denm-numr : cof
299
			odm     = odm+round((cof-odm)/(2.*denm))*2*denm
300
			odr     = (blend ? denm-numr : clear ? numr : highd ? numr : frfac<v0p5 ? 2*numr : 2*(denm-numr)) * .9
301
302
			cof     = Srestore_ldet%%%<0
303
						\? cof
304
						\: cof>odm+odr
305
							\? cof-Srestore_offs%%%-odm-odr>denm && res
306
								\? odm+2*denm-odr
307
								\: odm+odr
308
							\: cof<odm-odr
309
								\? Srestore_offs%%%>denm && res
310
									\? odm-2*denm+odr
311
									\: odm-odr
312
								\: Srestore_offs%%%<-1.15*denm && res
313
									\? cof+2*denm
314
									\: Srestore_offs%%%>1.25*denm && res
315
										\? cof-2*denm
316
										\: cof
317
318
			global	Srestore_offs%%%    = frfac==1 ? 0 : cof-cfo-2*numr*pos
319
			global	Srestore_lpos%%%    = pos
320
			opos    = frfac==1 ? 0 : -round((cfo+Srestore_offs%%%+(bfo && Srestore_offs%%%<=-4*numr ? denm : 0))/(2.*numr))
321
			pos     = opos<-2 ? -2 : opos>2 ? 2 : opos
322
323
			### frame output calculation - resync - dup ###
324
			dbb = select(pos+2, Srestore_d43%%%, Srestore_d32%%%, Srestore_d21%%%, Srestore_d10%%%, Srestore_d01%%%)
325
			dbc = select(pos+2, Srestore_d32%%%, Srestore_d21%%%, Srestore_d10%%%, Srestore_d01%%%, Srestore_d12%%%)
326
			dcn = select(pos+2, Srestore_d21%%%, Srestore_d10%%%, Srestore_d01%%%, Srestore_d12%%%, Srestore_d23%%%)
327
			dnn = select(pos+2, Srestore_d10%%%, Srestore_d01%%%, Srestore_d12%%%, Srestore_d23%%%, Srestore_d34%%%)
328
329
			## dup_hq - merge ##
330
			dup     = opos!=pos || abs(dm)<2 || abs(dm)==3 ? 0 : dcn*5<dbc && dnn*5<dbc && (dcn<1.25*thr || bn<bc && pos==Srestore_lpos%%%) ||
331
					\ (dcn*dcn<dbc || dcn*5<dbc) && bn<bc && pos==Srestore_lpos%%% && dnn<.9*dbc || dnn*9<dbc && dcn*3<dbc ? 1 :
332
					\ (dbc*dbc<dcn || dbc*5<dcn) && bb<bc && pos==Srestore_lpos%%% && dbb<.9*dcn || dbb*9<dcn && dbc*3<dcn ||
333
					\ dbb*5<dcn && dbc*5<dcn && (dbc<1.25*thr || bb<bc && pos==Srestore_lpos%%%) ? -1 : 0
334
			mer     = !bom && opos==pos && dup==0 && abs(dm)>2 && (dbc*8<dcn || dbc*8<dbb || dcn*8<dbc || dcn*8<dnn || dbc*2<thr ||
335
					\ dcn*2<thr || dnn*9<dbc && dcn*3<dbc || dbb*9<dcn && dbc*3<dcn)
336
337
			## deblend - doubleblend removal - postprocessing ##
338
			add     = Srestore_bp1%%%*Srestore_cn2%%%>Srestore_bn2%%%*Srestore_cp1%%%*(v1+thr*.01)
339
					  \&& Srestore_bn0%%%*Srestore_cn2%%%>Srestore_bn2%%%*Srestore_cn0%%%*(v1+thr*.01)
340
					  \&& Srestore_cn2%%%*Srestore_bn1%%%>Srestore_cn1%%%*Srestore_bn2%%%*(v1+thr*.01)
341
			dup     = bom
342
						\? (Srestore_bn0%%%>Srestore_bp2%%%
343
							\&& Srestore_bn0%%%>=Srestore_bp1%%%
344
							\&& Srestore_bn0%%%>Srestore_bn1%%%
345
							\&& Srestore_bn0%%%>Srestore_bn2%%%
346
							\&& Srestore_cn0%%%<v125
347
							\? (Srestore_d12%%%*Srestore_d12%%%<Srestore_d10%%%
348
								\|| Srestore_d12%%%*9<Srestore_d10%%%)
349
								\? 1
350
								\: (Srestore_d10%%%*Srestore_d10%%%<Srestore_d12%%%
351
									\|| Srestore_d10%%%*9<Srestore_d12%%%)
352
									\? 0
353
									\: 4
354
							\: Srestore_bp1%%%>Srestore_bp3%%%
355
								\&& Srestore_bp1%%%>=Srestore_bp2%%%
356
								\&& Srestore_bp1%%%>Srestore_bn0%%%
357
								\&& Srestore_bp1%%%>Srestore_bn1%%%
358
								\? 1
359
								\: 0)
360
						\: dup!=0
361
							\? dup
362
							\: om>0 && om<5
363
								\? (bbool==false
364
									\? 0
365
									\: (om==4 && Srestore_bp1%%%*Srestore_cn1%%%<Srestore_bn1%%%*Srestore_cp1%%%)
366
										\|| (om==3 && Srestore_d10%%%<Srestore_d01%%%)
367
										\|| om==1
368
										\? -1
369
										\: 1)
370
								\: om==5
371
									\? (Srestore_bp1%%%*Srestore_cp2%%%>Srestore_bp2%%%*Srestore_cp1%%%*(v1+thr*.01)
372
										\&& Srestore_bn0%%%*Srestore_cp2%%%>Srestore_bp2%%%*Srestore_cn0%%%*(v1+thr*.01)
373
										\&& Srestore_cp2%%%*Srestore_bn1%%%>Srestore_cn1%%%*Srestore_bp2%%%*(v1+thr*.01)
374
										\&& (add==false || Srestore_cp2%%%*Srestore_bn2%%%>Srestore_cn2%%%*Srestore_bp2%%%)
375
										\? -2
376
										\: add
377
											\? 2
378
											\: Srestore_bn0%%%*Srestore_cp1%%%>Srestore_bp1%%%*Srestore_cn0%%%
379
												\&& (Srestore_bn0%%%*Srestore_cn1%%%<Srestore_bn1%%%*Srestore_cn0%%%
380
												\|| Srestore_cp1%%%*Srestore_bn1%%%>Srestore_cn1%%%*Srestore_bp1%%%)
381
												\? -1
382
												\: Srestore_bn0%%%*Srestore_cn1%%%>Srestore_bn1%%%*Srestore_cn0%%%
383
													\? 1
384
													\: 0)
385
									\: 0
386
387
			### output clip ###
388
			oclp    = mer && dup==0 ? mec : source
389
			opos    = opos + dup - (dup==0 && mer && dbc<dcn ? 1 : 0)
390
			dup==4 ? fin : opos<0 ? oclp.loop(1-opos, 0, 0) : oclp.trim(opos, 0)
391
392
		}
393
	""", "%%%", string(Srestore_InstanceNumber)))	#"
394
}
395
396
397
398-
{ i = s.FindStr(find) return (i==0 ? s : (s.LeftStr(i-1)+replace+s.MidStr(Strlen(find)+i)).StrReplace(find, replace)) }
398+
399
# Repeated, string replacements
400
401
Function StrReplace(string s, string find, string replace)
402
{
403
 ssispmt = Findstr(VersionString(), "AviSynth+") != 0 && Findstr(VersionString(), "r1576") == 0
404
 ssispmt ? ReplaceStr(s,find,replace) : eval("""i = s.FindStr(find) Chr(3) i ==0 || Replace=="" ? s : (s.LeftStr(i-1)+replace+s.MidStr(Strlen(find)+i)).StrReplace(find, replace)""")
405
}