bidict/docs/addendum.rst

110 lines
3.3 KiB
ReStructuredText

Addendum
========
.. include:: performance.rst.inc
Terminology
-----------
- It's intentional that the term "inverse" is used rather than "reverse".
Consider a collection of *(k, v)* pairs.
Taking the reverse of the collection can only be done if it is ordered,
and (as you'd expect) reverses the order of the pairs in the collection.
But each original *(k, v)* pair remains in the resulting collection.
By contrast, taking the inverse of such a collection
neither requires the collection to be ordered
nor guarantees any ordering in the result,
but rather just replaces every *(k, v)* pair
with the inverse pair *(v, k)*.
- "keys" and "values" could perhaps more properly be called
"primary keys" and "secondary keys" (as in a database),
or even "forward keys" and "inverse keys", respectively.
bidict sticks with the terms "keys" and "values"
for the sake of familiarity and to avoid potential confusion,
but technically values are also keys themselves.
Concretely, this allows bidict to return a set-like (*dict_keys*) object
for :func:`bidict.values <bidict.BidirectionalMapping.values>` (Python 3) /
``bidict.viewvalues()``
(Python 2.7), rather than a non-set-like *dict_values* object.
Missing bidicts in Stdlib!
--------------------------
The Python standard library actually contains some examples
where bidicts could be used for fun and profit
(depending on your ideas of fun and profit):
- The :mod:`logging` module
contains a private ``_levelToName`` dict
which maps integer levels like *10* to their string names like *DEBUG*.
If I had a nickel for every time I wanted that exposed in a bidirectional map
(and as a public attribute, no less),
I bet I could afford some better turns of phrase.
- The :mod:`dis` module
maintains a mapping from opnames to opcodes
``dis.opmap``
and a separate list of opnames indexed by opcode
``dis.opnames``.
These could be combined into a single bidict.
- Python 3's
:mod:`html.entities` module /
Python 2's
``htmlentitydefs`` module
maintains separate
``html.entities.name2codepoint`` and
``html.entities.codepoint2name`` dicts.
These could be combined into a single bidict.
Featured Projects Using bidict
------------------------------
Send a pull request to add yours here!
- `BioSSPy <https://github.com/PIA-Group/BioSPPy>`_:
Biosignal Processing in Python
- `marz <https://github.com/sgso/marz>`_:
Communicate with RIOT nativenet nodes on TAP interfaces through local ports
- `charla <https://github.com/prologic/charla>`_:
an IRC Server and Daemon
- `MIPS-interpreter <https://github.com/Nuullll/MIPS-interpreter>`_:
interprete MIPS instructions to machine code
- `res-scheduler <https://github.com/AngryDevelopersLLC/res-scheduler>`_:
Resystem Scheduling Service
- `packetmq <https://github.com/not-na/packetmq>`_:
packet-based message-framing network library built with Twisted
- `gymnast <https://github.com/ajmarks/gymnast>`_: Pythonic PDF Parsing
- `efnilex-vect <https://github.com/makrai/efnilex-vect>`_:
lexicon generation from vector space models
Caveats
-------
.. include:: caveat-mutation.rst.inc
.. include:: caveat-inv-reference-cycle.rst.inc
.. include:: caveat-different-values-same-hash.rst.inc
.. include:: caveat-nan-as-key.rst.inc
Thanks
------
.. include:: thanks.rst.inc