|
typedef std::map< std::string, std::shared_ptr< DataAdapter > > | RegisteredDataAdapters |
| Type of the registry containing registered adapters. More...
|
|
typedef std::map< std::string, std::shared_ptr< AbstractDataTable > > | OutputTables |
| Collection of tables returned by reading methods implemented in derived classes. More...
|
|
typedef std::map< std::string, const AbstractDataTable * > | InputTables |
| Collection of tables accepted by writing methods implemented in derived classes. More...
|
|
OutputTables | extendRead (const std::string &filename) const override |
| Implementation of the read functionality. More...
|
|
void | extendWrite (const InputTables &tables, const std::string &filename) const override |
| Implementation of the write functionality. More...
|
|
SimTK::RowVector_< T > | readElems (const std::vector< std::string > &tokens) const |
| Read elements of type T (template parameter) from a sequence of tokens. More...
|
|
void | writeElem (std::ostream &stream, const T &elem, const unsigned &prec) const |
| Write an element of type T (template parameter) to stream with the specified precision. More...
|
|
static std::vector< std::string > | tokenize (const std::string &str, const std::string &delims) |
| Tokenize/split a given string using the given delimiters. More...
|
|
static std::shared_ptr< DataAdapter > | createAdapter (const std::string &identifier) |
| Creator of concrete DataAdapter(s) for the specified source type by its unique identifier (string). More...
|
|
template<typename T>
class OpenSim::STOFileAdapter_< T >
STOFileAdapter is a DelimFileAdapter that presets the delimiters appropriately for STO files.
The format of the file is as follows:
.................................
.................................
........ <metadata> .............
.................................
.................................
endheader
time colname1 colname2 ..........
.................................
.................................
............ <data-rows> ........
.................................
.................................
For example a TimeSeriesTable_<SimTK::Vec3> could look like:
units=m
endheader
time r_shoulder l_shoulder r_leg l_leg
0.1 0.11,0.22,0.33 0.44,0.55,0.66 0.77,0.88,0.99 0.10,0.11,0.12
0.2 0.22,0.44,0.66 0.88,0.99,0.35 0.75,0.65,0.43 0.47,0.57,0.67
Columns are delimited by tab character. Elements within a column are delimited by comma character. STOFileAdapter allows reading/writing following tables:
TimeSeriesTable_<double> | DataType=double |
TimeSeriesTable_<SimTK::Vec2> | DataType=Vec2 |
TimeSeriesTable_<SimTK::Vec3> | DataType=Vec3 |
TimeSeriesTable_<SimTK::Vec4> | DataType=Vec4 |
TimeSeriesTable_<SimTK::Vec5> | DataType=Vec5 |
TimeSeriesTable_<SimTK::Vec6> | DataType=Vec6 |
TimeSeriesTable_<SimTK::Vec7> | DataType=Vec7 |
TimeSeriesTable_<SimTK::Vec8> | DataType=Vec8 |
TimeSeriesTable_<SimTK::Vec9> | DataType=Vec9 |
TimeSeriesTable_<SimTK::Vec<10>> | DataType=Vec10 |
TimeSeriesTable_<SimTK::Vec<11>> | DataType=Vec11 |
TimeSeriesTable_<SimTK::Vec<12>> | DataType=Vec12 |
TimeSeriesTable_<SimTK::UnitVec3> | DataType=UnitVec3 |
TimeSeriesTable_<SimTK::Quaternion> | DataType=Quaternion |
TimeSeriesTable_<SimTK::SpatialVec> | DataType=SpatialVec |
Files contain metadata (in form of "DataType=<something>" as shown above) indicating the type of the table they contain.