官术网_书友最值得收藏!

The angle between vectors

If two vectors are of unit length, the angle between them is the cosine of their dot product:

If the two vectors are not normalized, the dot product needs to be divided by the product of the length of both vectors:

To find the actual angle, not just the cosine of it, we need to take the inverse of the cosine on both sides, which is the arccosine function:

Implement the angle function in vec3.cpp. Don't forget to add the function declaration to vec3.h:

float angle(const vec3 &l, const vec3 &r) {

    float sqMagL = l.x * l.x + l.y * l.y + l.z * l.z;

    float sqMagR = r.x * r.x + r.y * r.y + r.z * r.z;

    if (sqMagL<VEC3_EPSILON || sqMagR<VEC3_EPSILON) {

        return 0.0f;

    }

    float dot = l.x * r.x + l.y * r.y + l.z * r.z;

    float len = sqrtf(sqMagL) * sqrtf(sqMagR);

    return acosf(dot / len);

}

Important note:

The acosf function returns angles in radians. To convert radians to degrees, multiply by 57.2958f. To convert degrees to radians, multiply by 0.0174533f.

主站蜘蛛池模板: 朝阳县| 张家港市| 宁武县| 新蔡县| 龙川县| 隆尧县| 门源| 和林格尔县| 祁连县| 巧家县| 康平县| 仁布县| 满洲里市| 柳江县| 巴马| 通榆县| 岑溪市| 武邑县| 定南县| 靖边县| 富民县| 通化县| 礼泉县| 彭水| 阿鲁科尔沁旗| 滨州市| 湖南省| 茶陵县| 依安县| 阿荣旗| 永宁县| 维西| 合阳县| 莱州市| 汤阴县| 墨竹工卡县| 曲松县| 龙陵县| 丰顺县| 南陵县| 广西|