Approach: Matching To Assignment Distributed Systems

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

IEEE TRANSACTIONS ON COMPUTERS, VOL. c-34, NO.

3, MARCH 1985

197

Assignment in Distributed Computing Systems Using a Minimax Criterion


CHIEN-CHUNG SHEN
AND

A Graph Matching Approach to Optimal Task


WEN-HSIANG TSAI,

MEMBER, IEEE

Abstract - A graph matching approach is proposed in this paper for solving the task assignment problem encountered in distributed computing systems. A cost function defined in terms of a single unit, time, is proposed for evaluating the effectiveness of task assignment. This cost function represents the maximum time for a task to complete module execution and communication in all the processors. A new optimization criterion, called the minimax criterion, is also proposed, based on which both minimization of interprocessor communication and balance of processor loading can be achieved. The proposed approach allows various system constraints to be included for consideration. With the proposed cost function and the minimax criterion, optimal task assignment is defined. Graphs are then used to represent the module relationship of a given task and the processor structure of a distributed computing system. Module assignment to system processors is transformed into a type of graph matching, called weak homomorphism. The search of optimal weak homomorphism corresponding to optimal task assignment is next formulated as a state-space search problem. It is then solved by the well-known A* algorithm in artificial intelligence after proper heuristic information for speeding up the search is suggested. An illustrative example and some experimental results are also included to show the effectiveness of the heuristic search.

throughput caused by the "Csaturation effect" due to excessive interprocessor communication by data and control messages transferred from one program module to another residing in different processors [2]. Thus, the purpose of task assignment in distributed computing systems is to reduce the job turnaround time and increase the throughput. This can be done by maximizing and balancing the utilization of resources while minimizing the communication between processors [1]. While minimizing interprocessor communication tends to assign the whole task to a single processor, load balancing tries to distribute the program modules of the task evenly among the processors. Therefore, there exists conflict between these two criteria and a compromise must be made to obtain an optimal policy for task assignment. Several approaches to task assignment in distributed computing systems have been suggested [1]-[ 12], [16]. They can be roughly classified into three categories, namely, graphtheoretic [3]-[6], mathematical programming [2], [16], and heuristic methods [1]. The graph-theoretic method uses a Index Terms -A* algorithm, distributed computing systems, graph to represent a task, and applies the minimal-cut grapi matching, interprocessor communication, load balancing, algorithm to the graph to get the task assignment with miniminimax criterion, state-space search, weak homomorphism. mum interprocessor communication. The mathematical programming approach formulates task assignment as an optimization problem, and solves it with mathematical programming techniques. And the heuristic method provides I. INTRODUCTION fast but suboptimal algorithms for task assignment, which are useful for applications where an optimal solution can not be D ISTRIBUTED computing systems have become more and more attractive and important in recent years due obtained in real time. Most of the above methods adopt some types of cost functo the advancement of VLSI and computer networking techtion to evaluate the effectiveness of task assignment algonologies. Distributed computing systems not only provide the facility for utilizing remote computer resources or data rithms [1]-[ 12], [16]. The most commonly used cost function not existing in local computer systems but also increase the is defined as the sum of the interprocessor communication processing cost. But these two throughput by providing facilities for parallel processing [1]. cost and the different units, and it is difficult types ofa cost are measured in to give reasonFurthermore, the modularity, flexibility, and reliability of able meaning to the resulting cost summation. distributed computing systems make them attractive to many In this paper, we propose a new task assignment model for types of applications. But there are some major problems that distributed computing systems, based on a graph matching prevent widespread use of the distributed computing system as[1], [2], [16]. One of the problems is the degradation in approach and a more meaningful cost function for taskto a Each graph match corresponds signment optimization. specific task assignment. Cost values are defined in terms of a single unit, time. Minimization of cost functions is based on Manuscript received November 9, 1983; revised May 7, 1984. The authors are with the Institute of Computer Engineering, National Chiao a so-called minimax criterion. The proposed model allows Tung University, Hsinchu, Taiwan 300, Republic of China. easy incorporation of most system constraints encountered in

0018-9340/85/0300-0197$01.00 C) 1985 IEEE

198

IEEE TRANSACTIONS ON COMPUTERS, VOL.

c-34,

NO.

3,

MARCH

1985

applications. A state-space search method [15] is employed for finding optimal task assignment corresponding to minimum-cost graph matching. Useful heuristic information to speed up the search is also suggested. Optimal solutions guaranteed by the proposed approach are important for nonreal-time applications where the resulting assignment will be repeatedly executed on a distributed computing system. And speedup in solution search is useful for real-time applications. In the remainder of this paper, we describe system assumptions, the cost function, and the minimax criterion in Section II. In Section III, we formulate the graph matching model, and in Section IV, we review the state-space search algorithm and apply it to the search of optimal solutions. An illustrative example and some experimental results are given in Section V, followed by conclusive remarks in the last section.

Let

t(A) = max tp(A) which we call the task turnaround time of A. It is easy to see that t(A) is the total time required to complete the whole task according to assignment A under the assumption of negligible processor idleness. Therefore, t(A) may be, from the point of reducing total processing time, used as a cost measure for the effectiveness of task assignment A. The smaller t(A) is, the better A is. An optimal task assignment thus may be defined as the one AO which minimizes the task turnaround time t(A)), i.e., t(AO) = min t(A)
min max A
p

tp(A).

This means that we want to minimize the maximum processor turnaround time, resulting in the so-called minimax criterion. t(A,) will be called the minimum task turnaround time.

II. ASSUMPrIONS, COSTS, AND OPTIMIZATION CRITERION

Various assumptions made about the distributed computing system considered in this paper are first described in the following. 1) The processors in the system are heterogeneous. That is, a single program module, if executed on different processors, will require different amounts of running time, which specify different degrees of preference of the module on the processors. 2) Nonidentical communication links are used by the processors for message transmission. That is, an identical amount of message, if transmitted through different communication links, will require different amounts of transmission time, which specify different degrees of preference of the message on the links. 3) The processors in the system need not be fully connected. But the link between any two processors is symmetric, i.e., the time to transmit a certain amount of message from one processor to another is identical to that to transmit the same message in the reverse direction. 4) There exists little or no precedence relationship or synchronization requirement among the program modules so that processor idleness is negligible during task execution, provided that module partition has been resolved satisfactorily. Based on the above assumptions, the cost function and the minimax criterion proposed for task assignment optimization are described in the following. After a task is partitiohed into suitable modules, let tp(A) denote the total time spent for module execution, and tp(A) be the total time for interprocessor comrnunication delay, both in some processor p according to a certain task assign-

III. GRAPH MATCHING MODEL

Graphs are of a type of very general data structure for system representation. The graph matching problem is that of finding an efficient algorithm to compare two given graphs to see how well they match in a certain sense. A survey of such problems and the algorithms for solving them can be found in [13], [14]. Based on the purpose or the criterion of matching, there are various types of graph matching. The type we consider in this paper is weak homomorphism which is defined as follows. Definition 1: Let GI = (V1, E1) and G2 = (V2, E2) be two graphs where Vi (i = 1, 2) are the vertex sets and Ei (i = 1, 2) are the edge sets of GI and G2, respectively. G, is weakly homomorphic to G2 if there exists a mapping (possibly manyto-one) M: VI -> V2 such that if edge (a, b) E El, then edge (M(a), M(b)) E E2, and we say that there is a weak homomorphism from G1 to G2 As mentioned before, a task submitted into a distributed computing system is partitioned into suitable modules and then assigned to processors. Each task thus can be represented by an undirected graph T = (VT, ET), which we call the task graph where 1) VT is a set of vertices each of which represents a module of the task; 2) ET C VT X VT is a set of edges each of which represents the intermodule communication between the two modules at the ends of the edge. Similarly, the processors in a distributed computing system can also be represented by an undirected graph P = (Vp, Ep), which we call the processor graph where 1) Vp is a set of vertices representing the processors in a distributed ment A. Let computing system; 2) Ep C Vp x Vp is a set of edges representing the communication links between processors. tp(A) = te(A) + tc(A) Because two related modules may be assigned to a single which is the total time spent in processor p for task assign- processor, we add a self-looping edge to each vertex in the ment A. We call tp(A) the processor turnaround time of p. processor graph to follow the weak homomorphism definiThis turnaround time is different for each distinct processor. tion, as will be clear in the following discussion.

SHEN AND TSAI: OPTIMAL TASK ASSIGNMENT

199

Fig. 1 shows a typical task graph and Fig. 2 shows a typical processor graph. For a task assignment A to be acceptable, any two modules a and b which communicate with each other must be assigned either to a single processor X or to two processors X and Y with a communication link between them. In terms of graphtheoretic terminologies just defined and considering the task assignment A as defining a mapping M from the task graph T to the processor graph P, we see this requirement means that if edge (a,b) E ET, then it must be true that edge (X, X) E Ep, or that edge (X, Y) E Ep. Edge (X, X) is always included in the processor graph P as mentioned previously. By Definition 1, this in turn means that there must exist a weak homomorphism from T to P. Therefore, the task assignment problem cain be transformed into the problem of finding a weak homomorphism from the task graph T to the processor graph P with minimum task turnaround time. We call such a weak homomorphism the optimal weak homomorphism from T to P. Now, we have to discuss how task turnaround time (i.e., the cost value) can be computed for each mapping or weak homomorphism. Definition 2: Vertex Transformation -Let T and P be the task graph and the processor graph defined previously. If M is a mapping from T to P defined by a task assignment A, then we use a -* M(a) to denote the assignment of module a E VT to processor M(a) E Vp, and call it a vertex transformation. Let Cp be a nonnegative real-valued cost function defined on all vertex transformations such that Cp (a -* M(a)) denotes the execution time of module a on processor M(a). Definition 3: Edge Transformation -Similarly, we use (a, b) -* (M(a), M(b)) to denote the assignment of module communication between modules a and b to the communication link between processors M(a) and M(b), and call it an edge transformation. Let Cc be another nonnegative real-valued cost function defined on all edge transformations such that CQ ((a, b) -> (M(a), M(b))) denotes the communication time between modules a and b using the communication link (M (a), M (b)). If M (a) is equal to M (b), i. e., if modules a and b are assigned to the same processor, then the cost is defined to be zero. For those edges (a, b) nonexistent in ET, the costs for assigning them to any communication links are also set zero. If there are n modules mI, m2,* ,mn in a task and m processors P1I, P2, * *, P, in a distributed computing system, we can use an n by m matrix X to represent the mapping -> M: Vp VTwhere
{I
processorj
,

= (VT ET ) where = {A, B, C, D, E, F),

VT
I

C\\

ET = {(A,B), (A,C), (A,F), (B,C) (B,D), (B,E) , (D,E) , (C,E) }.

Fig. 1. Task graph.

(VP,EP) where Vp= {X, Y, Z), EP {(X,Y), (Y,Z), (X,X), (Y,Y) (Z,Z)}
P =

Fig. 2. Processor graph.

structure of the processors in a distributed computing system where


I 1

0,

if processors i and j are connected to each other; otherwise.

Let R be an n by n matrix representing the intermodule communication relationship of a task where

= 1: =09

if modules i and j communicate with each other; otherwise.


m

Thus, the total communication time spent in processor j is

CTj

k=1 s=1 t=1


-

E E[C ((mS mt)-> (Pj, Pk))


'
-

According to (1) and (2) the processor turnaround time of processor j is equal to

(2) Xsj Xtk R,t Ljkl In the above equation, Xsj and X,k are included to indicate whether m, is assigned to pj and whether m, is assigned to Pki
TAj = PTj
+

(3) Recalling that the task turnaround time is just the maximum of all the processor turnaround times, we can define the cost of a mapping M defined by a task assignment to be

CTj.

if module i is assigned to processor j; otherwise.

COST(M)

l:sfSm

max(TAj).

(4)

Thus, the total execution time of all the modules assigned to


is
n

According to the minimax criterion, our goal in this paper now is to find an optimal mapping M* which is a weak homomorphism such that

PT]

I
i=l

[Cp(mi

pj)

Xj]

(1)

COST(M*)

= min
M

COST(M).

Let L be

an m

by

matrix representing the configuration

This optimal weak homomorphism M* not only minimizes the interprocessor communication time but also achieves load

200

IEEE TRANSACTIONS ON COMPUTERS, VOL.

C-34,

NO.

3,

MARCH

1985

balancing and will be found by the state-space search method described in the next section.
IV. STATE-SPACE SEARCH METHOD In this section, the problem of finding the optimal weak' homomorphism between two graphs will be formulated as a state-space search problem, and the well-known A * algorithm in artificial intelligence will be used for solving this problem [15]. With the A* algorithm, not only the optimal weak homomorphism is guaranteed to be found, but the search will also speed up. Note that this approach so far has not been considered in any other investigation on task assignment in distributed computing systems. In a state-space search problem, each state description is denoted by a node. Operators applicable to nodes are defined for generating successors of nodes, called node expansion. A solution path of a search problem is a path in the state space defined by a sequence of operators which leads a start node to one of the goal nodes [ 15]. In our case here, a solution path defines the optimal weak homomorphism which is a weak homomorphic mapping M with minimum COST(M). We now formulate the state-space search method as follows. 1) State Description: Let ordered pair set K = {(i, x) i E VT, and x E Vp } denote the partially developed mapping M corresponding to a tree node n in the search tree. Each ordered pair (i, x) means that module i is assigned to processor x, i.e., M: i -- x or x =M(i). Let KG = {i I (i, x) E K} and imax = maxiEKG i. 2) Initial State: The initial state is K # 0, the empty set. 3) Operators: An operator adds new valid pairs (j,y) to K. The procedure is as follows. First, form a set of candidate ordered pairs

4) Goal State: Any state K with VT = KG is a goal state; that is, the search stops when all modules are assigned completely. The above formulation just offers a search scheme for finding a homomorphic mapping corresponding to a task assignment; it does not include computation of cost values. Next, we use the A* algorithm described in Nilsson [15] to find optimal weak homomorphisms. In an A * algorithm, an evaluation function is used to order nodes for expansion, and is guaranteed to find a solution path optimal in the sense that the path cost is minimized, if the evaluation function is properly defined. More specifically, according to Nilsson [15], if we define an evaluation function as f(n) = g(n) + h(n) where g (n) is the minimum path cost from the start node to node n in the state space, and h (n) is a lower-bound estimate, using any heuristic information available, of the minimum path cost h *(n) from node n to a goal node, then as long as h(n) . h*(n) for all n (i.e., h(n) is consistent), theA* algorithm using such an evaluation function will be guaranteed to find an optimal solution path in the state space after expanding fewer nodes during the search than any uninformed algorithms. In other words, such a heuristic search algorithm can speed up the search of an optimal weak homomorphism, which is usually time consuming for graphs with large numbers of vertices and edges. According to the previous formulation of task assignment as the graph matching problem, a node n in the state space denotes a partially developed homomorphic mapping which assigns part of the modules of a task to processors. Thus, we can let the evaluation function at node n in the state space be

D = {(j,y)l] = max + l,y E Vp}. j

f(n) = g(n) + h(n)

(5)

Next, check all candidate pairs one by one for validity, using vertex adjacency information in the task graph T and the processor graph P. A candidate pair (j, y) E D is said to be valid if for each (i, x) E K it is true that if edge (i,j) E ET, then either edge (x, y) E EP or x = y. This validity check is necessary to preserve the property of weak homomorphism (see Definition 1). Each candidate pair (j, y) represents a possible additional assignment of module j to processor y, but if j communicates with any other module i already assigned to a processor x (i.e., i E KG), thenj should also be assigned either to processor x or to another distinct processor y which has a communication link to x. Let D' be the set of all valid pairs in D. Then the operator finally updates set K as the union of old K and D'. Note that the operator is defined in such a way that it always expands the partially developed mapping M (as represented by K) by assigning the module with next larger index number j = imax + 1 (see the definition of D above) to each of all the processors y in Vp. It is in this way that developing of partial mapping can be kept in order until all possible module assignments are exhaustively considered (see Fig. 5 for an illustration).

where the value of g (n) is the total minimum cost of the vertex and edge transformations included in the partially developed mapping M corresponding to n, and the value of the heuristic function h (n) is an estimate of the value h *(n) which is the minimum cost of the vertex and edge transformations required to complete the partial mapping M. To calculate g (n), we first set up the X and R matrices as mentioned in the previous section for the partial mapping M corresponding to node n, and then use (1), (2), (3), and (4) to calculate the cost of a partial mapping M which defines g (n). As to the heuristic function h (n) in (5), it can be defined by several different approaches. The simplest way is to set h (n) =0 for all n, and the resulting search is a uniform-cost search [15] which nevertheless is still guaranteed to find an optimal weak homomorphism. To be more efficient in the search, nonzero h (n) values, of course, should be used, and this has been found possible as is discussed in the following. Let M be the corresponding partial mapping at search tree node n. When using (4) to find the cost of M, try to find the k such that

COST(M)

=
=

COST(TAk)
1:5j-M

max(TAj).

SHEN AND TSAI: OPTIMAL TASK ASSIGNMENT

201
2

That is, processor k is currently with the maximum processor turnaround time in the partial task assignment. Let MK be the set of modules assigned to processor k by the partial mapping M, and MK' be the set of all the remaining modules not assigned by M. Then, define LK = {(a,b)Ia E MK', b E MK, and (a, b) E ET (edge set of task graph)} which denotes a set of the edges representing all the communications between the modules in MK and MK', and define B = {a (a, b) E LK} which denotes the set of those unassigned modules in MK' communicating with the modules in processor k. The heuristic information useful for defining h(n) is observed as follows. When the state-space search process goes forward, each module a in B will have to be assigned either to processor k or to a processor I connected through a communication link to processor k so that communication between module a and those modules in k can be accomplished. But these two different types of assignments will result in different amounts of partial processor turnaround time being increased at processor k. To keep h (n) as a lower bound of h *(n), we must find out the smallest amount for each module a in B and then sum up these amounts for all the modules in B as the value h (n), as is calculated in the following algorithm. Algorithm 1: Computation of h (n). M is the corresponding partial mapping at search tree node n. Step 1): Find the k such that

=(VT, ET)

where

.VT

{1,2,3,4},
= { (1,2),(2,3), (3,4),(4,1), (2,4)}.

ET

Fig. 3. Task graph.


P =

(Vp, Ep )
={

where

BsR

A,B,C},
{ (A,B), (B,C), (A,A), (B,B), (C,C) }

Fig. 4. Processor graph.

Step 4): Expand node n, using operators applicable to n, and compute the valuef(n') = g(n') + h(n') for each successor n' of n where g(n') is computed according to (1), (2), (3), and (4), and h(n') is computed according to Algorithm 1. Put all the successors of n on OPEN. Step 5): Go to Step 2). In Step 4), if h(n') is always set 0, then Algorithm 2 is a uniform-cost search. Otherwise, it is an A* algorithm.
V. ILLUSTRATIVE EXAMPLE

COST(M)

COST(TAk)

max(TAj). 1l.j5m

Step 2): Find the sets MK, MK', LK, and B as defined previously. Step 3): For each a E B, find La= {b(a,b) E LK} which is the set of the modules in processor k communicating with module a E B.

processor I connected to processor k, then ACa is set infinite. Step 5): Let Ia min(ACa,APa). Then compute the heuristic function h(n) as

Step 4): Define ACa = minl.cl,m[1bELa Cc((b, a) (Pk,Pl))] where I denotes any processor connected to processor k, and define APa = Cp(a -> Pk). If there exists no

Here, we give an example to illustrate the mapping between the task graph and the processor graph by the proposed state-space search method. Task graph T and processor graph P are shown in Figs. 3 and 4. The intermodule communication time and the module processing time are listed in Tables I and II. Using the vertex and edge transformation notations defined previously, we have

h(n) = >LIa
aEB

It is not difficult to see that h (n) is a consistent lower bound of h *(n) for all n, so the state-space search will be guaranteed to find an optimal weak homomorphism using the algorithm described in the following. Algorithm 2: Find an optimal weak homomorphism between two graphs. Step 1): Put the initial node K = 0 on a list called OPEN, and set f(K) = 0 where f is an evaluation function defined

Cp(l->A) = 10, Cp(l -> B) = 20, Cp(I -> C) = 30, Cp(2 ->A) = 40, Cp(2 -- B) = 5, CP(2-* C) = 10,
and

CP(3 -* A)

70,

Cp(3 ->B) = 50, CP(3-* C) = 80, Cp(4->A) = 50, Cp(4->B) = 80, Cp(4 -> C) = 20,

= = by (5). Step 2): Remove from OPEN the node n with a smallest f = 70. = value and put it on a list called CLOSED. Step 3): If n satisfies the goal state defined in the previous Then, using Algorithm 2 as an ordered-search algorithm, section, then find out the corresponding graph mapping M as we can find an optimal weak homomorphism M*: VT Vp the desired homomorphism and exit. Otherwise, continue. and compute the minimum task turnaround time. Fig. 5

CC((1, 2) CC((2, 3) CC((3, 4) CC((4, 1) CC((2,4)

(A,B)) (A,B)) (A, B)) (A, B)) (A,B))

= =
=

CC((1, 2) CC((2, 3) CC((3, 4) CC((4, 1) CC((2,4) --

(B, C)) (B, C)) (B, C)) (B, C)) (B,C))

= = =

20, 5,

35, 40,

202

IEEE TRANSACTIONS ON COMPUTERS, VOL. c-34, NO. 3, MARCH 1985

TABLE I INTERMODULE COMMUNICATION TIME


m O d U I e

4
40

m I

20

d 2
U

20
0

0
5

5
0 35

70
35
0

1 3 4

40

70

TABLE II MODULE. PROCESSING TIME


A
m 1

proc essor C B
20 30

10

d 2

40 70
50

5 50
80

10 80
20

1 3
e

(START NODE)

(1,A)

(1,B)
65 L65]

I-iol
(2,A)
10

(1,C) 60

(2,B)

(2,A)
11

(2,B)
110

(2,C)
E80 l

(2,B)
70

(2,C)
1
65

(3,A)

(3,B)

(3,C)

(3,B)

(3,C)

(3,A)

(3,B)

C)

(3 3,
90

C)

1551 1155

105

1l70

1110

155

1155}
(4,B

140

r2451 (GOAL NODE) 100l

4,C)

Fig. 5. State-space search tree of the illustrative example (circled numbers indicate node expansion order, and squared numbers indicate node costs).

shows the resulting search tree. The optimal weak homomorphism M *, as shown, is

12 yC M*:{3 3 yB
4
C

which defines the optimal assignment of task T to distributed computing system P, and the minimum task turnaround time of this assignment is 100. As shown in Fig. 5, totally only 9 state-space nodes are expanded and 23 nodes generated before the goal node is found. The search concentrates rather well on the right path to the goal node with only a few branches elsewhere. To

prove that such concentration is a result from utilizing the heuristics proposed previously, we further reuse Algorithm 2 as a uniform-cost algorithm (by setting h(n) zero for all nodes) to find the optimal weak homomorphism again. The resulting state-space search tree is too large to be included here as a figure. We only mention that totally 22 state-space nodes are expanded in the tree with 49 nodes generated. More experiments have been performed on a CDC CYBER 170/720 computer for some other cases to test the effectiveness of the heuristic function h (n) used in Algorithm 2. The results [ 18] show that in most cases with module numbers and processor numbers less than 10, the number of generated nodes by Algorithm 2 is about a half of that generated by the uniform-cost algorithm. It is also found in these cases that the complexity of Algorithm 2 as defined by the number of'generated nodes is approximately to the order of N2, although

SHEN AND TSAI: OPTIMAL TASK ASSIGNMENT

203

optimal task assignment, like many.other graph matching problems, needs exponential time in the worst case [17].
VI. CONCLUSIONS In this paper, we describe a graph matching approach to task assignment optimization. Optimal task assignment is transformed into the search problem of optimal weak graph homomorphism, which is then solved by heuristic state-space search using the A* algorithm. The approach uses the task turnaround time as the cost measure and the minimax criterion as the criterion for assignment optimization. This approach allows various system constraints to be easily included for consideration. It minimizes interprocessor communication and optimizes load balancing by minimizing the task turnaround time. There are MN possible assignments to be considered in an assignment problem with M processors and N modules, and actual computation using an enumerative algorithm requires time to the order of MN [ 10]. The state-space heuristic search algorithm proposed in this paper is shown effective by an illustrative example and some case studies for speeding up solution search. Further research can be directed to the improvement of the proposed lower-bound estimate h (n) of h *(n) in Algorithm 1 and the inclusion of precedence consideration into the proposed algorithms.
REFERENCES
[1] K. Efe, "Heuristic models of task assignment scheduling in distributed systems," Computer, vol. 15, pp. 50-56, June 1982. [2] W. W. Chu, L. J. Holloway, M. T. Lan, and K. Efe, "Task allocation in distributed data processing," Computer, vol. 13, pp. 57-69, Nov. 1980. [3] H. S. Stone and S. H. Bokhari, "Control of distributed processes," Computer, vol. 11, pp. 97-106, July 1978. [4] H. S. Stone, "Multiprocessor scheduling with the aid of network flow algorithms," IEEE Trans. Software Eng., vol. SE-3, pp. 85-93, Jan. 1977. [5] T. C. K. Chow and J. A. Abraham, "Load balancing in distributed systems," IEEE Trans. Software Eng., vol. SE-8, July 1982. [6] S. H. Bokhari, "Dual processor scheduling with dynamic reassignment," IEEE Trans. Software Eng., vol. SE-5, July 1979. "On the mapping problem," IEEE Trans. Comput., vol. C-30, [7] pp. 207-214, Mar. 1981. [8] H. S. Stone, "Critical load factors in two-processor distribluted systems," IEEE Trans. Software Eng., vol. SE-4, pp. 254-258, May 1978. [9] G. S. Rao, H. S. Stone, and T. C. Hu, "Assignment of tasks in a distributed processor system with limited memory," IEEE Trans. Comput., vol. C-28, pp. 291-299, Apr. 1979. [10] C. C. Price, "The assignment of computational tasks among processors in a distributed system," in Proc. Nat. Comput. Conf., May 1981, pp. 291-296. [11] L. Kleinrock and A. Nilsson, "On optimal scheduling algorithms for time-shared systems," J. ACM, vol. 28, no. 3, pp. 477-486, July 1981. [12] Y. C. Chow and W. Kohler, "Models for dynamic load balancing in a heterogeneous multiple processor system," IEEE Trans. Comput., vol. C-28, pp. 354-361, May 1979.
,

[13] W. H. Tsai, "Graph matching problems: A survey and a tutorial," in Proc. Ist Conf. Comput. Algorith., Hsinchu, Taiwan, China, July 1982. [14] W. H. Tsai and K. S. Fu, "Subgraph error-correcting isomorphisms for syntactic pattern recognition," IEEE Trans. Syst. Man, Cybern., vol. SMC-13, pp. 48-62, Jan./Feb. 1983. [15] N. J. Nilsson, Problem Solving Methods in Artificial Intelligence. New York: McGraw-Hill, 1971. [16] P. R. Ma, E. Y. S. Lee, and M. Tsuchiya, "A task allocation model for distributed computing systems," IEEE Trans. Comput., vol. C-31, pp. 41-47, Jan. 1982. [17] R. C. Read and D. G. Corneil, "The graph isomorphism disease," J. Graph Theory, pp. 339-363, 1977. [18] C. C. Shen and W. H. Tsai, "A graph matching approach to optimal task assignment in distributed computing systems using a minimax criterion," Inst. Comput. Eng., Nat. Chiao Tung Univ., Hsinchu, Taiwan, Republic of China, Tech. Rep., July 1983.

......

Chien-Chung Shen was born in Taiwan, Republic of China, on July 15, 1960. He received the B.S. and M.S. degrees in computer engineering from National Chiao Tung University, Hsinchu, Taiwan, in 1982 and 1984, respectively. From 1982 to 1984, he served as a Teaching and Research Assistant in the Institute of Computer Engineering, National Chiao Tung University. His

n f.,

pattern recognition, graph theory, database design,


and computer-aided design of VLSI.

research interests include artificial

intelligence,

Wen-Hsiang Tsai (S'79-M'80) was born in Tainan, Taiwan, Republic of China, on May 10, 1951. He received the B .S. degree from National Taiwan University, Taipei, Taiwan, in 1973, the M.S. degree from Brown University, Providence, RI, in 1977, and the Ph.D. degree from Purdue University, West Lafayette, IN, in 1979, all in electrical engineering. From 1973 to 1975, he served in the Chinese Navy as an Electronics Officer. From 1977 to 1979, he worked as a Research Assistant in the Advanced Automation Research Laboratory, School of Electrical Engineering, Purdue University. Since November 1979, he has been on the faculty of the Institute of Computer Engineering at National Chiao Tung University, Hsinchu, Taiwan. His current research interests are image processing and pattern recognition, computer vision applications in robotics and automation, and parallel processing and multiprocessor systems.

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy