File: assoclib.md

package info (click to toggle)
swi-prolog 8.2.4%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 78,084 kB
  • sloc: ansic: 362,656; perl: 322,276; java: 5,451; cpp: 4,625; sh: 3,047; ruby: 1,594; javascript: 1,509; yacc: 845; xml: 317; makefile: 156; sed: 12; sql: 6
file content (75 lines) | stat: -rw-r--r-- 2,067 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75

## Introduction {#assoc-introduction}

An _association list_ as implemented by this library is a collection
of unique _keys_ that are associated to _values_. Keys must be ground,
values need not be.

An association list can be used to _fetch_ elements via their keys and
to _enumerate_ its elements in ascending order of their keys.

This library uses **AVL trees** to implement association lists. This means that

  - inserting a key
  - changing an association
  - fetching a single element

are all _O(log(N))_ _worst-case_ (and expected) time operations, where
_N_ denotes the number of elements in the association list.

The logarithmic overhead is often acceptable in practice. Notable
advantages of association lists over several other methods are:

  - `library(assoc)` is written entirely in Prolog, making it portable to
    other systems
  - the interface predicates fit the declarative nature of Prolog, avoiding
    destructive updates to terms
  - AVL trees scale very predictably and can be used to represent sparse arrays
    efficiently.


## Creating association lists {#assoc-creation}

An association list is _created_ with one of the following predicates:

  * [[empty_assoc/1]]
  * [[list_to_assoc/2]]
  * [[ord_list_to_assoc/2]]

## Querying association lists {#assoc-querying}

An association list can be _queried_ with:

  * [[get_assoc/3]]
  * [[get_assoc/5]]
  * [[max_assoc/3]]
  * [[min_assoc/3]]
  * [[gen_assoc/3]]

## Modifying association lists {#assoc-modifications}

Elements of an association list can be changed and inserted with:

  * [[put_assoc/4]]
  * [[del_assoc/4]]
  * [[del_min_assoc/4]]
  * [[del_max_assoc/4]]

## Conversion predicates {#assoc-conversion}

Conversion of (parts of) an association list to _lists_ is possible
with:

  * [[assoc_to_list/2]]
  * [[assoc_to_keys/2]]
  * [[assoc_to_values/2]]

## Reasoning about association lists and their elements {#assoc-reasoning}

Further inspection predicates of an association list and its elements
are:

  * [[is_assoc/1]]
  * [[map_assoc/2]]
  * [[map_assoc/3]]