No project description provided
ticdat is a Python package that provides lightweight, ORM style functionality around either a dict-of-dicts or
pandas.DataFrame representation of tables. It is well suited for defining and validating the input data for complex
solve engines (i.e. optimization and scheduling-type problems).
ticdat functionality is organized around two classes -
PanDatFactory. Both classes define a
simple database style schema on construction. Data integrity rules can then be added in the form of foreign key
relationships, data field types (to include numerical ranges and allowed strings) and row predicates
(functions that check if a given row violates a particular data condition). The factory classes can then be used to
PanDat objects that contain tables consistent with the defined schema. By design,
ticdat, allows these data objects to violate the data integrity rules while providing convenient bulk query functions
to determine where those violations occur.
TicDat objects (created by a
TicDatFactory) contain tables in a dict-of-dict format. The outer dictionary maps
primary key values to data rows. The inner dictionaries are data rows indexed by field names (similar to
csv.DictReader/csv.DictWriter). Tables that do not have primary keys are rendered as a list of data row dictionaries.
PanDat objects (created by
PanDatFactory) render tables as
pandas.DataFrame objects. The columns in each
DataFrame will contain all of the primary key and data fields that were defined in the
PanDatFactory schema. The
PanDatFactory code can be thought of as implementing a shim library that organizes
DataFrame objects into a
predefined schema, and facilitates rich integrity checks based on schema defined rules.
ticdat example library is focused on two patterns for building optimization engines - using
gurobipy and using
PanDatFactory in conjunction with
amplpy. That said,
ticdat can also be
used with libraries like
xpress. It also has functionality to support the OPL and
LINGO modeling languages, although the AMPL support is far more mature.
ticdat is also useful for machine-learning applications. In this case, one typically uses
provide ORM-like functionality on top of
pandas, as well as to simplify the munging of time stamp data and
text columns that contain exclusively numbers.
ticdat library is distributed under the BSD2 open source license.
Release history Release notifications | RSS feed
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size ticdat-0.2.19-py2.py3-none-any.whl (179.2 kB)||File type Wheel||Python version py2.py3||Upload date||Hashes View|
|Filename, size ticdat-0.2.19.tar.gz (152.6 kB)||File type Source||Python version None||Upload date||Hashes View|
Hashes for ticdat-0.2.19-py2.py3-none-any.whl