Constness changes
[melted] / src / modules / motion_est / README
1 INTRO:
2
3 This module is designed to provide application agnostic motion estimation.
4 I wrote it from scratch because I found the other Open Source code to be
5 limited by their difficulty of reuse.
6
7
8 COMPILE:
9
10 To compile this module, you must supply these options to the root configure script:
11
12 --enable-gpl --enable-motion-est
13
14
15 EXAMPLES:
16
17 Estimate the motion:
18
19         > inigo -filter motion_est <movie_file>
20
21 To display the motion vectors as pretty arrows:
22
23         > inigo -filter motion_est -filter vismv <movie_file>
24
25 If your using a movie file that contains a crop, you will get better results with this:
26
27         > inigo -filter crop_detect -filter motion_est -filter vismv <movie_file>
28
29 If your computer is unable to do the above examples in real time, try this:
30
31         > inigo -filter motion_est -filter vismv -consumer inigo real_time=0 <movie_file>
32
33 If you'd like to see the motion vectors without the median denoising function, do this:
34
35         > inigo -filter motion_est denoise=0 -filter vismv <movie_file>
36
37 To reconstruct each frame by applying the motion to the previous frame:
38
39         > inigo -filter motion_est show_reconstruction=1 <movie_file>
40
41 To compare the reconstructed frame and the real frame (while paused):
42
43         > inigo -filter motion_est show_reconstruction=1 toggle_when_paused=1 <movie_file>
44
45 To show the difference (residual) between the reconstructed frame the real frame:
46
47         > inigo -filter motion_est show_residual=1 <movie_file>
48
49 To automatically track an object in the frame, try this:
50
51         > inigo -filter autotrack_rectangle:X,Y:WxH debug=1 <movie_file>
52
53 (Where X,Y is the origin of the rectangle indexed from upper left and WxH is the dimensions of the rectangle.)
54
55 To obscure that same object in the frame, try this:
56
57         > inigo -filter autotrack_rectangle:X,Y:WxH obscure=1 <movie_file>
58
59 There is now a slow motion producer that does interpolation based on the motion vectors:
60
61         > inigo slowmotion:<movie_file> _speed=0.1 method=1 debug=1
62
63 NOTES (and deficiencies):
64
65 1.  Ignore shot change detection when your using the autotrack_rectangle filter.
66
67 2.  Don't assume motion vectors displayed while stepping backwards and forward are that same vectors
68     that would be calculated while playing the footage from start to finish, nonstop. Stepping forward
69     should be fine after a few frames, however.
70
71 3.  SSE instructions are lazily assumed. MMX, Altivec, and SIMD-less would be good too.
72
73 4.  Motion estimation is only performed in the luma color space.
74
75 5.  Motion vectors should have sub-pixel accuracy.
76
77 6.  Motion vectors are not serializable yet.
78
79 7.  A diligent test suite is needed. (show_reconstruction & show_residual are a start)
80
81 8.  Multithreaded code will see HUGE benefits on multi-CPU systems. Donations of a multi-core cpu or a
82     multi-cpu system to the author will encourage development.
83
84 9.  Macroblock sizes are not dynamic (Though settable at runtime.)
85
86 10. Notes (5), (7), and (9) would go a long ways to making this code suitable for a modern video encoder.
87
88 11. Shot change works well but arbitrarily chosen thresholds need to be tuned.
89
90 12. Given the documentation of other motion estimation code bases, I will GLADLY clarify and
91     document any piece of code upon request.
92
93 13. Considerable effort has been put into the speed. I usually experience 10ms or less per frame for PAL on 2.8GHZ p4.
94
95 Zachary Drew
96 drew0054@tc.umn.edu
97