Skip to main content

No project description provided

Project description

ticdat

Go here for project status and installation instructions. Go here for documentation.

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 - TicDatFactory and 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 construct TicDat/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.

The ticdat example library is focused on two patterns for building optimization engines - using TicDatFactory in conjunction with gurobipy and using PanDatFactory in conjunction with amplpy. That said, ticdat can also be used with libraries like pyomo, pulp, docplex and 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 PanDatFactory to 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.

The ticdat library is distributed under the BSD2 open source license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ticdat-0.2.30.tar.gz (200.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ticdat-0.2.30-py2.py3-none-any.whl (221.2 kB view details)

Uploaded Python 2Python 3

File details

Details for the file ticdat-0.2.30.tar.gz.

File metadata

  • Download URL: ticdat-0.2.30.tar.gz
  • Upload date:
  • Size: 200.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.2

File hashes

Hashes for ticdat-0.2.30.tar.gz
Algorithm Hash digest
SHA256 93186576b053387900e93708969349e2147c66288889c8e9e1e256345bd0f7f6
MD5 a83df7ea00f074ca34afca100425ee62
BLAKE2b-256 909137b36a1acc8bab5c4955308bd5ecf3600543934c586e82b82eaa6bd94bc6

See more details on using hashes here.

File details

Details for the file ticdat-0.2.30-py2.py3-none-any.whl.

File metadata

  • Download URL: ticdat-0.2.30-py2.py3-none-any.whl
  • Upload date:
  • Size: 221.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.2

File hashes

Hashes for ticdat-0.2.30-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 02985c4ec3a053498202ef7a0992cfbe3d25abd60ce39274e412e4751753996c
MD5 253a35db409560f6af4a5f69f4becec1
BLAKE2b-256 bf84c72e054cde876eda27aafba5f9beac06bdabb562cdfd839e0c425748d92b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page