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"
19#include "pxr/base/vt/value.h"
21#include "pxr/base/tf/type.h"
27PXR_NAMESPACE_OPEN_SCOPE
85 bool operator==(
const TsSpline &other)
const;
88 bool operator!=(
const TsSpline &other)
const;
95 static bool IsSupportedValueType(
TfType valueType);
98 TfType GetValueType()
const;
100 template <
typename T>
101 bool IsHolding()
const;
104 void SetTimeValued(
bool timeValued);
107 bool IsTimeValued()
const;
114 void SetCurveType(TsCurveType curveType);
117 TsCurveType GetCurveType()
const;
124 void SetPreExtrapolation(
131 void SetPostExtrapolation(
157 void SetInnerLoopParams(
174 std::string *reasonOut =
nullptr)
const;
289 template <
typename T>
294 template <
typename T>
299 template <
typename T>
304 template <
typename T>
305 bool EvalPreDerivative(
309 template <
typename T>
314 template <
typename T>
315 bool EvalPreValueHeld(
339 template <
typename Vertex>
348 return _Sample(timeInterval, timeScale, valueScale, tolerance,
358 template <
typename Vertex>
367 return _Sample(timeInterval, timeScale, valueScale, tolerance,
376 bool IsEmpty()
const;
379 bool HasValueBlocks()
const;
390 bool HasInnerLoops()
const;
393 bool HasExtrapolatingLoops()
const;
415 std::pair<VtValue, VtValue> *rangeOut)
const;
418 template <
typename T>
421 std::pair<T, T> *rangeOut)
const;
428 bool HasValueBlockAtTime(
434 TsTime startTime)
const;
439 TsTime startTime)
const;
453 template <
typename HashState>
454 friend void TfHashAppend(
458 h.Append(spline._data.get());
463 void _SetKnotUnchecked(
const TsKnot & knot);
465 template <
typename SampleHolder>
471 SampleHolder* splineSamples)
const;
474 friend Ts_SplineData* Ts_GetSplineData(
TsSpline &spline);
475 friend const Ts_SplineData* Ts_GetSplineData(
const TsSpline &spline);
477 friend struct Ts_BinaryDataAccess;
478 friend struct Ts_SplineOffsetAccess;
483 const Ts_SplineData* _GetData()
const;
490 template <
typename T>
494 Ts_EvalAspect aspect,
495 Ts_EvalLocation location)
const;
502 std::shared_ptr<Ts_SplineData> _data;
517struct Ts_SplineOffsetAccess
520 static void ApplyOffsetAndScale(
531bool TsSpline::IsHolding()
const
533 if constexpr (!Ts_IsSupportedValueType<T>::value)
538 return GetValueType() == Ts_GetType<T>();
545 const Ts_EvalAspect aspect,
546 const Ts_EvalLocation location)
const
548 const std::optional<double> result =
549 Ts_Eval(_GetData(), time, aspect, location);
556 *valueOut = T(*result);
568 const Ts_EvalAspect aspect,
569 const Ts_EvalLocation location)
const;
572bool TsSpline::Eval(
const TsTime time, T*
const valueOut)
const
574 return _Eval(time, valueOut, Ts_EvalValue, Ts_EvalAtTime);
578bool TsSpline::EvalPreValue(
const TsTime time, T*
const valueOut)
const
580 return _Eval(time, valueOut, Ts_EvalValue, Ts_EvalPre);
584bool TsSpline::EvalDerivative(
const TsTime time, T*
const valueOut)
const
586 return _Eval(time, valueOut, Ts_EvalDerivative, Ts_EvalAtTime);
590bool TsSpline::EvalPreDerivative(
const TsTime time, T*
const valueOut)
const
592 return _Eval(time, valueOut, Ts_EvalDerivative, Ts_EvalPre);
596bool TsSpline::EvalHeld(
const TsTime time, T*
const valueOut)
const
598 return _Eval(time, valueOut, Ts_EvalHeldValue, Ts_EvalAtTime);
602bool TsSpline::EvalPreValueHeld(
const TsTime time, T*
const valueOut)
const
604 return _Eval(time, valueOut, Ts_EvalHeldValue, Ts_EvalPre);
608PXR_NAMESPACE_CLOSE_SCOPE
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 const TsKnotMap & GetKnotsWithInnerLoopsBaked() const
Not yet implemented.
TS_API bool IsG1Continuous() const
Not yet implemented.
TS_API TsKnotMap GetKnots() const
Returns the spline's knots.
TS_API bool Split(TsTime time, GfInterval *affectedIntervalOut=nullptr)
Not yet implemented.
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.
bool GetValueRange(const GfInterval &timeSpan, std::pair< T, T > *rangeOut) const
Not yet implemented.
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 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 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 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.
TS_API const TsKnotMap & GetKnotsWithLoopsBaked(const GfInterval &interval) const
Not yet implemented.
static TS_API TsAntiRegressionMode GetAntiRegressionAuthoringMode()
Returns the current effective anti-regression authoring mode.
TS_API bool BakeLoops(const GfInterval &interval)
Not yet implemented.
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].