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