本文整理汇总了C++中Vector2D::innerProduct方法的典型用法代码示例。如果您正苦于以下问题:C++ Vector2D::innerProduct方法的具体用法?C++ Vector2D::innerProduct怎么用?C++ Vector2D::innerProduct使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Vector2D
的用法示例。
在下文中一共展示了Vector2D::innerProduct方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: origin
/*!
*/
double
Segment2D::dist( const Vector2D & p ) const
{
double len = this->length();
if ( len == 0.0 )
{
return origin().dist( p );
}
const Vector2D vec = terminal() - origin();
const double prod = vec.innerProduct( p - origin() );
//
// A: p1 - p0
// A: p - p0
//
// check if 0 <= |B|cos(theta) <= |A|
// -> 0 <= |A||b|cos(theta) <= |A|^2
// -> 0 <= A.B <= |A|^2 // A.B = |A||B|cos(theta)
//
if ( 0.0 <= prod && prod <= len * len )
{
// return perpendicular distance
//return std::fabs( Triangle2D( *this, p ).doubleSignedArea() / len );
return std::fabs( Triangle2D::double_signed_area( origin(), terminal(), p ) / len );
}
return std::sqrt( std::min( origin().dist2( p ),
terminal().dist2( p ) ) );
}