Skip to content

Notes on caching translated attributes

John Bogovic edited this page Dec 15, 2021 · 3 revisions

Stephan and John 15 Dec 2021.

Readers

Can cache everything because the contents of the original container are unchanged.

Writers & Readers

Need forward and inverse translations.

Local effect

We will say that translations have local effects when adding/changing an attribute changes only one node of the container tree. If that is the case, attribute writing can be implemented as follows:

  1. Create sparse N5 sub-tree with attribute
  2. inverse translate sparse N5 tree.
  3. write elements of the result

General

In the general case, translations can be such that what paths are affected / written to can depend on attributes. Then attribute writing must be implemented like this:

  1. Read full N5 Tree
  2. Translate full N5 Tree
  3. modify attribute
  4. inverse translate full N5 Tree
  5. write full N5 Tree

This general case is terrible because any attribute change could have arbitrarily wide-ranging effects on other paths and attributes.

Proposal

Have a convention for translation such that any translation with non-local effects