opencv estimateRigidTransform:如何获得全球规模?

opencv estimateRigidTransform: How to get global scale?(opencv estimateRigidTransform:如何获得全球规模?)

本文介绍了opencv estimateRigidTransform:如何获得全球规模?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

I'm using openCV's estimateRigidTransform to stabilize a series of video frames, which works very well.

The function returns a 2x3 transformation matrix M:

|  a_11 a_12 b_1 |
| -a_12 a_11 b_2 |

As far as I understand the b elements represent the translation, and the a elements are used to do the scaling and rotation.

What I would like to do, is get global scale from M - a value that represents the camera zooming factor. How can I do calculate this correctly from a values?


To clarify a little more what I want to get, here is an example. Let's say estimateRigidTransform calculates a transformation matrix M for the second frame below regarding to the first frame:

The global zooming factor in this case should be aroud 2. My question is how to get this value from M?

解决方案

Ok, after additional search I found a great answer here: https://math.stackexchange.com/questions/13150/extracting-rotation-scale-values-from-2d-transformation-matrix

Where the "zooming" is represented by s_x and s_y. These two values will mostly be equal (since zoom in video captured by cameras is equal in both directions), so I can take either one.

这篇关于opencv estimateRigidTransform:如何获得全球规模?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:opencv estimateRigidTransform:如何获得全球规模?

基础教程推荐