[SYSTEMDS-2713] DAG height based eviction policy for lineage cache

This patch introduces a new eviction policy, DAGHEIGHT, for lineage cache
eviction. According to this policy, lineage items farthest from the
leaves get evicted first. We store the height of each item on construction.
For inputs having different heights, we find the maximum (linear time) and
increment it by one for the current node.
In addition, this patch updates the Comparator for the eviction queue.
Now, entries with same score are ordered by cost, size ratio in LRU and
DAGHEIGHT policies, and by timestamp in COSTNSIZE policy. For HYBRID,
entries with same score are still ordered by Ids.
5 files changed
tree: c0b9b52fef0c9af6305ec48ca8add11e1574e117
  1. .github/
  2. bin/
  3. conf/
  4. dev/
  5. docker/
  6. docs/
  7. notebooks/
  8. scripts/
  9. src/
  10. .gitattributes
  11. .gitignore
  12. CONTRIBUTING.md
  13. LICENSE
  14. NOTICE
  15. pom.xml
  16. README.md
README.md

Apache SystemDS

Overview: SystemDS is a versatile system for the end-to-end data science lifecycle from data integration, cleaning, and feature engineering, over efficient, local and distributed ML model training, to deployment and serving. To this end, we aim to provide a stack of declarative languages with R-like syntax for (1) the different tasks of the data-science lifecycle, and (2) users with different expertise. These high-level scripts are compiled into hybrid execution plans of local, in-memory CPU and GPU operations, as well as distributed operations on Apache Spark. In contrast to existing systems - that either provide homogeneous tensors or 2D Datasets - and in order to serve the entire data science lifecycle, the underlying data model are DataTensors, i.e., tensors (multi-dimensional arrays) whose first dimension may have a heterogeneous and nested schema.

Quick Start Install, Quick Start and Hello World

Documentation: SystemDS Documentation

Python Documentation Python SystemDS Documentation

Issue Tracker Jira Dashboard

Status and Build: SystemDS is renamed from SystemML which is an Apache Top Level Project. To build from source visit SystemDS Install from source

Build Documentation Component Test Application Test Function Test Python Test Federated Python Test