Abstract. We introduce Non-deterministic Boolean proof nets to study the correspondence with Boolean circuits, a parallel model of computation. We extend the cut elimination of Non-deterministic Multiplicative Linear logic to a parallel procedure in proof nets. With the restriction of proof nets to Boolean types, we prove that the cut-elimination procedure corresponds to Non-deterministic Boolean circuit evaluation and reciprocally. We obtain implicit characterization of the complexity classes NP and NC (the efficiently parallelizable functions).
Introduction
The proof nets [Gir87, DR89] of the Linear logic (LL) are a parallel syntax for logical proofs without all the bureaucracy of sequent calculus. Their study is also motivated by the well known Curry-Howard isomorphism: there is a correspondence between proofs and programs which associates cut-elimination in proofs and execution in functional programs. Proof nets were used in subsystems of LL to give Curry-Howard characterizations of complexity classes. Usually this is done in LL by reducing the deductive power of the exponentials connectives, also known as modalities, controlling duplication in cut-elimination process. The most known restrictions characterize P , the class of decision problems which can be solved in polynomial time. E.g. it is the case of the Intuitionistic Light Affine Logic (ILAL). By expressing non-determinism by an explicit rule to choose between proofs of the same formula, the Non-deterministic extension of ILAL characterizes quite naturally NP [Mau03] . This sum rule is a logical counterpart to non-deterministic choice in process calculi. With proof nets, other characterizations were given by correspondence with models of parallel computation like Boolean circuits as we shall see later. In this paper we make use of the sum rule to extend those proof nets to a non-deterministic framework.
Boolean circuits are a standard models of parallel computation [Coo85, BS90] [Vol99]. Several important complexity classes are defined in terms of Boolean circuits. E.g. NC can be thought of as the problems that can be efficiently solved on a parallel computer just as the class P can be thought of as the tractable problems. Because a Boolean circuit has a fixed input size, an infinite family of Boolean circuits is needed to do computations on arbitrary inputs. With a Work partially supported by the french project Complice (ANR-08-BLANC-0211-01) uniformity property, a family can be however regarded as an implementation of an algorithm. The Boolean circuit depth is the time on a parallel computer where the size is the number of processors. For instance NC is the set of Boolean functions computable by uniform Boolean circuits of polynomial size and polylogarithmic depth.
By restricting proved formulas and with a logical depth notion, there is a proofs-as-programs correspondence between proof nets and NC such that both size and depth are preserved [Ter04] . In this setting, the proof nets allow among others to simulate gates by higher order. Here we consider a nondeterministic extension of proof nets, to give a proof-as-programs correspondence with NNC (k(n)), the class defined from NC Boolean circuits with O(k(n)) nondeterministic variables. In particular NC = NNC (log n) and NP = NNC (poly). So the Curry-Howard isomorphism for parallel model of computation gives us new tools to study theoretical implicit complexity.
In section 2 we present MLL u , the multiplicative LL with arbitrary arity This is the smallest fragment of LL that encodes the unbounded fan-in Boolean circuits [Ter04] . We recall the reduction steps of the cut-elimination. We give its non-deterministic extension nMLL u and proof nets for it as in [Mau03] . We recall several size and depth notions used in the proofs, all are natural graph theoretic notions. In section 3 we mostly analyze and define a new cut elimination from a parallel point of view. We prove the central theorems which allow us to establish the results on the complexity classes. In section 4 we recall Boolean circuit definitions. They include uniformity of both proof net families and circuit families as well as hierarchy of NC and NNC (). We introduce the Boolean proof nets of nMLL u , i.e with sum-boxes, which generalize the Boolean proof nets of MLL u . In section 5 we apply the previous theorems to our Boolean proof nets with sum-boxes and we establish a proofs-as-programs correspondence with NNC () Boolean circuits. They are translation and simulation theorems that preserve both size and depth of the Boolean proof nets and Boolean circuits. Finally in section 6 we summarize the obtained results via UBPN (), a hierarchy of proof net complexity classes defined analogously to the NNC () hierarchy. The classes UBPN (poly), UBPN (polylog) and UBPN (1) of uniform Boolean proof net families with respectively n O(1)
, log O(1) n and O(1) sum-boxes are respectively equal to NP , NNC (polylog) and NC.
2 Non-deterministic Linear logic
Formulas, Sequent calculus and cut-elimination
We write − → A (respectively ← − A ) for an ordered sequence of formulas A 1 , . . . , A n (resp. A n , . . . , A 1 ).
The formulas of MLL u and nMLL u are built on literals by conjunction n ( − → A ) and disjunction n ( ← − A ) of Multiplicative Linear logic but with unbounded arities n 1. The only difference with binary connectives is that this gives us depth-efficient proofs [DR89] . The negation of a non-literal formula is defined by De Morgan's duality: (
where the negation applies to sequences of formulas as expected.
The sequents of nMLL u are of the form Γ , where Γ is a multiset of formulas. The rules of the nMLL u sequent calculus are described in Fig.1 . As in Linear logic sequent calculus, MLL u and nMLL u admit a cut-elimination theorem (Hauptsatz) and implicit exchange. The cut-elimination steps of nMLL u (a) sequent calculus are n-ary versions of the Linear logic proofs rewriting: an axiom cut (i.e. a cut rule with an axiom premise) rewrites without the axiom rule, and the multiplicative cut (i.e. a cut rule between multiplicative formulas) rewrites in sequence of cuts between premises. In Fig.2 we give the sum-rule cut-elimination step as in [Mau03] . 
Proof nets and reduction rules
We suppose the reader familiar with proof nets and more specifically with the reduction rules corresponding to the cut-elimination steps [Gir96] . A proof net [Gir87,DR89] is a graph that just keeps the structure of sequent calculus proofs without some computational irrelevant part. It is a set of connected links that we build by inference from the sequent calculus rules. There to MLL u rules. Every link has several ports numbered by convention as in Fig.3 . This numbering is omitted when there is no ambiguity. The conclusion port, also called conclusion of the link, is the port numbered 0. We use a wire between two conclusion ports rather than a cut-link that corresponds to sequent calculus cutrule. Now we focus us on the nMLL u proof nets which extend those of MLL u . As we only consider proof nets inferred from sequent calculus, we can inductively built them in a equivalent way from the ax-links with the constructors of Fig. 4 . The sequent calculus sum-rule corresponds to a box (Fig.4) , called sum-box, enclosing proof nets, called sub-nets, such that we associate one -link for each shared conclusion. 
giving the sort of each link, (iii) a symmetric binary relation over L × N for each wire between two ports of distinct links, and (iv) a function τ : L → N which associates to each link a unique number corresponding to the sum-box that encloses it.
A summand of a proof net is a proof net obtained by erasing all but one sub-net in every sum-box.
In section 4 we give a Logspace description which extends this one. We call the conclusions of a proof net the set of links whose conclusion ports are unrelated with other link ports. We write proof nets either with graphs or just with the link names. For instance the last proof net in Fig.4 is sum(S 1 , . . . , S n ).
Remark that in every summand of a proof net the -links correspond to superfluous sum-rules with only one premise. So every summand of a proof net of nMLL u easily induces a proof net of MLL u .
Definition 2. The reduction rules 1 for MLL u proof nets, called respectively axreduction and m-reduction, are defined by:
For nMLL u proof nets there are moreover the reduction rules [Mau03] , called respectively merge-reduction and down-reduction, defined for an arbitrary context C by:
1 Up to the order when they are not drawn
We define various notions of depth in a natural way: the box-depth associated to sum-boxes, the depth of formulas and the logical depth associated to cuts.
Definition 3. The box-depth b(l) of a link l is the number of sum-boxes that enclose it. The box-depth of a sum-box is the box-depth of its -link links. The box-depth b(P ) of a proof net P is the maximal box-depth of its links.
The depth d(A) of a formula A in a sequent calculus derivation π is the length of the longest sequence of rules in π since axioms until the introduction of the formula A. The depth d(π) of a nMLL u sequent calculus derivation π is the maximal depth of its cut formulas.
The logical depth c(P ) of a proof net P is c(P ) = min{d(π) | P is inferred by the sequent calculus derivation π}. We write c(P ) the logical depth without counting the sum-rules.
Remark that by definition all -links of the same sum-box are at same boxdepth. When a proof net is induced by a sequent calculus proof, he keeps traces of sequentialization by the sum-boxes. This corresponds to a stratification by the box-depth that we use in our reduction strategy.
The size |P | of a proof net P is the number of links in P such that we count boxes but not the -links.
Parallel reductions
Like the cut-elimination of sequent calculus the reduction of proof net is terminating. Even if the reduction of proof nets has the Church-Rosser property, reductions cannot be done in parallel as there is critical pairs. A critical pair arises when redexes of reduction rules overlap. In order to have efficient proof net reductions we consider all possible critical pairs. E.g. a cut between two distinct axioms has two overlapping redexes depending on if we consider one or the other axioms. This is solved for MLL u in [Ter04] by introducing a tightening reduction: one reduces each maximal alternating chain of cuts and axioms in only one global step leading to what is expected by sequential reduction steps. Here is an example where the maximal chain starts with a cut and finishes with an axiom:
We define various notions of depth in a natural way: the box-depth associated to sum-boxes, the depth of formulae and the logical depth associated to cuts.
Remark that by definition all -links of the same sum-box are at same boxdepth. If we consider stratification of boxes then the depth and the logical depth can be decomposed in partial depths. We write it with indexes for the box-depths as follows:
The size |P | of a proof net P is the number of links in P such that we count boxes but not the -links. The partial size |P | x of a proof net P for a sum-box x is the size of P restricted by the box-depth x: |P | = 0xb(P ) |P | x .
Like the cut-elimination of sequent calculus the reduction of proof net is terminating. Even if the reduction of proof nets has the Church-Rosser property, reductions cannot be done in parallel as there is critical pairs. A critical pair arises when redexes of reduction rules overlap. In order to have efficient proof net reductions we consider all possible critical pairs. E.g. a cut between two distinct axioms has two overlaping redexes depending on if we consider one or the other axioms. This is solved for MLL u in [Ter04] by introducing a tightening reduction: one reduces each maximal alternating chain of cuts and axioms in only one global step leading to what is expected by sequential reduction steps.
Here is an example where the maximal chain starts with a cut and finishes with an axiom:
Remark that by maximality, no critical pairs can be tightening redexes. So such reductions can be done in parallel. We denote t-reduction a tightening reduction and we write it → t . We write ⇒ t the parallel → t reductions. As → m redexes are never critical pairs we write ⇒ m the parallel → m reductions. In the rest of the paper we write ⇒ k for k parallel reduction steps (⇒ t or ⇒ m ) in MLL u .
5
Remark that by maximality, no critical pairs can be tightening redexes. So such reductions can be done in parallel. We denote t-reduction a tightening reduction and we write it → t . We write ⇒ t for the simultaneous application of all the → t reductions that can be fired in a given proof net. As → m redexes are never critical pairs we also write ⇒ m for the simultaneous → m reductions. In the rest of the paper we write ⇒ k for k parallel reduction steps (⇒ t or ⇒ m ) in MLL u . In this section we introduce new reduction rules to answer the parallelization question for nMLL u such that reduction is confluent. We will give a bound on the number of reductions to normalize a proof net (theorem 1).
Parallel reductions of merged sum-boxes
The merge rules applied to distinct sum-boxes immediately within a same sumbox are not really a conflict case even if it is a critical pair. We could merge them in parallel if the sum-box itself would not be merged at the same time. Because the merge-rule is confluent one can consider a global rewriting rule by merging sum-boxes as expected. This corresponds to a sort of innermost sequential strategy. We define a new reduction → M whose redex is a maximal tree of successively nested sum-boxes. So the root of the tree of sum-boxes is an outermost sum-box that cannot be merged further. The → M reduction merges this tree in the root sum-box as it is mimicked in Fig.5 . We do not draw neither wires between the -links nor the sub-nets which are not sum-boxes. By maximality this reduction has no critical pairs, so we can do simultaneously → M reductions.
In this section we introduce new reduction rules to answer the parallelization question for nMLL u such that reduction is confluent. We will give a bound on the number of reductions to normalize a proof net (theorem 1).
Applications of merge rules in distinct summands of the same sum-box are not a conflict case. We can apply merge rules in parallel on them if the sum-box itself would not be merged at the same time. Because the merge-rule is confluent one can easily consider a global rewriting rule by merging sum-boxes as expected. We reduce a sub-net composed of maximal successive sum-boxes in only one step: the sub-net starts with a tree of sum-boxes and is disjoint of all other merge redexes by maximality. The reduction merges this sum-box tree. We write it → M . To simplify the presentation we symbolically describe the corresponding rule in Fig.5 where we write only the links of one sum-box with a simple square. Definition 4. Let B be a sum-box and let S be a summand of B. Let {B i } i∈I be the family of sum-boxes of S such that b(B i ) = b(B) + 1 for all i ∈ I. Let C be the context of the B i with relation to S i.e. S = C[{B i } i∈I ]. Let B i be the family of summands of B i i.e. B i = sum(B i ). The section AF of a family F = {B i } i∈I is a family A = {a i } i∈I such that for all i ∈ I we have a i ∈ B i . We defined the reduction of a summand S = C[{sum(B i )} i∈I ] of a sum-box by:
We abusively use a set to denote the reduct but the corresponding family is easily obtained from the implicit order associated to sections. 
Parallel down-reductions
According to the context C, the pattern sum(C[sum(
can reveal a critical pair for the down rule. E.g. within a sum-box cut(sum(A 1 , A 2 ), sum(B 1 , B 2 )) reduces to sum(sum({cut(A i , B j )} 1 i,j 2 ))) in four → down steps. The same holds for a more general context C but remains convergent. So we define a new reduction rule based on the mathematical notion of section of indexed family of elements.
Definition 4. Let B be a sum-box and let S be a sub-net of B, i.e. B = sum( − → X , S). Let {B i } i∈I be the family of nested sum-boxes of B in S, i.e. B i ⊂ S and b(B i ) = b(B) + 1 for all i ∈ I. Let C be the context of the B i with relation to S, i.e. S = C[{B i } i∈I ]. We write B i the family of sub-nets of B i , i.e. B i = sum(B i ). The section A F of a family F = {B i } i∈I is a family A = {a k } k∈I such that for all k ∈ I we have a k ∈ B i . We define → B the reduction of a sub-net of a sum-box B by:
We abusively use a set to denote the reduct but the corresponding family is easily obtained from the implicit order associated to sections. The intuition is to reduce in one (parallelizable) reduction step the sum-boxes B i of one sub-net S, merging only affected sum-boxes: the result is a set of subnets which are the combination of all the contents of the B i and the context outside the B i . So the sum-boxes B i go down whereas contexts go up. Remark that if the family of B i is such that each B i contains exactly one sub-net then by definition the context C applies on this set of sub-nets.
We give an example: let B 1 = sum(a 1 , a 2 ) and B 2 = sum(b 1 , b 2 ), let C be a context without other sum-boxes than B 1 and B 2 . We have:
. Remark that the affected sum-boxes were merged by our reduction, but just to have a more readable definition. This reduction rule is a generalization of the case of context composed only with cut sum-boxes: in such case we need to reduce at fixed box-depth after all other reductions at this box-depth. But without this generalization we are not able to decrease at the same time the logical depth.
We redefine now → B as the previous reduction extended to all sub-nets of the same sum-box B. This reduction is well defined as sub-nets are disjoints. We write ⇒ D x such reductions applied in parallel to every sum-box at the same box-depth x − 1. By this way the sum-boxes at box-depth x go down. We do this in order to have no conflicts. For a given proof net P , we write ⇒ D b(P ) the reduction sequence ⇒ D b(P ) · · · ⇒ D 1 . So with our new reduction rule and our strategy we have the following remarkable properties: Lemma 1. Let P be a proof net such that b(P ) > 0. If sum(P )⇒ D b(P ) sum(P ) then b(P ) = b(P ) − 1 and c(P ) = c(P ).
Proof. Let S be a sub-net of a sum-box B of box-depth b(P ) − 1 in sum(P ). We have b(S) = 1. By definition each link in the reduct of S by → B has the box-depth b(P ) − 1. It is the same for all sub-nets of B by → B reduction. By definition the ⇒ D b(P ) reduction applies to all sum-boxes of box-depth b(P ) − 1 in sum(P ). So the conclusion follows.
The above Lemma implies the following:
Lemma 2. Let P be a proof net such that b(P ) > 0.
i) c(P ) = c(P ) and b(P ) = 0 i.e. P is sum-box free. ii) For all choice of summand s i for i ∈ I, s i (sum(P )) ⇒ c(P ) P i cut-free.
Theorem 1.
There is a sequence of O(c(P ) + b(P )) parallel reductions which reduces a nMLL u proof net P in a cut-free one.
Proof. Let P defined from P as in lemma 2. Because all the summands s i for i ∈ I are pairwise disjoint we have ∪ i∈I s i (sum(P )) ⇒ c(P ) ∪ i∈I P i cut-free. So
gives a cut-free proof net.
Boolean circuits and Boolean proof nets
In this section we recall the definitions and some properties of Boolean circuits and Boolean proof nets. We give also certain relationships between complexity classes associated to Boolean circuits [Coo85,All89,Wol94,Par89]. The novelties concern only the Boolean proof nets of nMLL u that extend those of MLL u .
Boolean circuits
A basis is a finite set of sequences of Boolean functions. The standard basis are B 0 = {¬, ∧, ∨} and
The circuits over basis with an infinite sequence of Boolean functions (resp. without) are called unbounded fan-in (resp. bounded fan-in) circuits. We extend the basis with a stCONN 2 gate to test the strong connectivity of an edge set given in input. As in [Ter04] we will use this gate to simulate the tightening reduction of proof nets.
Definition 5. A deterministic Boolean circuit with n inputs over a basis B is a directed acyclic graph with n + 1 sources or inputs (vertices with no incoming edges) and one sink or output (a vertex with no out-going edges). Sources are labeled by literals from {x 1 , . . . , x n } ∪ {1} and nodes of in-degree k are labeled by one of the k-ary Boolean functions of B. Non-inputs nodes are called gates, and in-degree and out-degree are called fan-in and fan-out respectively. Let F n be the set of all Boolean functions f : {0, 1} n → {0, 1} for some n ∈ N. A deterministic circuit computes a function in F n (or accepts a set X ⊆ {0, 1} n ) in a natural way. A non-deterministic Boolean circuit C with n inputs over a basis B with k nondeterministic variables [Wol94, Par89] is a circuit with n + k + 1 sources labeled by {x 1 , . . . , x n } ∪ {y 1 , . . . , y k } ∪ {1} s.t. it computes a function f ∈ F n as follows: for x ∈ {0, 1} n , f (x) = 1 iff ∃y ∈ {0, 1} k a witness s.t. C(x, y) evaluates to 1. A family of circuits C = (C n ) n∈N computes a function f : {0, 1} * → {0, 1} (or accepts a set X ∈ {0, 1} * ) if for every n ∈ N the circuit C n computes the restriction of f to F n . The size of a circuit is the number of gates and the depth is the length of a longest directed path.
Boolean proof nets
Boolean values are represented with the type B = 
Definition 6 ([Ter04]).
A Boolean proof net with n inputs − → p = p 1 , . . . , p n , one output and k(n) sum-boxes is a proof net P ( − → p ) of nMLL u of type:
with k(n) a function of n, and some
. . , C m where we denote B[A] the formula B where all occurrences of α are substituted by A. Given − → x ≡ b i1 , . . . , b in we write P ( − → x ) the proof net where we cut every
Without loss of generality we can always set sum(P ) for P : if a Boolean proof net P is without sum-boxes then sum(P ) is a sum-box with only one summand in MLL u . This generalizes uniform MLL u Boolean proof nets. We often omit this initial sum-box for the sake of simplicity. Following the definition, for a given − → x ≡ b i1 , . . . , b in , a Boolean proof net
(B, − → C ) and reduces in a unique cut-free proof net of the same type (e.g. by the reduction sequence of the previous section). We say that sum(P ( − → x )) evaluates to 1 iff one of its summands is b 1 with some garbage − → C . There is an asymmetry between 1 and 0 as for non-deterministic Turing machines.
Definition 7 ([Ter04]). A Boolean proof net
The Boolean proof net encoding of K. Terui [Ter04] of functions as negation, conditional, disjunction, composition, duplication, and so on, is trivially valid in the extended setting of nMLL u . We give some of them in the Appendix.
Uniformity and complexity classes
The given notions are used for Boolean circuit families and for nMLL u proof net families. Both are denoted by F = (F n ) n∈N . From an algorithmic point of view the uniformity is an important issue because only a uniform family can be regarded as an implementation of an algorithm.
there is a function which computes a description of F n from 1 n (unary numeral) in space O(log |F n |)) (respectively in time |F n |
O(1)
).
A description means all informations about elements like sort, predecessors, ... Usually the description is also chosen according to the uniformity notion used. Because we work with NP the P -uniformity is sufficient [All89] . Nevertheless if we want to study a property in NC then we use the L-uniformity with the following notion of description where links and sorts are identified by binary numbers. Let W be the set of binary words and let x be the binary representation of the integer x.
The direct connection language L DC (C) of a Boolean circuit family C = (C n ) n∈N over basis B is the set of tuples y, g, w, b ∈ W 4 , where for y = n we have g is a gate in C n labeled by the function b from B if w = ε else b is the w th predecessor gate of g. In case of input, b is not a function but a sort (deterministic input or non-deterministic variable).
This definition adapted to MLL u proof nets [MR07] is here extended analogously to nMLL u proof nets:
Definition 10. The direct connection language L DC (P ) of a nMLL u proof net family P = (P n ) n∈N is the set of tuple y, l, w, b, s ∈ W 5 where for y = n we have l is a link in P n of sort b if w = ε else the w th premise of l is the link b. The link l is also enclosed by the s th sum-box.
Remark that the length of all identifiers of such family P is bounded by log |P |.
We finish this section recalling the complexity classes defined with uniform families of Boolean circuits ([Coo85,All89,Vol99] and [Wol94, Par89] for nondeterministic Boolean circuits). All dimensions are defined w.r.t the length of the input, which we write everywhere n. We use abusively the words poly for n O(1) and polylog for log 
Logspace translation
Let C = (C n ) n∈N be a uniform Boolean circuit family over the basis B 1 (stCONN 2 ) with non-deterministic variables. The intermediate proof nets we build are called modules. First of all without distinguishing the inputs, we associate a uniform Boolean proof net family P = (P n ) n∈N to C using uniformity. After what we consider non-deterministic variables. Indeed the uniformity function of Boolean circuits builds the uniformity function of Boolean proof nets in the same way as in [MR07] . The main idea is already given in [Ter04] . Starting from L DC (C): -For each n-fan-in gate labeled f (n) read in L DC (C n ) we give a polysize module computing f (n). If the gate is a non-deterministic variable we cut the corresponding input with the proof net b 2 ≡ sum(b 0 , b 1 ), -For each n-fan-out gate read in L DC (C n ) we make a polysize duplication, -For each edge read in L DC (C n ) we joint modules and duplications.
Just parsing the L DC (C n ) for i = 0 to |C n | we detail a Logspace translation into L DC (P n ): everything is identified with a binary number 1. For each n, i, ε, b we build the module associated to the function b of the basis of the family (or to the sort b in case of inputs). It is a subset of L DC (P n ) where relationships between links and sorts are given. 2. If there are several n, i, k, j (i.e. j is the k-th predecessor of i) for fixed n and j then the fan-out of j is multiple. We build the corresponding duplication. It is again a subset of L DC (P n ). 3. For each n, i, k, j (i.e. j is the k-th predecessor of i) we build n, a, b, c, 0 (i.e. an edge from (a, 0) to (b, c)) where a is the link associated to the output of the module (step 1) corresponding to j and b is the link associated to the c-th input of the module corresponding to i, modulo added duplications.
The novelty is the translation of non-deterministic variables into cuts with b 2 ≡ sum(b 0 , b 1 ). Only in this case the last bit of the description is not null.
Theorem 2. For every uniform family C of unbounded fan-in Boolean circuit of size s and depth c over the basis B 1 (stCONN 2 ) and with k(n) non-deterministic variables, there is a uniform family of Boolean proof nets of nMLL u of size s
and logical depth O(c) and with k(n) sum-boxes, which accepts the same set as C does.
Proof. Let C n ∈ C and P n ∈ P the Boolean proof net obtained by translation. By translation b(P n ) = 1. Every gate is translated by a module of size O(s
4
) and constant depth, and only the composition of these modules increases linearly the depth [Ter04] . Let x ∈ {0, 1} n an input of C n and − → x corresponding to x as in definition 7. By theorem 1 proof we have:
is an O(c) steps reduction such that sum({Q i } i∈I ) is cut free and there is a witness y ∈ {0, 1}
such that C n (x, y) evaluates to 1 if and only if P n ( − → x ) evaluates to 1 (i.e. ∃i ∈ I such that Q i = b 1 ).
By translation c = O(c), so we have the same result for logical depth O(c).
Simulation of parallel reductions
Let P = (P n ) n∈N be a uniform Boolean proof net family of nMLL u with k(n) sum-boxes. We associate a uniform Boolean circuit family C = (C n ) n∈N to P in two big steps based on the reduction sequence of theorem 1:
-We both initialize the circuit descriptions and simulate all the parallel down reductions with a polysize and constant depth circuit, using uniformity, -As in [Ter04] we simulate all the ⇒ reductions of all summands using stCONN 2 gates for ⇒ t simulation and then we check the result of the last configuration.
In more detail, from the description of a proof net P n ∈ P we build Θ 0 an initial set of Boolean values representing the proof net to simulate. A configuration Θ ∈ Conf (P n ) is the set of the following Boolean values: alive(l), sort(l, s), box(l, i) and edge(l, 0, l , i ). These values are initialized to 1 respectively iff a link l ∈ L is in P n , l is of sort s, l is enclosed by the sum-box numbered i, and the conclusion port of l is in relation with the i th port of a link l ∈ L. In other terms our initial configuration Θ 0 is the description itself extended to alive values. Every reduction step simulation is made by a small circuit which modifies a configuration in the other. All of this can be done in Logspace. The parallel reduction strategy is simulated as follows: this is the tricky part Lemma 3. There is an unbounded fan-in circuit C of size O(|P n | 3 ) and constant depth over B 1 with non-deterministic variables, which computes in Logspace Θ ∈
Proof. Like in the translation we parse the configuration of P n (b i1 , . . . , b in ) without taking care of sum-boxes to build partially L DC (C) in Logspace. From Conf (P n ), we complete L DC (C) in Logspace and compute Conf (P ) as follows: The simulation of one k-ary sum-box t which corresponds to k summands/choices, uses log(k) non-deterministic variables {G t }. Let l be a link of box-depth b(l), i.e. l is enclosed in exactly b(l) sum-boxes {t i } i∈I . Let k i be the arity of the sum-box t i . So the link l simulation depends on Σ i∈I log(k i ) non-deterministic gates. We initialize the value of the corresponding edges with the conjunction of the values of these non-deterministic gates ∪ i∈I {G ti } like in Fig. 6 . Globally this constant depth initialization uses one conjunction gate by edge in Conf (P n ) and one negation gate by non-deterministic gates. ) and constant depth such that whenever a configuration Θ ∈ Conf (P ) is given as input and P ⇒ P , C outputs a Θ ∈ Conf (P ).
Theorem 3. For every uniform family P of Boolean proof nets of nMLL u of size s and logical depth c, with k(n) sum-boxes of maximal arity k, there is a uniform family of unbounded fan-in Boolean circuit over the basis B 1 (stCONN 2 ) of size s
and depth O(c) and with O(k(n).log(k)) non-deterministic variables, which accepts the same set as P does.
Proof. By theorem 1, i 1 · · · i n is accepted by P if and only if b 1 ∈ {Q i } i∈I where
. By lemma 3 we build from P n a uniform polysize constant depth circuit with O(k(n).log(k)) nondeterministic variables. For each of the ⇒ c(P ) reductions we apply the same construction as in Terui's lemma starting from our previous configuration. At the end we easily build a polysize constant depth circuit to check if the last configuration represents b 1 or not.
Proof net complexity
We define a hierarchy of complexity classes based on proof nets: Definition 11. For i ∈ N, the classes UBPN i (k(n)) and UBPN i are functions computable by uniform families of polynomial size, O(log i n) depth Boolean proof nets of respectively nMLL u with O(k(n)) sum-boxes and MLL u . We write UBPN (k(n)) and UBPN the respective unions over the exponents of the depth.
From theorem 2 and theorem 3 we have:
Proof. For a Boolean proof net of size s the arity k of a sum-box is O(s) in the worst case. By theorem 2 we have O(s) = n O(1)
. So O(k(n).log k) = O(k(n) × log n). ). Point 3. NAC (1)(stCONN 2 ) = NC = NNC (log n) = NAC (log n)(stCONN 2 ). Point 5. by union over i and j from Point 2. Point 6. by union over i from Point 1.
Remark that UBPN (1) = UBPN is what we expect: a constant number of sum-boxes corresponds to n O(1) summands/choices in the worst case, and so it can be simulated with a disjunction of a polynomial number of circuits of the same depth. I.e. it corresponds to NNC (log n) = NC.
Conclusion
Our study generalizes the work of K. Terui [Ter04] to non-deterministic extension as follows. We have defined new parallel reductions of proof nets of Nondeterministic Multiplicative Linear logic, nMLL u . We have defined the uniform Boolean proof nets with an amount of explicit non-determinism analogously to the uniform Boolean circuits of NNC (), the non-deterministic NC class. By the way we give a proof-as-programs correspondence between this model of parallel computation and the uniform Boolean proof nets, preserving both size and depth. We define in a standard way the classes of uniform Boolean proof nets families UBPN () and we establish the following results:
Remark that the proofs of translation and simulation theorems could apply for Boolean circuits without depth constraint. Such a Boolean circuit is simply called a polynomial size circuit and the corresponding class equal P . So there is a chain from P to NP for families of uniform polynomial size Boolean proof nets.
There is a reduction which replaces a sequence of ⇒ D in our theorem in only one step: our circuit simulating parallel down reductions made it in lemma 3. The same thing could be done by parsing the sub-nets without reducing sumboxes (only k(n).log(n) bits are used) but with our theorem reduction we do fully parallel computation. Ad-hoc Boolean proof net classes can be given to have a more strictly correspondence with NNC (), using only binary -links. Then the encoding are no more constant depth but O(k(n)) depth: it corresponds to NC with O(log n) sum-boxes. Remark that if we use a bigger uniformity notion then the descriptions are easier: e.g. for sum-boxes a relationship between the -links is sufficient. 
