Learning to Estimate Hidden Motions with Global Motion Aggregation
Occlusions pose a significant challenge to optical flow algorithms that rely on local evidences. We consider an occluded point to be one that is imaged in the reference frame but not in the next, a slight overloading of the standard definition since it also includes points that move out-of-frame. Estimating the motion of these points is extremely difficult, particularly in the two-frame setting. Previous work relies on CNNs to learn occlusions, without much success, or requires multiple frames to reason about occlusions using temporal smoothness. In this paper, we argue that the occlusion problem can be better solved in the two-frame case by modelling image self-similarities. We introduce a global motion aggregation module, a transformer-based approach to find long-range dependencies between pixels in the first image, and perform global aggregation on the corresponding motion features. We demonstrate that the optical flow estimates in the occluded regions can be significantly improved without damaging the performance in non-occluded regions. This approach obtains new state-of- the-art results on the challenging Sintel dataset, improving the average end-point error by 13.6% on Sintel Final and 13.7% on Sintel Clean. At the time of submission, our method ranks first on these benchmarks among all published and unpublished approaches. Code is available at https://github.com/zacjiang/GMA.
Models | Training datasets | Flying Chairs | Sintel(training) | KITTI2015(training) | Log | Config | Download | ||
clean | final | Fl-all | EPE | ||||||
---|---|---|---|---|---|---|---|---|---|
GMA | Flying Chairs | 0.72 | 2.40 | 4.53 | - | - | log | Config | Model |
GMA | FlyingChairs + FlyingThing3d | - | 1.31 | 2.61 | 16.54% | 5.00 | log | Config | Model |
GMA | FlyingChairs + FlyingThing3d + Sintel | - | 0.56 | 0.84 | - | - | log | Config | Model |
GMA | Mixed Dataset[1] | - | 0.56 | 0.85 | 5.27% | 1.50 | log | Config | Model |
GMA | KITTI2015 | - | - | - | 1.34% | 0.58 | log | Config | Model |
GMA(p only) | Flying Chairs | 0.76 | 2.38 | 4.69 | - | - | log | Config | Model |
GMA(p only) | FlyingChairs + FlyingThing3d | - | 1.48 | 2.73 | 16.46% | 4.81 | log | Config | Model |
GMA(p only) | Mixed Dataset[1] | - | 0.58 | 0.89 | 5.28% | 1.47 | log | Config | Model |
GMA(p only) | KITTI2015 | - | - | - | 1.39% | 0.58 | log | Config | Model |
GMA(+p) | Flying Chairs | 0.73 | 2.52 | 4.65 | - | - | log | Config | Model |
GMA(+p) | FlyingChairs + FlyingThing3d | - | 1.38 | 2.79 | 19.17% | 6.73 | log | Config | Model |
GMA(+p) | Mixed Dataset[1] | - | 0.63 | 0.94 | 9.07% | 3.82 | log | Config | Model |
GMA(+p) | KITTI2015 | - | - | - | 1.50% | 0.62 | log | Config | Model |
@article{jiang2021learning, title={Learning to Estimate Hidden Motions with Global Motion Aggregation}, author={Jiang, Shihao and Campbell, Dylan and Lu, Yao and Li, Hongdong and Hartley, Richard}, journal={arXiv preprint arXiv:2104.02409}, year={2021} }
[1] The mixed dataset consisted of FlyingChairs, FlyingThing3d, Sintel, KITTI2015, and HD1K.