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


C# Quaternion.Conjugate方法代码示例

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


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

示例1: Calibrate

 public virtual void Calibrate()
 {
     var conjugate = new Quaternion(RawRotation.X, RawRotation.Y, RawRotation.Z, RawRotation.W) * RotationOffset;
     conjugate.Conjugate();
     BaseRotation = conjugate;
     BasePosition = -(RawPosition * PositionScaleFactor) + _positionOffset;
 }
开发者ID:Riuy,项目名称:OculusRacingCar,代码行数:7,代码来源:TrackerBase.cs

示例2: update_needle_holder_position

        private void update_needle_holder_position(Vector3D forearm_orientation)
        {
            Vector3D axis = new Vector3D();
            axis = Vector3D.CrossProduct(circle_normal, forearm_orientation);
            axis = axis / axis.Length;
            double angle;
            angle = Math.Acos(Vector3D.DotProduct(circle_normal,forearm_orientation)/(circle_normal.Length*forearm_orientation.Length));
            //needle_holder_position = 2 * circle_center - needle_tip_position;
            Vector3D temp = new Vector3D();
            temp = 2 * (circle_center - needle_tip_position);
            Quaternion q_needle_holder_position = new Quaternion(temp.X, temp.Y, temp.Z, 0);

            Quaternion q_axis = new Quaternion(Math.Sin(angle / 2) * axis.X, Math.Sin(angle / 2) * axis.Y, Math.Sin(angle / 2) * axis.Z, Math.Cos(angle / 2));
            Quaternion q_axis_conjugate = new Quaternion();
            q_axis_conjugate = q_axis;
            q_axis_conjugate.Conjugate();
            q_needle_holder_position = q_axis * q_needle_holder_position * q_axis_conjugate;
            needle_holder_position.X = q_needle_holder_position.X + needle_tip_position.X;
            needle_holder_position.Y = q_needle_holder_position.Y + needle_tip_position.Y;
            needle_holder_position.Z = q_needle_holder_position.Z + needle_tip_position.Z;
        }
开发者ID:surgical-robots,项目名称:robot-control-app,代码行数:21,代码来源:trajectory_version3+-+Copy.cs

示例3: Vector3D

        /*private void update_needle_holder_twist()
        {
            Vector3D temp = new Vector3D();
            temp = needle_holder_position - circle_center;
            needle_holder_twist = Math.Acos(Vector3D.DotProduct(temp, e_x) / (temp.Length * e_x.Length));
        }*/
        private void update_needle_holder_position()
        {
            Vector3D temp = new Vector3D();
            temp = needle_holder_position - circle_center;
            Quaternion q_needle_holder_position = new Quaternion(temp.X, temp.Y, temp.Z, 0);
            //print_quaternion(q_needle_holder_position);

            Quaternion q_circle_normal = new Quaternion(Math.Sin(-t_incr / 2) * circle_normal.X, Math.Sin(-t_incr / 2) * circle_normal.Y, Math.Sin(-t_incr / 2) * circle_normal.Z, Math.Cos(-t_incr / 2));
            Quaternion q_circle_normal_conjugate = new Quaternion();
            q_circle_normal_conjugate = q_circle_normal;
            q_circle_normal_conjugate.Conjugate();
            q_needle_holder_position = q_circle_normal * q_needle_holder_position * q_circle_normal_conjugate;
            needle_holder_position.X = q_needle_holder_position.X + circle_center.X;
            needle_holder_position.Y = q_needle_holder_position.Y + circle_center.Y;
            needle_holder_position.Z = q_needle_holder_position.Z + circle_center.Z;
            //print_quaternion(q_circle_normal);
            //print_quaternion(q_needle_holder_position);
        }
开发者ID:surgical-robots,项目名称:robot-control-app,代码行数:24,代码来源:trajectory_version2.cs

示例4: update_needle_tip_position

 public Vector3D update_needle_tip_position()
 {
     Vector3D circle_normal = new Vector3D();
     circle_normal = local_coordinate.e_z;
     Vector3D circle_center = new Vector3D();
     circle_center = local_coordinate.origin;
     Vector3D temp = new Vector3D();
     temp = needle_tip_position - circle_center;
     Quaternion q_needle_tip_position = new Quaternion(temp.X, temp.Y, temp.Z, 0);
     Quaternion q_circle_normal = new Quaternion(Math.Sin(-incr / 2) * circle_normal.X, Math.Sin(-incr / 2) * circle_normal.Y, Math.Sin(-incr / 2) * circle_normal.Z, Math.Cos(-incr / 2));
     Quaternion q_circle_normal_conjugate = new Quaternion();
     q_circle_normal_conjugate = q_circle_normal;
     q_circle_normal_conjugate.Conjugate();
     q_needle_tip_position = q_circle_normal * q_needle_tip_position * q_circle_normal_conjugate;
     needle_tip_position.X = q_needle_tip_position.X + circle_center.X;
     needle_tip_position.Y = q_needle_tip_position.Y + circle_center.Y;
     needle_tip_position.Z = q_needle_tip_position.Z + circle_center.Z;
     /*
     needle_tip_position = rotateAboutAxis(normal, needle_tip_position - center, incr);
     needle_tip_position = needle_tip_position + center;
     */
     return needle_tip_position;
 }
开发者ID:surgical-robots,项目名称:robot-control-app,代码行数:23,代码来源:Trajectory0.cs


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