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;
156 bool IsPreExtrapolationValid()
const;
166 bool IsPostExtrapolationValid()
const;
188 void SetInnerLoopParams(
205 std::string *reasonOut =
nullptr)
const;
347 std::string* reason =
nullptr);
385 template <
typename T>
390 template <
typename T>
395 template <
typename T>
400 template <
typename T>
401 bool EvalPreDerivative(
405 template <
typename T>
410 template <
typename T>
411 bool EvalPreValueHeld(
438 template <
typename Vertex>
447 return _Sample(timeInterval, timeScale, valueScale, tolerance,
457 template <
typename Vertex>
466 return _Sample(timeInterval, timeScale, valueScale, tolerance,
573 bool IsEmpty()
const;
576 bool HasValueBlocks()
const;
587 bool HasInnerLoops()
const;
590 bool HasExtrapolatingLoops()
const;
612 std::pair<VtValue, VtValue> *rangeOut)
const;
615 template <
typename T>
618 std::pair<T, T> *rangeOut)
const;
625 bool HasValueBlockAtTime(
631 TsTime startTime)
const;
636 TsTime startTime)
const;
650 template <
typename HashState>
651 friend void TfHashAppend(
655 h.Append(spline._data.get());
662 void _SetKnotUnchecked(
const TsKnot & knot);
664 template <
typename SampleHolder>
670 SampleHolder* splineSamples)
const;
673 friend Ts_SplineData* Ts_GetSplineData(
TsSpline &spline);
674 friend const Ts_SplineData* Ts_GetSplineData(
const TsSpline &spline);
676 friend struct Ts_BinaryDataAccess;
677 friend struct Ts_SplineOffsetAccess;
687 const Ts_SplineData* _GetData()
const;
694 template <
typename T>
698 Ts_EvalAspect aspect,
699 Ts_EvalLocation location)
const;
706 bool _UpdateAllTangents();
711 bool _UpdateKnotTangents(
const size_t knotIndex);
718 std::shared_ptr<Ts_SplineData> _data;
726std::ostream& operator<<(std::ostream& out,
const TsSpline &spline);
736struct Ts_SplineOffsetAccess
739 static void ApplyOffsetAndScale(
750bool TsSpline::IsHolding()
const
752 if constexpr (!Ts_IsSupportedValueType<T>::value)
757 return GetValueType() == Ts_GetType<T>();
764 const Ts_EvalAspect aspect,
765 const Ts_EvalLocation location)
const
767 const std::optional<double> result =
768 Ts_Eval(_GetData(), time, aspect, location);
775 *valueOut = T(*result);
787 const Ts_EvalAspect aspect,
788 const Ts_EvalLocation location)
const;
791bool TsSpline::Eval(
const TsTime time, T*
const valueOut)
const
793 return _Eval(time, valueOut, Ts_EvalValue, Ts_EvalAtTime);
797bool TsSpline::EvalPreValue(
const TsTime time, T*
const valueOut)
const
799 return _Eval(time, valueOut, Ts_EvalValue, Ts_EvalPre);
803bool TsSpline::EvalDerivative(
const TsTime time, T*
const valueOut)
const
805 return _Eval(time, valueOut, Ts_EvalDerivative, Ts_EvalAtTime);
809bool TsSpline::EvalPreDerivative(
const TsTime time, T*
const valueOut)
const
811 return _Eval(time, valueOut, Ts_EvalDerivative, Ts_EvalPre);
815bool TsSpline::EvalHeld(
const TsTime time, T*
const valueOut)
const
817 return _Eval(time, valueOut, Ts_EvalHeldValue, Ts_EvalAtTime);
821bool TsSpline::EvalPreValueHeld(
const TsTime time, T*
const valueOut)
const
823 return _Eval(time, valueOut, Ts_EvalHeldValue, Ts_EvalPre);
827PXR_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 TsSpline GetTruncated(const GfInterval &interval, TsExtrapolation preFallback=TsExtrapolation(TsExtrapValueBlock), TsExtrapolation postFallback=TsExtrapolation(TsExtrapValueBlock)) const
Returns a new spline resulting from truncation of the given spline to the given interval.
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 void SetPreExtrapolation(const TsExtrapolation &extrap)
Sets pre extrapolation.
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 void SetPostExtrapolation(const TsExtrapolation &extrap)
Sets post extrapolation.
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...