Int. J. of Computers, Communications & Control, ISSN 1841-9836, E-ISSN 1841-9844 Vol. IV (2009), No. 2, pp. 167-177 Hierarchical Distributed Reasoning System for Geometric Image Generation Nicolae Ţăndăreanu, Mihaela Verona Ghindeanu, Sergiu Andrei Nicolescu University of Craiova, Romania Department of Mathematics and Computer Science A.I. Cuza St, No. 13, 200585 E-mail: ntand@rdslink.ro, mghindeanu@yahoo.com Abstract: The concept of hierarchical reasoning system was introduced in [5], where an intuitive method to build such systems based on their inputs is given. In this paper we formalize several concepts which open a possible research line concerning the use of these structures. A hierarchical reasoning system H is a directed graph organized on several levels such that each node of the level j is a hyper-schema of order j. As a mathematical structure, H is an abstract one and a special kind of formal computation is introduced. As a result of this computation we obtain a set F(H) of formulas. We explain what we understand by an interpretation of H and define its corresponding semantical computation. By means of an interpretation I(H) for H and applying the rules of the semantical computation, each element of w ∈ F(H) becomes some object I(w) of a given space. We exemplify these concepts and we show that for two distinct interpretations I1(H) and I2(H) for the same system H, a given formula w ∈ F(H) is transformed into a sentence I1(w) of a natural language whereas I2(w) is a geometric image. A short description of a Java implementation of a hierarchical system generating images is also given in a separate section. By examples we show that the mechanism introduced in this paper allows us to model the distributed knowledge. Finally several open problems are specified. Keywords: semantic schema, interpretation, hyper-schema, distributed reasoning system, geometrical image generation 1 Introduction Various kinds of mechanisms for image synthesis were presented and implemented on computer. The panel of the mathematical models for this subject includes the rewriting systems and graph-based models. Picture-processing grammars ([2]), picture grammars ([3]), stochastic grammars ([14]) and L-systems are some of the rewriting systems used to process images. The L-systems are a class of string rewriting mechanism originally developed by a biologist, A. Lindenmayer, in 1968 ([7]). The original emphases were on plant topology - spatial relations between cells or larger plant modules. The L-systems are a practical tool for generating fractal forms. Today these models are applied in architecture, physiology ([1]) and music. In order to interpret the L-system as music, LMUSe system ([9]) maps any of the turtle’s 3D movement, orientation directions (forward, up, and left), its drawing line length, and thickness into musical pitches, note durations and volume. A great number of research works and practical implementations have confirmed the interest of mathematicians and computer scientists in developing and applying the methods of graph theory. These methods were applied to obtain new knowledge representation models and to process images. A very productive notion with large applications in knowledge representation is that of conceptual graph, a Copyright © 2006-2009 by CCC Publications 168 Nicolae Ţăndăreanu, Mihaela Verona Ghindeanu, Sergiu Andrei Nicolescu notion introduced in literature by J.F.Sowa ([8],[10]). We can find several applications of the graph- based methods in [6] (low-level processing of digital images, learning algorithms for high-level computer vision and pattern recognition). The concept of semantic schema was introduced in [11] as an extension of semantic networks. This structure is obtained by means of a labeled graph and a Peano algebra built over the edge labels. Since then many applications of this structure were presented (new semantics in logic programming, knowledge representation for intelligent dialog systems etc). In [12] we defined a new mechanism for generating images similar with the edge rewriting in the way that both approaches can be used to define complex images based on some simple other images. In the mentioned paper the concept of Hierarchical Distributed Reasoning System was introduced. Each leaf of the system is given by a semantic schema. The other nodes are hyper-schemas ([12]). We presented an intuitive method to obtain geometrical images. The leaves represent the input of the system in semantic schemas and, by appending proper interpretations, they obtain the graphical illustrations of the received inputs. In this manner the leaves obtains the initial images. Then, at the upper levels, these images are combined by hyper-schemas to obtain complex images. We obtained a bottom-up method to obtain images from initiators. In this paper we obtain the following results: • Starting with the concept of Hierarchical Distributed and Reasoning System (HGR system) intro- duced in [12] in Section 3 we define a formal computation in such a structure. As a result of this computation we obtain a set F(H) of formulas for an arbitrary HDR system H. This is the formal computation in an HDR system. • An HDR system H is an abstract structure. In Section 4 we introduce the concept of interpretation for H. By means of an interpretation I(H) for H each element of F(H) becomes some object of a given space. This gives the semantical computation. Both the formal and semantical computations are exemplified. We show that for two distinct interpretations I1(H) and I2(H) for the same system H we can generate sentences in a natural language giving the reasoning conclusions and geometrical images respectively. • A short description of a Java implementation of an HDR system is also given in Section 5. • By examples we show that the mechanism introduced in this paper allows us to model the dis- tributed knowledge. • The last section contains the conclusions and future works. Several open problems are specified in this section. 2 Basic concepts Consider a symbol θ of arity 2. A θ-semantic schema ([11]) or shortly, θ-schema is a system S = (X, A0, A, R), where: • X is a finite non-empty set of symbols named object symbols; • A0 is a finite non-empty set of elements named label symbols and A0 ⊆ A ⊆ A0, where A0 is the Peano θ-algebra generated by A0; • R ⊆ X × A × X is a non-empty set of relations which fulfills the following conditions: 1. (x, θ(u, v), y) ∈ R ⇒ ∃z ∈ X : (x, u, z) ∈ R, (z, v, y) ∈ R 2. θ(u, v) ∈ A, (x, u, z) ∈ R, (z, v, y) ∈ R ⇒ (x, θ(u, v), y) ∈ R Hierarchical Distributed Reasoning System for Geometric Image Generation 169 3. {α | ∃(x, α, y) ∈ R} = A An element from R ∩ (X × A0 × X) is a regular arc of S. We denote by Ded(S) the least set satisfying the following properties ([13]): • If (x, a, y) ∈ R0 then ([x, y], a) ∈ Ded(S) • If ([xi, . . . , xk], u) ∈ Ded(S) and ([xk, . . . , xr], v) ∈ Ded(S), i < k < r and θ(u, v) ∈ A then ([xi, . . . , xr], θ(u, v)) ∈ Ded(S). An element of Ded(S) is a deductive path of S. Let us consider the schemas S1 = (X1, A01, A1, R1) and S2 = (X2, A02, A2, R2). In the remainder of this section we describe a new structure which relieves a special kind of cooperation between S1 and S2. If d1 = ([x, . . . , y], u) ∈ Ded(Si) and d2 = ([y, . . . , z], v) ∈ Ded(S3−i), where i ∈ {1, 2}, then we say that d1 is connected to right by d2 or d2 is connected to left by d1. We say that d1 is connected by d2 if d1 is connected to right or to left by d2. We consider the sets of deductive paths L1 ⊆ Ded(S1) and L2 ⊆ Ded(S2). We say that L1 ∪ L2 is a pairwise connected set of deductive paths if every deductive path of Li is connected by some deductive path of L3−i. For each i ∈ {1, 2} we consider a set Vi of symbols such that Vi ∩ (A1 ∪ A2) = ∅. We consider also a set Ei such that Ei ⊆ Xi × Vi × Xi, Card(Ei) = Card(Li) and E1 ∩ E2 = ∅. Consider also a bijective mapping gi : Li −→ Ei such that gi(d) = (x, e, y), where d = ([x, . . . , y], θ(u, v)) ∈ Li. This mapping transforms each deductive path ([x, . . . , y], θ(u, v)) from Li into a regular arc (x, e, y). Shortly, we say that the path ([x, . . . , y], θ(u, v)) is designated by (x, e, y). We can define now a cooperating structure of hyper-schemas. A hyper-schema of order zero is a semantic schema. Consider the hyper-schemas S1 and S2 of order zero. A hyper-schema of order one over S1 and S2 obtained by means of L1 and L2 is a θ-schema S which includes the regular arcs obtained from L1 and L2 ([12]). We denote by Hyp1({S1, S2}) the set of all hyper-schemas of first order over S1 and S2. In general we write S ∈ Hypk({S1, S2}) and we name S a hyper-schema of order k if S1 and S2 are hyper-schemas of order j ≤ k − 1 and at least one of them has the order k − 1. An HDR system ([12]) is the tuple H = (Q1, Q2, . . . , Qk) where k ≥ 2 and • Q1 = {S1, . . . , Sn1 }, n1 > 1, constitutes the first level of the system. The entities {S1, . . . , Sn1 } are hyper-schemas of order zero. The set Q1 gives the leaves of H. • Q2 = {Sn1+1, . . . , Sn2 }, n2 ≥ n1 + 1, gives the second level of the system and Sn1+1, . . . , Sn2 are hyper-schemas of order 1. More precisely, for every m ∈ {n1 + 1, . . . , n2} there are m1, m2 ∈ {1, . . . , n1}, m1 6= m2 such that Sm ∈ Hyp1({Sm1 , Sm2 }). • For j ∈ {3, . . . , k}, Qj = {Snj−1+1, . . . , Snj } represents the j-th level of the system, where nj ≥ nj−1 + 1. For every m ∈ {nj−1 + 1, . . . , nj} there is m1 ∈ {nj−2, . . . , nj−1} and there is m2 ∈ {1, . . . , nj−1} such that Sm ∈ Hypj−1({Sm1 , Sm2 }). 3 Formal computations in HDR Systems Suppose that H = (Q1, Q2, . . . , Qk) is an HDR system. The components of H are the hyper-schemas S1, . . . , Snk . We can visualize H as a graph structure. In order to obtain this structure we represent each hyper-schema by a node and we draw two directed arcs from Sr to Sj and to Sm if Sr ∈ Hypp({Sj, Sm}) for some p. The structure obtained in this manner is not a tree. This can be observed in Figure 1: there are two distinct paths from S7 to S2 and there is no root of this structure. 170 Nicolae Ţăndăreanu, Mihaela Verona Ghindeanu, Sergiu Andrei Nicolescu À ^ S1 S2 S5 S3 S6 À ^ À ^ S7 S8 À ^ S4 Figure 1: The graph structure of H For each i ∈ {1, . . . , nk} we consider that Si is given by the tuple Si = (Xi, A0i, Ai, Ri) and we denote R0i = Ri ∩ (Xi × A0i × Xi). For each r ∈ {n1 + 1, . . . , nk} such that Sr is a hyper-schema over Sj and Sm in H we consider: • the connected sets Lj,r ⊆ Ded(Sj) and Lm,r ⊆ Ded(Sm); • the sets Ej,r, Em,r and the transformational mappings gj,r : Lj,r −→ Ej,r, gm,r : Lm,r −→ Em,r. By the assumptions of the previous section we have R0r ⊇ Ej,r ∪ Em,r. We denote N0r = Ej,r ∪ Em,r. Obviously we have the following property: Proposition 1. N0i = ∅ if and only if Si is a leaf of H. For a symbol h of arity 1 we consider the set: M = nk⋃ i=1 { h([x, y], a) | (x, a, y) ∈ R0i \ N0i} where we used the notation h([x, y], a) instead of h(([x, y], a)). We consider the symbols σ1, . . . , σnk of arity 2 and denote by HH the Peano {σ1, . . . , σnk }-algebra generated by M. We consider the alphabet Z including the symbols σi, the elements of Xi, the elements of Ai, the left and right parentheses, the square brackets [ and ], the symbol h and comma. As in the theory of formal languages, the set Z∗ defines all the words over Z. Because a hyper-schema is a semantic schema we have the following property: Proposition 2. If Si is a hyper-schema of H and ([x1, . . . , xk+1], θ(u, v)) ∈ Ded(Si) then there is r uniquely determined such that ([x1, . . . , xr+1], u) ∈ Ded(Si) and ([xr+1, . . ., xk+1], v) ∈ Ded(Si). Definition 1. Let be w1, w2 ∈ Z∗. We define the following binary relation on Z∗, denoted by ⇒H: • For i ∈ {1, . . . , nk}, if (x, e, y) ∈ R0i \ N0i then w1([x, y], e)w2 ⇒H w1h([x, y], e)w2; • For i ∈ {1, . . . , nk}, if (x, e, y) ∈ N0i then w1([x, y], e)w2 ⇒H w1dw2, where d is the deductive path designated by (x, e, y); • Suppose that ([x1, . . . , xk+1], θ(u, v)) ∈ Ded(Si), i ∈ {1, . . . , n(H)}, ([x1, . . . , xr+1], u) ∈ Ded(Si) and ([xr+1, . . ., xk+1], v) ∈ Ded(Si) then: w1([x1, . . . , xk+1], θ(u, v))w2 ⇒H w1σi(([x1, . . . , xr+1], u), ([xr+1, . . ., xk+1], v))w2 The reflexive and transitive closure of ⇒H is denoted by ⇒∗H. We denote F(Si) = {w ∈ H(H) | ∃d ∈ Ded(Si) : d ⇒∗H w} and F(H) = ⋃nk i=1 F(Si). Let us exemplify this computation. We consider the hyper-schemas S1 and S2 of order zero from Figure 2 and the hyper-schema of order 1 from Figure 3. If we take Hierarchical Distributed Reasoning System for Geometric Image Generation 171 x1 x2 x3 x4 - - ? a b a ? θ(a, b) x3 x6 x5 y1 - - 6 b c a ? θ(b, c) S1 S2 Figure 2: Semantic schemas S1 and S2 of order zero x1 x3 x5 z1- - - e1 e2 a? θ(e1, e2) 6 θ(θ(e1, e2), a) Figure 3: Hyper-schema S3 ∈ Hyp1({S1, S2}) • L1,3 = {([x1, x2, x3], θ(a, b))}, L2,3 = {([x3, x6, x5], θ(b, c))} • E1,3 = {(x1, e1, x3)}, E2,3 = {(x3, e2, x5)} • g1,3([x1, x2, x3], θ(a, b)) = (x1, e1, x3), g2,3([x3, x6, x5], θ(b, c)) = (x3, e2, x5) then we obtain the following computations: • ([x1, x3, x5], θ(e1, e2)) ⇒H σ3(([x1, x3], e1), ([x3, x5], e2)) • ([x1, x3], e1) ⇒H ([x1, x2, x3], θ(a, b)) ⇒H σ1(([x1, x2], a), ([x2, x3], b)) ⇒∗H σ1(h([x1, x2], a), h([x2, x3], b)) ∈ F(S1) • ([x3, x5], e2) ⇒H ([x3, x6, x5], θ(b, c)) ⇒H σ2(([x3, x6], b), ([x6, x5], c)) ⇒∗H σ2(h([x3, x6], b), h([x6, x5], c)) ∈ F(S2) In conclusion, ([x1, x3, x5], θ(e1, e2)) ⇒∗H σ3(σ1(h([x1, x2], a), h([x2, x3], b)), σ2(h([x3, x6], b), h([x6, x5], c))) and the last formula is an element of F(H), where H = (Q1, Q2), Q1 = {S1, S2} and Q2 = {S3}. 4 Semantical computations in HDR systems The semantical computation in an HDR system H transforms every formula of F(H) into an object of some space. In this section we describe this transformational process. Let us consider the HDR system H = (Q1, Q2, . . . , Qk) and an element w ∈ F(H). If d = ([x1, . . . , xk], θ(u, v)) ∈ Ded(Si and d ⇒∗H w then we write sort(w) = θ(u, v). Definition 2. An interpretation for H is a system I = (Ob, ob, ALG): • Ob is a set of objects; • ob : X −→ Ob, where X = ⋃nki=1 Xi, is a mapping that "interprets" each node as an object; • ALG = ⋃nki=1{Algiu}u∈Ai , where Algiu is an algorithm with two input arguments and one output argument such that if gj,k([x, . . . , y], θ(u, v)) = (x, e, y) then Algke = Alg j θ(u,v) . Definition 3. The valuation mapping ValH of the HDR system H is defined as follows: • If w = h([x, y], a) ∈ F(H) then ValH(w) = ⋃nk i=1{Alg i a(ob(x), ob(y))}. 172 Nicolae Ţăndăreanu, Mihaela Verona Ghindeanu, Sergiu Andrei Nicolescu • If w = σj(w1, w2) ∈ F(H), w1 ∈ F(H), w2 ∈ F(H) and sort(w) = α then ValH(w) = {Alg j α(o1, o2) | ok ∈ ValH(wk), k = 1, 2} In order to exemplify the computations we consider again the HDR system H from Section 3. We define an interpretation of H by means of some sentential forms. Such a structure is a sentence containing two variables. If we substitute each variable by an object then a sentential form becomes a sentence in a natural language. We shall consider the following sentential forms: p1(x, y)="x is the father of y"; p2(x, y)="x is the mother of y"; p3(x, y)="x is the brother of a y"; p4(x, y)="x likes to eat y"; q1(x, y)="x is the grandmother of y"; q2(x, y)="a brother of x likes to eat y"; r(x, y)="A nephew of x likes to eat y"; We consider the following algorithms: Algorithm Alg1a(o1, o2) { return p1(o1, o2)}; Algorithm Alg 1 b(o1, o2) { return p2(o1, o2)}; Algorithm Alg2b(o1, o2) { return p3(o1, o2)}; Algorithm Alg 2 c(o1, o2) { return p4(o1, o2)}; Algorithm Alg1 θ(a,b) (o1, o2) { if o1 = p1(t1, t2), o2 = p2(t2, t3) then return q1(t1, t3)} Algorithm Alg2 θ(b,c) (o1, o2) { if o1 = p3(t1, t2), o2 = p4(t2, t3) then return q2(t1, t3)} Algorithm Alg1e1 (o1, o2) { return q1(o1, o2)}; Algorithm Alg1e2 (o1, o2) { return q2(o1, o2)}; Algorithm Alg1b(o1, o2) { return p2(o1, o2)}; Algorithm Alg3 θ(e1,e2) (o1, o2) { if o1 = q1(t1, t2), o2 = q2(t2, t3) then return r(t1, t3)} Consider the interpretation I1 = (Ob1, ob1, ALG1) of the system H, where we specify only the useful entities allowing to exemplify the computation: • Ob1 = {Peter, Helen, John, Sorin, pizza} • ob1(x1) = Peter, ob1(x2) = Helen, ob1(x3) = John, ob1(x6) = Sorin, ob1(x5) = pizza • ALG1 = {Alg1a, Alg1b, Alg2b, Alg2c, Alg1θ(a,b), Alg2θ(b,c), Alg3e1 , Alg3e2 , Alg3θ(e1,e2)} where Alg3e1 = Alg 1 θ(a,b) , Alg3e2 = Alg 2 θ(b,c) . It is not difficult to observe that for the formula w = σ3(σ1(h([x1, x2], a), h([x2, x3], b)), σ2(h([x3, x6], b), h([x6, x5], c))) = σ3(α, β) from the last part of the previous section we obtain the following computations: ValH(α) = {Alg 1 e1 (o3, o4) | o3 ∈ ValH(h([x1, x2], a)), o4 ∈ ValH(h([x2, x3], b))} ValH(h([x1, x2], a)) = {Alg 1 a(Peter, Helen)} = {p1(Peter, Helen)} ValH(h([x2, x3], b)) = {Alg 1 b(Helen, John), Alg 2 b(Helen, John)} = {p2(Helen, John), p3(Helen, John)} therefore ValH(α) = {Alg1e1 (p1(Peter, Helen), p2(Helen, John)), Alg 1 e1 (p1(Peter, Helen), p3(Helen, John))} = {q1(Peter, John)} ValH(β) = {Alg 2 e2 (o5, o6) | o5 ∈ ValH(h([x3, x6], b)), o6 ∈ ValH(h([x6, x5], c))} ValH(h([x3, x6], b)) = {Alg 1 b(John, Sorin), Alg 2 b(John, Sorin)} = {p2(John, Sorin), p3(John, Sorin)} ValH(h([x6, x5], c)) = Alg 2 c(Sorin, pizza)} = {p4(Sorin, pizza)} therefore ValH(β) = {Alg2e2 (p2(John, Sorin), p4(Sorin, pizza)), Alg 2 e2 (p3(John, Sorin), p4(Sorin, pizza))} = {q2(John, pizza)} Finally, from ValH(α) and ValH(β) we deduce ValH(w) = {Alg 3 θ(e1,e2) (q1(Peter, John), q2(John, pizza))} = {A nephew of Peter likes to eat pizza} We observe that the conclusion obtained by H can not be obtained neither by S1, neither by S2. This explains why H is named a distributed system. Hierarchical Distributed Reasoning System for Geometric Image Generation 173 Figure 4: The image generated by I2 We give now a short description of another interpretation I2 for the same system H. As a result we obtain geometrical images. • Ob2 = {1, (3, 3), (3, 1.5)} • ob2(x1) = 1, ob2(x2) = ob2(x6) = (3, 3), ob2(x3) = 1, ob2(x5) = (3, 1.5) • Alg1a(p, q){Return the interior of circle with radius p and center q} • Alg1b(p, q){Return the interior of the square centered in p and the sides of length 2*q parallel with coordinate axes } • Alg1 θ(a,b) (α, β){ If α = Alg1a(p, q) and β = Alg 1 b(q, r) then return β \ α } • Alg2b(p, q){Return the exterior of circle with radius p and center q} • Alg2c(p, q){Return the interior of the rectangle centered in p and the sides of lengths specified by q, parallel with coordinate axes } • Alg2 θ(b,c) (α, β){ If α = Alg1 θ(a,b) (p, q) and β = Alg2 θ(b,c) (q, r) then return β ∩ α } • Alg3 θ(e1,e2) (α, β){ If α = Alg2a(p, q) and β = Alg 2 c(q, r) then return β ∪ α } For the same formula w ∈ F(H) as in the previous computation, the object ValH(w) given by I2 is shown in Figure 4. 5 A Java implementation If we note by A the set consisting of some geometrical objects names then each system’s input is an word w = a1 . . . ak over the alphabet V = A ∪ {+, −} having the following properties: • ai = +/− means a left/right rotation with a specific angle, denoted by δ and to draw a line on the current direction • ai = Oj means to draw the graphical illustration of the object Oj such that its entry direction is on the current direction. In our implementation, each geometrical object used in the generation method is an instance of the a class named Object. Graphically, it is a representation of a figure inside a square. Every instance of this class can have one of the following types: circle, triangle, star and square corresponding to the figure it consists of. Other members of this class are the entry direction and the exit direction related to some corner of the object. The corner corresponding to the entry direction becomes the entry point of the object. Similar for the exit point. The main routine of the Algorithm is createHDRS (Algorithm 2). The construction of the system starts by defining the schemas of the agents (steps 1 ÷ 4). The hyper-schemas of order one corresponding to the managers of the second level are constructed using the steps 7 ÷ 14. The condition for existing a hyper-schema over two schemas is that their maximal paths are connected deductive paths. This property is verified using the routine connectedPaths (Algorithm 3). If the second level of the system was successfully defined (If condition of step 15) then the process of creating new levels in HDRS continues using the While loop of step 17. The hyper-schemas of orders greater than 2 are created using the routine createHypSchs (Algorithm 4). The geometrical objects that are used for the image generation process are introduced using the first 174 Nicolae Ţăndăreanu, Mihaela Verona Ghindeanu, Sergiu Andrei Nicolescu Figure 5: First window of the application window of the application. For each object the user must specify the type, the entry and exit points (the corners are numbered starting from the down-left) and related to them the entry and the exit direction. Also, using the controls of the first window, the input descriptions can be edited(see Figure 5). The second window of the application gives the outputs provided by the system’s reasoning components (see Figure 6). It consists of three buttons and a panel. The application can draw maximum 1000 images with maximum 50 geometrical objects per image. 6 Conclusions and future works In this paper we formalized the syntactical and semantical computations in an HDR system. We exemplified these computations and for some HDR system H we gave two interpretations: one inter- pretation generates phrases and the other generates geometrical images. This examples give an idea concerning the generative power of our mechanism. We relieved also by these examples the fact that the distributed reasoning can be modeled by an HDR system. A short description of a Java implementation for an HDR system generating images is also given. We intend to develop the applications of an HDR system. First, we intend to use the mobile agents to process such systems ([4]). Second, we intend to use the HDR systems in e-learning. The basic idea comes from the fact that a link in an HTML document gives a reference to another document of the similar structure. Hierarchical Distributed Reasoning System for Geometric Image Generation 175 (a) The initiators and some images obtained by the managers of Q2 and Q3 levels (b) Images obtained at the 4th level in the system Figure 6: Second window of the application 176 Nicolae Ţăndăreanu, Mihaela Verona Ghindeanu, Sergiu Andrei Nicolescu Algorithm 2 Procedure createHDRS Procedure createHDRS 1. For i ← 1, noCmd 2. call create−schema(commands[i], schema[i], agent[i]) 3. maximalPath[i] ← schema[i].getMaximalPath() 4. EndFor 5. noAg ← noComd 6. noKM ← noAg + 1 7. For i, j ← 1, noAg; j 6= i 8. If connectedPaths(maximalPath[i], maximalPath[j]) 9. call create−hyperSch(hypSch[noKM], schema[i], schema[j]) 10. hypSch[noKM].order ← 1 11. maximalPath[noKM] ← hypSch[noKM].getMaximalPath() 12. noKM ← noKM + 1 13. EndIf 14. EndFor 15. If noKM > noAg + 1 16. order ← 2 17. While createHypSchs(order) 18. order ← order + 1 19. EndWhile 20. EndIf EndProcedure Algorithm 3 Function connectedPaths Function connectedPathsPath1, Path2 1. If Path1.lastNode=Path2.firstNode 2. return true 3. EndIf 4. If Path1.firstNode=Path2.lastNode 5. return true 6. EndIf 7. return false EndFunction Algorithm 4 Function createHypSchs FunctioncreateHypSchsorder 1. newHypSch ← false 2. For i ← noKM − 1, noAg 3. If hypSch[i].order 6= order − 1 4. continue 5. EndIf 6. For j ← 1, noKM − 1; j 6= i 7. If connectedPaths(maximalPath[i], maximalPath[j]) 8. newHypSch ← true 9. If j ≤ noAg 10. call create−hyperSch(hypSch[noKM], hypSch[i], schema[j]) 11. Else 12. call create−hyperSch(hypSch[noKM], hypSch[i], hypSch[j]) 13. EndIf 14. hypSch[noKM].order ← order 15. maximalPath[noKM] ← hypSch[noKM].getMaximalPath() 16. noKM ← noKM + 1 17. EndIf 18. EndFor 19. EndFor 20. return newHypSch EndFunction Hierarchical Distributed Reasoning System for Geometric Image Generation 177 Bibliography [1] Allen M., Prusinkiewicz P., DeJong T. (2004) Systems for Modeling the Architecture and Physi- ology of Growing Trees: The L-PEACH Model, Proceedings of the 4thInternational Workshop on Functional-Structural Plant Models, pp. 220-225 [2] Chang Shi-Kuo (1970) The analysis of two-dimensional patterns using picture processing gram- mars, Annual ACM Symposium on Theory of Computing archive, Proceedings of the second an- nual ACM symposium on Theory of computing, p. 206-216 [3] Drewes F., Ewert S., Klempien-Hinrichs R., Kreowsky H.J. (2003) Computing raster images from grid picture grammars, Journal of Automata, Languages and Combinatorics, Vol.8, Issue 3, p. 499-519 [4] Dzitac I., Bărbat B. E. (2009) Artificial Intelligence + Distributed Systems = Agents, Int. J. of Computers, Communications & Control, ISSN 1841-9836, E-ISSN 1841-9844, vol. IV, no. 1, pp. 17-26 [5] Ghindeanu M. (2008) Constructing Architectures for an Hierarchical Distributed Reasoning System Based on its Inputs, International Multi-Conference on Engineering and Technological Innovation, USA, p. 231-234 [6] Kandel A., Bunke H., Last M. (eds) (2007) Applied Graph Theory in Computer Vision and Pattern Recognition, Springer, Studies in Computational Intelligence 52 [7] Lindenmayer A. (1968) Mathematical models for cellular interaction in development, Parts I and II, Journal of Theoretical Biology (18), p. 280-315. [8] Priss U., Corbett D., Angelova G. (Eds.) (2002) Conceptual Structures: Integration and Interfaces, 10th Int. Conf. on Conceptual Structures, ICCS 2002 [9] Sharp D. (1998) LMUSe version 0.7b, http://www.geocities.com/Athens/Academy/8764/ lmuse/l- musetxt.html [10] Sowa J.F. (1984) Conceptual structures- Information Processing in Mind and Machine, Addison- Wesley [11] Ţăndăreanu N. (2004). Semantic schemas and applications in logical representation of knowledge, Proceedings of the 10th International Conference on Cybernetics and Information Technologies, Systems and Applications, USA, Vol.III, p. 82-87 [12] Ţăndăreanu N., Ghindeanu M. (2008) Hierarchical Semantic Structures Applied in Automatic Im- age Generation, Proceedings of 11th IASTED International Conference on Intelligent Systems and Control, ISBN: 978-0-88986-777-2 [13] Ţăndăreanu N., Ghindeanu M. (2008) Path-based Reasoning in Semantic Schemas, Annals of Uni- versity of Craiova, Mathematics and Computer Science Series, Vol.35, p.171-181 [14] Zu Song-Chun , Mumford D. (2006) A stochastic grammar of images, Foundations and Trends in Computer Graphics and Vision, Vol. 2, Issue 4, p. 259-362