平移矩阵、点绕轴的旋转矩阵、平面直角坐标系旋转矩阵、点绕向量旋转公式(罗德里格斯旋转公式)

news2025/1/7 22:55:11

平移矩阵

点绕轴的旋转矩阵

平面直角坐标系旋转矩阵

点绕向量旋转公式(罗德里格斯旋转公式)

代码

#include "myPoint.h"
#include <cmath>
myPoint::myPoint()
{
	m_x = m_y = m_z = 0;
}

myPoint::myPoint(double x, double y, double z):m_x(x),m_y(y),m_z(z)
{
}

myPoint::myPoint(const myPoint& ref) : m_x(ref.X()), m_y(ref.Y()), m_z(ref.Z())
{
}

myPoint myPoint::operator=(const myPoint& rhs)
{
	SetX(rhs.X());
	SetY(rhs.Y());
	SetZ(rhs.Z());
	return *this;
}

void myPoint::SetX(double x)
{
	m_x = x;
}

void myPoint::SetY(double y)
{
	m_y = y;
}

void myPoint::SetZ(double z)
{
	m_z = z;
}

double myPoint::X()const
{
	return m_x;
}

double myPoint::Y()const
{
	return m_y;
}

double myPoint::Z()const
{
	return m_z;
}

myPoint myPoint::add(myPoint& rhs)const
{
	myPoint ret(0.0, 0.0, 0.0);
	ret.SetX(m_x + rhs.X());
	ret.SetY(m_y + rhs.Y());
	ret.SetZ(m_z + rhs.Z());
	return ret;
}

myPoint myPoint::Sub(myPoint& rhs)const
{
	myPoint ret(0.0, 0.0, 0.0);
	ret.SetX(m_x - rhs.X());
	ret.SetY(m_y - rhs.Y());
	ret.SetZ(m_z - rhs.Z());
	return ret;
}

myPoint myPoint::cross(myPoint& rhs)const
{
	myPoint ret(0.0, 0.0, 0.0);
	ret.SetX(m_y * rhs.Z() - m_z * rhs.Y());
	ret.SetY(m_z * rhs.X() - m_x * rhs.Z());
	ret.SetZ(m_x * rhs.Y() - m_y * rhs.X());
	return ret;
}

myPoint myPoint::Normalize() const
{
	myPoint ret(0.0, 0.0, 0.0);
	ret.SetX(m_x / Length());
	ret.SetY(m_y / Length());
	ret.SetZ(m_z / Length());
	return ret;
}

double myPoint::Length() const
{
	return sqrt(m_x * m_x + m_y * m_y + m_z * m_z);
}

myPoint myPoint::Scale(const double& rhs) const
{
	myPoint ret(0.0, 0.0, 0.0);
	ret.SetX(m_x * rhs);
	ret.SetY(m_y * rhs);
	ret.SetZ(m_z * rhs);
	return ret;
}

double myPoint::Dot(const myPoint& rhs) const
{
	return m_x * rhs.X() + m_y * rhs.Y() + m_z * rhs.Z();
}

myPoint myPoint::Reversal() const
{
	return myPoint(-X(), -Y(), -Z());
}


#include "myMatrix4x4.h"
#include <cmath>
myMatrix4x4::myMatrix4x4()
{
	Identity();
}

void myMatrix4x4::Zero()
{
	for (int i = 0; i < 4; ++i)
	{
		for (int j = 0; j < 4; ++j)
		{
			m_Element[i][j] = 0;
		}
	}
}

void myMatrix4x4::Identity()
{
	for (int i = 0; i < 4; ++i)
	{
		for (int j = 0; j < 4; ++j)
		{
			if (i == j)
			{
				m_Element[i][j] = 1.0;
			}
			else
			{
				m_Element[i][j] = 0.0;
			}
		}
	}
}

void myMatrix4x4::SetElement(int i, int j, double value)
{
	m_Element[i][j] = value;
}

void myMatrix4x4::Move(const myPoint& vec)
{
	Identity();
	SetElement(0, 3, vec.X());
	SetElement(1, 3, vec.Y());
	SetElement(2, 3, vec.Z());
}
//绕vec向量旋转radian度的矩阵
void myMatrix4x4::Rotate(const myPoint& vec, const double& radian)
{
	Identity();
	float dx = vec.X() / vec.Length();
	float dY = vec.Y() / vec.Length();
	float dZ = vec.Z() / vec.Length();

	SetElement(0, 0, cos(radian) + (dx * dx) * (1 - cos(radian)));
	SetElement(1, 0, dx * dY * (1 - cos(radian)) - dZ * sin(radian));
	SetElement(2, 0, dx * dZ * (1 - cos(radian)) + dY * sin(radian));
	SetElement(0, 1, dx * dY * (1 - cos(radian)) + dZ * sin(radian));
	SetElement(1, 1, cos(radian) + dY * dY * (1 - cos(radian)));
	SetElement(2, 1, dY * dZ * (1 - cos(radian)) - dx * sin(radian));
	SetElement(0, 2, dx * dZ * (1 - cos(radian)) - dY * sin(radian));
	SetElement(1, 2, dZ * dY * (1 - cos(radian)) + dx * sin(radian));
	SetElement(2, 2, cos(radian) + dZ * dZ * (1 - cos(radian)));
}
//点按this矩阵运算返回运算结果
myPoint myMatrix4x4::MultiplyPoint(const myPoint& pt)const
{
	myPoint retPt;
	double v0 = pt.X();
	double v1 = pt.Y();
	double v2 = pt.Z();
	double v3 = 1;
	double ret[4];
	for (int i=0;i<4;i++)
	{
		ret[i] = m_Element[i][0] * v0 + m_Element[i][1] * v1 + m_Element[i][2] * v2 + m_Element[i][3] * v3;
	}
	retPt.SetX(ret[0]);
	retPt.SetY(ret[1]);
	retPt.SetZ(ret[2]);
	return retPt;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2050176.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

探索tailwindcss多主题切换

现在的多主题切换基本上都是用的 css 变量的形式, 而tailwindcss也支持 css 变量定义主题的方式 至于为什么用 tailwindcss变量, 还是因为 tailwind 写类名提示比较方便, 也不需要再在css或者style中去一个个var的形式去写变量了 这里我在assets/style/theme文件夹中创建了三个…

智能与生产力、生产关系的关系

机器学习和自主系统是推动新质生产力和新质生产关系形成的关键技术。它们与这两个概念之间的关系可以从以下几个方面进行分析&#xff1a; 一、机器学习与新质生产力 提升效率和精准度&#xff1a;机器学习通过对大量数据进行分析&#xff0c;能够提供精准的预测和决策支持。这…

MyBatis(初阶)

1.什么是MyBtis MyBatis是持久层框架&#xff0c;⽤于简化JDBC的开发。 2.准备工作 2.1 创建⼯程 数据库: 2.2 配置数据库连接字符串 以application.yml⽂件为例: 2.3 写持久层代码 Data public class UserInfo {private Integer id;private String username;private Stri…

YOLOv10训练,适合小白训练,新手YOLOv10训练自己数据集教程!超简单,超详细!!

YOLOv10训练&#xff0c;适合小白训练&#xff0c;新手YOLOv10训练自己数据集教程&#xff01;超简单&#xff0c;超详细&#xff01;&#xff01; AI学术叫叫兽在这&#xff01;家人们&#xff0c;给我遥遥领先&#xff01;&#xff01;&#xff01; 方法一&#xff1a;云服务…

如何打造一款爆款手游?

现在开发一款游戏太简单了&#xff0c;各种源码满地飞&#xff0c;大家拿过来随便改改有个版号就可以上线运营了&#xff0c; 但是这种的游戏品质一般都不会怎么样&#xff0c;留存的周期也是比较短的&#xff0c;更别说让玩家持续消费了&#xff0c;想要打造一款火热的游戏我们…

Android Media Framework(十八)ACodec - Ⅵ

ACodec之所以复杂&#xff0c;主要是因为状态太多。在上一篇文章中&#xff0c;我们学习了在ExecutingState下对buffer的处理。ExecutingState可能会切换到OutputPortSettingsChangedState、FlushingState&#xff0c;或者当组件被释放时&#xff0c;进入UninitializedState。接…

泛微云桥前台文件上传漏洞-202408

漏洞简介 2024 年 8 月份新出漏洞&#xff0c;泛微云桥任意文件上传漏洞&#xff0c;详情如图所示。 环境搭建 1、下载漏洞环境。 https://wx.weaver.com.cn/download 2、运行install64.bat&#xff0c;安装环境。 3、安装成功界面。 未安装补丁&#xff0c;系统不能使用…

Java方法01:什么是方法

本节视频链接&#xff1a;Java方法01&#xff1a;什么是方法&#xff1f;_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV12J41137hu?p45&vd_sourceb5775c3a4ea16a5306db9c7c1c1486b5 Java中的‌方法‌是一段执行特定任务的代码片段&#xff0c;‌它是程序的基本构…

Keepalived:不只是心跳检测,更是高可用性的秘密武器

keepalived博客(Keepalived&#xff1a;不只是心跳检测&#xff0c;更是高可用性的秘密武器) 文章目录 keepalived博客(**Keepalived&#xff1a;不只是心跳检测&#xff0c;更是高可用性的秘密武器**)keepalived介绍概述工作原理核心模块应用场景配置与安装总结 keepalived基本…

工 厂设计模式

简单工厂模式 基本介绍 1) 简单工厂模式是属于创建型模式,是工厂模式的一种。 简单工厂模式是由一个工厂对象决定创建出哪一 种产品类 的实例。简单工厂模式是工厂模式家族中最简单实用的模式 2) 简单工厂模式:定义了一个创建对象的类,由这个类来 封装实例化对象的行为 (代…

从零开始学cv-6:图像的灰度变换

文章目录 一&#xff0c;简介&#xff1a;二、图像的线性变换三、分段线性变换四&#xff0c;非线性变换4.1 对数变换4.2 Gamma变换 五&#xff0c;效果: 一&#xff0c;简介&#xff1a; 图像灰度变换涉及对图像中每个像素的灰度值执行数学运算&#xff0c;进而调整图像的视觉…

Python基础和变量使用

1. 基础了解 1.1 运行方式 Python有多种运行方式&#xff0c;以下是几种常见的执行Python代码的方法&#xff1a; 交互式解释器&#xff1a; 打开终端或命令提示符&#xff0c;输入python或python3&#xff08;取决于你的系统配置&#xff09;&#xff0c;即可进入Python交互…

HelpLook AI 知识库:为企业提供高效智能的知识管理解决方案

“管理就是把复杂的问题简单化&#xff0c;混乱的事情规范化。” 在当今竞争激烈的商业环境中&#xff0c;企业面临着快速变化的市场需求和日益复杂的业务流程。为了保持竞争力并提升运营效率&#xff0c;选择一款合适的知识管理系统至关重要。在众多选项中&#xff0c;HelpLoo…

day05--Vue

一、Vue入门 1.1入门案例 1.在页面中引入vue.js框架 2.定义vue对象 let app new Vue({ el:"#vue作用域的div标签id", data:{ //所有数据模型 }&#xff0c; methods:{ //页面中所有触发的js方法 }&#xff0c; created(){ //页面初始化&#xff0c;准备调用方法 } …

MODELSIM仿真报错解决记录

目录 问题&#xff1a;Modelsim报错&#xff1a;Error (10228): Verilog HDL error at Line_Shift_RAM_1Bit.v(39): module “Line_Shift_RAM_1 原因&#xff1a;创建的IP核放到了别的位置 解决方法&#xff1a;删掉IP核以及QIP等文件&#xff0c;将IP核创建到工程目录下 问…

vue3旋转木马型轮播图,环型滚动

<template><div><div class"content"><div class"but1" click"rotateLeft">--向左</div><div class"ccc"><main id"main"><div class"haha" ref"haha"&g…

垂直电商的兴衰与开源AI智能名片S2B2C商城系统的崛起:一场商业模式的革新

摘要&#xff1a;随着互联网技术的飞速发展&#xff0c;电子商务行业经历了从萌芽到繁荣再到精细化分化的历程。垂直电商作为电商领域的一个重要分支&#xff0c;曾因其聚焦细分市场、满足特定用户需求、产品标准化及快速整合供应链等优势&#xff0c;吸引了大量资本的关注。然…

Ubuntu上安装Redis的详细教程

1、安装redis 首先&#xff0c;访问Redis官网&#xff0c;点击首页的【Get Started】&#xff0c;然后点击Install Redis on Linux 安装 终端依次输入以下命令&#xff0c;如果过程中没有错误提示&#xff0c;则redis安装完成。 sudo apt install lsb-release curl gpg cu…

【前端】NodeJS:会话控制

文章目录 1 介绍2 cookie2.1 cookie是什么2.2 cookie的特点2.3 cookie的运行流程2.4 浏览器操作cookie2.5 cookie的代码操作 3 session3.1 session是什么3.2 session的作用3.3 session运行流程3.4 session的代码操作 4 session和cookie的区别5 token5.1 token是什么5.2 token的…

网络安全之xss靶场练习

目录 一、xss靶场练习 1、Ma Spaghet! 2、Jefff 第一个方法 第二个方法 3、Ugandan Knuckles 4、Ricardo Milos 5、Ah Thats Hawt 6、Ligma 7、Mafia​编辑 8、Ok, Boomer 一、xss靶场练习 靶场地址 https://xss.pwnfunction.com/ 页面显示如下 1、Ma Spaghet! 分析…