Embedded harmonic control for dynamic trajectory planning on by Bernard Girau & Amine Boumaza
EMBEDDED HARMONIC CONTROL FOR DYNAMIC TRAJECTORY
PLANNING ON FPGA
Bernard Girau
Cortex team - LORIA INRIA-Lorraine
Nancy - France
email: Bernard.Girau@loria.fr
Amine Boumaza
Maia team - LORIA INRIA-Lorraine
Nancy - France
email: Amine.Boumaza@loria.fr
Abstract
This paper presents a parallel hardware implementation of
a well-known navigation control method on reconﬁgurable
digital circuits. Trajectories are estimated after an iterated
computation of the harmonic functions, given the goal and
obstaclepositionsof the navigationproblem. The proposed
massively distributed implementation locally computes the
directiontochoosetogettothegoalpositionatanypointof
the environment. Changes in this environment may be im-
mediately taken into account, for example when obstacles
are discovered during an on-line exploration. The imple-
mentation results show that the proposed architecture si-
multaneously improves speed, power consumption, preci-
sion, and environment size.
1 Introduction
Trajectory planning consists in ﬁnding a way to get from a
starting position to a goal position while avoiding obstacles
within a given environment or navigation space.
Harmonic functions have been proposed as potential
ﬁelds fortrajectoryplanningin [4] and [1]. This “harmonic
control” approach was mainly motivated by the fact that
harmonic functions do not have local extrema (unlike other
potential based methods as in [10]). In this approach, ob-
stacles correspond to maxima of the potential, while goals
correspond to minima. Control algorithms then reduce to
locally descend the potential until they reach the global
minimum.
Harmonic control has had some impact on the
robotics community [12, 18, 2, 6, 8, 9, 14, 16]. Neverthe-
less, very few hardware implementations have been pro-
posed, and they are usually analog, so that they suffer from
a verylongandcomplexdesignprocess, anda lack ofﬂexi-
bility(environmentsize, precision). Theaimofthis workis
to propose a embeddable digital implementation that uses
reconﬁgurable circuits, so as to reduce design time and to
improve ﬂexibility.
The proposed implementation maps the massively
distributed structure of the space-discretized estimation of
the harmonic function onto the circuit. An area-saving se-
rial arithmetic is used, within a global scheme that simul-
taneously ensures pipelining and parallelism of the itera-
tive computations. The decision process is also taken into
account, through local estimations of the direction to take
from any point.
Though the speed performance reported in this paper
outperformsoftwareimplementations,themainadvantages
of the described architecture is to provide low-power and
scalable solutions that are able to handle the very large pre-
cisions required by harmonic control within large naviga-
tion environments.
Section 2 describes the principles of harmonic func-
tions and of their use for trajectory planning. Section 3
summarizestheadvantagesofhardwareparallelimplemen-
tations on FPGAs for embedded navigation in autonomous
systems, and it justiﬁes the choice of serial arithmetics, es-
pecially with respect to the precision requirements of har-
monic control. The proposed hardware architecture and its
implementation results are described in section 4.
2 Harmonic control
In this part, we beginby a brief reminderof harmonicfunc-
tions and some of their properties after which we will dis-
cuss their application to the navigation problem.
2.1 Harmonic functions
Let Ω be an open subset of IR
n, ∂Ω its boundary and ¯ Ω its
closure such that ¯ Ω = Ω ∪ ∂Ω.
Deﬁnition Let u : ¯ Ω → IR be a real function, twice con-
tinuously differentiable, and Ω ⊆ IR
n with n > 1. The
function u is harmonic iff ∆u =
Pn
i=1
∂
2u
∂x2
i
= 0.
This equation is known as Laplace’s equation. Harmonic
functions satisfy interesting properties:
• The maximum principle states that: if u is a non-
constant continuousfunctionon ¯ Ω that is harmonicon
Ω, then u attains its maximum and minimum values
over ¯ Ω on ∂Ω.
• Applying the divergence theorem on harmonic func-
tions, the following equation holds:
Z
s
  ∇u    ndS = 0where s is the boundary of a closed region strictly in
Ω and   n is a normal vector of s. This equation ex-
presses that the normalﬂux ofthe gradientvectorﬁeld
through the region bounded by s is zero. It follows
that there can be no local minimum or maximum of
the potential inside a bounded region of Ω.
2.2 Application to navigation
To solve the navigation problem using harmonic functions,
we consider the problem as a Dirichlet problem: its solu-
tion is to ﬁnd the function u that is harmonic on Ω (the
navigation space) and that satisﬁes boundaryconditions on
∂Ω (obstacles and navigation goal), in other words, ﬁnd u
such that:
￿
∀x ∈ Ω, ∆u(x) = 0
∀x ∈ ∂Ω, u(x) = g(x)
where the function g : ∂Ω → IR represents boundary con-
ditions on ∂Ω. These conditions deﬁne the values of the
navigation function on obstacle and goal positions. With-
out loss of generalitywe choose g(x) = 1 forobstacles and
g(x) = 0 for goals. Therefore solving the Dirichlet prob-
lem consists in ﬁnding the function u that is harmonic on
Ω and that has value 1 on obstacle positions and value 0 on
goal positions.
The navigation problem is then solved as follows: a
simple descent along the gradientof u providesa trajectory
towards a given goal from any starting position. Properties
of harmonic functions ensure that such a path exists and it
is free of local optima.
2.2.1 Numerical method to solve Laplace’s equation
In this part we consider the case where Ω = IR2. Tradi-
tionally, Laplace’s equation is solved using methods from
ﬁnite differenceson a regulargrid(discretesamplingof Ω).
Using a Taylor approximation of the second derivatives we
obtain the following discrete form of u(x1,x2):
∆δu(x1,x2) =
1
δ2 [u(x1 + δ,x2) + u(x1 − δ,y1)
+u(x1,x2 + δ) + u(x1,x2 − δ) − 4u(x1,x2)]
where δ is thesamplingofthegridthatrepresents Ω. Inthis
form, the equation can be solved using relaxation methods
such as Jacobi or Gauss-Seidel whose principle is to itera-
tively replace each grid point value with the simple average
of its four neighbors. Figure 1 shows different trajectories
generated by simulations using this numerical scheme.
2.2.2 Properties of harmonic navigation functions
Harmonic navigation functions have many interesting
properties which motivated their use in numerous applica-
tions especially in robotics [1, 15, 11, 5, 8, 6, 18, 16, 12,
14, 2, 9]:
Figure1. Trajectories generatedby harmoniccontrol,start-
ing at equally spread points on a 100 × 100 grid (two goal
positions).
Global navigation: Complete trajectories may be gener-
ated towards a goal position from anywhere in the environ-
ment, since there are no local minima.
Dynamic trajectory planning: Unexpected updates of
the environmentmaybe takenintoaccount,since harmonic
functions are computed by iterative relaxation methods.
Therefore newly detected obstacles may be integrated in
the modelas new boundaryconditionsduringcomputation,
so that harmonic control is available in dynamic environ-
ments or in environments explored on-line [18, 3].
Parallel computation: An interesting property of the
computations described above is their massively parallel
distribution. Computing grid point values only requires lo-
calinformationoftheneighboringcells. Fine-grainparallel
implementations appear as an opportunity, as discussed in
the next section.
3 Towards an embedded implementation
The results shown in ﬁgure 1 were obtained from software
simulations carried out on a PC. The aim of our work is
to design an embedded system for robot navigation. Com-
putation speed is not the only criterion (trajectory decision
must be performed in real time). Power consumption is
also essential for autonomous systems. Moreover, compu-
tation precision and scalability appear as critical issues for
harmonic control, as discussed below. These combined as-
pects motivate the design of a parallel hardware implemen-
tation. In such a work, the number of inputs/outputs and
above all the level of parallelism have a direct inﬂuence
on the obtained implementationconsumptionand speed. A
massively parallel implementation is a real challenge, tak-ing into account constraints such as precision, grid size,
dynamic updates, etc.
3.1 Implementation environment
Since the appearance of programmable hardware devices,
such as ﬁeld programmable gate arrays (FPGAs), algo-
rithms may be implemented on very fast integrated circuits
with software-like design principles. Usual VLSI designs
lead to very high performances. But the time needed to
realize an ASIC (application speciﬁc integrated circuit) is
too long, especially when different conﬁgurations must be
tested. The chip productiontime is usually very long (up to
6 months).
FPGAs, such as Xilinx FGPA ([17]), are based on a
matrix of conﬁgurable logic blocks (CLBs). Each CLB is
able to implement small logical functions (4 or 5 inputs
functions) with a few elementary memory devices (ﬂip-
ﬂops or latches) and somes multiplexors. Depending on
the CLB capabilites, some operators can lead to small or
large solutions in the FPGA. The Xilinx Virtex series are
well-suited for the implementation of serial arithmetic op-
erators. The CLBs can be connected using a conﬁgurable
routing structure.
An FPGA approach simply adapts to the handled ap-
plication, whereas a usual VLSI implementation requires
costlyrebuildingsofthewholecircuitwhenchangingsome
characteristics. A design on FPGAs requires the descrip-
tion of several operating blocks. Then the control and the
communication schemes are added to the description, and
an automatic “compiling” tool maps the described circuit
onto the chip.
3.2 Technological choices
The main issues when a massively distributed model is
mapped onto a FPGA are the huge number of operators,
and the routing problems due to the dense interconnections
of these models. A ﬁrst standard technological choice to
solve these problems is to use serial arithmetics: smaller
operators may be implemented, and they require less con-
nection wires. Another essential technological choice is to
estimate the minimum precision required to keep satisfac-
tory results, so as to use as small as possible operators and
memory resources.
3.2.1 Serial arithmetics
Serial arithmetics correspond to computation architectures
where digits are provided in a serial way, i.e. digit after
digit. Serial arithmetics lead to operators that need small
implementation areas and less inputs/outputs, and that eas-
ily handle different precisions, without an excessive in-
crease of the implementation area. Serial systems are char-
acterised by their delay, i.e, the number δ such that p digits
of the result are deduced from p +δ digits of the input val-
ues.
Two main kinds of serial arithmetics are available:
LSBF (least signiﬁcant bit ﬁrst), and MSBF (most signif-
icant bit ﬁrst). Standard serial operators work in a LSBF
mode (for example to propagate the carry in serial adders).
Though our model requires the computation of a minimum
value (gradient descent), that may only be computed in a
MSBF mode, we have chosen to use standard serial opera-
tors to optimize the required space 1.
3.2.2 Computation precision
Softwaresimulationareusuallyperformedtostudythepre-
cision that is required by an application before its hard-
ware implementation. Precision issues appear as critical
for harmonic control. This problem has already been men-
tioned as a major limitation for analog implementations
[15]. Computing a harmonic potential over a large grid
may result in gradients that are too small to use because
the allowable precision is easily reached. Connolly [5]
presents a relationship between the precision required for
ﬂoating point representation on a computer and the num-
ber of nodes on the grid. He argues that the precision
should at least represent 1
N, where N is the total number
of grid points, to circumvent precision problems. This fur-
ther modivates the use of an embeded implementation in
which we can allow very high precisions (see 4.3).
We have carried out experimental simulations with
differentnavigationspaces. Theyhaveshownthat forsome
50 × 50 grids, a 22-bit precision is required at least to en-
sure signiﬁcant differences between neighboringgrid point
values so as to generate correct trajectories. Other simu-
lations have shown that very large grids may require more
than 64-bitprecisionnumbers. It shouldbe pointedoutthat
in case of insufﬁcient precision, large areas of the grid may
share the same value, which results in wrong trajectories.
It must be mentioned that implementations based on
serial arithmetics may be more easily extended to larger
precisions than implementations based on parallel arith-
metics. Since the size of serial adders and comparators
does not depend on precision (unlike multipliers and ele-
mentary functions), our implementation may handle large
precisions by means of rathersimple changes in the control
modules.
4 Hardware implementation of harmonic
control
Thoughharmoniccontrolhas been widely used in robotics,
few hardware implementations have been proposed. Their
technological choices are very different. Most works are
motivated by the fact that analog resistive grids may easily
compute the harmonic function as in 2.2.1. For example
1The only existing radix-2 MSBF serial arithmetics is called on-line
arithmetics. It uses a redundant number representations system, which
induces less area-saving operators.obstacle X
Y
position module
x y
robot
control
border
nodes
nodes
NEWS
all enable signals
decision module control module
all NEWS signals
Figure 2. General architecture
in [13] an analog implementation of a 16 × 16 grid is pro-
posed. The main limitation of this work is the precision (as
for most analog implementations). To our knowledge, dig-
ital FPGA-based implementations have not yet been pro-
posed.
In this work, the discretized computation of the har-
monic function is performed to make navigation decisions
for a robot in an environmentthat may be exploredon-line.
Navigation orders are also discretized: at each position, the
robot is ordered to move north, east, west or south. This
simpliﬁcation implies that the optimal trajectory along the
gradient is only roughly estimated by elementary move-
ments along the axis’. It still results in global trajectories
towards the goal position from any starting point.
4.1 General architecture
The ﬁne grain pipelined internal structure of the proposed
digital architecture was implemented using ﬁxed point
arithmetic. Since grid point values range from 0 to 1, an
unsigned representation with 25 bits is chosen, with a 24-
bit fractionalpart. As mentionedabove,largerwordlengths
may easily be handled.
Figure 2 illustrates the general architecture of the im-
plementation of harmonic control for a n × n grid. It con-
sists of a grid of n × n identical node modules (gathered
16 by 16 to handle on-chip data storage and access) sur-
rounded by border node modules, a control module, a de-
cision module, and a module to interact with the robot.
The role of each component is the following:
• Each node computes its corresponding grid point
value, as well as the direction (north, east, west or
south) to follow to get to the goal position. All nodes
use loop computations within an internal pipeline
scheme. This scheme is particularlyefﬁcient forserial
implementationsof iterated computationswithin mas-
sively distributed models ([7]). The control of these
computations are synchronized in the whole grid so
that nodes may serially communicate their grid point
values to their neighbors. In order to simplify the
block-diagram of ﬁgure 2, only few buses and wires
are shown: the signals that carry the grid point values
from and to any neighboring node.
• The nodes are split in groups of 4×4 nodes that share
common storage resources: a single dual port SRAM
block stores the values of the 16 grid points, and its
R/W accesses arecontrolledbyasinglesetofcounters
(see 4.2).
• The node modules are very simple. They serially
generate the grid point value of obstacles (see the
Counters module in 4.2).
• The interaction with the robot has not yet been imple-
mented. It stronglydependsontheexactconﬁguration
of the robot and of the FPGA board. It includes a po-
sition modules, which role is mainly to compute the
coordinates (X,Y) of the closest grid point around
the real coordinates (x,y) of the robot in its envi-
ronment.
• The control module generates the enable signals that
are sent to all nodes to control their individual be-
haviour when a non-synchronizedevent occurs:
– convergenceof the computationof the harmonic
function (it depends on the local convergence
signals computed by all nodes, see 4.2)
– detection of an unknown obstacle (at node
(X,Y))
• The decision modules collects the navigation direc-
tions locally indicated by each node, and it forwards
the selected direction of node (X,Y) to the robot.
In the following subsections, the hardware architec-
ture for the node model and its main components will be
described in some detail.
4.2 Node implementation
The architecture for the node model is shown in the simpli-
ﬁed block diagram of ﬁgure 3. It uses 1-bit inputs and out-
puts to exchange data among nodes and with global mod-
ules. Inputsare mainlyused to receivethe neighboringgride sel sat Saturation
FA
FA
FA
RAM
cntW
cntR
r_cnt
comp
comp
NEWS
comp
h
to_W
to_S
to_E
to_N
h_S
h_W
h_N
h_E
NE WS EN R W
reset
clk
gnd
Update
Direction
Counters Mem
Enable
Cvg
cvg
d_h
enable
1
Figure 3. Architecture of a node
point values (signals h_N,h_E,h_W,h_S) and global
control signals (standard signals clk,reset,enable,
signals sel,sat to indicate obstacle/goal changes, and
SRAM controls EN,R,W). Outputs are twofold: the local
value h of the harmonic function is sent to all 4 neighbors
(signals to_N,to_E,to_W,to_S) and signals NE and
WS code the 4 possible directions to which a robot located
around this grid point should move.
The proposed hardware node model is constituted by
ﬁve main modules: the iterative computation of the har-
monic function is performed by the Update module, the
local convergence of this computation is detected by the
Cvg module, the local navigation decision is performed by
the Decision module,the nodereceives ordersto behave
as an obstacleora goalthroughthe Saturationmodule,
and communication with the dual port SRAM block that
stores the grid point value is controled by the Mem module.
Figure 3 shows this architecture, as well as its interaction
with sharedresources(thelocal CountersandRAM mod-
ules are shared by a groupof 4×4 nodes, and the Enable
moduleis part of the global control module). The function-
ality of the main modules and their implementation details
are described below.
Update: This module performs the iterated computation
of the harmonic function value hi,j where (i,j) are
the coordinates of the node in the grid. As described
in 2.2.1, each iteration computes:
hi,j(t + 1) =
hi−1,j(t) + hi,j−1(t) + hi+1,j(t) + hi,j+1(t)
4
Three standardFull-Addercells are sufﬁcient to com-
pute this average, without any shift or division opera-
tor, since the output value is sent to the RAM with a
write address that is delayed by 2 clock cycles (divi-
sion by 4) with respect to the read address. Additional
ﬂip-ﬂops are required to store the carry values.
Cvg: Thismoduleseriallycomparestheoutputoftheiter-
ated computation to the stored value (delayed by two
ﬂip-ﬂops in the Mem module). This local convergence
test is thensenttoaglobalNOR gate(seetheEnable
module) to disable the computation loop after conver-
gence.
Decision: This module operates after convergence of the
computationiterations. It computesthe minimumgrid
point value among the 4 neighbors. Its output is the 2-
bit code of the direction to choose among N, E, W
and S. This code is computed by the NEWS module
that receives the results of the three comparators. This
computation is performed in a MSBF mode, thanks to
the reverse address counter r_cnt.
Counters: This module is shared by 16 nodes. It gener-
ates the read (resp. write) addresses for the dual portRAM by means of counters cntR (resp. cntW). The
read address is multiplexed with the reverse counter
r_cnt to change from LSBF to MSBF mode. When
handling d-bit precision data, these counters are re-
set each d + 2 cycles (the RAM is written with a 2-
clock cycles delay). All stored values have two zeros
asmostsigniﬁcantbits. Value1(forobstacles)iscom-
puted as a logical function of counter cntR.
Mem and Saturation: The local grid point value is not
directly the output of the Update module. It may
also be a constant 0 or 1 (goal or obstacle). A multi-
plexer selects the correct value with respect to a con-
trol given by the Saturation module that memo-
rizes the sat valueto be the constant valueof the grid
point when the node is selected by the global control
module (signal sel).
4.3 Implementation results
This work uses a PCI bus board equiped with a Vir-
tex XC2V6000-4FF1517 FPGA from Xilinx, with up to
6,000,000 system gates. It must be pointed out that the
current largest FPGAs already outperform the capacity of
the Virtex XC2V6000: such a FPGA contains 67,584 logic
cells, to be compared with the 200,448 ones of the largest
Virtex-4.
The design was synthesized, placed and routed au-
tomatically in Xilinx Foundation ISE 7.1i. Each node re-
quires16logiccells, sothateachblockof16nodesrequires
280 logic cells (counters included). On a XC2V6000, 144
dual port SRAM blocks are available, that may be conﬁg-
ured as 1K×18 RAMs to be shared by blocks of 16 nodes.
The whole architecture implements a 48 × 48 grid on less
than 65% of the XC2V6000logic cells. Larger grids (up to
73×73)maybe implementedon the currentlargest FPGAs
with this approach (the available SRAM blocks being the
critical resource).
When considering the harmonic function computa-
tion, software implementations on a microprocessor based
computer, Pentium 4, 2GHz, require around 100 s per it-
eration with a 50 × 50 grid (100 to 1000 iterations are re-
quired to converge). In the proposed hardware implemen-
tation, 27 clock cycles are required per iteration, with an
estimated clock frequency of 55MHz. Thus, the architec-
ture provides a speed factor up to 200×, that would even
increase with the number of nodes in the grid (sequential
vs parallel implementation). But the implementation speed
is not the main advantage of our implementation: real-time
computationis easily reachedby software implementations
for such precisions and size grids. Power consumption is a
key factor for embedded implementations, and above all
very large precisions may be easily handled by the pro-
posedserialimplementation(upto1K bitswhenfullyusing
the SRAM blocks).
5 Conclusion and future work
We have presented an embedded architecture to solve the
navigation problem in robotics, that computes trajectories
along a harmonic potential, using a FPGA implementa-
tion. This architecture includes the iterated estimation of
theharmonicfunctions,withthe possibilityofchangingthe
goal and obstacle positions of the navigation problem dur-
ing computation. The trajectory decision is also performed
on-chip, by means of local computations of the preferred
direction at each point of the discretized environment. The
proposed architecture uses a massively distributed grid of
identical nodes that interact with each other within mutu-
ally dependant serial streams of data to perform pipelined
iterative updatesof the local harmonicfunctionvalues until
global convergence.
The proposed architecture enables us to handle very
large precisions using SRAM blocks, which is a beneﬁt
over computer resolution of harmonic funtions. Furthe-
more, a greatly improvedspeed and a low power consump-
tion are other non-negligible advantages, since the goal is
to embed this implementation on mobile robots. The cur-
rent hardware model is already able to handle signiﬁcantly
large discretized environments.
Future architecture improvements are already consid-
ered to extend the capacities of the model to navigation
within larger and more complex environments. A stud-
ied extentionefﬁciently uses the available SRAM to handle
very large grid, by means of an iterated computation mode
that is both globally asynchronousand block-synchronous.
Current efforts are also made to extend our implementation
to optimal control, a more generic (and tunable) trajectory
planning method.
References
[1] S. Akishita, S. Kawamura, and K. Hayashi. Laplace
potentialformovingobstacleavoidanceandapproach
of a mobile robot. In Japan-USASymposium on Flex-
ible Automation, A Paciﬁc Rim Conference, pages
139–142, 1990.
[2] D. Alvarez, JC Alvarez, and RC Gonzalez. Online
motion planning using laplace potential ﬁelds. In
Proceedings of the IEEE International Conference
Robotics and Automation, 2003., volume 3, pages
3347–3352,2003.
[3] A. Boumaza and J. Louchet. Mobile robot sensor fu-
sionusingﬂies. InApplicationsofEvolutionaryCom-
puting, volume 2611 of LNCS, pages 357–367, 2003.
[4] C. I. Connolly, J. B. Burns, and R. Weiss. Path plan-
ning using laplace’s equation. In Proceedings of the
1990IEEE InternationalConference on Roboticsand
Automation, pages 2102–2106.IEEE, May 1990.[5] C.I. Connolly and R. Grupen. On the applications of
harmonic functions to robotics. Journal of Robotic
and Systems, 10(7):931–946,October 1993.
[6] HJS Feder and J.J.E. Slotine. Real-time path plan-
ning using harmonic potentials in dynamic environ-
ments. InProceedingsof theIEEEInternationalCon-
ference Robotics and Automation, 1997, volume 1,
pages 874–881, 1997.
[7] Bernard Girau and Cesar Torres-Huitzil. FPGA im-
plementationofan integrate-and-ﬁrelegionmodelfor
image segmentation. In European Symp. on Artiﬁcial
Neural Networks, 2006.
[8] M. Huber, WS MacDonald, and RA Grupen. A con-
trol basis for multilegged walking. In Proceedings of
the IEEE International Conference Robotics and Au-
tomation, 1996, volume 4, pages 2988–2993,1996.
[9] M. Kazemi, M. Mehrandezh, and K. Gupta. An
incremental harmonic function-based probabilistic
roadmap approach to robot path planning. In
Proceedings of the IEEE International Conference
Robotics and Automation, 2005, pages 2136–2141,
2005.
[10] O. Khatib. Real-time obstacle avoidance for manip-
ulators and mobile robots. International Journal of
Robotic Research, 5(1):90–98,1986.
[11] J.O.Kim andP.Khosla. Real-timeobstacleavoidance
using harmonic potential functions. IEEE Transac-
tions on Robotics and Automation, June 1992.
[12] A.A. Masoud S.A. Masoud. Motion planning in the
presence of directional and obstacle avoidance con-
straints using nonlinear anisotropic, harmonic poten-
tial ﬁelds: A physical metaphor. IEEE Transactions
on Systems, Man, & Cybernetics, Part A: systems and
humans, 32(6):705–723,November2002.
[13] M. Stan, W. Burleson, C. Connolly, and R. Grupen.
Analog vlsi for robot path planning. Journal of VLSI
Signal Processing, 8(1):61–73,1994.
[14] JD Sweeney, H. Li, RA Grupen, and K. Ramam-
ritham. Scalability and schedulability in large, coor-
dinated, distributed robot systems. In Proceedings of
the IEEE International Conference Robotics and Au-
tomation, 2003, volume 3, pages 4074–4079,2003.
[15] L. Trassenko and A. Blake. Analogue computation
of collision-free paths. In International Conference
on Robotics and Automation, pages 540–545. IEEE,
April 1991.
[16] Y. Wang and GS Chirikjian. A new potential ﬁeld
method for robot path planning. In Proceedings of
the IEEE International Conference Robotics and Au-
tomation, 2000, volume 2, pages 977–982, 2000.
[17] Xilinx, editor. The Programmable Logic Data Book.
Xilinx, 2002.
[18] J.S. Zelek. Complete real-time path planning during
sensor-based discovery. In IEEE/RSJ International
Conference on Intelligent Robots and systems, 1998.