Read Data Matrix from an IT file. More...
Read Data Matrix from an IT file.
The constructor creates an internal matrix Data
from an IT++ file. The file is binary and can be made using the IT++ library or the Matlab/Octave function itsave. NB: the data are stored columnwise, i.e. each column contains the data for time !
#include <datasources.h>
Public Member Functions | |
ITppFileDS (const string &fname, const string &varname) | |
Convenience constructor. | |
void | from_setting (const Setting &set) |
void | getdata (vec &dt) |
Returns full vector of observed data=[output, input]. | |
void | getdata (vec &dt, const ivec &indices) |
Returns data records at indeces. | |
int | ndat () |
returns number of data in the file; | |
void | log_add (logger &L) |
no sense to log this type | |
void | logit (logger &L) |
no sense to log this type | |
int | max_length () |
Returns maximum number of provided data, by default it is set to maximum allowed length, shorter DS should overload this method! See, MemDS.max_length(). | |
void | set_drv (const RV &drv, const RV &urv) |
set random variables | |
void | write (const vec &ut) |
Accepts action variable and schedule it for application. | |
void | write (const vec &ut, const ivec &indices) |
Accepts action variables at specific indeces. | |
void | step () |
Moves from to , i.e. perfroms the actions and reads response of the system. | |
virtual const RV & | _drv () const |
access function | |
const RV & | _urv () const |
access function | |
const RV & | _yrv () const |
access function | |
virtual string | to_string () |
This method returns a basic info about the current instance. | |
virtual void | to_setting (Setting &set) const |
This method save all the instance properties into the Setting structure. | |
virtual void | validate () |
This method TODO. | |
Protected Attributes | |
mat | Data |
internal matrix of data | |
int | time |
active column in the Data matrix | |
ivec | rowid |
vector of rows that are presented in Dt | |
int | dtsize |
size of data returned by getdata() | |
int | utsize |
size of data | |
int | ytsize |
size of output | |
RV | Drv |
Description of data returned by getdata() . | |
RV | Urv |
Description of data witten by by write() . | |
RV | Yrv |
Description of output data. | |
ivec | LIDs |
Remember its own index in Logger L, [0=dt, 1=ut]. |
void ITppFileDS::from_setting | ( | const Setting & | set | ) | [virtual] |
Create object from the following structure
{ class = "MemDS"; Data = (...); // Data matrix or data vector --- optional --- drv = {class="RV"; ...} // Identification how rows of the matrix Data will be known to others time = 0; // Index of the first column to user_info, rowid = [1,2,3...]; // ids of rows to be used }
If the optional fields are not given, they will be filled as follows:
rowid= [0, 1, 2, ...number_of_rows_of_Data]; drv = {names=("ch0", "ch1", "ch2", ..."number_of_rows_of_Data"); sizes=( 1 1 1 ...); times=( 0 0 0 ...); }; time = 0;
If rowid
is given, drv
will be named after indeces in rowids.
Hence the data provided by method getdata()
will be full column of matrix Data starting from the first record.
Reimplemented from bdm::MemDS.
References bdm::MemDS::Data, bdm::MemDS::set_drv(), and bdm::MemDS::time.