<?xml version="1.0"?>
<?xml-stylesheet type="text/css" href="http://140-77-166-78.cprapid.com/mediawiki/skins/common/feed.css?303"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>http://140-77-166-78.cprapid.com/mediawiki/index.php?action=history&amp;feed=atom&amp;title=Proof-nets</id>
		<title>Proof-nets - Revision history</title>
		<link rel="self" type="application/atom+xml" href="http://140-77-166-78.cprapid.com/mediawiki/index.php?action=history&amp;feed=atom&amp;title=Proof-nets"/>
		<link rel="alternate" type="text/html" href="http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;action=history"/>
		<updated>2026-04-12T05:49:55Z</updated>
		<subtitle>Revision history for this page on the wiki</subtitle>
		<generator>MediaWiki 1.19.20+dfsg-0+deb7u3</generator>

	<entry>
		<id>http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=587&amp;oldid=prev</id>
		<title>Lionel Vaux: fix wording</title>
		<link rel="alternate" type="text/html" href="http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=587&amp;oldid=prev"/>
				<updated>2013-06-25T14:41:46Z</updated>
		
		<summary type="html">&lt;p&gt;fix wording&lt;/p&gt;
&lt;table class='diff diff-contentalign-left'&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
			&lt;tr valign='top'&gt;
			&lt;td colspan='2' style=&quot;background-color: white; color:black;&quot;&gt;← Older revision&lt;/td&gt;
			&lt;td colspan='2' style=&quot;background-color: white; color:black;&quot;&gt;Revision as of 14:41, 25 June 2013&lt;/td&gt;
			&lt;/tr&gt;&lt;tr&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
  &lt;td class=&quot;diff-marker&quot;&gt;−&lt;/td&gt;
  &lt;td style=&quot;background: #ffa; color:black; font-size: smaller;&quot;&gt;&lt;div&gt;We &lt;span class=&quot;diffchange diffchange-inline&quot;&gt;can have a look at&lt;/span&gt; [[a formal account of nets]], but it is probably not the best way to learn about proof-nets if you have never seen them before.&lt;/div&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-marker&quot;&gt;+&lt;/td&gt;
  &lt;td style=&quot;background: #cfc; color:black; font-size: smaller;&quot;&gt;&lt;div&gt;We &lt;span class=&quot;diffchange diffchange-inline&quot;&gt;provide&lt;/span&gt; [[a formal account of nets]], but it is probably not the best way to learn about proof-nets if you have never seen them before.&lt;/div&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Lionel Vaux</name></author>	</entry>

	<entry>
		<id>http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=559&amp;oldid=prev</id>
		<title>Olivier Laurent: Link to a formal account of nets.</title>
		<link rel="alternate" type="text/html" href="http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=559&amp;oldid=prev"/>
				<updated>2012-08-31T15:24:11Z</updated>
		
		<summary type="html">&lt;p&gt;Link to &lt;a href=&quot;/mediawiki/index.php/A_formal_account_of_nets&quot; title=&quot;A formal account of nets&quot;&gt;a formal account of nets&lt;/a&gt;.&lt;/p&gt;
&lt;table class='diff diff-contentalign-left'&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
			&lt;tr valign='top'&gt;
			&lt;td colspan='2' style=&quot;background-color: white; color:black;&quot;&gt;← Older revision&lt;/td&gt;
			&lt;td colspan='2' style=&quot;background-color: white; color:black;&quot;&gt;Revision as of 15:24, 31 August 2012&lt;/td&gt;
			&lt;/tr&gt;&lt;tr&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-empty&quot;&gt;&amp;#160;&lt;/td&gt;
  &lt;td class=&quot;diff-marker&quot;&gt;+&lt;/td&gt;
  &lt;td style=&quot;background: #cfc; color:black; font-size: smaller;&quot;&gt;&lt;div&gt;We can have a look at [[a formal account of nets]], but it is probably not the best way to learn about proof-nets if you have never seen them before.&lt;/div&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Olivier Laurent</name></author>	</entry>

	<entry>
		<id>http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=555&amp;oldid=prev</id>
		<title>Lionel Vaux: Blanked the page</title>
		<link rel="alternate" type="text/html" href="http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=555&amp;oldid=prev"/>
				<updated>2012-08-31T11:17:57Z</updated>
		
		<summary type="html">&lt;p&gt;Blanked the page&lt;/p&gt;
&lt;a href=&quot;http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;amp;diff=555&amp;amp;oldid=554&quot;&gt;Show changes&lt;/a&gt;</summary>
		<author><name>Lionel Vaux</name></author>	</entry>

	<entry>
		<id>http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=554&amp;oldid=prev</id>
		<title>Lionel Vaux: Created page with &quot;The aim of this page is to provide a common framework for describing linear logic proof nets, interaction nets, multiport interaction nets, and the likes, while factoring out mos…&quot;</title>
		<link rel="alternate" type="text/html" href="http://140-77-166-78.cprapid.com/mediawiki/index.php?title=Proof-nets&amp;diff=554&amp;oldid=prev"/>
				<updated>2012-08-30T23:43:00Z</updated>
		
		<summary type="html">&lt;p&gt;Created page with &amp;quot;The aim of this page is to provide a common framework for describing linear logic proof nets, interaction nets, multiport interaction nets, and the likes, while factoring out mos…&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;The aim of this page is to provide a common framework for describing linear&lt;br /&gt;
logic proof nets, interaction nets, multiport interaction nets, and the likes,&lt;br /&gt;
while factoring out most of the tedious, uninteresting details (clearly not the&lt;br /&gt;
fanciest page of LLWiki).&lt;br /&gt;
&lt;br /&gt;
== Preliminaries ==&lt;br /&gt;
&lt;br /&gt;
=== The short story ===&lt;br /&gt;
&lt;br /&gt;
* the general flavor is that of multiport interaction nets;&lt;br /&gt;
* the top/down or passive/active orientation of cells is related with the distinction between premisses and conclusions of rules, (and in that sense, a cut is not a logical rule, but the focus of interaction between two rules);&lt;br /&gt;
* cuts are thus wires rather than cells/links: this fits with the intuition of GoI, but not with the most common presentations of proof nets;&lt;br /&gt;
* when representing proof nets, we introduce axioms explicitly as cells, so that axiom-cuts do not vanish.&lt;br /&gt;
=== Conventions ===&lt;br /&gt;
&lt;br /&gt;
If &amp;lt;math&amp;gt;A&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;B&amp;lt;/math&amp;gt; are sets, we write &amp;lt;math&amp;gt;A+B&amp;lt;/math&amp;gt; for&lt;br /&gt;
&amp;lt;math&amp;gt;\{0\}\times A \cup \{1\}\times B&amp;lt;/math&amp;gt;.&lt;br /&gt;
More generally,&lt;br /&gt;
&amp;lt;math&amp;gt;A_0+\cdots+A_n=\{0\}\times A \cup {\cdots} \cup \{n\}\times A_n&amp;lt;/math&amp;gt;.&lt;br /&gt;
There are natural bijections &amp;lt;math&amp;gt;A+(B+C)\cong A+B+C \cong (A+B)+C&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Nets ==&lt;br /&gt;
&lt;br /&gt;
=== Wires ===&lt;br /&gt;
&lt;br /&gt;
A ''wiring'' is the data of a finite set &amp;lt;math&amp;gt;P&amp;lt;/math&amp;gt; of ports&lt;br /&gt;
and of a partition &amp;lt;math&amp;gt;{W}&amp;lt;/math&amp;gt; of &amp;lt;math&amp;gt;P&amp;lt;/math&amp;gt; by pairs (the ''wires''):&lt;br /&gt;
if &amp;lt;math&amp;gt;\{p,q\}\in{W}&amp;lt;/math&amp;gt;, we write &amp;lt;math&amp;gt;{W}(p)=q&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;{W}(q)=p&amp;lt;/math&amp;gt;.&lt;br /&gt;
Hence a wiring is equivalently given by&lt;br /&gt;
an involutive permutation &amp;lt;math&amp;gt;{W}&amp;lt;/math&amp;gt; of finite domain &amp;lt;math&amp;gt;P&amp;lt;/math&amp;gt;,&lt;br /&gt;
without fixpoints (forall &amp;lt;math&amp;gt;p&amp;lt;/math&amp;gt;, &amp;lt;math&amp;gt;{W}(p)\not=p&amp;lt;/math&amp;gt;): the wires are then&lt;br /&gt;
the orbits.&lt;br /&gt;
Another equivalent presentation is to consider &amp;lt;math&amp;gt;{W}&amp;lt;/math&amp;gt; as&lt;br /&gt;
a (simple, loopless, undirected) graph, with vertices in P,&lt;br /&gt;
all of degree 1.&lt;br /&gt;
&lt;br /&gt;
We say two wirings are disjoint when their sets of ports are.&lt;br /&gt;
A ''connection'' between two disjoint wirings &amp;lt;math&amp;gt;W&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;W'&amp;lt;/math&amp;gt; is&lt;br /&gt;
a partial injection &amp;lt;math&amp;gt;(I,I',f):P\pinj P'&amp;lt;/math&amp;gt;: &amp;lt;math&amp;gt;I\subseteq P&amp;lt;/math&amp;gt;,&lt;br /&gt;
&amp;lt;math&amp;gt;I'\subseteq P'&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;f&amp;lt;/math&amp;gt; is a bijection &amp;lt;math&amp;gt;I\leftrightarrow I'&amp;lt;/math&amp;gt;.&lt;br /&gt;
We then write &amp;lt;math&amp;gt;W\bowtie_f{{W}'}&amp;lt;/math&amp;gt; for the wiring obtained&lt;br /&gt;
by identifying the ports pairwise mapped by &amp;lt;math&amp;gt;f&amp;lt;/math&amp;gt;, and then&lt;br /&gt;
``straightening`` the paths thus obtained to recover wires:&lt;br /&gt;
notice this might also introduce loops and we write &amp;lt;math&amp;gt;\Inner{W}{W'}_f&amp;lt;/math&amp;gt;&lt;br /&gt;
for the number of loops thus appeared.&lt;br /&gt;
&lt;br /&gt;
We describe these operations a bit more formally.&lt;br /&gt;
Write &amp;lt;math&amp;gt;P = P_0\uplus I&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;P' = P_0'\uplus I'&amp;lt;/math&amp;gt;.&lt;br /&gt;
Then consider the graph &amp;lt;math&amp;gt;W\dblcolon_f{{W}'}&amp;lt;/math&amp;gt; with vertices in&lt;br /&gt;
&amp;lt;math&amp;gt;P\cup P'&amp;lt;/math&amp;gt;, and such that&lt;br /&gt;
there is an edge between &amp;lt;math&amp;gt;p&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;q&amp;lt;/math&amp;gt; iff&lt;br /&gt;
&amp;lt;math&amp;gt;q={W}(p)&amp;lt;/math&amp;gt;,&lt;br /&gt;
&amp;lt;math&amp;gt;q={W'}(p)&amp;lt;/math&amp;gt;,&lt;br /&gt;
&amp;lt;math&amp;gt;q=f(p)&amp;lt;/math&amp;gt;,&lt;br /&gt;
&amp;lt;math&amp;gt;p=f(q)&amp;lt;/math&amp;gt;:&lt;br /&gt;
in other words, &amp;lt;math&amp;gt;W\dblcolon_f{{W}'}=W\cup W'\cup f\cup f^{-1}&amp;lt;/math&amp;gt;.&lt;br /&gt;
Vertices in &amp;lt;math&amp;gt;P_0\cup P'_0&amp;lt;/math&amp;gt;&lt;br /&gt;
are of degree 1, and the others are of degree 2.&lt;br /&gt;
Hence maximal paths in &amp;lt;math&amp;gt;W\dblcolon_f{{W}'}&amp;lt;/math&amp;gt; are of two kinds:&lt;br /&gt;
&lt;br /&gt;
* straight paths, with both ends in &amp;lt;math&amp;gt;P_0\cup P_0'&amp;lt;/math&amp;gt;;&lt;br /&gt;
* cycles, with vertices all in &amp;lt;math&amp;gt;I\cup I'&amp;lt;/math&amp;gt;.&lt;br /&gt;
Then the wires in &amp;lt;math&amp;gt;W\bowtie_f{{W}'}&amp;lt;/math&amp;gt; are the pairs &amp;lt;math&amp;gt;\{p,p'\}&amp;lt;/math&amp;gt; such that&lt;br /&gt;
&amp;lt;math&amp;gt;p&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;p'&amp;lt;/math&amp;gt; are the ends of a path in &amp;lt;math&amp;gt;W\dblcolon_f{{W}'}&amp;lt;/math&amp;gt;.&lt;br /&gt;
And &amp;lt;math&amp;gt;\Inner{W}{W'}_{f}&amp;lt;/math&amp;gt; is the number of&lt;br /&gt;
cycles in &amp;lt;math&amp;gt;W\dblcolon_f{{W}'}&amp;lt;/math&amp;gt;, or more precisely&lt;br /&gt;
the number of support sets of cycles (i.e. we forget about the starting&lt;br /&gt;
vertice of cycles).&lt;br /&gt;
&lt;br /&gt;
{{Lemma|&lt;br /&gt;
Consider three wirings &amp;lt;math&amp;gt;(P,W)&amp;lt;/math&amp;gt;, &amp;lt;math&amp;gt;(P',W')&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;(P'',W'')&amp;lt;/math&amp;gt;,&lt;br /&gt;
and two connections &amp;lt;math&amp;gt;(I,I',f):P\pinj P'&amp;lt;/math&amp;gt; and&lt;br /&gt;
&amp;lt;math&amp;gt;(J',J'',g):P'\pinj P''&amp;lt;/math&amp;gt; such that &amp;lt;math&amp;gt;I'\cap J'=\emptyset&amp;lt;/math&amp;gt;.&lt;br /&gt;
Then&lt;br /&gt;
&lt;br /&gt;
&amp;lt;math&amp;gt; (W\bowtie_f W')\bowtie_g W''=&lt;br /&gt;
  W\bowtie_f(W'\bowtie_g W'')&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
and&lt;br /&gt;
&lt;br /&gt;
&amp;lt;math&amp;gt; \Inner{W}{W'}_{f}+\Inner{(W\bowtie_f{{W}'})}{{W}''}_g=&lt;br /&gt;
    \Inner{W}{(W'\bowtie_g W'')}_f+\Inner{{W}'}{{W}''}_g.&amp;lt;/math&amp;gt;&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
{{Proof|&lt;br /&gt;
The first equation holds because open maximal paths in&lt;br /&gt;
&amp;lt;math&amp;gt;W\dblcolon_f{W\bowtie_g'}{{W}''}&amp;lt;/math&amp;gt; correspond with those in&lt;br /&gt;
&amp;lt;math&amp;gt;W\dblcolon_f{(W'\dblcolon_g{{W}''})}&amp;lt;/math&amp;gt;, hence in&lt;br /&gt;
&amp;lt;math&amp;gt;(W\dblcolon_f W')\dblcolon_g W''&amp;lt;/math&amp;gt;, hence in&lt;br /&gt;
&amp;lt;math&amp;gt;{W\bowtie_f{{W}'}}\dblcolon_g{{W}''}&amp;lt;/math&amp;gt;.&lt;br /&gt;
The second equation holds because both sides are two possible writings for&lt;br /&gt;
the number of loops in &amp;lt;math&amp;gt;{(W\dblcolon_f{{W}'})}\dblcolon_g{{W}''}&amp;lt;/math&amp;gt;&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
=== Nets ===&lt;br /&gt;
&lt;br /&gt;
A ''signature'' is the data of a set&lt;br /&gt;
&amp;lt;math&amp;gt;\Sigma&amp;lt;/math&amp;gt; of symbols, together with arity functions&lt;br /&gt;
&amp;lt;math&amp;gt;\alpha:\Sigma\to\mathbf{N}\setminus\{0\}&amp;lt;/math&amp;gt; (number of&lt;br /&gt;
''active'' ports, or conclusions)&lt;br /&gt;
and &amp;lt;math&amp;gt;\pi:\Sigma\to\mathbf N&amp;lt;/math&amp;gt; (number of&lt;br /&gt;
''passive'' ports, or hypotheses).&lt;br /&gt;
In the remaining, we assume&lt;br /&gt;
such a signature is given.&lt;br /&gt;
&lt;br /&gt;
A ''cell'' &amp;lt;math&amp;gt;c&amp;lt;/math&amp;gt; with ports in &amp;lt;math&amp;gt;P&amp;lt;/math&amp;gt; is the data of&lt;br /&gt;
a symbol &amp;lt;math&amp;gt;\sigma\in\Sigma&amp;lt;/math&amp;gt; and of two disjoint lists&lt;br /&gt;
of pairwise distinct ports:&lt;br /&gt;
&amp;lt;math&amp;gt;\alpha(c)\in P^{\alpha(\sigma)}&amp;lt;/math&amp;gt;&lt;br /&gt;
is the list of ''active'' ports&lt;br /&gt;
and &amp;lt;math&amp;gt;\pi(c)\in P^{\pi(\sigma)}&amp;lt;/math&amp;gt;&lt;br /&gt;
is the list of ''passive'' ports.&lt;br /&gt;
&lt;br /&gt;
A ''net'' is the data of a wiring &amp;lt;math&amp;gt;(P,W)&amp;lt;/math&amp;gt; and of a set &amp;lt;math&amp;gt;C&amp;lt;/math&amp;gt; of disjoint cells on&lt;br /&gt;
&amp;lt;math&amp;gt;P&amp;lt;/math&amp;gt;. It follows from the definitions that each port &amp;lt;math&amp;gt;p\in P&amp;lt;/math&amp;gt; appears in&lt;br /&gt;
exactly one wire and in at most one cell: we say &amp;lt;math&amp;gt;p&amp;lt;/math&amp;gt; is ''free'' if it is&lt;br /&gt;
not part of a cell, and &amp;lt;math&amp;gt;p&amp;lt;/math&amp;gt; is ''internal'' otherwise. We write &amp;lt;math&amp;gt;\textrm{fp}(R)&amp;lt;/math&amp;gt; for&lt;br /&gt;
the set of free ports of a net &amp;lt;math&amp;gt;R&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Generally, the “names” of internal ports of a net are not relevant, but free&lt;br /&gt;
ports matter most often: internal ports are the analogue of bound variables in&lt;br /&gt;
&amp;lt;math&amp;gt;\lambda&amp;lt;/math&amp;gt;-terms.&lt;br /&gt;
More formally, an ''isomorphism'' from net &amp;lt;math&amp;gt;R&amp;lt;/math&amp;gt; to net &amp;lt;math&amp;gt;R'&amp;lt;/math&amp;gt;&lt;br /&gt;
is the data of a bijection of ports &amp;lt;math&amp;gt;\phi:P\leftrightarrow P'&amp;lt;/math&amp;gt; and a bijection&lt;br /&gt;
of cells &amp;lt;math&amp;gt;\psi:C\leftrightarrow C'&amp;lt;/math&amp;gt; such that:&lt;br /&gt;
&lt;br /&gt;
* for all &amp;lt;math&amp;gt;p\in P&amp;lt;/math&amp;gt;, &amp;lt;math&amp;gt;W'(\phi(p))=\phi(W(p))&amp;lt;/math&amp;gt;;&lt;br /&gt;
* for all &amp;lt;math&amp;gt;c\in C&amp;lt;/math&amp;gt;:&lt;br /&gt;
Observe that under these conditions  &amp;lt;math&amp;gt;\psi&amp;lt;/math&amp;gt; is uniquely induced by &amp;lt;math&amp;gt;\phi&amp;lt;/math&amp;gt;.&lt;br /&gt;
We say that the isomorphism &amp;lt;math&amp;gt;\phi&amp;lt;/math&amp;gt; is ''nominal'' if moreover &amp;lt;math&amp;gt;p\in\textrm{fp}(R)&amp;lt;/math&amp;gt;&lt;br /&gt;
implies &amp;lt;math&amp;gt;p=\phi(p)&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
=== Rewriting ===&lt;br /&gt;
&lt;br /&gt;
We say two nets are disjoint when their sets of ports are.&lt;br /&gt;
Let &amp;lt;math&amp;gt;R&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;R'&amp;lt;/math&amp;gt; be disjoint nets,  and &amp;lt;math&amp;gt;(I,I',f)&amp;lt;/math&amp;gt; be a&lt;br /&gt;
connection between &amp;lt;math&amp;gt;W&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;W'&amp;lt;/math&amp;gt;, such that&lt;br /&gt;
&amp;lt;math&amp;gt;I\subseteq \textrm{fp}(R)&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;I'\subseteq \textrm{fp}(R')&amp;lt;/math&amp;gt;.&lt;br /&gt;
We then write &amp;lt;math&amp;gt;R\bowtie_f{R'}&amp;lt;/math&amp;gt; for the net&lt;br /&gt;
with wiring &amp;lt;math&amp;gt;W\bowtie_f{W'}&amp;lt;/math&amp;gt; and cells&lt;br /&gt;
&amp;lt;math&amp;gt;C\cup C'&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
{{Lemma|&lt;br /&gt;
Let &amp;lt;math&amp;gt;R_0&amp;lt;/math&amp;gt;, &amp;lt;math&amp;gt;R_1&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;R'&amp;lt;/math&amp;gt; be nets such that &amp;lt;math&amp;gt;R_0&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;R_1&amp;lt;/math&amp;gt;&lt;br /&gt;
are disjoint from &amp;lt;math&amp;gt;R&amp;lt;/math&amp;gt;,&lt;br /&gt;
&amp;lt;math&amp;gt;(I,I',f)&amp;lt;/math&amp;gt; be a connection &amp;lt;math&amp;gt;\textrm{fp}(R_0)\pinj \textrm{fp}(R')&amp;lt;/math&amp;gt;&lt;br /&gt;
and &amp;lt;math&amp;gt;\phi&amp;lt;/math&amp;gt; an isomorphism &amp;lt;math&amp;gt;R_0\cong R_1&amp;lt;/math&amp;gt; such that&lt;br /&gt;
&amp;lt;math&amp;gt;\phi(p)=\phi(p')&amp;lt;/math&amp;gt; for all &amp;lt;math&amp;gt;p\in\textrm{fp}(R_0)\setminus I&amp;lt;/math&amp;gt;.&lt;br /&gt;
Then &amp;lt;math&amp;gt;R_0\bowtie_f{R'}&amp;lt;/math&amp;gt; is nominally isomorphic to&lt;br /&gt;
&amp;lt;math&amp;gt;R_1\bowtie_f\circ\phi^{-1}{R'}&amp;lt;/math&amp;gt;.&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
A ''net rewriting rule'' is a pair &amp;lt;math&amp;gt;(r_0,r_1)&amp;lt;/math&amp;gt; of nets&lt;br /&gt;
such that &amp;lt;math&amp;gt;\textrm{fp}(r_0)=\textrm{fp}(r_1)&amp;lt;/math&amp;gt;. Then an instance of this rule&lt;br /&gt;
is a pair &amp;lt;math&amp;gt;(R_0,R_1)&amp;lt;/math&amp;gt; such that there exist:&lt;br /&gt;
&lt;br /&gt;
* a nets &amp;lt;math&amp;gt;R'_0&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;R'_1&amp;lt;/math&amp;gt; isomorphic to &amp;lt;math&amp;gt;r_0&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;r_1&amp;lt;/math&amp;gt; respectively, namely &amp;lt;math&amp;gt;R'_i=\phi_i(r_i)&amp;lt;/math&amp;gt;, so that moreover &amp;lt;math&amp;gt;\phi_0(p)=\phi_1(p)&amp;lt;/math&amp;gt; for all &amp;lt;math&amp;gt;p\in\textrm{fp}(r_0)&amp;lt;/math&amp;gt; (in particular, &amp;lt;math&amp;gt;\textrm{fp}(R'_0)=\textrm{fp}(R'_1)&amp;lt;/math&amp;gt;);&lt;br /&gt;
* a net &amp;lt;math&amp;gt;R''&amp;lt;/math&amp;gt;, disjoint from &amp;lt;math&amp;gt;R'_0&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;R'_1&amp;lt;/math&amp;gt;;&lt;br /&gt;
* a connection &amp;lt;math&amp;gt;(\textrm{fp}(R'_0),J,f):\textrm{fp}(R'_0)\pinj \textrm{fp}(R'')&amp;lt;/math&amp;gt;;&lt;br /&gt;
such that each &amp;lt;math&amp;gt;R_i&amp;lt;/math&amp;gt; is nominally isomorphic to&lt;br /&gt;
&amp;lt;math&amp;gt;R'_i\bowtie_f{R''}&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
=== Typing ===&lt;br /&gt;
&lt;br /&gt;
A typing system on signature &amp;lt;math&amp;gt;\Sigma&amp;lt;/math&amp;gt; is the data of a&lt;br /&gt;
set &amp;lt;math&amp;gt;\Theta&amp;lt;/math&amp;gt; of types, an involutive negation &amp;lt;math&amp;gt;\cdot\orth:\Theta\to\Theta&amp;lt;/math&amp;gt;,&lt;br /&gt;
together with a typing discipline for each symbol, ''i.e.'' a relation&lt;br /&gt;
&amp;lt;math&amp;gt;\Theta(\sigma)\subseteq\Theta^{\alpha(\sigma)}\times\Theta^{\pi(\sigma)}&amp;lt;/math&amp;gt;.&lt;br /&gt;
We then write &amp;lt;math&amp;gt;A_1,\cdots,A_{\pi(\sigma)}\vdash_\sigma&lt;br /&gt;
B_1,\cdots,B_{\alpha(\sigma)}&amp;lt;/math&amp;gt; for &amp;lt;math&amp;gt;(\vec A,\vec B)\in\Theta(\sigma)&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Then a ''typing'' for net &amp;lt;math&amp;gt;R=(P,W,C)&amp;lt;/math&amp;gt; is a function &amp;lt;math&amp;gt;\tau:P\to \Theta&amp;lt;/math&amp;gt;&lt;br /&gt;
such that:&lt;br /&gt;
&lt;br /&gt;
* for all &amp;lt;math&amp;gt;p\in P&amp;lt;/math&amp;gt;, &amp;lt;math&amp;gt;\tau(W(p))=\tau(p)\orth&amp;lt;/math&amp;gt;;&lt;br /&gt;
* for all &amp;lt;math&amp;gt;c\in C&amp;lt;/math&amp;gt; of symbol &amp;lt;math&amp;gt;\sigma&amp;lt;/math&amp;gt;, &amp;lt;math&amp;gt;\tau(\pi(c))\vdash\tau(\alpha(c))\orth&amp;lt;/math&amp;gt;;&lt;br /&gt;
where, in the last formula, we implicitly generalized&lt;br /&gt;
&amp;lt;math&amp;gt;\tau&amp;lt;/math&amp;gt; to lists of ports and &amp;lt;math&amp;gt;\cdot\orth&amp;lt;/math&amp;gt; to lists of formulas,&lt;br /&gt;
in the obvious, componentwise fashion.&lt;br /&gt;
The ''interface'' of the typed net &amp;lt;math&amp;gt;(R,\tau)&amp;lt;/math&amp;gt; is then&lt;br /&gt;
the restriction of &amp;lt;math&amp;gt;\tau&amp;lt;/math&amp;gt; to &amp;lt;math&amp;gt;\textrm{fp}(R)&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
The idea, is that a wire &amp;lt;math&amp;gt;{p,q}&amp;lt;/math&amp;gt;, bears the type &amp;lt;math&amp;gt;\tau(q)&amp;lt;/math&amp;gt; (resp. &amp;lt;math&amp;gt;\tau(p)&amp;lt;/math&amp;gt;) in&lt;br /&gt;
the direction &amp;lt;math&amp;gt;(p,q)&amp;lt;/math&amp;gt; (resp. &amp;lt;math&amp;gt;(q,p)&amp;lt;/math&amp;gt;), so that a rule&lt;br /&gt;
&amp;lt;math&amp;gt;\vec A\vdash_\sigma \vec B&amp;lt;/math&amp;gt; reads as an inference from passive inputs (hypotheses)&lt;br /&gt;
to active outputs (conclusions).&lt;br /&gt;
&lt;br /&gt;
Observe that if &amp;lt;math&amp;gt;(R,\tau)&amp;lt;/math&amp;gt; is a typed net, and&lt;br /&gt;
&amp;lt;math&amp;gt;\phi:R\leftrightarrow R'&amp;lt;/math&amp;gt; is an isomorphism,&lt;br /&gt;
then &amp;lt;math&amp;gt;R'&amp;lt;/math&amp;gt; is typed and its interface is &amp;lt;math&amp;gt;\tau\circ\phi^{-1}&amp;lt;/math&amp;gt;:&lt;br /&gt;
in particular, if &amp;lt;math&amp;gt;\phi&amp;lt;/math&amp;gt; is nominal, &amp;lt;math&amp;gt;R'&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;R&amp;lt;/math&amp;gt; have the same interface.&lt;br /&gt;
&lt;br /&gt;
Now let &amp;lt;math&amp;gt;(R,\tau)&amp;lt;/math&amp;gt; and &amp;lt;math&amp;gt;(R',\tau')&amp;lt;/math&amp;gt; be typed nets&lt;br /&gt;
and &amp;lt;math&amp;gt;(I,I',f)&amp;lt;/math&amp;gt; a connection so that &amp;lt;math&amp;gt;\tau'\circ f&amp;lt;/math&amp;gt; and&lt;br /&gt;
&amp;lt;math&amp;gt;\tau\orth=\cdot\orth\circ\tau&amp;lt;/math&amp;gt; coincide on &amp;lt;math&amp;gt;I&amp;lt;/math&amp;gt;.&lt;br /&gt;
Then this induces a typing of &amp;lt;math&amp;gt;R\bowtie_f{R'}&amp;lt;/math&amp;gt;&lt;br /&gt;
preserving the interface on the remaining free ports.&lt;br /&gt;
&lt;br /&gt;
=== Boxes ===&lt;br /&gt;
&lt;br /&gt;
TODO&lt;/div&gt;</summary>
		<author><name>Lionel Vaux</name></author>	</entry>

	</feed>