Skip to main content

Distributional Compositional Python

Project description

snake equation

Distributional Compositional Python

readthedocs Build Status codecov pylint Score PyPI version

discopy computes natural language meaning in pictures.

Features

Diagrams & Recipes

Diagrams are the core data structure of discopy, they are generated by the following grammar:

diagram ::= Box(name, dom=type, cod=type)
    | diagram @ diagram
    | diagram >> diagram
    | Id(type)

type ::= Ty(name) | type.l | type.r | type @ type | Ty()

String diagrams (also known as tensor networks or Penrose notation) are a graphical calculus for computing with monoidal categories. For example, if we take ingredients as types and cooking steps as boxes then a diagram is a recipe:

from discopy import Ty, Box, Id

egg, white, yolk = Ty('egg'), Ty('white'), Ty('yolk')
crack = Box('crack', egg, white @ yolk)
swap = lambda x, y: Box('swap', x @ y, y @ x)
merge = lambda x: Box('merge', x @ x, x)

crack_two_eggs = crack @ crack\
    >> Id(white) @ swap(yolk, white) @ Id(yolk)\
    >> merge(white) @ merge(yolk)
crack_two_eggs.draw(path='docs/imgs/crack-eggs.png')

crack two eggs

Snakes & Sentences

The wires in a diagram are never allowed to cross (they are planar string diagrams) but they can be bended using two special kinds of boxes: cups and caps. Cups and caps satisfy the snake equations, also called triangle identities:

from discopy import Cup, Cap

x = Ty('x')
left_snake = Id(x) @ Cap(x.r, x) >> Cup(x, x.r) @ Id(x)
right_snake =  Cap(x, x.l) @ Id(x) >> Id(x) @ Cup(x.l, x)
assert left_snake.normal_form() == Id(x) == right_snake.normal_form()

snake equations, with types

In particular, discopy can draw the grammatical structure of natural language sentences encoded as reductions in a pregroup grammar (see Lambek, From Word To Sentence (2008) for an introduction).

from discopy import pregroup, Word

s, n = Ty('s'), Ty('n')
Alice, Bob = Word('Alice', n), Word('Bob', n)
loves = Word('loves', n.r @ s @ n.l)

sentence = Alice @ loves @ Bob >> Cup(n, n.r) @ Id(s) @ Cup(n.l, n)
pregroup.draw(sentence, path='docs/imgs/alice-loves-bob.png')

Alice loves Bob

Functors & Meanings

Functors compute the meaning of a diagram, given a meaning for each box. Free functors (i.e. from diagrams to diagrams) can fill each box with a complex diagram, the result can then be simplified using diagram.normalize() to remove the snakes.

love_box = Box('loves', n @ n, s)
love_ansatz = Cap(n.r, n) @ Cap(n, n.l) >> Id(n.r) @ love_box @ Id(n.l)
ob, ar = {s: s, n: n}, {Alice: Alice, Bob: Bob, loves: love_ansatz}
A = RigidFunctor(ob, ar)
rewriting_steps = A(sentence).normalize()
Diagram.to_gif(A(sentence), diagrams=rewriting_steps
               path='docs/imgs/autonomisation.gif')

autonomisation

Functors into the category of matrices evaluate a diagram as a tensor network using numpy. Applied to pregroup diagrams, matrix functors implement the distributional compositional (DisCo) models of Clark, Coecke, Sadrzadeh (2008).

import numpy as np
from discopy import MatrixFunctor

ob = {s: 1, n: 2}
ar = {Alice: [1, 0], loves: [0, 1, 1, 0], Bob: [0, 1]}
F = MatrixFunctor(ob, ar)

assert F(sentence) == np.array([1])

Getting Started

pip install discopy

Documentation

The documentation is hosted at readthedocs.io, you can also checkout the notebooks for a demo!

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

discopy-0.2.1.tar.gz (31.5 kB view hashes)

Uploaded Source

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