网站大量收购独家精品文档,联系QQ:2885784924

线性代数妙用:怎样在Windows画图软件中实现28度旋转?.doc

线性代数妙用:怎样在Windows画图软件中实现28度旋转?.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
线性代数的妙用:怎样在Windows画图软件中实现28度旋转? 线性代数的妙用:怎样在Windows画图软件中实现28度旋转? PAGE / NUMPAGES 线性代数的妙用:怎样在Windows画图软件中实现28度旋转? 线性代数的妙用:怎样在 Windows 画图软件中实现 28 度旋转? 在早期的小型图像编辑软件中,考虑到时间空间的限制,再加 上算法本身的难度,很多看似非常简单的功能都无法实现。比如说, 很多图像编辑软件只允许用户把所选的内容旋转 90 度、 180 度或 者 270 度,不支持任意度数的旋转。毕竟,如果我们只是旋转 90 度的整数倍,那么所有像素仅仅是在做某些有规律的轮换,这甚至 不需要额外的内存空间就能完成。但是,如果旋转别的度数,那么 在采样和反锯齿等方面都将会有不小的挑战。 不过, Windows 自带的画图软件聪明地用 skew 功能(中文版 翻译成 “扭曲 ”)部分地填补了无法自由变形的缺陷。随便选中图中 的一块区域,再在菜单栏上选择 “图像 ”→“拉伸 /扭曲 ”,然后在 “水平 扭曲 ”那儿填写一个 -89 到 89 之间的整数(表示一个角度值),再 按一下确定,于是整个图形就会像下图所示的那样被拉斜,其中 θ 就是你刚才填的度数。如果你填入的 θ是负数值,则倾斜的方向会 与下图方向相反。类似地, “垂直扭曲 ”功能会在竖直方向上对图形 进行拉扯,如果角度值为正数,则整个图形会变得左低右高,如果 角度值为负数,则整个图形会变得左高右低。 不过,这玩意儿对于我们来说似乎完全没用。估计 99% 的人在 使用画图软件的时候就从来没用过这个功能吧。如果真是这样,那 么今天的问题恐怕将会是大家最近一段时间见过的最有趣的问题了: 想办法利用 Windows 画图中的扭曲功能(近似地)实现 28 度旋转。 答案:如下图,首先水平扭曲 -14 度,然后垂直扭曲 25 度,最后 再水平扭曲 -14 度即可。这样的话,画板中被选中的内容将会被逆 时针旋转 28 度。 为什么?这是因为,扭曲的本质其实就是在原图上进行一个线 性变换。水平扭曲实际上相当于是对图像各行进行平移,平移量与 纵坐标的位置成正比。而这又可以看作是对每个点执行了下图所示 的矩阵乘法操作: 类似地,垂直扭曲则相当于对每个点执行了这么一个矩阵乘法 的操作: 另外,由于 因此 而最后一行就是大家非常熟悉的旋转矩阵! 也就是说,连续执行上式中的三次扭曲,就可以实现旋转 θ度 了。其中,第一次扭曲和第三次扭曲都是水平扭曲 -θ/2度,当 θ = 28°时,我们应该填写的度数就是 -14 。麻烦的就是第二次扭曲: 它看上去并不符合垂直扭曲矩阵的标准形式。垂直扭曲矩阵中,左 下角那一项应该是 tan( θ,)而并非 sin( θ。)不过,我们完全可以用 正切值去模拟 sin( θ呀)!利用计算机可以解得,当 θ = 28 °时, sin(28 °)约为 0.469 ,离它最近的正切值是 tan(25 °) ≈ 0.466。因此, 我们在第二步的时候填入了垂直扭曲 25 度。 值得一提的是,实际上我们已经得到了一种非常高效并且非常 容易编写的图像旋转算法:只需要连续调用三次扭曲操作即可。而 每次扭曲操作本质上都是对各行或者各列的像素进行平移,因而整 个算法完全不需要任何额外的内存空间!根据 Wikipedia 的描述, 这种方法是由 Alan Paeth 在 1986 年提出的。 由于 tan(25 °)并不精确地等于 sin(28 °),因而这里实现的 28 度旋转也并不是绝对精确的。不过,画图软件本身还提供了水平缩 放和垂直缩放的功能,把它们也加进来的话,线性变换的复合将会 变得更加灵活,或许我们就能设计出一些更复杂但却更精确的旋转 方案了。这些问题就留给感兴趣的读者继续探究吧。

文档评论(0)

zdq7355 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档