P system

From Wikipedia, the free encyclopedia

For the computer p-System, see UCSD p-System.

A P system is a computational model based upon the architecture of a biological cell, abstracting from the way in which chemicals interact and cross cell membranes. This concept was first introduced in a 1998 report[1] by the computer scientist Gheorghe Paun, whose last name is the origin of the letter P in 'P Systems'. Variations on the P system model led to the formation of a branch of research known as 'membrane computing.'

Although inspired by biological processes, the research interest regarding P systems is mainly concerned with their use as a computational model, rather than for biological modelling, although this is also being investigated.[2]

Contents

[edit] Informal description

A P system is a way of implementing a computation in a biologically-inspired way, based upon the structure of a living cell. P systems are defined as a series of membranes containing chemicals, in finite amounts, catalysts and rules which determine possible ways in which chemicals may react with one another to form products. Rules may also cause chemicals to pass through membranes or even cause membranes to dissolve.

Just as in a biological cell, where a chemical reaction may only take place on the chance that the required chemicals come together (possibly also with a catalyst), the rules in a P system are applied at random, causing the computation to proceed in a non-deterministic manner.

The result of a P system's computation is all those chemicals which have been moved out of the outermost membrane (i.e. out of the 'cell'), once no more more reactions can take place.

[edit] Components of a P system

Although many varieties of P system exist, most share the same basic components. Each element has a specific role to play, and each has a founding in the biological cell architecture upon which P systems are based.

[edit] The environment

The environment is the surroundings of the P system. In the initial state of a P system it contains only the container-membrane, and while the environment can never hold rules, it may have objects passed into it during the computation. The objects found within the environment at the end of the computation constitute its “result.”

[edit] Membranes

Membranes are the main “structures” within a P system. A membrane is a discrete unit which can contain a set of objects (symbols/catalysts), a set of rules, and a set of other membranes contained within. The outermost membrane, held within the environment, is often referred to as the 'container membrane' or 'skin membrane'. As implied to by their namesake, membranes are permeable and symbols resulting from a rule may cross them. A membrane (but not the container membrane) may also “dissolve”, in which case its content, except for rules (which are lost), migrate into the membrane in which it was contained. Some P system variants also allow for a membrane to divide, possess an charge, have selective permeability or have varying thickness.

[edit] Symbols

Symbols represent chemicals which may react with other chemicals to form some product. In a P system each type of symbol is typically represented by a different letter. The symbol content of a membrane is therefore represented by a string of letters. Because the multiplicity of symbols in a region matters, multisets are commonly used to represent the symbol content of a region.

Special case symbols exist, for example a lower case delta (δ) is often used to initiate the dissolving of a membrane, and this will only ever be found in the output of a rule: upon being encountered it invokes a reaction, and is used in the process.

[edit] Catalysts

Catalysts are similar to their namesakes in chemistry. They are represented and used in the same way as symbols, but are never consumed during a “reaction,” they are simply a requirement for it to occur.

[edit] Rules

Rules represent a possible chemical reaction within a membrane, causing it to evolve to a new state. A rule has a required set of input objects (symbols or catalysts) which must be present in order for it to be applied. If the required objects are present, it consumes them and produces a set of output objects. A rule may also be specified to have a priority over other rules, in which case less dominant rules will only be applied when it is not possible to apply a more dominant rule (i.e. the required inputs are not present).

There are three (in the basic P system model) distinct ways in a rule may handle its output objects. Usually the output objects are passed into the current membrane (the same membrane in which the rule and the inputs reside), known as a here rule. However there are two modifiers which can be specified upon output objects when rules are defined, in and out. The in modifier causes the object to be passed to one of the current membrane’s children (travelling inwards relative to the structure of the P system), chosen at random during the computation. The out modifier causes the object to be passed out of the current membrane and into either its parent membrane or to a sibling membrane, specified during specification of the P system.

[edit] Computations

A computation works from an initial starting state towards an end state through a number of discrete steps. Each step involves iterating through all membranes in the P system and the application of rules, which occurs in both a maximally parallel and non-deterministic manner.

Working through step-by-step, a computation halts when no further evolution can take place (i.e. when no rules are able to be applied). At this point whatever objects have been passed to the environment are counted as the result of the computation.

[edit] Rule application

At each step of a computation an object may only be used once, as they are consumed by rules when applied. The method of applying a rule within a membrane is as follows:

  1. Assign symbols from a membrane’s content to the rule’s inputs
  2. If all inputs are satisfied, remove all assigned symbols from membrane
  3. Create output symbols and hold until all rule assignment, for all membranes, has taken place.
  4. Add output symbols to targeted membranes.
  5. Dissolve membranes as necessary

Outputs are not passed immediately into membranes because this would contravene the maximally parallel nature of rule application, instead they are distributed after all possible rules have been applied.

[edit] Non-deterministic application

The order of rule application is chosen at random. Rule application order can have a significant effect on which rules may be applied at any given time, and the outcome of a step of execution.

Consider a membrane containing only a single "a" symbol, and the two rules a → ab and a → aδ. As both rules rely on an “a” symbol being present, of which there is only one, the first step of computation will allow either the first or second rule to be applied, but not both. The two possible results of this step are very different:

  1. The membrane carries over to the next step of the computation with both an "a" symbol and a "b" symbol present, and again one of the two rules is randomly assigned to the "a" symbol.
  2. The membrane dissolves and a single "a" symbol is passed out to the containing membrane.

[edit] Maximally parallel application

This is a property of rule application whereby all possible rule assignments must take place during every step of the computation. In essence this means that the rule a → aa has the effect of doubling the number of "a" symbols in its containing membrane each step, because the rule is applied to every occurrence of an "a" symbol present.

[edit] An example

The graphical representation of a P system which outputs square numbers
The graphical representation of a P system which outputs square numbers

The image shown depicts the initial state of a P system with three membranes. Because of their hierarchical nature, P systems are often depicted graphically with drawings that resemble Venn diagrams or David Harel's Higraph (see Statechart).

The outermost membrane, 1, is the container membrane for this P system and contains a single out rule. Membrane 2 contains four here rules, with two in a priority relationship: c → cc will always be applied in preference to c → cδ. The delta symbol represents the special “dissolve” symbol. The innermost membrane, 3, contains a set of symbols (“ac”) and three rules, of type here. In this initial state no rules outside of membrane 3 are applicable: there are no symbols outside of that membrane. However, during evolution of the system, as objects are passed between membranes, the rules in other membranes will become active.

[edit] Computation

Because of the non-deterministic nature of P systems, there are many different paths of computation a single P system is capable of, leading to different results. The following is one possible path of computation for the P system depicted.

[edit] Step 1

From the initial configuration only membrane 3 has any object content: "ac"

  • "c" is assigned to c → cc
  • "a" is assigned to a → ab

[edit] Step 2

Membrane 3 now contains: "abcc"

  • "a" is assigned to a → bδ
  • "c" is assigned to c → cc
  • "c" is assigned to c → cc

Notice the maximally parallel behaviour of rule application leading to the same rule being applied twice during one step.

Membrane 3 now dissolves, as the dissolve symbol (δ) has been encountered and all object content from this membrane passes into membrane 2.

[edit] Step 3

Membrane 2 now contains: “bbcccc”

  • "b" is assigned to b → d
  • "b" is assigned to b → d
  • "cc" is assigned to cc → c
  • "cc" is assigned to cc → c

[edit] Step 4

Membrane 2 now contains: "ddcc"

  • "d" is assigned to d → de
  • "d" is assigned to d → de
  • "cc" is assigned to cc → c

[edit] Step 5

Membrane 2 now contains: “ddeec”

  • "d" is assigned to d → de
  • "d" is assigned to d → de
  • "c" is assigned to c → δ

Notice that the priority over c → δ has been lifted now the required inputs for cc→ c no longer exist. Membrane 2 now dissolves, and all object content passes to membrane 1.

[edit] Step 6

Membrane 1 now contains: “ddeeee”

  • "e” is assigned to e → eout
  • "e” is assigned to e → eout
  • "e” is assigned to e → eout
  • "e” is assigned to e → eout
  • "e” is assigned to e → eout

[edit] Computation halts

Membrane 1 now contains: "add" and, due to the out rule e → eout, the environment contains: "eeee." At this point the computation halts as no further assignments of objects to rules is possible. The result of the computation is four "e" symbols.

The only non-determanistic choices occurred during steps 1 and 2, when choosing where to assign the solitary "a" symbol. Consider the case where "a" is assigned to a → bδ during step 1: upon membrane 3 dissolving only a single "b" and two "c" objects would exist, leading to the creation of only a single "e" object to eventually be passed out as the computation’s result.

[edit] As a computational model

P systems, which satisfy certain rules, have been proved to be computationally universal. The flexible nature of P systems allows for variants to alter the nature of constraints upon which universal computation holds, in fact it has been proven that a type of P system which does not use rule priorities, usually a fundamental aspect of P systems, is capable of universal computation.[3]

[edit] Motivations for developing P systems

A large portion of research into membrane computing appears to be centred around a very attractive proposition: solving NP-complete problems in less-than exponential time. It has been proven that certain P system variants are capable of solving the SAT (boolean satisfiability) problem in linear time,[4] and owing to the property of all NP-complete problems being equivalent, serves as a proof for all such problems.

It has also been proven that any deterministic P system may be simulated on a Turing Machine in polynomial time.[5] This is important as there is currently no way to directly implement a P system in its own right: their functionality must be simulated on a computer (i.e. a turing machine).

These two proofs together serve as a huge incentive to work on P systems, as solving NP-complete problems quickly would have far-reaching consequences in many fields. It also leads on to the question of whether or not it is possible to directly implement a P system, rather than emulating the functionality of one.[6]

[edit] See also

[edit] References

  1. ^ Gheorghe Păun. Computing with membranes. TUCS Report 208, Turku Center for Computer Science, 1998.
  2. ^ Ardelean, Ioan; Matteo Cavaliere (June 2003). "Modelling biological processes by using a probabilistic p system software". Natural Computing 2 (2): 173–197. doi:10.1023/A:1024943605864. ISSN 1567-7818. 
  3. ^ Freund, Rudolf; Marion Oswald and Petr Sosík (2005). "Computationally universal P systems without priorities: two catalysts are sufficient". Theoretical Computer Science 330 (2): 251–266. doi:10.1016/j.tcs.2004.06.029. 
  4. ^ Păun, Gheorghe (2001). "P systems with active membranes: attacking NP compete problems". Automata, Languages and Combinatorics 6 (1): 75-90. 
  5. ^ Păun, Gheorghe; Grzegorz Rozenberg (2002). "A guide to membrane computing". Theoretical Computer Science 287 (1): 73–100. doi:10.1016/S0304-3975(02)00136-6. .
  6. ^ Zandron, Claudio; Claudio Ferretti and Giancarlo Mauri (2000). "Solving NP-Complete Problems Using P Systems with Active Membranes". Unconventional Models of Computation: 289-301. ISBN 1-85233-415-0. 

[edit] External links