首页 > 解决方案 > 带有acos的两个向量之间的C ++角度

问题描述

我试图让这段代码工作,它给出了角度,但不是正确的,它们加起来不等于 180°,我找不到问题。我已经实现了一个类似于二维向量的 Vector2 结构,并且我一直在尝试为其定义 ^ 运算符作为给出两个向量之间角度的函数。

我在这里先向您的帮助表示感谢!

#include <iostream>
#include <cstdlib>
#include <cmath>

using namespace std;

struct Vector2 {
    double x, y;
};

ostream& operator<<(ostream& out, const Vector2& w){
    cout  << '[' << w.x << " , " << w.y << ']';
    return out;
}

double operator*(const Vector2& a, const Vector2& b){
    double w = a.x*b.x + a.y*b.y;
    return w;
}

double absc(const Vector2& d) {
    return sqrt(d*d);  
}

constexpr Vector2 operator+(const Vector2& a, const Vector2& b){
    Vector2 y{a.x+b.x, a.y+a.y};
    return y;
}

constexpr Vector2 operator-(const Vector2& a,const Vector2& b){
    Vector2 z{a.x-b.x, a.y-b.y};
    return z;
}

double operator^(const Vector2& a,const Vector2& b){
    double n = (absc(a))*(absc(b));
    double c = acos((a*b)/n);
    return c;
}

int main(){
    Vector2 a = {1.0, 1.0};
    Vector2 b = {4.0, 7.0};
    Vector2 c = {-2.0, 5.0};
    double d =c^b;
    double e = a^c;
    double f = a^b;
    auto grad = [](double rad) { return rad * (45./atan(1.0)); };

    cout<<"Angle Alpha: "<<grad(c^b)<<"rad "<<d<<"\n";
    cout<<"Angle Beta: "<<grad(a^c)<<"rad "<<e<<"\n";
    cout<<"Angle Gamma: "<<grad(a^b)<<"rad "<<f<<"\n";

    return EXIT_SUCCESS;
}

标签: c++vectoranglecmath

解决方案


你不是在比较直角,而是试试这个(从你拥有的点创建向量):

double d = (a-c)^(a-b);
double e = (b-a)^(b-c);
double f = (c-b)^(c-a);
auto grad = [](double rad) { return rad * (45./atan(1.0)); };

cout<<"Angle Alpha: "<<grad((a-c)^(a-b))<<"rad "<<d;
cout<<"\nAngle Beta: "<<grad((b-a)^(b-c))<<"rad "<<e;
cout<<"\nAngle Gamma: "<<grad((c-a)^(c-b))<<"rad "<<f;

现在你有 180° 或 pi。


推荐阅读