8#ifndef PXR_BASE_TS_SPLINE_H
9#define PXR_BASE_TS_SPLINE_H
12#include "pxr/base/ts/api.h"
13#include "pxr/base/ts/splineData.h"
14#include "pxr/base/ts/knotMap.h"
15#include "pxr/base/ts/knot.h"
16#include "pxr/base/ts/types.h"
17#include "pxr/base/ts/typeHelpers.h"
18#include "pxr/base/ts/eval.h"
20#include "pxr/base/vt/value.h"
22#include "pxr/base/tf/type.h"
28PXR_NAMESPACE_OPEN_SCOPE
86 bool operator==(
const TsSpline &other)
const;
89 bool operator!=(
const TsSpline &other)
const;
96 static bool IsSupportedValueType(
TfType valueType);
99 TfType GetValueType()
const;
101 template <
typename T>
102 bool IsHolding()
const;
105 void SetTimeValued(
bool timeValued);
108 bool IsTimeValued()
const;
115 void SetCurveType(TsCurveType curveType);
118 TsCurveType GetCurveType()
const;
125 void SetPreExtrapolation(
132 void SetPostExtrapolation(
158 void SetInnerLoopParams(
175 std::string *reasonOut =
nullptr)
const;
310 std::string* reason =
nullptr);
348 template <
typename T>
353 template <
typename T>
358 template <
typename T>
363 template <
typename T>
364 bool EvalPreDerivative(
368 template <
typename T>
373 template <
typename T>
374 bool EvalPreValueHeld(
398 template <
typename Vertex>
407 return _Sample(timeInterval, timeScale, valueScale, tolerance,
417 template <
typename Vertex>
426 return _Sample(timeInterval, timeScale, valueScale, tolerance,
485 bool IsEmpty()
const;
488 bool HasValueBlocks()
const;
499 bool HasInnerLoops()
const;
502 bool HasExtrapolatingLoops()
const;
524 std::pair<VtValue, VtValue> *rangeOut)
const;
527 template <
typename T>
530 std::pair<T, T> *rangeOut)
const;
537 bool HasValueBlockAtTime(
543 TsTime startTime)
const;
548 TsTime startTime)
const;
562 template <
typename HashState>
563 friend void TfHashAppend(
567 h.Append(spline._data.get());
574 void _SetKnotUnchecked(
const TsKnot & knot);
576 template <
typename SampleHolder>
582 SampleHolder* splineSamples)
const;
585 friend Ts_SplineData* Ts_GetSplineData(
TsSpline &spline);
586 friend const Ts_SplineData* Ts_GetSplineData(
const TsSpline &spline);
588 friend struct Ts_BinaryDataAccess;
589 friend struct Ts_SplineOffsetAccess;
594 const Ts_SplineData* _GetData()
const;
601 template <
typename T>
605 Ts_EvalAspect aspect,
606 Ts_EvalLocation location)
const;
613 bool _UpdateAllTangents();
618 bool _UpdateKnotTangents(
const size_t knotIndex);
625 std::shared_ptr<Ts_SplineData> _data;
643struct Ts_SplineOffsetAccess
646 static void ApplyOffsetAndScale(
657bool TsSpline::IsHolding()
const
659 if constexpr (!Ts_IsSupportedValueType<T>::value)
664 return GetValueType() == Ts_GetType<T>();
671 const Ts_EvalAspect aspect,
672 const Ts_EvalLocation location)
const
674 const std::optional<double> result =
675 Ts_Eval(_GetData(), time, aspect, location);
682 *valueOut = T(*result);
694 const Ts_EvalAspect aspect,
695 const Ts_EvalLocation location)
const;
698bool TsSpline::Eval(
const TsTime time, T*
const valueOut)
const
700 return _Eval(time, valueOut, Ts_EvalValue, Ts_EvalAtTime);
704bool TsSpline::EvalPreValue(
const TsTime time, T*
const valueOut)
const
706 return _Eval(time, valueOut, Ts_EvalValue, Ts_EvalPre);
710bool TsSpline::EvalDerivative(
const TsTime time, T*
const valueOut)
const
712 return _Eval(time, valueOut, Ts_EvalDerivative, Ts_EvalAtTime);
716bool TsSpline::EvalPreDerivative(
const TsTime time, T*
const valueOut)
const
718 return _Eval(time, valueOut, Ts_EvalDerivative, Ts_EvalPre);
722bool TsSpline::EvalHeld(
const TsTime time, T*
const valueOut)
const
724 return _Eval(time, valueOut, Ts_EvalHeldValue, Ts_EvalAtTime);
728bool TsSpline::EvalPreValueHeld(
const TsTime time, T*
const valueOut)
const
730 return _Eval(time, valueOut, Ts_EvalHeldValue, Ts_EvalPre);
734PXR_NAMESPACE_CLOSE_SCOPE
#define VT_VALUE_TYPE_CAN_TRANSFORM(T)
A helper for specializing the above trait.
A basic mathematical interval class.
static GfInterval GetFullInterval()
Returns the full interval (-inf, inf).
TfType represents a dynamic runtime type.
A knot belonging to a TsSpline.
An authoring helper class that enforces non-regression in splines.
A mathematical description of a curved function from time to value.
TS_API bool CanBreakdown(TsTime time, std::string *reason=nullptr)
Test if a knot could be inserted by Breakdown at time.
TS_API bool IsG1Continuous() const
Not yet implemented.
TS_API TsKnotMap GetKnots() const
Returns the spline's knots.
TS_API GfInterval Diff(const TsSpline &other, const GfInterval &compareInterval) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
TS_API bool IsLinear() const
Not yet implemented.
TS_API bool SetKnot(const TsKnot &knot, GfInterval *affectedIntervalOut=nullptr)
Incompletely implemented; affectedIntervalOut is not yet populated.
TS_API TsKnotMap GetKnotsWithInnerLoopsBaked() const
Return all the knots on the spline, including knots generated by inner looping.
bool GetValueRange(const GfInterval &timeSpan, std::pair< T, T > *rangeOut) const
Not yet implemented.
TS_API TsKnotMap GetKnots(const GfInterval &timeInterval) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
TS_API bool GetValueRange(const GfInterval &timeSpan, std::pair< VtValue, VtValue > *rangeOut) const
Not yet implemented.
TS_API bool IsC1Continuous() const
Not yet implemented.
TS_API TsSpline(TfType valueType)
Creates a spline with a specified value type.
TS_API GfInterval Diff(const TsSpline &other) const
Compare two splines.
TS_API bool ClearRedundantKnots(VtValue defaultValue=VtValue(), const GfInterval &interval=GfInterval::GetFullInterval())
Not yet implemented.
bool Sample(const GfInterval &timeInterval, double timeScale, double valueScale, double tolerance, TsSplineSamples< Vertex > *splineSamples) const
Evaluates the value of the TsSpline over the given time interval, typically for drawing.
TS_API bool IsSegmentMonotonic(TsTime startTime) const
Not yet implemented.
TS_API TsKnotMap GetKnotsWithLoopsBaked(const GfInterval &interval) const
Return baked knots that will replicate this spline over the given time interval without any looping.
TS_API void RemoveKnot(TsTime time, GfInterval *affectedIntervalOut=nullptr)
Incompletely implemented; affectedIntervalOut is not yet populated.
bool Sample(const GfInterval &timeInterval, double timeScale, double valueScale, double tolerance, TsSplineSamplesWithSources< Vertex > *splineSamples) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
TS_API TsSpline()
Default constructor creates a spline without a value type.
TS_API bool AdjustRegressiveTangents()
Shorten any regressive tangents; or, if the current authoring mode is Contain, any tangents that exce...
TS_API bool Breakdown(TsTime time, GfInterval *affectedIntervalOut=nullptr)
Add a knot at the specified time.
TS_API bool HasLoops() const
Convenience for HasInnerLoops() || HasExtrapolatingLoops().
TS_API bool HasRegressiveTangents() const
Returns whether this spline has any tangents long enough to cause regression; or, if the current auth...
TS_API bool IsSegmentFlat(TsTime startTime) const
Not yet implemented.
TS_API bool IsVarying() const
Not yet implemented.
TS_API bool GetKnot(TsTime time, TsKnot *knotOut) const
Retrieves a copy of the knot at the specified time, if one exists.
TS_API bool IsKnotRedundant(TsTime time, VtValue defaultValue=VtValue()) const
Not yet implemented.
static TS_API TsAntiRegressionMode GetAntiRegressionAuthoringMode()
Returns the current effective anti-regression authoring mode.
TS_API bool BakeInnerLoops()
Bake inner loops in the spline.
TS_API bool IsC0Continuous() const
Not yet implemented.
TsSplineSamples<Vertex> holds a collection of piecewise linear polylines that approximate a TsSpline.
TsSplineSamplesWithSources<Vertex> is a TsSplineSamples<Vertex> that also includes source information...
A map with string keys and VtValue values.
Provides a container which may hold any type, and provides introspection and iteration over array typ...
GF_API std::ostream & operator<<(std::ostream &, const GfBBox3d &)
Output a GfBBox3d using the format [(range) matrix zeroArea].