Encodings and Arithmetic Operations in P Systems⋆
Total Page:16
File Type:pdf, Size:1020Kb
Encodings and Arithmetic Operations in P Systems? Artiom Alhazov1, Cosmin Bonchi»s2, Gabriel Ciobanu2;3, and Cornel Izba»sa2 1 Research Group on Mathematical Linguistics, Rovira i Virgili University and Institute of Mathematics and Computer Science, Academy of Sciences of Moldova, [email protected] 2 Research Institute \e-Austria" Timi»soara,Romania [email protected], [email protected],[email protected] 3 Romanian Academy, Institute of Computer Science Blvd. Carol I nr.8, 700505 Ia»si,Romania [email protected] Summary. Following [2], we present in this paper various number encodings and opera- tions over multisets. We obtain the most compact encoding and several other interesting encodings and study their properties using elements of combinatorics over multisets. We also construct P systems that implement their associated operations. We quantify the ef- fect of adding order to a multiset thus obtaining a string, as going from encoding lengths p of the number n in base b and time complexities of operations of the order b n to lengths and complexities of order logbn: 1 Introduction Membrane systems represent a new abstract model inspired by cell compartments and molecular membranes. Essentially, such a system is composed of various com- partments, each compartment with a di®erent task, and all of them working si- multaneously to accomplish a more general task of the whole system. A detailed description of the membrane systems (also called P systems) can be found in [9]. A membrane system consists of a hierarchy of membranes that do not intersect, with a distinguishable membrane, called the skin membrane, surrounding them all. The membranes produce a delimitation between regions. For each membrane there is a unique associated region. Regions contain multisets of objects, evolution rules and possibly other membranes. Only rules in a region delimited by a membrane act on the objects in that region. The multisets of objects from a region correspond to the \chemicals swimming in the solution in the cell compartment", while the rules correspond to the \chemical reactions possible in the same compartment". Graphically, a membrane structure is represented by a Venn diagram in which two ? Work partially supported by the CEEX grant 47/2005 2 A. Alhazov, C. Bonchi»s,G. Ciobanu, C. Izba»sa sets can be either disjoint, or one is a subset of the other. We refer mainly to the so-called transition membrane systems. Other variants and classes are introduced [9]. The membrane systems represent a new abstract machine. For each abstract machine, the theory of programming introduces and studies various paradigms of computation. For instance, Turing machines and register machines are mainly re- lated to imperative programming, and ¸-calculus is related to functional program- ming. Looking at the membrane systems from the point of view of programming theory, we intend to provide useful results for future de¯nitions and implementa- tions of P system-based programming languages, that is, programming languages that generate P systems as an executable form. The authors of such languages will certainly have to face the problem of number encoding using multisets, since the multiset is the support structure of P systems. The idea to encode numbers using multisets and to de¯ne arithmetical operations in membrane computing is presented in [2]. Here we present more details, emphasizing other interesting as- pects related to the number encoding using multisets and P systems. We outline various approaches of the most compact encodings using one membrane, also com- paring it to the most compact encoding using strings. This comparison is meant to o®er some hints about information encoding in general, speci¯cally how do we most compactly encode information over structures that have underlying or- der (strings), or just multiplicity (multisets), or neither (sets), that is how do we encode information using strings, multisets or sets. Prior work related to number encodings using multisets was done in [1], where the encoding is done by allocating a membrane for each digit, thus \stringising" the multiset, constructing a string-like structure over it. Then this string-like struc- ture is used to encode numbers in the classical manner. Our approach does not attempt to superimpose this string structure over the multiset, but tries to use only the already present quality of multiset elements, multiplicity, to encode num- bers and, by extension, information. Thus, this approach is a more native one and might be easier to use in related biochemical experiments. Another advan- tage is that using this approach it is possible to represent numbers with arbitrary number of digits, without membrane creation, division or dissolution. One dis- advantage is that the arithmetic operations have slightly higher complexity. We have designed and implemented sequential and parallel software simulators [5, 6]; a web-based implementation is presented in [3]. We have implemented the arithmetic operations, and each example is tested with our web-based simulator available at http://psystems.ieat.ro/. 2 Combinatorics Over Multisets (Review) To develop encoding and decoding algorithms for the above encodings we start with a short review of combinatorics over multisets based on [4]. Let M be a multiset. Encodings and Arithmetic Operations in P Systems 3 2.1 Permutations over multisets De¯nition: An r ¡ permutation of M is an ordered arrangement of r objects of M. If jMj = n then an n ¡ permutation of M is called a permutation of M. Theorem 1. Let M be a multiset of k di®erent types where each type has in¯nitely many elements. Then the number of r ¡ permutations of M equals kr. 2.2 Combinations over multisets De¯nition: An r ¡ combination of M is an unordered collection of r objects from M. Thus an r ¡ combination of M is itself an r ¡ submultiset of M. For a multiset M = f1a1; 1a2; :::; 1ang, an r ¡ combination of M is also called an r ¡ combination with repetition allowed of the n-set S = fa1; a2; :::; ang. The ¿numberÀ of r ¡ combinations with repetition allowed of an n-set is denoted by n : r Theorem 2. Let M = f1a1; 1a2; :::; 1ang be a multiset of n types. Then the number of r ¡ combinations of M is given by ¿ À µ ¶ µ ¶ n n + r ¡ 1 n + r ¡ 1 = = r r n ¡ 1 3 Number Encodings Over Multisets We consider several encodings with useful features such as the most compact en- coding (MCE), Gray-style most compact encoding (GSMCE), square root en- coding (SqRE), and Gray-style square root encoding (GSqRE). Gray-style most compact encoding (GSMCE) Gray-style encodings are based on the fact that a minimal change is performed on the encoded number to obtain its successor or predecessor. The change means either converting an existing symbol or adding a new symbol (with the remark that after this step cannot be performed an other addition step). 3.1 Most compact encoding using one membrane (MCE) The natural encoding is easy to understand and work with, but it has the dis- advantage that for very large numbers the P system membranes will contain a very large number of objects, which is undesirable for practical reasons. First we analyze the most compact encoding using two object types (binary case) and then briefly the ternary case. 4 A. Alhazov, C. Bonchi»s,G. Ciobanu, C. Izba»sa MCE1 Decimal Natural MCE2 MCE3 GSMCE2 SqRE2 GSqRE2 encoding 0 ¸ = a0 ¸=0010 ¸=001020 ¸=0010 ¸=0010 ¸=0010 1 a1 0=0110 0=011020 0=0110 00=0210 00=0210 2 a2 1=0011 1=001120 1=0011 01=0111 01=0111 3 a3 00=0210 2=001021 11=0012 11=0012 11=0012 4 a4 01=0111 00=021020 10=0111 0000=0410 1111=0014 5 a5 11=0012 01=011120 00=0210 0001=0311 1110=0113 6 a6 000=0310 02=011021 000=0310 0011=0212 1100=0212 7 a7 001=0211 11=001220 001=0211 0111=0113 1000=0113 8 a8 011=0112 12=001121 011=0112 1111=0014 0000=0410 9 a9 111=0013 22=001022 111=0013 000000=0610 000000=0610 10 a10 0000=0410 000=031020 1111=0014 000001=0511 000001=0511 11 a11 0001=0311 001=021120 1110=0311 000011=0412 000011=0412 12 a12 0011=0212 002=021021 1100=0212 000111=0313 000111=0313 13 a13 0111=0113 011=011220 1000=0113 001111=0214 001111=0214 Table 1. Number encodings b=m 0 1 2 3 4 5 6 7 8 9 2 1 2 3 4 5 6 7 8 9 10 3 1 3 6 10 15 21 28 36 45 55 4 1 4 10 20 35 56 84 120 165 220 5 1 5 15 35 70 126 210 330 495 715 6 1 6 21 56 126 252 462 792 1287 2002 Table 2. Number of numbers encoded in base b with m objects De¯nitions, properties We denote as N(b; m) the number of numbers encoded in base b with m objects. Here are some values for the function N(b; m): For our representations, the de¯nition of r ¡ combinations is useful in deter- mining the number of objects represented with m objects in a multiset with b types. b indicates our base. ¿ À µ ¶ µ ¶ b b ¡ 1 + m b ¡ 1 + m N(b; m) = = = (1) m m b ¡ 1 which is also the number of m ¡ combinations of a multiset of b types. Based on the Pascal formula: µ ¶ µ ¶ µ ¶ n n ¡ 1 n ¡ 1 = + r r r ¡ 1 Encodings and Arithmetic Operations in P Systems 5 and its extended form: µ ¶ r µ ¶ n X n ¡ 1 ¡ i = (2) r r ¡ i i=0 we replace in 2 b ¡ 1 + m for n and m for r, ¿ À µ ¶ µ ¶ b b ¡ 1 + m (b ¡ 1) ¡ 1 + (m ¡ i) N(b; m) = = = = m m (m ¡ i) m ¿ À m ¿ À m X b ¡ 1 X b ¡ 1 X = = N(b ¡ 1; i) m ¡ i i i=0 i=0 i=0 and obtain that Xm N(b; m) = N(b ¡ 1; i) (3) i=0 To develop encoding and decoding algorithms for a certain base b we have to solve this equation: mX¡1 N(b; i) ¡ n = 0 i=0 Since from 3 m¡1 ¿ À X b + 1 N(b; i) = N(b + 1; m ¡ 1) = = m ¡ 1 i=0 µ ¶ Q b + m ¡ 1 (b + m ¡ 1)! b¡1(m + i) = = i=0 m ¡ 1 b!(m ¡ 1)! b! we obtain that Q mX¡1 b¡1(m + i) N(b; i) ¡ n = 0 , i=0 ¡ n = 0: (4) b! i=0 The integer part of its greatest real positive root of 4 will represent m; i.e.