Skip to main content

Library for computing Deterministic Acyclic Finite State Automata (DAFSA)

Project description

DAFSA is a library for computing Deterministic Acyclic Finite State Automata (also known as “directed acyclic word graphs”, or DAWG). DAFSA are data structures derived from tries that allow to represent a set of sequences (typically character strings or n-grams) in the form of a directed acyclic graph with a single source vertex (the start symbol of all sequences) and at least one sink edge (final symbols, each pointed to by one or more sequences). In the current implementation, a trait of each node expresses whether it can be used a sink.

The primary difference between DAFSA and tries is that the latter eliminates suffix and infix redundancy, as in the example of Figure 1 (from the linked Wikipedia article) storing the set of strings "tap", "taps", "top", and "tops". Even though DAFSAs cannot be used to store precise frequency information, given that multiple paths might reach the same terminal node, they still allow to estimate the sampling frequency; being acyclic, they can also reject any sequence not included in the training. Fuzzy extensions will allow to estimate the sampling probability of unobserved sequences.

Trie vs. DAFSA

Trie vs. DAFSA

This data structure is a special case of a finite state recognizer that acts as a deterministic finite state automaton, as it recognizes all and only the sequences it was built upon. Frequently used in computer science for the space-efficient storage of sets of sequences without common compression techniques, such as dictionary or entropy types, or without probabilistic data structures, such as Bloom filters, the automata generated by this library are intended for linguistic exploration, and extend published models by allowing to approximate probability of random observation by carrying information on the weight of each graph edge.

Installation and usage

The library can be installed as any standard Python library with pip, and used as demonstrated in the following snippet:

In any standard Python environment, dafsa can be installed with:

$ pip install dafsa

A conda package is also available, and can be installed (from the tresoldi channel) with:

$ conda install -c tresoldi dafsa

Detailed instructions on how to use the library can be found in the official documentation. For most purposes, it is enough to pass a list of sequences to the DAFSA object:

>>> from dafsa import DAFSA
>>> print(DAFSA(["dib", "tip", "tips", "top"]))
DAFSA with 8 nodes and 9 edges (4 inserted sequences)
  +-- #0: 0(#1/4:<d>/1|#4/4:<t>/3) [('t', 4), ('d', 1)]
  +-- #1: n(#2/1:<i>/1) [('i', 2)]
  +-- #2: n(#3/1:<b>/1) [('b', 3)]
  +-- #3: F() []
  +-- #4: n(#5/3:<i>/2|#8/3:<o>/1) [('i', 5), ('o', 8)]
  +-- #5: n(#6/2:<p>/2) [('p', 6)]
  +-- #6: F(#3/2:<s>/1) [('s', 3)]
  +-- #8: n(#3/1:<p>/1) [('p', 3)]

Full documentation is available at ReadTheDocs.io.

Showcase

  • Basic example:

First example

First example

  • Output can be textual, GML, DOT, or (via dot and third-party software) PNG, PDF, ASCII-art and Unicode-art:

DNA example

DNA example

                                 G                                A
                             +---------------------+          +----------+
                             |                     v          |          v
    #====#  C   +---+  G   +---+  C   +---+  G   +---+  A   +---+  T   +---+  A   #===#
+-- H 0  H ---> | 5 | ---> | 6 | ---> | 7 | ---> | 8 | ---> | 9 | ---> | 3 | ---> H 4 H
|   #====#      +---+      +---+      +---+      +---+      +---+      +---+      #===#
|     |    A                                                             ^
| G   +-----------+                                                      |
|                 v                                                      |
|   +----+  G   +---+  A   +---+  T                                      |
+-> | 20 | ---> | 1 | ---> | 2 | ----------------------------------------+
    +----+      +---+      +---+
                                 G                                A
                             ┌─────────────────────┐          ┌──────────┐
                             │                     ▼          │          ▼
    ╔════╗  C   ┌───┐  G   ┌───┐  C   ┌───┐  G   ┌───┐  A   ┌───┐  T   ┌───┐  A   ╔═══╗
┌── ║ 0  ║ ───▶ │ 5 │ ───▶ │ 6 │ ───▶ │ 7 │ ───▶ │ 8 │ ───▶ │ 9 │ ───▶ │ 3 │ ───▶ ║ 4 ║
│   ╚════╝      └───┘      └───┘      └───┘      └───┘      └───┘      └───┘      ╚═══╝
│     │    A                                                             ▲
│ G   └───────────┐                                                      │
│                 ▼                                                      │
│   ┌────┐  G   ┌───┐  A   ┌───┐  T                                      │
└─▶ │ 20 │ ───▶ │ 1 │ ───▶ │ 2 │ ────────────────────────────────────────┘
    └────┘      └───┘      └───┘
  • With or without single-path joining:

Phoneme example

Phoneme example

Reduced Phoneme example

Reduced Phoneme example

Changelog

Version 0.6:

  • Documentation improvements following JOSS review

  • Fixed bug where node finality was not considered in minimization

Version 0.5.1:

  • Minor changes in preparation for submission (including tagged release)

Version 0.5:

  • Improvements in speed, particularly in the __eq__() method of DAFSANode and the _minimize() method of DAFSA. The computation of a DAFSA for the contents of /usr/share/dict/words in the test machine (99,171 sequences) is now performed in under 8 minutes.

  • Added code from Daciuk’s packages in an extra directory, along with notes on license

Version 0.4:

  • Full documentation for existing code

  • Added GML, PDF, and SVG export

  • Allow to access all options from command-line

Version 0.3:

  • Allow to join transitions in single sub-paths

  • Allows to export a DAFSA as a networkx graph

  • Preliminary documentation at ReadTheDocs

Version 0.2.1:

  • Added support for segmented data

Version 0.2:

  • Added support for weighted edges and nodes

  • Added DOT export and Graphviz generation

  • Refined minimization method, which can be skipped if desired (resulting in a standard trie)

  • Added examples in the resources, also used for test data

Version 0.1:

  • First public release.

Roadmap

After 1.0:

  • Preliminary generation of minimal regular expressions matching the contents of a DAFSA

  • Consider adding support for empty transitions (or depend on the user aligning those)

  • Work on options for nicer graphviz output (colors, widths, etc.)

Community guidelines

While the author can be contacted directly for support, it is recommended that third parties use GitHub standard features, such as issues and pull requests, to contribute, report problems, or seek support.

Contributing guidelines, including a code of conduct, can be found in the CONTRIBUTING.md file.

Author and citation

The library is developed by Tiago Tresoldi (tresoldi@shh.mpg.de).

The author has received funding from the European Research Council (ERC) under the European Union’s Horizon 2020 research and innovation programme (grant agreement No. ERC Grant #715618, Computer-Assisted Language Comparison.

If you use dafsa, please cite it as:

Tresoldi, Tiago (2020). DAFSA, a a library for computing Deterministic Acyclic Finite State Automata. Version 1.0. Jena. Available at: https://github.com/tresoldi/dafsa

In BibTeX:

@misc{Tresoldi2020dafsa,
  author = {Tresoldi, Tiago},
  title = {DAFSA, a a library for computing Deterministic Acyclic Finite State Automata. Version 1.0.},
  howpublished = {\url{https://github.com/tresoldi/dafsa}},
  address = {Jena},
  year = {2020},
}

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

dafsa-1.0.tar.gz (24.8 kB view details)

Uploaded Source

Built Distribution

dafsa-1.0-py3-none-any.whl (19.9 kB view details)

Uploaded Python 3

File details

Details for the file dafsa-1.0.tar.gz.

File metadata

  • Download URL: dafsa-1.0.tar.gz
  • Upload date:
  • Size: 24.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.5

File hashes

Hashes for dafsa-1.0.tar.gz
Algorithm Hash digest
SHA256 0842b4dd3817099aa6c13fd1202bb5f6a2d86da74149baa9068c93abd41c418a
MD5 11c50d3cea023dcfc9a583a6b4fefc34
BLAKE2b-256 d6088bf5f26a2a038b62654a7abcfbfff58b922664c5cb6ad824f11d314bcf31

See more details on using hashes here.

File details

Details for the file dafsa-1.0-py3-none-any.whl.

File metadata

  • Download URL: dafsa-1.0-py3-none-any.whl
  • Upload date:
  • Size: 19.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.5

File hashes

Hashes for dafsa-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ff5e1beaf118198e688507c2bc1cd575784ed4bc34260f3ac21dba1bba208909
MD5 4a361af6b50852462641880451c1613a
BLAKE2b-256 f939199abcf83e5d589dbfaad9d500baae4a4d823fc635fbf294704891687a4f

See more details on using hashes here.

Supported by

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