Data Sources¶
This module provides base classes for data sources. Data sources provide data to calculations. All data used comes from a data source. The requirements for data sources are as follows:
- Data sources must be sub-classed to - DataSource.
- They must know where to get their data, either from a file or from other
- data sources. 
 
- They need a data reader that knows how to extract the data from the file,
- or combine data in calculations to produce new data. 
 
- They require a parameter map that states exactly where the data is and what
- its units are, what the data will be called in calculations and any other meta-data the registry requires. 
 
Data Parameter¶
Data Regsitry¶
- 
class simkit.core.data_sources.DataRegistry[source]¶
- A registry for data sources. The meta names are: - uncertainty,- variance,- isconstant,- timeseriesand- data_source- 
meta_names= ['uncertainty', 'variance', 'isconstant', 'timeseries', 'data_source']¶
- meta names 
 - 
register(newdata, *args, **kwargs)[source]¶
- Register data in registry. Meta for each data is specified by positional or keyword arguments after the new data and consists of the following: - uncertainty- Map of uncertainties in percent corresponding to new keys. The uncertainty keys must be a subset of the new data keys.
- variance- Square of the uncertainty (no units).
- isconstant: Map corresponding to new keys whose values are``True`` if constant or- Falseif periodic. These keys must be a subset of the new data keys.
- timeseries: Name of corresponding time series data,- Noneif no time series. _EG_: DNI data- timeseriesattribute might be set to a date/time data that it corresponds to. More than one data can have the same- timeseriesdata.
- data_source: the- DataSourcesuperclass that was used to acquire this data. This can be used to group data from a specific source together.
 - Parameters
- newdata (mapping) – New data to add to registry. When registering new data, keys are not allowed to override existing keys in the data registry. 
- Raises
 
 
- 
Data Source Base¶
Data Source¶
- 
class simkit.core.data_sources.DataSource(*args, **kwargs)[source]¶
- Required interface for all SimKit data sources such as PVSim results, TMY3 data and calculation input files. - Each data source must specify a - data_readerwhich must subclass- DataReaderand that can read this data source. The default is- JSONReader.- Each data source must also specify a - data_fileand- data_paththat contains the parameters required to import data from the data source using the data reader. Each data reader had different parameters to specify how it reads the data source, so consult the API.- This is the required interface for all source files containing data used in SimKit. - 
args= None¶
- positional arguments 
 - 
data= None¶
- data loaded from reader 
 - 
data_source= None¶
- name of - DataSource
 - 
filename= None¶
- filename of file containing data 
 - 
isconstant= None¶
- Trueif data is constant for all dynamic calculations
 - 
kwargs= None¶
- keyword arguments 
 - 
saveas_json(save_name)[source]¶
- Save - data,- param_file, original- data_readerand UTC modification time as keys in JSON file. If data is edited then it should be saved using this method. Non-JSON data files are also saved using this method.- Parameters
- save_name (str) – Name to save JSON file as, “.json” is appended. 
 
 - 
timeseries= None¶
- name of corresponding time series data, - Noneif no time series
 - 
uncertainty= None¶
- data uncertainty in percent 
 - 
variance= None¶
- variance 
 
- 
Data Readers¶
This module provides the base classes for data readers, such as
XLRD and numpy.loadtxt(),
which are used to read in data sources.
DataReader¶
- 
class simkit.core.data_readers.DataReader(parameters, meta=None)[source]¶
- Required interface for all SimKit data readers. - Parameters
- parameters (dict) – parameters to be read 
 - 
apply_units_to_cache(data)[source]¶
- Apply units to cached data. This method must be implemented by each data reader. - Parameters
- data – cached data 
- Returns
- data with units applied 
- Return type
- Quantity
- Raises
- NotImplementedError
 
 - 
is_file_reader= True¶
- True if reader accepts - filenameargument
 - 
load_data(*args, **kwargs)[source]¶
- Load data from source using reader. This method must be implemented by each data reader. - Parameters
- args – positional arguments 
- kwargs – keyword arguments 
 
- Returns
- data read by - DataReader
- Return type
- Raises
- NotImplementedError
 
 - 
meta= None¶
- meta if any 
 - 
parameters= None¶
- parameters to be read by reader 
 
JSONReader¶
- 
class simkit.core.data_readers.JSONReader(parameters, meta=None)[source]¶
- Read data from a JSON file. - Parameters
- parameters (dict) – parameters to read 
- data_reader – original - DataReaderif data cached as JSON
 
 - This the default data reader if not specified in the data source. The format of the data is similar to the dictionary used to create the data registry, except without units. - For example: - { "data": { "DNI": [834, 523, 334, 34, 0, 0], "zenith": [21, 28, 45, 79, 90, 90] }, "param_file": "path/to/corresponding/param_file.json", "data_source": "MyDataSource" } - Parameters can be specified in a JSON file. - { "DNI": { "description": "direct normal insolation", "units": "W/m*^2", "isconstant": false }, "zenith": { "description": "solar zenith", "units": "degrees", "isconstant": false } } - Parameters can also be specified in the data source as class attributes. - class MyDataSrc(DataSource): data_reader = JSONReader DNI = { "description": "direct normal insolation", "units": "W/m*^2", "isconstant": false } zenith = { "description": "solar zenith", "units": "degrees", "isconstant": false } - 
apply_units_to_cache(data)[source]¶
- Apply units to data read using - JSONReader.- Parameters
- data – cached data 
- Returns
- data with units applied 
- Return type
- Quantity
 
 - 
orig_data_reader= None¶
- original data reader [None] 
 
 
    
    