annotate libmpcodecs/vf_divtc.c @ 12225:eb79a6192b2b

New filter by Ville Saari (114263 at foo dot bar dot org) for removing duplicate frames from telecined video that was incorrectly deinterlaced. Minor bugfixes added by me.
author rfelker
date Sat, 17 Apr 2004 17:08:31 +0000
parents
children 821f464b4d90
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
12225
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
1 #include <stdio.h>
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
2 #include <stdlib.h>
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
3 #include <string.h>
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
4 #include <limits.h>
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
5 #include <math.h>
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
6
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
7 #include "../config.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
8 #include "../mp_msg.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
9 #include "../cpudetect.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
10 #include "../bswap.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
11
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
12 #include "img_format.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
13 #include "mp_image.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
14 #include "vf.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
15
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
16 #include "../libvo/fastmemcpy.h"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
17
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
18 vf_info_t vf_info_divtc;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
19
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
20 struct vf_priv_s
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
21 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
22 int deghost, pass, phase, window, fcount, bcount, frameno, misscount,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
23 ocount, sum[5];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
24 double threshold;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
25 FILE *file;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
26 char *bdata;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
27 unsigned int *csdata;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
28 int *history;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
29 };
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
30
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
31 /*
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
32 * diff_MMX and diff_C stolen from vf_decimate.c
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
33 */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
34
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
35 #ifdef HAVE_MMX
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
36 static int diff_MMX(unsigned char *old, unsigned char *new, int os, int ns)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
37 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
38 volatile short out[4];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
39 asm (
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
40 "movl $8, %%ecx \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
41 "pxor %%mm4, %%mm4 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
42 "pxor %%mm7, %%mm7 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
43
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
44 ".balign 16 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
45 "1: \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
46
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
47 "movq (%%esi), %%mm0 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
48 "movq (%%esi), %%mm2 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
49 "addl %%eax, %%esi \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
50 "movq (%%edi), %%mm1 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
51 "addl %%ebx, %%edi \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
52 "psubusb %%mm1, %%mm2 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
53 "psubusb %%mm0, %%mm1 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
54 "movq %%mm2, %%mm0 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
55 "movq %%mm1, %%mm3 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
56 "punpcklbw %%mm7, %%mm0 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
57 "punpcklbw %%mm7, %%mm1 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
58 "punpckhbw %%mm7, %%mm2 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
59 "punpckhbw %%mm7, %%mm3 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
60 "paddw %%mm0, %%mm4 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
61 "paddw %%mm1, %%mm4 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
62 "paddw %%mm2, %%mm4 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
63 "paddw %%mm3, %%mm4 \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
64
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
65 "decl %%ecx \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
66 "jnz 1b \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
67 "movq %%mm4, (%%edx) \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
68 "emms \n\t"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
69 :
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
70 : "S" (old), "D" (new), "a" (os), "b" (ns), "d" (out)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
71 : "memory"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
72 );
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
73 return out[0]+out[1]+out[2]+out[3];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
74 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
75 #endif
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
76
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
77 static int diff_C(unsigned char *old, unsigned char *new, int os, int ns)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
78 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
79 int x, y, d=0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
80
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
81 for(y=8; y; y--, new+=ns, old+=os)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
82 for(x=8; x; x--)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
83 d+=abs(new[x]-old[x]);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
84
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
85 return d;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
86 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
87
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
88 static int (*diff)(unsigned char *, unsigned char *, int, int);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
89
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
90 static int diff_plane(unsigned char *old, unsigned char *new,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
91 int w, int h, int os, int ns, int arg)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
92 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
93 int x, y, d, max=0, sum=0, n=0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
94
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
95 for(y=0; y<h-7; y+=8)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
96 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
97 for(x=0; x<w-7; x+=8)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
98 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
99 d=diff(old+x+y*os, new+x+y*ns, os, ns);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
100 if(d>max) max=d;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
101 sum+=d;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
102 n++;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
103 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
104 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
105
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
106 return (sum+n*max)/2;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
107 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
108
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
109 /*
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
110 static unsigned int checksum_plane(unsigned char *p, unsigned char *z,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
111 int w, int h, int s, int zs, int arg)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
112 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
113 unsigned int shift, sum;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
114 unsigned char *e;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
115
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
116 for(sum=0; h; h--, p+=s-w)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
117 for(e=p+w, shift=32; p<e;)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
118 sum^=(*p++)<<(shift=(shift-8)&31);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
119
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
120 return sum;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
121 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
122 */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
123
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
124 static unsigned int checksum_plane(unsigned char *p, unsigned char *z,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
125 int w, int h, int s, int zs, int arg)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
126 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
127 unsigned int shift;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
128 uint32_t sum, t;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
129 unsigned char *e, *e2;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
130 #if MP_WORDSIZE==64
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
131 typedef uint64_t wsum_t;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
132 #else
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
133 typedef uint32_t wsum_t;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
134 #endif
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
135 wsum_t wsum;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
136
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
137 for(sum=0; h; h--, p+=s-w)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
138 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
139 for(shift=0, e=p+w; (int)p&(sizeof(wsum_t)-1) && p<e;)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
140 sum^=*p++<<(shift=(shift-8)&31);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
141
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
142 for(wsum=0, e2=e-sizeof(wsum_t)+1; p<e2; p+=sizeof(wsum_t))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
143 wsum^=*(wsum_t *)p;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
144
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
145 #if MP_WORDSIZE==64
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
146 t=be2me_32((uint32_t)(wsum>>32^wsum));
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
147 #else
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
148 t=be2me_32(wsum);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
149 #endif
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
150
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
151 for(sum^=(t<<shift|t>>(32-shift)); p<e;)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
152 sum^=*p++<<(shift=(shift-8)&31);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
153 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
154
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
155 return sum;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
156 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
157
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
158 static int deghost_plane(unsigned char *d, unsigned char *s,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
159 int w, int h, int ds, int ss, int threshold)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
160 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
161 int t;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
162 unsigned char *e;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
163
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
164 for(; h; h--, s+=ss-w, d+=ds-w)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
165 for(e=d+w; d<e; d++, s++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
166 if(abs(*d-*s)>=threshold)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
167 *d=(t=(*d<<1)-*s)<0?0:t>255?255:t;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
168
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
169 return 0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
170 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
171
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
172 static int imgop(int(*planeop)(unsigned char *, unsigned char *,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
173 int, int, int, int, int),
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
174 mp_image_t *dst, mp_image_t *src, int arg)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
175 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
176 if(dst->flags&MP_IMGFLAG_PLANAR)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
177 return planeop(dst->planes[0], src?src->planes[0]:0,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
178 dst->w, dst->h,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
179 dst->stride[0], src?src->stride[0]:0, arg)+
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
180 planeop(dst->planes[1], src?src->planes[1]:0,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
181 dst->chroma_width, dst->chroma_height,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
182 dst->stride[1], src?src->stride[1]:0, arg)+
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
183 planeop(dst->planes[2], src?src->planes[2]:0,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
184 dst->chroma_width, dst->chroma_height,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
185 dst->stride[2], src?src->stride[2]:0, arg);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
186
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
187 return planeop(dst->planes[0], src?src->planes[0]:0,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
188 dst->w*(dst->bpp/8), dst->h,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
189 dst->stride[0], src?src->stride[0]:0, arg);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
190 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
191
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
192 /*
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
193 * Find the phase in which the telecine pattern fits best to the
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
194 * given 5 frame slice of frame difference measurements.
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
195 *
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
196 * If phase1 and phase2 are not negative, only the two specified
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
197 * phases are tested.
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
198 */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
199
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
200 static int cmp(int *a, int *b) { return *b-*a; }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
201
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
202 static int match(struct vf_priv_s *p, int *diffs,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
203 int phase1, int phase2, double *strength)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
204 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
205 static const int pattern1[]={ -4, 1, 1, 1, 1 },
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
206 pattern2[]={ -2, -3, 4, 4, -3 }, *pattern;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
207 int f, m, n, t[5];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
208
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
209 pattern=p->deghost>0?pattern2:pattern1;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
210
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
211 for(f=0; f<5; f++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
212 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
213 if(phase1<0 || phase2<0 || f==phase1 || f==phase2)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
214 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
215 for(n=t[f]=0; n<5; n++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
216 t[f]+=diffs[n]*pattern[(n-f+5)%5];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
217 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
218 else
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
219 t[f]=INT_MIN;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
220 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
221
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
222 /* find the best match */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
223 for(m=0, n=1; n<5; n++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
224 if(t[n]>t[m]) m=n;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
225
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
226 if(strength)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
227 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
228 /* the second best match */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
229 for(f=m?0:1, n=f+1; n<5; n++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
230 if(n!=m && t[n]>t[f]) f=n;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
231
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
232 *strength=(t[m]>0?(double)(t[m]-t[f])/t[m]:0.0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
233 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
234
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
235 return m;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
236 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
237
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
238 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
239 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
240 mp_image_t *dmpi, *tmpi=0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
241 int n, m, f, newphase;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
242 struct vf_priv_s *p=vf->priv;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
243 unsigned int checksum;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
244 double d;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
245
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
246 dmpi=vf_get_image(vf->next, mpi->imgfmt,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
247 MP_IMGTYPE_STATIC, MP_IMGFLAG_ACCEPT_STRIDE |
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
248 MP_IMGFLAG_PRESERVE | MP_IMGFLAG_READABLE,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
249 mpi->width, mpi->height);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
250 vf_clone_mpi_attributes(dmpi, mpi);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
251
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
252 newphase=p->phase;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
253
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
254 switch(p->pass)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
255 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
256 case 1:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
257 fprintf(p->file, "%08x %d\n",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
258 (unsigned int)imgop((void *)checksum_plane, mpi, 0, 0),
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
259 p->frameno?imgop(diff_plane, dmpi, mpi, 0):0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
260 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
261
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
262 case 2:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
263 if(p->frameno/5>p->bcount)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
264 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
265 mp_msg(MSGT_VFILTER, MSGL_ERR,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
266 "\n%s: Log file ends prematurely! "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
267 "Switching to one pass mode.\n", vf->info->name);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
268 p->pass=0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
269 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
270 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
271
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
272 checksum=(unsigned int)imgop((void *)checksum_plane, mpi, 0, 0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
273
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
274 if(checksum!=p->csdata[p->frameno])
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
275 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
276 for(f=0; f<100; f++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
277 if(p->frameno+f<p->fcount && p->csdata[p->frameno+f]==checksum)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
278 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
279 else if(p->frameno-f>=0 && p->csdata[p->frameno-f]==checksum)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
280 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
281 f=-f;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
282 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
283 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
284
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
285 if(f<100)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
286 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
287 mp_msg(MSGT_VFILTER, MSGL_INFO,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
288 "\n%s: Mismatch with pass-1: %+d frame(s).\n",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
289 vf->info->name, f);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
290
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
291 p->frameno+=f;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
292 p->misscount=0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
293 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
294 else if(p->misscount++>=30)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
295 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
296 mp_msg(MSGT_VFILTER, MSGL_ERR,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
297 "\n%s: Sync with pass-1 lost! "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
298 "Switching to one pass mode.\n", vf->info->name);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
299 p->pass=0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
300 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
301 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
302 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
303
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
304 n=(p->frameno)/5;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
305 if(n>=p->bcount) n=p->bcount-1;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
306
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
307 newphase=p->bdata[n];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
308 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
309
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
310 default:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
311 if(p->frameno)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
312 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
313 int *sump=p->sum+p->frameno%5,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
314 *histp=p->history+p->frameno%p->window;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
315
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
316 *sump-=*histp;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
317 *sump+=(*histp=imgop(diff_plane, dmpi, mpi, 0));
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
318 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
319
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
320 m=match(p, p->sum, -1, -1, &d);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
321
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
322 if(d>=p->threshold)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
323 newphase=m;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
324 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
325
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
326 n=p->ocount++%5;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
327
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
328 if(newphase!=p->phase && ((p->phase+4)%5<n)==((newphase+4)%5<n))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
329 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
330 p->phase=newphase;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
331 mp_msg(MSGT_VFILTER, MSGL_STATUS,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
332 "\n%s: Telecine phase %d.\n", vf->info->name, p->phase);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
333 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
334
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
335 switch((p->frameno++-p->phase+10)%5)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
336 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
337 case 0:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
338 imgop((void *)memcpy_pic, dmpi, mpi, 0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
339 return 0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
340
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
341 case 4:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
342 if(p->deghost>0)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
343 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
344 tmpi=vf_get_image(vf->next, mpi->imgfmt,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
345 MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
346 mpi->width, mpi->height);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
347 vf_clone_mpi_attributes(tmpi, mpi);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
348
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
349 imgop((void *)memcpy_pic, tmpi, mpi, 0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
350 imgop(deghost_plane, tmpi, dmpi, p->deghost);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
351 imgop((void *)memcpy_pic, dmpi, mpi, 0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
352 return vf_next_put_image(vf, tmpi);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
353 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
354 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
355
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
356 imgop((void *)memcpy_pic, dmpi, mpi, 0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
357 return vf_next_put_image(vf, dmpi);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
358 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
359
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
360 static int analyze(struct vf_priv_s *p)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
361 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
362 int *buf=0, *bp, bufsize=0, n, b, f, i, j, m, s;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
363 unsigned int *cbuf=0, *cp;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
364 char *pbuf;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
365 char lbuf[256];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
366 int sum[5];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
367 double d;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
368
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
369 /* read the file */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
370
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
371 n=15;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
372 while(fgets(lbuf, 256, p->file))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
373 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
374 if(n>=bufsize-19)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
375 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
376 bufsize=bufsize?bufsize*2:30000;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
377 if((bp=realloc(buf, bufsize*sizeof *buf))) buf=bp;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
378 if((cp=realloc(cbuf, bufsize*sizeof *cbuf))) cbuf=cp;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
379
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
380 if(!bp || !cp)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
381 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
382 mp_msg(MSGT_VFILTER, MSGL_FATAL, "%s: Not enough memory.\n",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
383 vf_info_divtc.name);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
384 free(buf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
385 free(cbuf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
386 return 0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
387 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
388 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
389 sscanf(lbuf, "%x %d", cbuf+n, buf+n);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
390 n++;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
391 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
392
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
393 if(!n)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
394 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
395 mp_msg(MSGT_VFILTER, MSGL_FATAL, "%s: Empty 2-pass log file.\n",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
396 vf_info_divtc.name);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
397 free(buf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
398 free(cbuf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
399 return 0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
400 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
401
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
402 /* generate some dummy data past the beginning and end of the array */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
403
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
404 buf+=15, cbuf+=15;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
405 n-=15;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
406
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
407 memcpy(buf-15, buf, 15*sizeof *buf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
408 memset(cbuf-15, 0, 15*sizeof *cbuf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
409
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
410 while(n%5)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
411 buf[n]=buf[n-5], cbuf[n]=0, n++;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
412
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
413 memcpy(buf+n, buf+n-15, 15*sizeof *buf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
414 memset(cbuf+n, 0, 15*sizeof *cbuf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
415
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
416 p->csdata=cbuf;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
417 p->fcount=n;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
418
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
419 /* array with one slot for each slice of 5 frames */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
420
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
421 p->bdata=pbuf=malloc(p->bcount=b=(n/5));
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
422 memset(pbuf, 255, b);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
423
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
424 /* resolve the automatic mode */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
425
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
426 if(p->deghost<0)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
427 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
428 int deghost=-p->deghost;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
429 double s0=0.0, s1=0.0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
430
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
431 for(f=0; f<n; f+=5)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
432 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
433 p->deghost=0; match(p, buf+f, -1, -1, &d); s0+=d;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
434 p->deghost=1; match(p, buf+f, -1, -1, &d); s1+=d;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
435 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
436
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
437 p->deghost=s1>s0?deghost:0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
438
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
439 mp_msg(MSGT_VFILTER, MSGL_INFO,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
440 "%s: Deghosting %-3s (relative pattern strength %+.2fdB).\n",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
441 vf_info_divtc.name,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
442 p->deghost?"ON":"OFF",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
443 10.0*log10(s1/s0));
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
444 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
445
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
446 /* analyze the data */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
447
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
448 for(f=0; f<5; f++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
449 for(sum[f]=0, n=-15; n<20; n+=5)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
450 sum[f]+=buf[n+f];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
451
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
452 for(f=0; f<b; f++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
453 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
454 m=match(p, sum, -1, -1, &d);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
455
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
456 if(d>=p->threshold)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
457 pbuf[f]=m;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
458
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
459 if(f<b-1)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
460 for(n=0; n<5; n++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
461 sum[n]=sum[n]-buf[5*(f-3)+n]+buf[5*(f+4)+n];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
462 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
463
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
464 /* fill in the gaps */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
465
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
466 /* the beginning */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
467 for(f=0; f<b && pbuf[f]==-1; f++);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
468
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
469 if(f==b)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
470 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
471 free(buf-15);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
472 mp_msg(MSGT_VFILTER, MSGL_FATAL, "%s: No telecine pattern found!\n",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
473 vf_info_divtc.name);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
474 return 0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
475 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
476
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
477 for(n=0; n<f; pbuf[n++]=pbuf[f]);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
478
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
479 /* the end */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
480 for(f=b-1; pbuf[f]==-1; f--);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
481 for(n=f+1; n<b; pbuf[n++]=pbuf[f]);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
482
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
483 /* the rest */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
484 for(f=0;;)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
485 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
486 while(f<b && pbuf[f]!=-1) f++;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
487 if(f==b) break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
488 for(n=f; pbuf[n]==-1; n++);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
489
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
490 if(pbuf[f-1]==pbuf[n])
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
491 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
492 /* just a gap */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
493 while(f<n) pbuf[f++]=pbuf[n];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
494 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
495 else
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
496 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
497 /* phase change, reanalyze the original data in the gap with zero
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
498 threshold for only the two phases that appear at the ends */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
499
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
500 for(i=0; i<5; i++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
501 for(sum[i]=0, j=5*f-15; j<5*f; j+=5)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
502 sum[i]+=buf[i+j];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
503
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
504 for(i=f; i<n; i++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
505 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
506 pbuf[i]=match(p, sum, pbuf[f-1], pbuf[n], 0);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
507
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
508 for(j=0; j<5; j++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
509 sum[j]=sum[j]-buf[5*(i-3)+j]+buf[5*(i+4)+j];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
510 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
511
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
512 /* estimate the transition point by dividing the gap
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
513 in the same proportion as the number of matches of each kind */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
514
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
515 for(i=f, m=f; i<n; i++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
516 if(pbuf[i]==pbuf[f-1]) m++;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
517
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
518 /* find the transition of the right direction nearest to the
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
519 estimated point */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
520
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
521 if(m>f && m<n)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
522 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
523 for(j=m; j>f; j--)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
524 if(pbuf[j-1]==pbuf[f-1] && pbuf[j]==pbuf[n]) break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
525 for(s=m; s<n; s++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
526 if(pbuf[s-1]==pbuf[f-1] && pbuf[s]==pbuf[n]) break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
527
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
528 m=(s-m<m-j)?s:j;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
529 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
530
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
531 /* and rewrite the data to allow only this one transition */
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
532
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
533 for(i=f; i<m; i++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
534 pbuf[i]=pbuf[f-1];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
535
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
536 for(; i<n; i++)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
537 pbuf[i]=pbuf[n];
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
538
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
539 f=n;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
540 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
541 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
542
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
543 free(buf-15);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
544
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
545 return 1;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
546 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
547
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
548 static int query_format(struct vf_instance_s* vf, unsigned int fmt)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
549 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
550 switch(fmt)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
551 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
552 case IMGFMT_444P: case IMGFMT_IYUV: case IMGFMT_RGB24:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
553 case IMGFMT_422P: case IMGFMT_UYVY: case IMGFMT_BGR24:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
554 case IMGFMT_411P: case IMGFMT_YUY2: case IMGFMT_IF09:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
555 case IMGFMT_YV12: case IMGFMT_I420: case IMGFMT_YVU9:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
556 case IMGFMT_IUYV: case IMGFMT_Y800: case IMGFMT_Y8:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
557 return vf_next_query_format(vf,fmt);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
558 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
559
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
560 return 0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
561 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
562
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
563 static void uninit(struct vf_instance_s* vf)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
564 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
565 if(vf->priv)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
566 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
567 if(vf->priv->file) fclose(vf->priv->file);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
568 if(vf->priv->csdata) free(vf->priv->csdata-15);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
569 free(vf->priv->bdata);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
570 free(vf->priv->history);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
571 free(vf->priv);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
572 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
573 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
574
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
575 static int open(vf_instance_t *vf, char* args)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
576 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
577 struct vf_priv_s *p;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
578 char *filename="framediff.log", *ap, *q, *a;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
579
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
580 if(args && !(args=strdup(args)))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
581 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
582 nomem:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
583 mp_msg(MSGT_VFILTER, MSGL_FATAL,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
584 "%s: Not enough memory.\n", vf->info->name);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
585 fail:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
586 uninit(vf);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
587 free(args);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
588 return 0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
589 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
590
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
591 vf->put_image=put_image;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
592 vf->uninit=uninit;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
593 vf->query_format=query_format;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
594 vf->default_reqs=VFCAP_ACCEPT_STRIDE;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
595 if(!(vf->priv=p=calloc(1, sizeof(struct vf_priv_s))))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
596 goto nomem;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
597
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
598 p->phase=5;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
599 p->threshold=0.5;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
600 p->window=30;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
601
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
602 if((ap=args))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
603 while(*ap)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
604 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
605 q=ap;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
606 if((ap=strchr(q, ':'))) *ap++=0; else ap=q+strlen(q);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
607 if((a=strchr(q, '='))) *a++=0; else a=q+strlen(q);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
608
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
609 switch(*q)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
610 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
611 case 0: break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
612 case 'f': filename=a; break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
613 case 't': p->threshold=atof(a); break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
614 case 'w': p->window=5*(atoi(a)+4)/5; break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
615 case 'd': p->deghost=atoi(a); break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
616 case 'p':
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
617 if(q[1]=='h') p->phase=atoi(a);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
618 else p->pass=atoi(a);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
619 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
620
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
621 case 'h':
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
622 mp_msg(MSGT_VFILTER, MSGL_INFO,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
623 "\n%s options:\n\n"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
624 "pass=1|2 - Use 2-pass mode.\n"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
625 "file=filename - Set the 2-pass log file name "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
626 "(default %s).\n"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
627 "threshold=value - Set the pattern recognition "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
628 "sensitivity (default %g).\n"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
629 "deghost=value - Select deghosting threshold "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
630 "(default %d).\n"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
631 "window=numframes - Set the statistics window "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
632 "for 1-pass mode (default %d).\n"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
633 "phase=0|1|2|3|4 - Set the initial phase "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
634 "for 1-pass mode (default %d).\n\n"
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
635 "The option names can be abbreviated to the shortest "
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
636 "unique prefix.\n\n",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
637 vf->info->name, filename, p->threshold, p->deghost,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
638 p->window, p->phase%5);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
639 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
640
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
641 default:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
642 mp_msg(MSGT_VFILTER, MSGL_FATAL,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
643 "%s: Unknown argument %s.\n", vf->info->name, q);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
644 goto fail;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
645 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
646 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
647
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
648 switch(p->pass)
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
649 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
650 case 1:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
651 if(!(p->file=fopen(filename, "w")))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
652 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
653 mp_msg(MSGT_VFILTER, MSGL_FATAL,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
654 "%s: Can't create file %s.\n", vf->info->name, filename);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
655 goto fail;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
656 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
657
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
658 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
659
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
660 case 2:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
661 if(!(p->file=fopen(filename, "r")))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
662 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
663 mp_msg(MSGT_VFILTER, MSGL_FATAL,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
664 "%s: Can't open file %s.\n", vf->info->name, filename);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
665 goto fail;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
666 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
667
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
668 if(!analyze(p))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
669 goto fail;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
670
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
671 fclose(p->file);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
672 p->file=0;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
673 break;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
674 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
675
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
676 if(p->window<5) p->window=5;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
677 if(!(p->history=calloc(sizeof *p->history, p->window)))
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
678 goto nomem;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
679
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
680 diff=
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
681 #ifdef HAVE_MMX
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
682 gCpuCaps.hasMMX?diff_MMX:
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
683 #endif
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
684 diff_C;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
685
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
686 free(args);
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
687 return 1;
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
688 }
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
689
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
690 vf_info_t vf_info_divtc =
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
691 {
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
692 "inverse telecine for deinterlaced video",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
693 "divtc",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
694 "Ville Saari",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
695 "",
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
696 open,
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
697 NULL
eb79a6192b2b New filter by Ville Saari (114263 at foo dot bar dot org)
rfelker
parents:
diff changeset
698 };