1. Introduction
In this paper, we investigate the problem of optimal robotic base placement for industrial multi-robot car painting (see
Figure 1). Robotic spray painting, which aims at covering object surfaces with varnish, paint, or ink, utilizes compressed-air driven spray guns. These spray guns atomize fluid particles, directing them onto industrial target surfaces [
1,
2,
3].
Conventional industrial painting automation systems using robots, however, suffer from time-consuming trajectory generation for the robotic arms [
4,
5]. To avoid the time-consuming process of manually guiding the robot arm through a complete spraying cycle, CAD-based methods have emerged as a viable and faster alternative for generating robot trajectories [
2,
6]. These methods employ various techniques for path planning, such as RRT-based algorithms [
7], iterative schemes with adaptive spray-gun stroke diameters [
8], and path-constrained trajectory planning [
4]. In all these algorithms, poor robot base placement can detrimentally affect motion/trajectory planning in terms of convergence time and quality of generated paths/motion trajectories (see, e.g., [
9]).
Base placement plays a critical role in optimizing performance across various robotic application domains, including industrial manufacturing [
10,
11], surgical robotics [
12], and human–robot interaction [
13,
14]. In particular, the placement of a robot’s base affects the robot’s reachability, manipulability, and workspace coverage during task execution [
15]. These factors can, in turn, minimize redundant movements in flexible production lines with limited workspace and further optimize the robot energy consumption profiles [
16,
17].
In an increasing number of flexible manufacturing settings such as vehicle painting, teams of collaborative robots need to execute a delicate and complex task such as coating/painting/welding, where a single robot is not capable of accomplishing the objectives individually (see, e.g., [
18,
19,
20,
21]). It should come as no surprise that base placement is of crucial importance to the field of collaborative industrial robotics, where repositioning of the robots is costly and time-consuming. As opposed to traditional, highly repetitive industrial processes, a primary goal in collaborative robotics is to enable flexible manufacturing systems for agile product customization. For example, in flexible manufacturing-based car painting, if one or more robotic arms malfunction and uninterrupted production is essential, the manufacturer may need to replace the inoperative arms with different robotic manipulators from their inventory. Alternatively, the manufacturer might need to rapidly change the vehicle model in the production line. In both cases, a new set of base positions and motion trajectories must be planned swiftly to meet agile manufacturing demands. Indeed, one of the keys to successful trajectory/motion planning for industrial collaborative robots is that of properly choosing the fixed base positions on the factory floor/ceiling.
Gaps in the literature: Table 1 provides an overview of various industrial robotic base placement algorithms that have been proposed in the literature. Many of these algorithms have been designed to be general and applicable to a wide range of applications including robotic welding, coating, and painting. Consequently, their generality prevents them from leveraging the inherent geometrical and task specific features in particular industrial applications such as robotic-based vehicle painting. Furthermore, a majority of these algorithms take a holistic and centralized approach to the problem by combining base placement and motion/trajectory planning together. However, centralized approaches to multi-robot path planning are plagued by NP-hardness, where the computational complexity grows exponentially with increasing robot numbers [
22,
23]. Given the complexity of simultaneous base placement and trajectory planning, it is not surprising that many generic solutions resort to computationally expensive meta-heuristic search algorithms (see
Table 1). A detailed discussion and comparison with three of the most recent approaches in
Table 1 is provided in
Section 7 (see
Discussion and Comparison with the State of the Art).
Considering the literature gaps, this paper exclusively focuses on the collaborative robotic car-painting application. This specific focus allows us to deviate from generic base placement methods, which try to perform base placement and trajectory planning simultaneously. Specifically, we leverage the unique geometric properties of this industrial automation process to develop a computationally efficient algorithm without the need for simultaneous path planning and base placement. Our hierarchical approach prioritizes determining optimal base positions before engaging existing robotic painting motion/trajectory planners. The core challenge lies in quantifying paint coverage maximization and collision avoidance minimization for multi-robot vehicle painting without relying on prior knowledge or real-time data from motion/trajectory planners. Furthermore, this quantification requires design of cost functions tailored to the collaborative robotic car-painting application, which can be efficiently computed in an iterative manner, hence making them well suited for being utilized within any standard multi-objective optimization algorithm.
Contributions of the paper: This paper presents a computationally efficient algorithm for multi-robot car-painting base placement problem. Our approach represents a departure from the generic methods in the literature (see
Table 1 for a sample overview), which combine base placement and motion/trajectory planning. In particular, our proposed algorithm does not rely on information from motion/trajectory planners during any stage of the base placement computations. Instead, our solution provides a hierarchical framework where computed optimal base positions can be employed as input to existing robotic painting motion planners. By leveraging the unique geometric characteristics of car painting, we develop two types of cost functions specifically designed for multi-robot vehicle painting scenarios. These cost functions, which are tailored to the collaborative robotic car-painting application, can be efficiently computed in an iterative manner. Consequently, they are well suited for being utilized within any standard multi-objective optimization algorithm. A key advantage of our proposed approach is that it primarily involves planar computations, with the exception of a one-time three-dimensional (3D) point cloud rendering and ellipsoidal fitting in its pre-processing stage.
Relationship to our previous work: The current article is independent from and complements our previous work [
18], in which we investigated the design of motion planning algorithms for collaborative robotic car painting. In that work, we were assuming that the manufacturer would provide a suitable collection of base positions, usually from experience and/or heuristics. However, a poor choice of base positions for painting robots resulted in the failure of the motion/trajectory planning algorithms. The base placement algorithm proposed in the current paper makes the process completely automatic, whereby the computed optimal base positions can be utilized within any available robotic painting motion/trajectory planner including but not limited to [
18].
The rest of the paper is organized as follows. After presenting our assumptions and problem statement, we present our high-level solution strategy in
Section 2. Next, we present the pre-processing computational step associated with our algorithm, which entails a one-time 3D point cloud rendering and ellipsoidal fitting for the reachable workspace of the robotic arms in
Section 3. Thereafter, we present the two types of base placement cost functions tailored to the multi-robot car-painting application in
Section 4 and
Section 5. Subsequently, in
Section 6, we present the multi-objective optimization framework and our overall algorithm. We demonstrate our simulation results in
Section 7. Finally, we conclude this article with some final remarks and future research directions in
Section 8.
3. Pre-Processing: Point Cloud Rendering and Ellipsoidal Fitting
In this section, we devise a numerical algorithm for the point cloud rendering of the reachable workspace of the forearms of the robotic arms and fit 3D ellipsoids to these point clouds. The 3D computations in this section can be considered as the pre-processing stage and need to be run only once.
We consider a team of
M painting robots, each equipped with an articulated RRR arm (see the assumptions in
Section 2). We describe the base positions of the robots relative to a common coordinate frame rigidly attached to the factory floor/ceiling.
Note that some robotic arm manufacturers, such as FANUC with their R-2000iC/220U model (see [
35]), offer flip-over capability. This allows for ceiling installation in work cells unsuitable for floor or wall mounting, accommodating narrower cell designs. Without loss of generality, we consider the robots to be floor-mounted and assume that the floor coincides with the plane
. Accordingly, we can express the base positions as
where
i is the enumeration index for the robotic arms. In the base placement problem, the coordinates
and
,
, are unknown and are determined through the optimal base placement algorithm.
Let
represent the angular position of the
kth joint angle of the
ith robot, where
and
. The joint angle vector for the
ith robot is then expressed as
where
. Specifically, the constant angles
and
represent the minimum and maximum joint angle limits, respectively, for the
kth joint of the
ith robot (e.g., see [
31] for limit values of the ABB IRB 4600).
Point Cloud Generation: To determine the reachable volume of each robot’s forearm, we employ the Denavit–Hartenberg parameters for the first three joints and forward kinematics mapping of the robot. Specifically, the forearm tip position
of the
ith robot with its base at
on the factory floor/ceiling,
, can be computed from the forward kinematics mapping
. This mapping relates the first three joint angles to the forearm tip’s orientation and position. The forearm positions can be expressed as
To maintain generality for any RRR industrial manipulator (see the assumptions in
Section 2), we approximate reachable forearm spaces using a sampling-based numerical approach. Unlike analytical or geometric methods (e.g., [
36]), sampling techniques (see, e.g., [
37,
38,
39]) generate 3D point clouds amenable to efficient Khachiyan’s algorithm [
40,
41]. It is remarked that while
-distribution or Gaussian growth-based sampling algorithms ([
37,
42]) are also viable options for workspace point cloud generation, uniform joint position sampling proved sufficient for our car-painting base placement application.
The reachable volume of the
ith, where
, robot forearm tip is represented by a 3D point cloud. This point cloud can be expressed as
In Equation (
4),
is the position of the forearm tip under base position
and joint configuration vector
that can be computed using the forward kinematics mapping in (
3). Each of the configuration vectors
, which is associated with the
ith robot, is a sample drawn from the cube
Consequently, the number of samples
in the point cloud
is given by:
In Equation (
6),
denotes the floor function, and
is a constant that specifies the distance between the samples in the
jth angular interval. For example, if
, the samples from the interval
are
radians apart. As seen in what follows, the number of points
in (
6) in each forearm point cloud directly affects the computational complexity of the 3D ellipsoidal fitting algorithm.
Remark 3. As it can be seen from Equation (4), the robot workspace point clouds depend on the base positions. However, the base coordinates are not known beforehand. To address this issue, we can express the relationship in (4) as follows: This expression indicates that the point cloud can be obtained by translating each element of a point cloud based at the origin. In particular, each element in the set is the sum of one element from and the base position vector . Accordingly, in the pre-processing stage of the algorithm, we can carry out the point cloud rendering of the reachable workspace of the robot forearms at the origin without the need to know the base positions. As seen in Section 4 and Section 5, the base positions , , can be considered as optimization decision variables. Ellipsoidal fitting to the robot workspace point clouds: Consider the point cloud
associated with the
ith robot, which consists of
points in
. This point cloud
is computed using (
4) by setting
(also, see Remark 3).
To fit 3D ellipsoids to the point cloud
, we used Khachiyan’s algorithm, a widely used method in convex optimization [
40,
43]. Khachiyan’s algorithm is designed to compute the
minimum-volume enclosing ellipsoid (MVEE) of the point cloud
, denoted by
, which is found by solving the following optimization problem:
where
is the center of the ellipsoid
, and the matrix
provides the shape of the ellipsoid
. In particular, by computing the singular value decomposition of
as
, the length of the ellipsoid semi-axes are given by
,
, where the
’s are the components of the diagonal of the matrix
. Furthermore, the orientation of the ellipsoid is given by the rotation matrix
.
Khachiyan’s algorithm solves the Lagrangian dual problem of (
8) using a conditional gradient ascent method [
40] (see also [
41]). In this paper, we utilized the implementation of Khachiyan’s algorithm provided in [
44].
The point cloud rendering of the robotic forearm reachable spaces and Khachiyan’s algorithm result in
M ellipsoids given by
Algorithm 1 summarizes the computations needed for the pre-processing stage. As depicted by
Figure 4, Algorithm 1 generates a 3D point cloud and an MVEE for each of the robotic arms. To prevent unnecessary computations, the if conditional in Algorithm 1 ensures that the point cloud rendering and ellipsoid fitting computations are performed only for robotic arms having different kinematic parameters. For instance, if there are six ABB IRB 4600 robots, since their point clouds
,
and corresponding fitted ellipsoids
,
are the same, the rendering/fitting computations in the for loop are only run for the first robot.
Algorithm 1 The pre-processing stage (run only once) |
- 1:
Input: The make of the M robotic arms and their kinematic parameters - 2:
Output: 3D point clouds and 3D ellipsoids ,
|
3: |
- 4:
for to M do - 5:
if Make and kinematic parameters of the ith robot arm are the same as the jth robot arm, where , then - 6:
- 7:
- 8:
continue ▹ Terminate the current iteration and go to the next one. - 9:
end if - 10:
Compute the 3D point cloud associated with the reachable volume of the ith robot forearm tip. ▹ Utilize ( 7) with and ( 3)
|
11: |
- 12:
Fit an ellipsoid to the point cloud . ▹ Solve ( 8) using Khachiyan’s algorithm - 13:
end for
|
14: |
- 15:
Return, , .
|
Computational complexity for point cloud generation: The forward kinematics for an RRR arm typically involves calculations using trigonometric operations (like sine and cosine) and matrix multiplications. These calculations are generally constant-time operations, i.e.,
for each configuration. Since we are computing forward kinematics for each configuration, the total computational complexity is the number of configurations multiplied by the complexity of forward kinematics (see, e.g., [
45,
46,
47]). Thus, the total computational complexity for the point cloud generation is
.
Computational complexity for ellipsoid fitting: As demonstrated in [
40], the original algorithm for computing MVEEs can be solved in
arithmetic operations, achieving a relative accuracy of
in the volume.
4. Construction of the First Cost Function: Minimizing the Possibility of Collision
In this section, we construct a cost function that quantifies the notion of collision possibility in the context of multi-robot car painting, which is based on computing the overlap area between planar ellipses.
To provide the intuition behind our proposed cost function in this section, let us consider the multi-robot arrangements depicted in
Figure 5. The ellipses are the MVEEs that closely fit the reachable workspace of the forearms of the robotic arms. As it can be seen from these arrangement, larger volumes of intersection in-between the ellipsoids amount to a higher possibility of collision in-between the robots while they are painting the vehicle. Additionally, larger volumes of intersection in-between the 3D ellipsoids correspond to larger areas of intersection in-between their projections on the factory floor. Remarkably, the projection of these 3D ellipses on the factory floor results in planar ellipses. Hence, the overlap areas of planar ellipses can quantify the possibility of collision in-between the arms during painting (see
Figure 6). Additionally, there are very efficient computational algorithms in the literature for computing the overlap area between ellipses as elaborated in what follows.
To formalize this intuition, we first consider each of the ellipsoids
,
, which are generated by the pre-processing stage summarized in Algorithm 1. According to Remark 3, each computed ellipsoid
is obtained based on the assumption that its corresponding robot base position is located at the origin. Considering the variable unknown base position vector
given by (
1), it is possible to translate the ellipsoid using this vector. In particular, the ellipsoid associated with the
ith arm with base position
,
, is given by
We project the translated ellipsoids given by (
10) onto the floor/ceiling to obtain planar ellipses, which are parameterized by the Cartesian coordinates of the robot base positions. Specifically, we project the ellipsoid
,
, given by (
10) to obtain the planar ellipse
Having obtained the planar ellipses, we denote the overlap area between the ith ellipse and the jth ellipse , where , by . It can be easily seen that for all , , and (i.e., overlap areas are positive or zero). Moreover, due to symmetry.
It is now possible to define the cost function quantifying the possibility of collision between the
M robots during painting. In particular, using the ellipse overlap areas, we define the cost function
according to
There are a variety of ellipse overlap area computation algorithms in the literature such as computationally intensive Monte Carlo methods [
48], approximations based on polyarcs [
49], and polygon-based methods [
50]. Since we feed the cost function
given by (
12) to a multi-objective optimizer, we need a fast and accurate algorithm for computing ellipse overlap areas. A very appealing algorithm suited for our needs is the one due to Hughes and Chraibi [
51], which avoids the use of approximating proxy curves. Rather, that algorithm, which is based on a strategy that combines segment and polygon areas to compute the overlap, is applicable to any two general ellipses. The algorithm distinguishes between a variety of different ellipse intersection configurations (see
Figure 7) and utilizes the Gauss–Green theorem to compute segment areas (see [
51] for further details).
Remark 4. While the overlap of robotic arm workspaces provides a useful heuristic for evaluating collision potential, it is important to recognize that the actual likelihood of collisions is primarily influenced by the motion planning and control strategies applied after base placement. Workspace overlap alone does not directly correlate with collision risk, as modern algorithms are capable of dynamically adjusting the robot trajectories to avoid collisions, even in scenarios where significant overlap exists. However, poor base placement can negatively impact the performance of subsequent path planning algorithms, potentially leading to suboptimal coverage or even failure in certain areas. To address this, advanced collision avoidance strategies that operate in densely populated robotic environments are applied after base placement. These strategies mitigate the risks associated with workspace overlap while maximizing the effective utilization of robotic arms. This hierarchical approach ensures that while base placement reduces collision potential, the subsequent dynamic adjustments during motion planning handle remaining collision concerns (see, e.g., [34,52]), thus optimizing both safety and efficiency. 5. Construction of the Second Type of Cost Functions: Maximization of the Possibility of Paint Coverage
In this section, we construct a group of cost functions to quantify the amount of vehicle paint coverage. These cost functions are obtained by projecting the point clouds, which are computed in the pre-processing stage, onto the sides and top of the vehicle.
We first create grid map representations of the top and sides of the car. These grid maps are computed using standard image processing algorithms like the Moore–Neighbor Tracing algorithm (see, e.g., [
53]), which traces given contours and detects object boundaries in the vehicle’s CAD model (see
Figure 8). It is remarked that the grid map computation needs to be run only once.
After creating the grid maps from the vehicle’s CAD model, we consider the point cloud representation of the reachable workspace of the robotic forearms. In particular, we consider the point clouds
,
, obtained from the pre-processing stage (see
Section 3). Given a collection of base positions
,
, we translate each of the given point clouds
to obtain their translated versions
,
, by utilizing Equation (
7). Subsequently, we obtain a planar point cloud by projecting
,
, onto the sides and top of the vehicle. This is equivalent to the projection of
onto the car sides and top.
Focusing on the vehicle top for brevity, we can assess its coverage using a computationally efficient technique like ray-casting (see, e.g., [
54]). This method, which can determine if a point lies within a traced boundary from the Moore–Neighbor algorithm, can be used to provide a quantitative measure of the top’s (resp., sides’) paint coverage. Algorithm 2 provides the procedure for computing the top paint coverage ratio. The same algorithm can be utilized for computing the paint coverage ratio of the vehicle sides, whose details we skip for brevity.
Algorithm 2 Computation of the second cost function (the car’s top paint coverage ratio) Remark: The algorithm structure remains the same for the sides of the car. |
- 1:
Input: Base positions , 3D point clouds , , and grid map of the top of the vehicle CAD model of size - 2:
Output: The paint coverage ratio of the vehicle top given by
|
3: |
- 4:
Compute , , using ( 7). - 5:
Initialize covered_cells as an empty set. - 6:
Consider the vehicle top grid map of size . - 7:
Project onto the top of the vehicle to obtain a 2D point cloud. - 8:
Run a ray-casting computation to add cells to the covered_cells. - 9:
Compute the cardinality of the set covered_cells. - 10:
Calculate the paint coverage ratio as: .
|
11: |
- 12:
Return.
|
In summary, the second cost function
, which is calculated according to Algorithm 2, can be expressed as
where the resulting value of
lies in the interval
. We can repeat the same process (details omitted for brevity) for obtaining the coverage ratio of the sides of the car to obtain the cost functions
and
according to
Computational complexity for computing the paint coverage ratios: The worst-case computational complexity for testing the inclusion of
points from a point cloud in a boundary from a grid map of size
is
. It is remarked that the worst case-complexity of ray casting for point inclusion in a general 2D polygon is
, where
n is the number of the polygon edges (see, e.g., [
54,
55]). Similar computational complexity expressions can also be stated for computing
and
.
6. Formulating the Multi-Objective Optimization Problem
In this section, we formulate a proper multi-objective optimization problem using the cost functions developed in
Section 4 and
Section 5.
Considering the base positions
,
, as the decision variables, the cost functions
constitute a proper objective function vector. We recall that
given by (
12) quantifies the possibility of collision between the robots during painting. On the other hand,
,
, and
given by (
13), (
14), and (
15), respectively, quantify the vehicle’s top and sides’ paint coverage ratios.
We are interested in finding optimal decision variables
,
, such that
is minimized while
(resp.,
) is maximized. Equivalently, we can seek to minimize
(resp.,
). Using the cost functions
,
,
, and
we formulate the following multi-objective optimization problem
where the objective function vector
is defined by
Having formulated the multi-objective optimization problem as in (
16) and (
17), we can invoke any standard multi-objective optimizer for computing the optimal fixed base positions. In this paper, we adopted the goal attainment algorithm [
56], which has an efficient implementation through the function
fgoalattain in MATLAB, R2020b, Mathworks, Natick, MA. To determine the goals in the goal attainment problem, we set the goal of the first cost function equal to 0. This indicates a goal value of zero for the overlap area between the projection of the robot workspace ellipsoids. Since we are minimizing the cost functions
,
, and
in the objective function vector given by (
17), we set their associated goal values equal to
.
The overall proposed solution:Figure 9 illustrates the overall proposed solution to the multi-robot car-painting base placement problem. The pre-processing stage (see Algorithm 1) performs a point cloud rendering of the reachable workspace of the forearms of the robotic arms and fits ellipsoids to these point clouds. Using the constructed cost function in (
12), we quantify the possibility of collision between the robotic arms without any need for planning their motion trajectories a priori. This cost function can be computed using a projection of the ellipsoids on the factory floor/ceiling and summing the resulting ellipse overlap areas. Similarly, using the constructed cost functions in (
13), (
14), and (
15) computed using Algorithm 2, we quantify the possibility of the vehicle paint coverage. These cost functions can then be utilized within any standard multi-objective optimization routine to compute the optimal robot base positions.
7. Simulation Results
In this section, we present the simulation results associated with our optimal base placement algorithm. Our simulations were conducted using two different kinds of robotic arms, namely, ABB IRB 4600 and FANUC R-2000iC robots, for painting an F-150 truck produced by Ford Motor Company (see
Figure 3). To demonstrate the versatility of our proposed base placement solution, we applied our algorithm to homogeneous as well as heterogeneous teams of robots. This is especially beneficial when one or more robotic arms malfunction, where the manufacturer can replace the faulty arms with alternative robotic manipulators from their inventory to avoid disruptions in the painting process.
To further assess the impact of base positions on the performance of the robotic arms during painting, we also computed the manipulability index (manipulability for brief) of the robots in our simulations. Given the Jacobian matrix
of a robotic arm, where
represents the configuration vector of the arm, the manipulability at
can be computed according to
(see [
30] [Section 4.12] for further details). The normalized manipulability at configuration
during a certain task such as car painting is then given by
, where
is the maximum value of arm manipulability over all possible robot configurations.
Figure 9 illustrates the overall algorithm for optimal multi-robot car-painting base placement. The most computationally expensive part of the algorithm is the pre-processing stage (Algorithm 1), which needs to be run only once. Even on a single core of a modest PC, this polynomial-time algorithm can efficiently handle point cloud rendering and ellipsoid fitting. For instance, a MATLAB implementation of Algorithm 1 was run on six ABB IRB 4600 robots on an Intel Core i7 CPU. With point cloud sizes of around 1000 and an ellipsoidal fitting tolerance of
, the pre-processing computations were completed in less than one minute.
Simulations with a homogeneous robotic team: We first considered six ABB IRB 4600 robotic arms and computed their optimal base positions using our proposed algorithm.
Table 2 provides an overview of various base positions, planar ellipse overlap areas, percentages of vehicle paint coverage, and the mean and standard deviation values of the normalized manipulability of the robotic arms during painting. Since the robot arms were positioned in a symmetric manner on the sides of the F-150 vehicle, we only included the information associated with one side.
Table 3 presents the computational times (in seconds) required to compute the overlap areas and paint coverage ratios for various base positions, using an Intel Core i7 CPU. Additionally, the multi-objective optimizer
fgoalattain took approximately 3.33 min to determine the optimal base positions, highlighted in bold in the table.
The gray entries demonstrate the results obtained from our proposed optimal base placement algorithm. As shown in
Table 2, the optimal base positions (the gray entries in the table) not only achieved complete paint coverage and minimal ellipse overlap areas but also exhibited the highest mean normalized manipulability with a low standard deviation. After base placement calculations, we utilized the mutli-robot path planning algorithm devised in our previous work [
18] to determine the joint trajectories of the robotic arms for painting the vehicle. In our previous work [
18], we assumed that the manufacturer would provide a suitable collection of base positions, usually from experience and/or heuristics. However, as seen in the simulations, a poor choice of base positions for painting robots resulted in the failure of the motion/trajectory planning.
Figure 10 depicts the snapshots of the homogeneous team of six ABB IRB 4600 robots painting a Ford Motor Company F-150 truck where the robot base positions were obtained from our proposed optimal base placement algorithm. Furthermore,
Figure 11 depicts the snapshots of the same team placed at non-optimal positions. The figures demonstrate that in the non-optimal case, the robots failed to paint the top of the vehicle completely, despite the fact that both painting scenarios were utilizing the same motion planning algorithm. Furthermore, suboptimal base positions forced the robots to traverse configurations close to elbow and shoulder singularities during painting, which can be clearly seen when the arms have to overstretch to perform their painting task. Finally, the histograms in
Figure 12 depict the normalized manipulability values of the robots during painting. The percentage values on each bar in the histograms provide the painting duration during which the robot manipulability belonged to a certain interval. For instance, a
value on the bar in
for Robot 1 in histograms on the left indicate that Robot 1 had a normalized manipulability value belonging to the interval
during half of the painting task duration.
Simulations with a heterogeneous robotic team: In all simulation scenarios, suboptimal base positions led to degraded algorithm performance, even when using the same path planning algorithm. This resulted in reduced coverage and frequent encounters with singular configurations. Specifically, elbow and shoulder singularities occurred during the painting process when the robot bases were poorly positioned. Elbow singularities arise when the robotic arm is fully extended, while shoulder singularities occur when the shoulder joint aligns in a way that restricts the arm’s ability to rotate freely in certain directions (see
Figure 13).
The collection of simulation results considered six robotic arms of different types, namely, four ABB IRB 4600 and two Fanuc R2000iC robots.
Figure 14 depicts the snapshots of the heterogeneous team of robots painting the Ford Motor Company F-150 truck where the robot base positions were obtained from our proposed optimal base placement algorithm. Furthermore,
Figure 15 depicts the snapshots of the same team placed at non-optimal positions. The figures demonstrate that in the non-optimal case, the robots failed to paint the top of the vehicle completely, despite the fact that both painting scenarios were utilizing the same motion planning algorithm. Furthermore, suboptimal base positions forced the robots to traverse configurations close to elbow and shoulder singularities during painting, which can be clearly seen when the arms have to overstretch to perform their painting task.
Discussion and comparison with the state of the art: In the development of our base placement algorithm for industrial painting robots, we initially utilized ellipsoidal fitting and point cloud rendering techniques (Algorithm 1) during the pre-processing phase. This stage was critical for modeling the reachable workspace of the robots, ensuring that we had an accurate geometric representation to base further calculations on. Although this process involved polynomial time complexity, it was executed only once, thereby minimizing its impact on the overall computational load. Following the pre-processing, we implemented a multi-objective optimization strategy by utilizing custom-designed cost functions specifically aimed at minimizing collision risk (see
Section 4) and maximizing paint coverage (see
Section 5). As it can be seen from
Table 3, the computation of each of these cost functions took less than 0.4 s on a modest Intel Core i7 CPU. The primary advantage of our approach is decoupling the base placement from trajectory planning. Additionally, after base placement, one has the freedom to choose from a plethora of robotic painting path planning algorithms available in the literature.
The method of base placement for single robot machining operation proposed by [
28] incorporates two main algorithms: sparse uniform grid decomposition (SUGD) and sequential quadratic programming (SQP). Initially, the SUGD is employed to identify feasible base positions within a defined search space. The SUGD requires significant computational resources, largely due to its dependency on the resolution of the grid and the extent of the search area. This approach serves as a preliminary filter to establish a starting point for further optimization. Following this, SQP takes over to find the optimal base positions using these initial guesses. SQP is well-suited for handling the nonlinearities and constraints typical in such optimization scenarios, offering an effective means to navigate through complex decision spaces. As for SQP, while it is capable of achieving superlinear convergence rates, the complexity and the computational expense can escalate quickly depending on the size of the problem and the intricacies of the constraints involved.
In the base position optimization proposed by [
14], a GA was employed to iteratively evaluate and refine multiple solutions, aiming to find the optimal configuration. While a GA provides flexibility in exploring various solutions, its iterative nature often results in higher computational demands, particularly when multiple constraints like collision avoidance and workspace coverage must be considered. Complementing the optimization, the Object Collision Algorithm was used to detect potential collisions between robot arms and their environment. This algorithm evaluated bounding boxes around objects with a quadratic computational cost. To further ensure efficient and stable robot movements, Singularity Detection through the Manipulability Index assessed the robot’s Jacobian matrix for potential kinematic singularities. Additionally, Inverse Kinematics, often solved using Powell’s method, calculated joint angles for specific end-effector positions. By integrating these algorithms, especially within a GA framework, the overall complexity increased, but the approach ensured a simultaneous optimization of robot base placement while addressing collisions, singularities, and precise kinematic configurations.
The authors in [
17] developed a comprehensive framework for optimizing robot placement in large-scale manufacturing environments, utilizing an intricate blend of energy consumption models and quality metrics like dimensional accuracy. Central to this framework was the application of a simulated annealing algorithm—a heuristic method celebrated for its ability to approximate global optima efficiently. Complementing the simulated annealing was the Recursive Newton–Euler Algorithm (RNEA), which calculated the energy requirements of robotic movements. Moreover, the framework integrated a multi-objective optimization model that simultaneously addressed energy conservation and printing quality, navigating the complex trade-offs between these objectives. Additionally, the system incorporated task decomposition and scheduling algorithms to manage the assignment and coordination of tasks among multiple robots, ensuring collision-free operation and optimizing production timelines. The computational methods employed, like simulated annealing, can be resource-intensive and might not scale well with larger numbers of robots or more complex tasks. Additionally, the effectiveness of these algorithms can depend heavily on initial conditions and parameter settings, which may complicate their implementation and optimization in practical scenarios.