当前位置: 首页>>代码示例>>C++>>正文


C++ mat3::At方法代码示例

本文整理汇总了C++中mat3::At方法的典型用法代码示例。如果您正苦于以下问题:C++ mat3::At方法的具体用法?C++ mat3::At怎么用?C++ mat3::At使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在mat3的用法示例。


在下文中一共展示了mat3::At方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: SymmetricEigenSystem

	bool SymmetricEigenSystem(const mat3& m, vec3& value, mat3& r)
	{
		const int max_sweep = 32;
		const float epsilon = 1.0e-10f;
		float m11 = m.At(0,0);
		float m12 = m.At(0,1);
		float m13 = m.At(0,2);
		float m22 = m.At(1,1);
		float m23 = m.At(1,2);
		float m33 = m.At(2,2);

		r.Identity();

		for (int a = 0; a < max_sweep; ++a)
		{
			if ((Abs(m12) < epsilon) && (Abs(m13) < epsilon) && (Abs(m23) < epsilon))
				break;

			//	annihilate 1 2
			if (m12 != 0.0f)
			{
				float u = (m22 - m11) * 0.5f / m12;
				float u2 = u*u;
				float u2p1 = u2 + 1.0f;
				float t = (u2p1 != u2) ? ((u < 0.0f) ? -1.0f : 1.0f) * (sqrt(u2p1) - fabs(u)) : 0.5f / u;
				float c = 1.0f / sqrt(t*t + 1.0f);
				float s = c * t;

				m11 -= t * m12;
				m22 += t * m12;
				m12 = 0.0f;

				float temp = c*m13 - s * m23;
				m23 = s * m13 + c * m23;
				m13 = temp;

				for (int i = 0; i < 3; ++i)
				{
					float temp = c * r.At(i, 0) - s * r.At(i,1);
					r.At(i,1) = s * r.At(i,0) + c * r.At(i,1);
					r.At(i,0) = temp;
				}
			}

			//	annihilate 1 3
			if (m13 != 0.0f)
			{
				float u = (m33 - m11) * 0.5f / m13;
				float u2 = u*u;
				float u2p1 = u2 + 1.0f;
				float t = (u2p1 != u2) ? ((u < 0.0f) ? -1.0f : 1.0f) * (sqrt(u2p1) - fabs(u)) : 0.5f / u;
				float c = 1.0f / sqrt(t*t + 1.0f);
				float s = c * t;

				m11 -= t * m13;
				m33 += t * m13;
				m13 = 0.0f;

				float temp = c * m12 - s * m23;
				m23 = s * m12 + c * m23;
				m12 = temp;

				for (int i = 0; i < 3; ++i)
				{
					float temp = c * r.At(i, 0) - s * r.At(i, 2);
					r.At(i, 2) = s * r.At(i, 0) + c * r.At(i, 2);
					r.At(i, 0) = temp;
				}
			}

			//	annihilate 2 3
			if (m23 != 0.0f)
			{
				float u = (m33 - m22) * 0.5f / m23;
				float u2 = u*u;
				float u2p1 = u2 + 1.0f;
				float t = (u2p1 != u2) ? ((u < 0.0f) ? -1.0f : 1.0f) * (sqrt(u2p1) - fabs(u)) : 0.5f / u;
				float c = 1.0f / sqrt(t*t + 1.0f);
				float s = c * t;

				m22 -= t * m23;
				m33 += t * m23;
				m23 = 0.0f;

				float temp = c * m12 - s * m13;
				m13 = s * m12 + c * m13;
				m12 = temp;

				for (int i = 0; i < 3; ++i)
				{
					float temp = c * r.At(i, 1) - s * r.At(i, 2);
					r.At(i, 2) = s * r.At(i, 1) + c * r.At(i, 2);
					r.At(i, 1) = temp;
				}
			}
		}

		value.Set(m11, m22, m33);
		return true;
	}
开发者ID:Mikalai,项目名称:punk_project,代码行数:100,代码来源:helper.cpp


注:本文中的mat3::At方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。