C3D Kernel  104598
Открытые члены | Защищенные члены
Класс MbCosinusoid

Косинусоида в двумерном пространстве. Подробнее...

Граф наследования:MbCosinusoid:
Inheritance graph
[см. легенду]
Граф связей класса MbCosinusoid:
Collaboration graph
[см. легенду]

Полный список членов класса

Открытые члены

 MbCosinusoid (const double &am, const double &phase, const double &anf)
 MbCosinusoid (const double &am, const double &phase=0.0, bool maxBegin=true)
 MbCosinusoid (const MbPlacement &pos, const double &am=0.0, const double &phase=0.0, const double &anf=0.0)
 MbCosinusoid (const MbPlacement &pos, double am, double ph, double af, double t1, double t2)
 VISITING_CLASS (MbCosinusoid)
virtual MbePlaneType IsA () const
 Получить тип объекта.
virtual bool SetEqual (const MbPlaneItem &)
 Сделать объекты равным.
virtual bool IsBounded () const
 Определить, является ли кривая ограниченной.
virtual void Transform (const MbMatrix &matr, MbRegTransform *ireg=NULL, const MbSurface *newSurface=NULL)
 Преобразовать согласно матрице.
virtual void Move (const MbVector &to, MbRegTransform *=NULL, const MbSurface *newSurface=NULL)
 Сдвинуть вдоль вектора.
virtual void Rotate (const MbCartPoint &pnt, const MbDirection &angle, MbRegTransform *=NULL, const MbSurface *newSurface=NULL)
 Повернуть вокруг точки.
virtual bool IsSame (const MbPlaneItem &other, double accuracy=LENGTH_EPSILON) const
 Определить, являются ли объекты равными.
virtual MbPlaneItemDuplicate (MbRegDuplicate *=NULL) const
 Создать копию.
virtual void Refresh ()
 Перевести все временные (mutable) данные объекта в неопределённое (исходное) состояние.
virtual void PrepareIntegralData (const bool forced) const
 Рассчитать временные (mutable) данные объекта.
virtual void AddYourGabaritTo (MbRect &r) const
 Расширить присланный габаритный прямоугольник так, чтобы он включал в себя данный объект.
virtual void CalculateGabarit (MbRect &r) const
 Определить габаритный прямоугольник кривой.
virtual bool IsVisibleInRect (const MbRect &r, bool exact=false) const
 Определить видимость объекта в прямоугольнике.
virtual double GetTMin () const
 Получить минимальное значение параметра.
virtual double GetTMax () const
 Получить максимальное значение параметра.
virtual bool IsClosed () const
 Определить, является ли кривая замкнутой.
virtual void PointOn (double &t, MbCartPoint &p) const
 Вычислить точку на кривой.
virtual void FirstDer (double &t, MbVector &v) const
 Вычислить первую производную.
virtual void SecondDer (double &t, MbVector &v) const
 Вычислить вторую производную.
virtual void ThirdDer (double &t, MbVector &v) const
 Вычислить третью производную.
virtual void _PointOn (double t, MbCartPoint &p) const
 Вычислить точку на кривой и её продолжении.
virtual void _FirstDer (double t, MbVector &v) const
 Вычислить первую производную на кривой и её продолжении.
virtual void _SecondDer (double t, MbVector &v) const
 Вычислить вторую производную на кривой и её продолжении.
virtual void _ThirdDer (double t, MbVector &v) const
 Вычислить третью производную на кривой и её продолжении.
virtual void Explore (double &t, bool ext, MbCartPoint &pnt, MbVector &fir, MbVector *sec, MbVector *thir) const
 Вычислить значения точки и производных для заданного параметра.
virtual bool HasLength (double &length) const
 Вычислить метрическую длину кривой.
virtual double GetMetricLength () const
 Вычислить метрическую длину кривой.
virtual void Inverse (MbRegTransform *iReg=NULL)
 Изменить направления кривой на противоположное.
virtual MbNurbsNurbsCurve (const MbCurveIntoNurbsInfo &) const
 Построить NURBS копию кривой.
virtual MbeState DeletePart (double t1, double t2, MbCurve *&part2)
 Удалить часть кривой.
virtual MbeState TrimmPart (double t1, double t2, MbCurve *&part2)
 Оставить часть кривой.
virtual MbCurveTrimmed (double t1, double t2, int sense) const
 Построить усеченную кривую.
virtual void IntersectHorizontal (double y, SArray< double > &cross) const
 Найти пересечения кривой с горизонтальной прямой.
virtual void IntersectVertical (double x, SArray< double > &cross) const
 Найти пересечения кривой с вертикальной прямой.
virtual double Step (double t, double sag) const
 Вычислить шаг параметра.
virtual double DeviationStep (double t, double angle) const
 Вычислить шаг параметра.
virtual double PointProjection (const MbCartPoint &pnt) const
 Найти проекцию точки на кривую.
virtual bool NearPointProjection (const MbCartPoint &pnt, double xEpsilon, double yEpsilon, double &t, bool ext, MbRect1D *tRange=NULL) const
 Найти проекцию точки на кривую.
virtual void GetProperties (MbProperties &properties)
 Выдать свойства объекта.
virtual void SetProperties (const MbProperties &properties)
 Записать свойства объекта.
virtual void GetBasisPoints (MbControlData &) const
 Выдать базовые точки кривой.
virtual void SetBasisPoints (const MbControlData &)
 Изменить объект по контрольным точкам.
virtual bool IsSimilarToCurve (const MbCurve &curve, double precision=PARAM_PRECISION) const
 Определить, подобны ли кривые для объединения (слива).
const MbPlacementGetPlacement () const
MbPlacementSetPlacement ()
double GetFrequency () const
double GetPhase () const
double GetAmplitude () const
double GetOwnTMin () const
double GetOwnTMax () const
void SetPlacement (const MbPlacement &pos)
void SetFrequency (double f)
void SetPhase (double p)
void SetAmplitude (double a)
void SetOwnTMin (double t)
void SetOwnTMax (double t)
void CheckParam (double &t) const
bool IsHorizontal (double eps=Math::AngleEps) const
bool IsVertical (double eps=Math::AngleEps) const
void Init (const MbCosinusoid &)
void Init (double t1, double t2)
void Init (const MbPlacement &pos, double am, double ph, double af)
void Init1 (CosinusoidPar &par, MbCartPoint &p1, MbCartPoint &p2, double &len, double &angle)
void Init2 (CosinusoidPar &par, const MbCartPoint &p1, MbCartPoint &p2, const double &len, double &angle)
void Init3 (CosinusoidPar &par, const MbCartPoint &p1, MbCartPoint &p2, double &len, const double &angle, const DiskreteLengthData *=NULL)
void Init4 (CosinusoidPar &par, MbCartPoint &p1, const MbCartPoint &p2, const double &len, double &angle)
void Init5 (CosinusoidPar &par, MbCartPoint &p1, const MbCartPoint &p2, double &len, const double &angle, const DiskreteLengthData *=NULL)
void Init6 (CosinusoidPar &par, const MbCartPoint &p1, MbCartPoint &p2, const double &len, const double &angle)
void Init7 (CosinusoidPar &par, MbCartPoint &p1, const MbCartPoint &p2, const double &len, const double &angle)
void Init8 (CosinusoidPar &par, MbCartPoint &p1, MbCartPoint &p2, double &len, double &angle, const DiskreteLengthData &diskrData, bool correctP1)
void SpecInit (const CosinusoidPar &, const MbCartPoint &p1, double angle, double len)

Защищенные члены

 MbCosinusoid (const MbCosinusoid &)

Подробное описание

Косинусоида расположена вдоль оси X локальной системы координат.
Радиус-вектор кривой в методе PointOn(double&t,MbCartPoint3D&r) описывается векторной функцией
r(t) = position.origin + (position.axisX ((tmin + t) - phase) / frequency) + (amplitude cos(tmin + t) position.axisY).
Косинусоида приведена на рисунке ниже. t = 0 amplitude | /\ /\ |/ \ / \ t = -phase | \ tmin t/ \ tmax ______/|_____\|_____/______\|_____________________________ / | \ / \ / | \ / / | \/ y = amplitude cos(frequency x + phase)


Методы

virtual bool MbCosinusoid::SetEqual ( const MbPlaneItem item) [virtual]

Равными можно сделать только подобные объекты. Подобный объект приравнивается присланному путем изменения численных данных.

Аргументы:
[in]item- Объект для инициализации.
Возвращает:
Сделан ли объект равным присланному.

Замещает MbCurve.

virtual void MbCosinusoid::Transform ( const MbMatrix matr,
MbRegTransform iReg = NULL,
const MbSurface newSurface = NULL 
) [virtual]

Преобразовать исходный объект согласно матрице c использованием регистратора. Если объект содержит ссылки на другие геометрические объекты, то вложенные объекты так же преобразуются согласно матрице. Регистратор служит для предотвращения многократного преобразования объекта. Допустимо использовать функцию без регистратора, если надо преобразовать одиночный объект. Если надо преобразовать набор взаимосвязанных объектов, необходимо использовать регистратор для предотвращения повторного преобразования вложенных объектов, поскольку не исключена ситуация, когда несколько объектов из набора содержат ссылки на один или несколько общих объектов, подлежащих трансформации.

Аргументы:
[in]matr- Матрица преобразования.
[in]iReg- Регистратор.
[in]surface- Новая базовая поверхность объекта при условии, что matr - матрица преобразования из старой поверхности в новую. Для трансформации проекционной кривой. Не учитывается, если поверхность плоская.

Замещает MbCurve.

virtual void MbCosinusoid::Move ( const MbVector to,
MbRegTransform iReg = NULL,
const MbSurface newSurface = NULL 
) [virtual]

Сдвинуть геометрический объект вдоль вектора с использованием регистратора. Если объект содержит ссылки на другие геометрические объекты, то к вложенным объектам так же применяется операция сдвига. Регистратор служит для предотвращения многократного преобразования объекта. Допустимо использовать функцию без регистратора, если надо преобразовать одиночный объект. Если надо преобразовать набор взаимосвязанных объектов, необходимо использовать регистратор для предотвращения повторного преобразования вложенных объектов, поскольку не исключена ситуация, когда несколько объектов из набора содержат ссылки на один или несколько общих объектов, подлежащих сдвигу.

Аргументы:
[in]to- Вектор сдвига.
[in]iReg- Регистратор.
[in]surface- Новая базовая поверхность объекта при условии, что matr - матрица преобразования из старой поверхности в новую. Для трансформации проекционной кривой. Не учитывается, если поверхность плоская.

Замещает MbCurve.

virtual void MbCosinusoid::Rotate ( const MbCartPoint pnt,
const MbDirection angle,
MbRegTransform iReg = NULL,
const MbSurface newSurface = NULL 
) [virtual]

Повернуть объект вокруг точки на заданный угол с использованием регистратора. Если объект содержит ссылки на другие геометрические объекты, то к вложенным объектам так же применяется операция поворота. Регистратор служит для предотвращения многократного преобразования объекта. Допустимо использовать функцию без регистратора, если надо преобразовать одиночный объект. Если надо преобразовать набор взаимосвязанных объектов, необходимо использовать регистратор для предотвращения повторного преобразования вложенных объектов, поскольку не исключена ситуация, когда несколько объектов из набора содержат ссылки на один или несколько общих объектов, подлежащих повороту.

Аргументы:
[in]pnt- Неподвижная точка.
[in]angle- Угол поворота.
[in]iReg- Регистратор.
[in]surface- Новая базовая поверхность объекта при условии, что matr - матрица преобразования из старой поверхности в новую. Для трансформации проекционной кривой. Не учитывается, если поверхность плоская.

Замещает MbCurve.

virtual bool MbCosinusoid::IsSame ( const MbPlaneItem item,
double  accuracy = LENGTH_EPSILON 
) const [virtual]

Равными считаются однотипные объекты, все данные которых одинаковы (равны).

Аргументы:
[in]item- Объект для сравнения.
[in]accuracy- Точность сравнения.
Возвращает:
Равны ли объекты.

Замещает MbCurve.

virtual MbPlaneItem& MbCosinusoid::Duplicate ( MbRegDuplicate iReg = NULL) const [virtual]

Создать копию объекта с использованием регистратора. Регистратор используется для предотвращения многократного копирования объекта. Если объект содержит ссылки на другие объекты, то вложенные объекты так же копируются. Допустимо не передавать регистратор в функцию. Тогда будет создана новая копия объекта. При копировании одиночного объекта или набора не связанных между собой объектов допустимо не использовать регистратор. Регистратор необходимо использовать, если надо последовательно копировать несколько взаимосвязанных объектов. Возможно, что связь объектов обусловлена наличием в них ссылок на общие объекты. Тогда, при копировании без использования регистратора, можно получить набор копий, содержащих ссылки на разные копии одного и того же вложенного объекта, что ведет к потере связи между копиями.

Аргументы:
[in]iReg- Регистратор.
Возвращает:
Копия объекта.

Замещает MbCurve.

virtual void MbCosinusoid::PrepareIntegralData ( const bool  forced) const [virtual]

Рассчитать временные данные объекта в зависимости от параметра forced. Если параметр forced равен false, рассчитываются только ещё не насчитанные данные. Если параметр forced равен true, перерасчитываются все временные данные объекта. Принудительный перерасчёт.

Переопределяет метод предка MbCurve.

virtual void MbCosinusoid::CalculateGabarit ( MbRect ) const [virtual]

Для получения габарита объекта присланный прямоугольник делается пустым. Затем вычисляются габариты объекта и сохраняются в прямоугольнике rect.

Переопределяет метод предка MbCurve.

virtual bool MbCosinusoid::IsVisibleInRect ( const MbRect rect,
bool  exact = false 
) const [virtual]

Определить, виден ли объект в заданном прямоугольнике. Есть возможность выполнить быструю проверку или более тщательную при соответствующем значении второго параметра.

Аргументы:
[in]rect- Заданный двумерный прямоугольник.
[in]exact- Выполнять ли более тщательную проверку?
Возвращает:
true - объект полностью или частично содержится в прямоугольнике, иначе - false.

Переопределяет метод предка MbCurve.

virtual bool MbCosinusoid::IsClosed ( ) const [virtual]

Определить, является ли кривая замкнутой.
Замкнутой считается кривая, если она циклична:

  • начальная и конечная точка кривой совпадают,
  • производные в начальной и конечной точке совпадают;
    если по своей природе кривая допускает изломы (контур, ломаная), то допускается не совпадение производных; у кривой Безье производные должны совпадать по направлению, но могут не совпадать по модулю.
Возвращает:
true, если кривая замкнута.

Замещает MbCurve.

virtual void MbCosinusoid::PointOn ( double &  t,
MbCartPoint p 
) const [virtual]

Скорректировать параметры при выходе их за пределы области определения и вычислить точку на кривой.

Аргументы:
[in]t- Параметр curve.
[out]p- Вычисленная точка на кривой.

Замещает MbCurve.

virtual void MbCosinusoid::_PointOn ( double  t,
MbCartPoint p 
) const [virtual]

Вычислить точку на кривой в том числе и за пределами области определения параметрa.

Аргументы:
[in]t- Параметр curve.
[out]p- Вычисленная точка на кривой.

Переопределяет метод предка MbCurve.

virtual void MbCosinusoid::Explore ( double &  t,
bool  ext,
MbCartPoint pnt,
MbVector fir,
MbVector sec,
MbVector thir 
) const [virtual]

Значения точки и производных вычисляются в пределах области определения и на расширенной кривой.

Аргументы:
[in]t- Параметр.
[in]ext- В пределах области определения (false), на расширенной кривой (true).
[out]pnt- Точка.
[out]fir- Производная.
[out]sec- Вторая производная по t, если не ноль.
[out]thir- Третья производная по t, если не ноль.

Переопределяет метод предка MbCurve.

virtual bool MbCosinusoid::HasLength ( double &  length) const [virtual]

Вычислить метрическую длину кривой и записать ее в переменную length.

Аргументы:
[in,out]length- Вычисленная длина кривой.
Возвращает:
true - если длина кривой отлична от нуля. Иначе возвращает false.

Замещает MbCurve.

virtual double MbCosinusoid::GetMetricLength ( ) const [virtual]

Если длина кривой уже была вычислена и запомнена в объекте, эта функция возвращает готовый результат, не выполняя повторных вычислений. Иначе длина вычисляется с помощью функции CalculateMetricLength().

Возвращает:
Длина кривой.

Замещает MbCurve.

virtual MbNurbs* MbCosinusoid::NurbsCurve ( const MbCurveIntoNurbsInfo nInfo) const [virtual]

Строит NURBS кривую, аппроксимирующую заданную в диапазоне параметров [t1, t2] с заданным направлением. По возможности, строит точную кривую, возможно с кратными узлами. Количество узлов для NURBS определяется в зависимости от кривой.

Аргументы:
[in,out]nurbs- Построенная NURBS кривая.
[in]t1- Параметр, соответствующий началу аппроксимируемой части кривой.
[in]t2- Параметр, соответствующий концу аппроксимируемой части кривой.
[in]sense- Совпадает ли направление возрастания параметра вдоль NURBS кривой с направлением на исходной кривой. sense > 0 - направление совпадает.
[in]nInfo- Параметры преобразования кривой в NURBS.
Возвращает:
Построенная NURBS кривая или NULL при неуспешном построении.

Замещает MbCurve.

virtual MbeState MbCosinusoid::DeletePart ( double  t1,
double  t2,
MbCurve *&  part2 
) [virtual]

Удалить часть кривой между параметрами t1 и t2. Если после удаления кривая распалась на две части, то исходный объект соответствует начальной части кривой, а в параметре part2 содержится конечная часть кривой. Если осталась односвязной, то изменяется только исходный объект.

Аргументы:
[in]t1- Начальный параметр усечения.
[in]t2- Конечный параметр усечения.
[in,out]part2- Конечная часть кривой после удаления, если исходная кривая распалась на части. Может являться единственной частью кривой после удаления, \ если не смогли изменить саму кривую (например, для прямой MbLine), в этом случае возвращаемый результат dp_Degenerated.
Возвращает:
Состояние кривой после модификации.

Замещает MbCurve.

virtual MbeState MbCosinusoid::TrimmPart ( double  t1,
double  t2,
MbCurve *&  part2 
) [virtual]

Оставить часть кривой между параметрами t1 и t2.
В случае успеха операции возвращаемое значение равно dp_Changed и кривая удовлетворяет следующим условиям:

  • если исходная кривая замкнута, то начальная точка усеченной кривой должна соответствовать параметру t1, конечная - параметру t2,
  • если исходная кривая не замкнута, то начальная точка усеченной кривой должна соответствовать минимальному параметру из t1 и t2, конечная - максимальному.
Аргументы:
[in]t1- Начальный параметр усечения.
[in]t2- Конечный параметр усечения.
[in,out]part2- Может заполниться результатом усечения, если не смогли изменить саму кривую. В этом случае возвращаемый результат dp_Degenerated. Иначе = NULL.
Возвращает:
Состояние кривой после модификации:
dp_Degenerated - кривая выродилась, может быть три варианта: кривая не была изменена, так как в результате преобразования она бы выродилась, или не была изменена, а результат усечения - part2,
dp_NoChanged - кривая не изменилась,
dp_Changed - кривая изменилась.
Предупреждения:
Функция предназначена для внутреннего использования.

Замещает MbCurve.

virtual MbCurve* MbCosinusoid::Trimmed ( double  t1,
double  t2,
int  sense 
) const [virtual]

Строит усеченную кривую, начало которой соответствует точке с параметром t1 и конец - точке с параметром t2. Можно изменить направление полученной кривой относительно исходной с помощью параметра sense. Если кривая замкнута, можно получить усеченную кривую, проходящую через начало кривой.
В случае замкнутой кривой (или для дуги - исключение) три параметра sense, t1 и t2 однозначно определяют результат. В случае разомкнутой кривой параметр sense и параметрами усечения должны соответствовать друг другу:
1) если sense == 1, то t1 < t2,
2) если sense == -1, то t1 > t2.
Если есть несоответствие между sense и параметрами усечения, то приоритетным параметром считается sense. Если параметры t1 и t2 равны и кривая замкнута, в результате должны получить замкнутую кривую.

Аргументы:
[in]t1- Параметр, соответствующий началу усеченной кривой.
[in]t2- Параметр, соответствующий концу усеченной кривой.
[in]sense- Направление усеченной кривой относительно исходной.
sense = 1 - направление кривой сохраняется. sense = -1 - направление кривой меняется на обратное.
Возвращает:
Построенная усеченная кривая.

Замещает MbCurve.

virtual void MbCosinusoid::IntersectHorizontal ( double  y,
SArray< double > &  cross 
) const [virtual]

Найти пересечения кривой с горизонтальной прямой.

Аргументы:
[in]y- Ордината точек горизонтальной прямой.
[in,out]cross- Массив параметров кривой, соответствующих точкам пересечения.

Переопределяет метод предка MbCurve.

virtual void MbCosinusoid::IntersectVertical ( double  x,
SArray< double > &  cross 
) const [virtual]

Найти пересечения кривой с вертикальной прямой.

Аргументы:
[in]x- Абсцисса точек вертикальной прямой.
[in,out]cross- Массив параметров кривой, соответствующих точкам пересечения.

Переопределяет метод предка MbCurve.

virtual double MbCosinusoid::Step ( double  t,
double  sag 
) const [virtual]

Вычислить шаг параметра для аппроксимации кривой по величине прогиба кривой. Вычисление шага проходит с учетом радиуса кривизны. Шаг аппроксимации кривой выбирается таким образом, чтобы отклонение кривой от её полигона не превышало заданную величину прогиба.

Аргументы:
[in]t- Параметр, определяющий точку на кривой, в которой надо вычислить шаг.
[in]sag- Максимально допустимая величина прогиба.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbCurve.

virtual double MbCosinusoid::DeviationStep ( double  t,
double  ang 
) const [virtual]

Вычислить шаг параметра для аппроксимации кривой по углу отклонения касательной. Шаг аппроксимации кривой выбирается таким образом, чтобы угловое отклонение касательной кривой в следующей точке не превышало заданную величину ang.

Аргументы:
[in]t- Параметр, определяющий точку на кривой, в которой надо вычислить шаг.
[in]ang- Максимально допустимый угол отклонения касательной.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbCurve.

virtual bool MbCosinusoid::NearPointProjection ( const MbCartPoint pnt,
double  xEpsilon,
double  yEpsilon,
double &  t,
bool  ext,
MbRect1D tRange = NULL 
) const [virtual]

Найти ближайшую проекцию точки на кривую или ее продолжение по заданному начальному приближению. Если задан диапазон изменения параметра tRange - то надо найти проекцию в заданном диапазоне. Диапазон параметра может выходить за область определения параметра кривой. Используется метод Ньютона.

Заметки:
Математическое ядро обеспечивает потокобезопасную реализацию функции для своих объектов.
Аргументы:
[in]pnt- Заданная точка.
[in]xEpsilon- Точность определения проекции по оси x.
[in]yEpsilon- Точность определения проекции по оси y.
[in,out]t- На входе - начальное приближение, на выходе - параметр кривой, соответствующий ближайшей проекции.
[in]ext- Флаг, определяющий, искать ли проекцию на продолжении кривой (если true, то искать).
[in]tRange- Диапазон изменения параметра, в котором надо найти решение.
Возвращает:
true - если найдена проекция, удовлетворяющая всем входным условиям.

Переопределяет метод предка MbCurve.


Объявления и описания членов класса находятся в файле:
 Указатель Классы Пространства имен Файлы Функции Переменные Определения типов Перечисления Элементы перечислений Друзья Макросы