1. Introduction
The Internet of Things (IoT) is a new wave significantly affecting our lives in various areas including smart energy grids, smart factories, smart cities, and smart farms [
1]. IoT is accomplished by sensing (monitoring) the target environment, collecting and analyzing the sensory information and actuating based on the feedback information from the analysis. The data produced in the IoT environment may be enormous and require intensive computation such as for deep learning-based prediction. Hence, the IoT data tend to be transmitted to the remote cloud data center (CDC) for storage and computation [
2,
3,
4]. Many IoT applications have stringent timing requirements which may not be met by cloud computing because of long-distance message transmissions through the network between CDC and end devices (aka IoT devices). For the reduced latency between CDC and end devices, the concept of fog computing has been introduced by Cisco [
5]. In fog/edge computing (FEC), fog/edge nodes (FENs) located in the proximity of end devices provide services to them in lieu of CDC without causing a long delay by executing the lightweight virtualized service images pre-allocated from CDC [
5,
6,
7]. However, due to the limited capacity (CPU, storage, etc.) of FENs, only a subset of service images can be placed on each FEN [
8,
9].
In the previous work on service provisioning (or placement) in FEC [
10,
11], a service is placed on the FEN satisfying the given service requirement for the execution of the service, assuming that the corresponding service image is already installed in the FEN. Service provisioning, service placement and service offloading are interchangeably used for installing service images and executing them on FENs or CDC instead of end devices. However, due to the limited capability of a FEN, it is infeasible to place all the services on an FEN. Even in the case that FENs install service images on demand for offloaded services, the resource of FENs may not be efficiently utilized because of patchwork-like service image placement [
12]. In addition, depending on the IoT applications, the type of services requested may vary. For example, in an area occupied by smart factories, the service analyzing the sensed data from a specific machine for the detection of malfunctions will be requested by the factories equipped with the machine. Placing service images on FENs in the per-service request-based manner may result in the improper resource usage of FENs due to redundantly placed service images. If we can optimally provision service images on FENs based on the pre-obtained service demands (service demands and service requests are interchangeably used in this paper), the resource utilization of FENs can be optimized. To our knowledge, this issue has not been addressed to date and thus, we formulate the problem of optimal service provisioning (SP) in the FEC environment. In our work, we adopted “service provisioning” instead of service placement in the sense that service provisioning means service placement with planning.
For the scalability of the FEC environment, FENs are located hierarchically near to end devices and in between end devices and CDC which is the last resort of providing services to end devices. The following two cases (c1) and (c2) are not desirable from the perspective of resource utilization and latency, respectively:
- (c1)
- For a sporadically requested service, the corresponding service images are redundantly placed on multiple FENs. 
- (c2)
- For the coverage of multiple requests of a service, the corresponding service image is provisioned on a FEN at a high level of the FEN hierarchy. 
If we consider both the resource usages and locations of FENs and the locations of end devices requesting services, we could avoid the above-mentioned cases. The consideration of only the case (c1) (i.e., the resource utilization of FENs) may result in the case (c2) (i.e., long delay), and vice versa. Therefore, in provisioning service images in the FEC environment, we must consider both the resource usages and locations of FENs and the delay requirements and locations of service requesters. In this paper, we propose two SP approaches by extending our previous work [
12]; the first one is on the basis of the number of service requests from end devices and the second one is based on the locations of end devices requesting services. We can assert that the proposed FEC environment is scalable because more service images can be accommodated by FENs thanks to the optimal provisioning of service images on them. For the performance evaluation of the proposed mechanisms, we perform simulations for various service requesting scenarios and analyze the performance in terms of the total number of service images provisioned on FENs and the total number of service requests not accommodated by FENs.
The rest of the paper is organized as follows. In 
Section 2, we describe the related work on the service provisioning, offloading or placement on FENs. In 
Section 3, the problem of service provisioning FENs is formulated as a 0–1 integer linear programming problem for the proof of the NP-hardness of the problem and then, our two approaches are described in detail. The performance of our mechanisms is evaluated in 
Section 4 from the simulation results. Finally, 
Section 5 concludes this paper.
  2. Related Work
Services can be offered to end devices via computation offloading in which CDC or FENs perform computation in lieu of end devices. SP on FENs is the pre-allotment of the resources, like CPU, RAM and storage, of FENs to service images for computation offloading [
6,
7,
8]. For the sake of effective computation offloading, SP on FENs must be properly carried out beforehand.
In the FEC environment, the service provisioning, placement or service offloading has been studied by many researchers with different objectives and considerations, like power consumption [
13], quality of experience (QoE) [
14,
15,
16], migration [
17], network perspective [
18], service atomization [
19], etc. The authors of [
19] proposed strategies for offloading service executions by considering the resources of CDC and FENs. For that, they introduced the concept of service atomization and parallel resource allocation. By service atomization, complex IoT services are divided into smaller atomic services which, then, can be executed on multiple FENs sequentially or parallelly in a distributed way. In their scheme, end devices offload service executions to CDC or FENs according to network and processing demands.
In [
18], the application provisioning problem in the fog-cloud environment is studied from a network perspective to guarantee the quality of service (QoS) of application (service) data streams in terms of transmission delay and bandwidth for each application. Application provisioning is to find the host node (i.e., FEN) and data routing for a specific application. The authors formulate the issue as the single application provisioning (SAP) and the multi-application provisioning (MAP) problems. SAP determines the path to the FEN satisfying the bandwidth and delay requirements of data traffics from end devices for one application. MAP is the extension of SAP for multiple applications from the perspective of network link capacity (bandwidth) usage.
In [
11], the deployment of multi-component application in the fog hierarchy is defined as the components deployment problem (CDP) which determines candidate FENs to be deployed with the components of an application according to application-specific QoS requirements of end devices on latency and bandwidth, software and hardware capabilities of FENs and business policies. They target to deploy large-scale applications composed of multiple components that can be independently deployable and work together for the infrastructure and prove that the CDP problem is NP-hard by the reduction from the subgraph isomorphism problem (SIP) [
20]. The CDP problem is to find the optimal deployment of a single application (service) based on the service requests of end devices in a centralized manner.
Both [
18] and [
11] determine the FENs to be provisioned with services in a centralized way for a given set of service requests, similar to ours. However, theirs take account of each individual FEN, not of entire FENs, from the perspective of resource usage. The consideration on the capacity of each FEN is just for checking the relevant constraint, but the consideration on the total resource usage of all the FENs is for optimizing the overall resource usage of FENs. Thus, the latter is more appropriate for enhancing the scalability of the fog infrastructure in terms of resource usage.
Related to the resource provision of FENs, the authors of [
14,
15] proposed a FEC architecture composed of fog colonies each consisting of one fog orchestration control node and multiple fog cells. The fog orchestration control node is a fog cell with extended functionalities like managing fog cells in the same fog colony and other connected control nodes. The fog cell is the software components running on an FEN. The fog orchestration control node keeps all the service implementations (i.e., service images) in its service registry, located in the low-cost abundant storage unit, and deploys the corresponding service image to the fog cell covering the service requester on demand. In this way, the constrained resources of FENs are effectively utilized. The fog cell for a service request is determined based on the resources of FENs and the resource and delay requirements of the service request such that the resource requirement is satisfied with the minimum delay. In the scheme, all the service images are kept in the storage of the fog orchestration control node and deployed on FENs per service request by the control node. This will incur overwhelming communication overhead and delay in deploying service images on demand from fog orchestration control nodes to fog cells, and the requirement on the fog orchestration control node to be installed with all the service images is infeasible or, at least, inefficient if plenty of services are to be deployed in the fog.
In this paper, we aim to formulate and resolve the problem of minimizing the total number of service images provisioned on FENs in order to optimize the overall resource usage of FENs.
  3. Service Provisioning for Fog/Edge Nodes
  3.1. System Environment and Problem Description
For the simplicity of problem formalization, we assume that there is one CDC and all the service demands are accommodated by the FENs. Each service demand is assumed to require the same amount (e.g., one capacity unit) of resources even though service demands are heterogeneous in reality. The network link capacity is assumed to be sufficient for the delivery of the data generated by the service demands (i.e., we do not consider the network link capacity as a constraint in the problem).
We define the notations needed for the problem formalization in 
Table 1. 
 is the set of the services, 
, and 
 is the set of the FENs, 
, and 
 is the set of the end devices, 
, and 
 is the service demand matrix, 
, where 
 is 1 if the service 
 is demanded by the end device 
.
The problem of the optimal service provisioning (SP) in the FEC environment can be defined as follows:
Equation (1) is the objective function of minimizing the total number of the service images provisioned on the FENs. Equation (2) is for the capacity constraint, termed Condition-C, and Equations (5) and (6) are for the delay constraint, termed Condition-D. The Equations (3), (4), (6) and (7) define the binary variables  and .  indicates that a service image of  is deployed in . Equation (2) checks whether each FEN accommodates service demands within its maximum capacity . Equation (5) checks for whether the delay requirements of all the service demands in  are satisfied. In Equation (6), the binary variable  is set to 1, for the service demand  with 1, if there exists at least one FEN with a service image of  that satisfies the maximum delay requirement of , i.e., .
Because the optimal SP problem was formulated as a 0–1 integer linear programming problem, the problem is NP-hard. Thus, we propose two heuristic mechanisms that determine how to deploy service images on FENs according to the collected service demands from end devices.
  3.2. Logical Fog Network
CDC determines the FENs to be installed with specific service images based on the service demands of the end devices. The locations of the FENs can be anywhere in the given network, determined by the deployment strategy which is out of the scope of this paper. In general, the physical network topology of the FEC environment is a mesh which increases the computational complexity of determining the optimal FENs to be provisioned with service images. Therefore, in order to simplify the problem, we form a logical tree topology of the FENs rooted at CDC, called a logical fog network [
12], 
, in a hierarchical manner, as shown in 
Figure 1b for the physical network in 
Figure 1a in which CDC is labeled as 
 for the sake of convenience. Because 
 is a subnetwork of the given physical network and the tree topology is a special case of the mesh topology, the SP problem for 
 is also NP-hard.
In , if an end device is in the coverage area of a FEN, we say that the end device is in the direct coverage of the FEN or the FEN directly covers the end device. If an FEN is an ancestor (including the parent) of the FEN directly covering an end device, the ancestor FEN is said to cover the end node indirectly. In , all the FENs on the path from CDC to the directly covering FEN of an end device cover the end device.
A service requester is an end device requesting the corresponding service. The data from a service requester can be handled by any FEN, with the service image and satisfying the requirements, both Condition-C and Condition-D, of the service requester on the path from the directly covering FEN up to CDC in . Each FEN, located in between the service requester and the service handling FEN, just delivers the data from the service requester to its parent FEN for the proper processing of the data.
We assume that CDC has the information on  including the end devices directly covered by the FENs and the information of the locations and the capacities of the FENs. For the provisioning of service images in , we assume that CDC has unlimited capacity such that any requirements of the end devices, except for latency, can be accommodated—that is, if there exist any service requests not accommodated by any FENs, CDC can cover those service requests.
The logical fog network, , is constructed as follows:
- [Step N1]
- The initial  is null and the FENs are sorted in the decreasing order of the capacity. 
- [Step N2]
- CDC is first included in  as the root and the level of CDC is set to 0. 
- [Step N3]
- From the sorted list of the FENs obtained at [Step N1], the first  FENs are selected as the child nodes of CDC.  is the set of the child FENs of CDC. The value of the parameter  has to be properly decided by the fog network designer. 
- [Step N4]
- The delay of the link between an FEN in  and CDC is adjusted to a value less than its original delay (e.g., a half of the original delay). 
- [Step N5]
- Each FEN in  is added to  via the minimum delay (shortest) path to CDC. 
In [Step N3], the criterion for selecting the FENs in 
 is the capacity because an FEN with more capacities can have more service images installed and a higher possibility of covering more end devices. In [Step N5], the criterion for adding the FENs in 
 to 
 is the latency because the main purpose of FEC is reducing the latency from end devices. After [Step N5], the obtained 
 is a logical tree rooted at CDC with the FENs in 
 directly connected to CDC and with each FEN in 
 connected to CDC via the shortest path. The reason for the link cost (delay) adjustment in [Step N4] is to make the possibility of the FENs in 
 to go through the FENs in 
 to get to CDC. From this, we can achieve the load balancing effect by making high-capacity FENs share the burden of computing load with CDC. Through the procedure of [Step N1]∼[Step N5], we can obtain a logical fog network that is appropriate for less service images provisioned thanks to the tree topology and for lower delays from end devices to FENs thanks to the shortest path branches. In the following 
Section 3.3, we described two mechanisms finding the right FENs, based on 
, that can accommodate the service images demanded by the end devices with the aim of minimizing the number of service images provisioned.
  3.3. Service Provisioning Based on Service Demands
In this subsection, we propose two heuristic SP mechanisms, based on 
, in which the amount of service demands for a FEN is the major factor to be considered in placing a service image on the FEN. The first SP mechanism provisions the highest-level FEN, satisfying the conditions, Condition-C and Condition-D, of the most-demanding service, with the service so that the coverage of the FEN for the service can be maximized. Thus, the first SP mechanism is named as the maximal coverage-SP (MC-SP) mechanism. The MC-SP mechanism performs well if the distribution of the end devices demanding a specific service is uniform in the logical fog network. However, if we consider an industrial area with many smart factories requesting a specific service, the MC-SP mechanism may not perform optimally. In this situation, it is desirable to place the corresponding service image near the area. Thus, in our second mechanism, we take into consideration the locations of the end devices demanding a specific service in finding the right FEN to be placed with service images. The second mechanism is named as the flexible coverage-SP (FC-SP) mechanism. In the 
Section 3.3.1 and 
Section 3.3.2, the MC-SP and the FC-SP mechanisms are described in detail, respectively. For the simplicity of the description of the mechanisms, we assume that, in 
, there exists at least one FEN satisfying Condition-C and Condition-D of each service in 
.
  3.3.1. Maximal Coverage-Service Provisioning Mechanism
Before we describe the procedure of the MC-SP mechanism, the FENs in 
 are rearranged to 
 such that the index of an FEN at the level 
 in 
 is smaller than that of a FEN at a level lower than 
. That is, 
 are the children FENs of CDC in 
 and 
 is at the lowest level of 
. We define the coverage matrix 
 representing 
 such that the element of 
, 
, is set to 1 if the end device 
 is covered by the FEN 
. With given the service demand matrix 
, 
 is the 
 matrix whose element 
 indicates the total demands on 
 from the end devices covered by 
. The notations for the SP mechanisms are listed in 
Table 2.
The procedure of the MC-SP mechanism with given 
, 
 and 
 is described in 
Figure 2.
In 
Figure 2, the 
th column of 
 is denoted as 
 and the 
th element of 
 as 
. 
 is the sorted list of 
, in the decreasing order of the amount of demands, which is obtained by carrying out the function 
 (see 
[M2]). 
 is the corresponding service list of 
 obtained from the function 
 (see 
[M3]). That is, 
 has the information of the service whose demands imposed on 
 is the 
th largest among the services in 
. The outer for-loop checks for each FEN from the highest to the lowest level of 
 and the inner for-loop checks for each service from the list in 
. That is, for 
, the larger the demands on a service, the earlier the service is checked for its provisioning in 
. The condition in 
[M5] is for excluding those services with no demands from being provisioned in 
. In 
[M6]∼
[M7], the provision of the service 
 in 
 is performed if the provision satisfies the Condition-C and the Condition-D of 
. The functions 
 and 
 check Condition-C and Condition-D, respectively, and return the true or false value according to whether the corresponding requirement is satisfied or not. The function 
 in 
[M7] provisions the FEN 
 with the service image of the service 
. The function 
 in 
[M8] removes the demands on the service 
 from the FENs which are the descendants of 
 because all the service demands are resolved by 
.
Figure 3 is a simple example showing 
 with the FENs 
, 
 and the end devices 
, 
 and the services 
, …, 
. The service demands of each end device are listed in its corresponding box and the capacity of 
 is indicated by 
. In this example, to focus more on SP from the aspect of Condition-C, all the FENs are assumed to satisfy Condition-D of 
 for all 
 For simplicity, 
 is also assumed to satisfy the Condition-Ds of all services. In the figure, we can see the result of applying the MC-SP mechanism, and the service placement matrix X = [
], indicated by a black solid line box, where 
 = 1 implies that 
 is provisioned on 
. Since all FENs satisfy Condition-D of each service, services are placed from 
 to 
. In MC-SP, the service with more demands has a higher chance to be placed on. In this example, 
 can accommodate at most three services and 
 have demands of 4, 3, 3, respectively, so 
 are provisioned on 
. After that, the demands on 
 are removed from the other FENs. Then, services 
 are placed on 
 and 
 is placed on 
.
   3.3.2. The Flexible Coverage-Service Provisioning Mechanism
The MC-SP mechanism takes into consideration only the hierarchical topology of 
 in the provisioning service images on FENs. This mechanism is the lack of the awareness of the patterns of service demands which may depend on some geographical, industrial, or social characteristics. Thus, in this subsection, we propose the FC-SP mechanism, which adaptively places service images on FENs according to the pattern of service demands. This is well suited for the situation with uneven service demands in a limited area. For this situation, an FEN near to the area is best placed to resolve the demands. Thus, we adopt the lowest-level common ancestor (LCA) FEN, in 
, of the end devices demanding a service as the candidate to be provisioned with the corresponding service image. If the LCA FEN 
f of a service 
s is installed with the service image of 
s, then those end devices having 
f as the LCA FEN demanding 
s can be commonly supported by 
f. In the FC-SP mechanism, the pattern of service demands is estimated by using the Shannon entropy [
21]. The preference of a service image to be provisioned is determined based on the total amount of demands imposed on the FEN which is currently considered for the service provisioning. The additional notations for the FC-SP mechanism are listed in 
Table 3.
The procedure of the FC-SP mechanism with given 
 and 
 is described in detail in 
Figure 4. Here, we assume that, in 
, there exists at least one FEN satisfying Condition-C and Condition-D of each service in 
. The pseudocode description in 
Figure 4b is somewhat lengthy and complicated because lots of notations were used, so we provided a simpler form of description, flowcharts, in 
Figure 4a.
The total demands on  is , . The elements in  are sorted in the decreasing order, resulting in the sorted list . The corresponding service list of  is . For each service  in , the LCA FEN satisfying Condition-D is determined by the function  and the ordered list of the LCA FENs for  is . Then, the function  returns  whose th element, , is the ordered list of the services, in the decreasing order, whose LCA FEN is .  in [F9] returns a service (the current to-be-provisioned service ) one by one from  per call. In [F7]∼[F10], the services in  are provisioned on  while the Condition-C of  is satisfied. If the condition in [F12] is met, the service  cannot be provisioned on  because of the capacity shortage. Then, according to the status of , upward provisioning (see [F31]∼[F39]) and/or downward provisioning (see [F22], [F41]∼[F50]) is performed. In the case that  cannot be provisioned on  and  is located at the highest level of ,  may replace the already provisioned service with the minimum entropy,  found by calling , if ‘s entropy is larger than the minimum entropy, i.e., ’s entropy (see [F16]∼[F20]), or be provisioned on a lower-level FEN (by calling , i.e., the downward provisioning of [F22]). Or, if  cannot be provisioned on  and  is not located at the highest level of , the upward provisioning of [F31]∼[F39] is performed first and if the upward provisioning fails (that is, if all the ancestors of  cannot provision ), the downward provisioning of [F41]∼[F50] is performed. This process is repeated until all the service images demanded by end devices are provisioned on FENs. Here,  is the set of FENs fully provisioned with services.
In the FC-SP mechanism, the Shannon entropy of a service is used as a metric for the provisioning priority of the service. In 
Figure 4, the function 
 is called when 
 cannot be provisioned on 
 because of Condition-C being not satisfied at 
. 
 returns the Shannon entropy of 
 by using the following Equation (8) which reflects the degree of the distribution of the end devices requesting 
:
In Equation (8), first,  is determined for , which is the set of the descendent LCA FENs of the LCA FEN currently failed in provisioning .  is obtained by dividing the total demands on  at  by the total demands on  at the FENs in .
Figure 5 shows an example of applying the FC-SP mechanism to 
 of 
Figure 1b with the result of the service placement matrix X. Here, we also assume that all FENs including 
 satisfy Condition-Ds of all services. On 
, services 
 are provisioned first since each of them has demands of 8 which is the largest. After that, because 
 have the same amount of total demands of 5, respectively, the Shannon entropy at 
 is calculated for 
. For that, 
 is determined for 
, respectively. 
 of 
 is {
, 
} and 
 of 
 is {
, 
}. Then, the entropy of 
 is “−(3/5 
(3/5) + 2/5 
(2/5) (about 0.9709506)” because the total demands on 
 at 
 is 3 and the total demands on 
 at 
 is 2. The entropy of 
 is “−(4/5 
(4/5) + 1/5 
(1/5) (about 0.7219281)” because the total demands on 
 at 
 is 4 and the total demands on 
 at 
 is 1. Because 
 has a higher entropy than 
, 
 is provisioned on 
 and 
 is provisioned on 
 by the downward provisioning of 
[F22]. The higher the entropy is, the more the service demands are distributed. Thus, by provisioning more distributed services on FECs at higher levels of 
, the capability of covering service demands can be enhanced.
   4. Performance Evaluation
Simulations were performed by using the NetworkX package [
22] and Python. The simulation network environment is similar to that of [
12]. The simulation network is obtained by designing an example of physical fog/edge network based on the administrative/population information obtained from Seoul open data center [
23], South Korea, as shown in 
Figure 6a. The physical fog/edge network is built by locating one CDC (the largest dot in the figure) at the geographic center of Seoul and by locating 449 FENs according to the two-level administrative districts of Seoul. The capacity of a FEN is determined as proportional to the number of households of the corresponding administrative district. In the figure, the dots except for the largest dot (i.e., CDC) are FENs and the size of a dot implies the capacity of the corresponding FEN. The weight of an edge between two FENs is determined proportional to the physical distance between them. The corresponding logical fog network, shown in 
Figure 6b, was constructed based on the logical fog network construction mechanism described in 
Section 3.2.
For the performance comparisons of the proposed MC-SP and FC-SP mechanisms, we designed and implemented a mechanism, called the on-demand mechanism, that dynamically places the corresponding service image upon a request based on the logical fog network. In the on-demand mechanism, if an end device receives a request on a service, it checks whether it has any FENs installed with the corresponding service image within 2-hop in the logical fog network. If there is none, it checks whether any of its ancestor FENs have the service image. If none of the ancestor FENs have the service image, it places the corresponding service image on itself. In the case when it is the lack of the resources, it places the service image on the 2-hop FEN which is the closest to itself. If it is not possible, it places the service image on one of its ancestor FENs which is the closest to itself. By comparing our proposed mechanisms with the on-demand mechanism operating on the basis of per-service request, we measure the performance of ours in terms of the resource utilization of FENs.
The number of service types, the distribution of service demands, the maximum capacity of CDC, and the maximum capacity of each FEN are the factors affecting performance. The number of service types requested by end devices is set to 1000 and 2000 service types and the number of end devices is 450. For the generation of service demands, we adopt the long-tailed distribution [
24] of service demands in which a small set of service types is heavily requested and the rest of the service types are not frequently requested. The long-tailed distribution is adopted because a set of popular services are heavily used in the real world. For the simulations, the long-tailed distribution of service demands (we call this the L distribution case) is used, where about 10% of 1000 service types are heavily requested by the end devices, as shown in 
Figure 7 [
12], which is obtained by using the zeta distribution [
25]. This is achieved by using the function np.random.zipf (1.6, 1000) [
26] where 1.6 is the value of the distribution parameter and 1000 is the number of service types. The function returns a value (we call this an L value) for each service type and the L value is used in determining the end devices with a service request for the service type. If the L value of a service type is greater than or equal to 100, all the end devices are assigned with a service request for the service type. Otherwise, the L value is used as the probability of assigning a service request for the service type to each end device. That is, for a service type, a higher L value implies a higher possibility of assigning a corresponding service request to each end device. If we sum up the service requests for all the service types in 
Figure 7, it becomes 42,210 in total.
The measured performance factors are the number of service images placed, the number of non-accommodated service requests, and the average network cost per service request. The average network cost per service request is the average one-way physical distance required for providing a service which is assumed to be proportional to the delay. For the calculation of the average network cost per service request, the physical distance between the end device with a service request and the FEN accommodating the corresponding service request is measured on the logical fog network. The physical distance is measured for each service request and then, all the measured physical distances are summed up. The average network cost per service request is obtained by dividing the total physical distance by the number of service requests. The maximum capacity of CDC is set to 300, 500 and 750 resource units, and one service image placement is assumed to require one unit of resources.
Figure 8, 
Figure 9, 
Figure 10 and 
Figure 11 show the performances of the proposed MC-SP and FC-SP mechanisms compared with the on-demand mechanism for various maximum CDC capacities of 300, 500 and 750 with 1000 services types for the L distribution case. 
Figure 8 depicts the graph showing the performance in terms of the number of service images placed on FENs. We can observe that, as the maximum capacity of CDC increases, more service images are placed on CDC, resulting in less service images placed on FENs in all the mechanisms. The on-demand mechanism places significantly more service images than our proposed mechanisms and even with increased CDC capacity, the on-demand mechanism slightly reduces the number of service images. The reason for this is that the on-demand mechanism places a service image near the end device which has requested the service, resulting in many service images near to end devices. On the other hand, the MC-SP and the FC-SP mechanisms reduce the number of service images placed significantly. Hence, we can assert that the FC-SP mechanism considering the service pattern performs the best in the resource utilization of FENs.
 Figure 9 is the graph showing the number of service requests for which the corresponding service images are not placed on any FENs for the L distribution case. Thanks to the well-utilized FEN resources, the FC-SP significantly outperforms the MC-SP mechanism and the on-demand mechanism, especially for larger CDC capacities. As we expected, the number of non-accommodated service requests decreases as the maximum CDC capacity increases for all the mechanisms.
 In 
Figure 10, the average network cost of handling a service request is shown for various maximum CDC capacities for the L distribution case. As the maximum CDC capacity increases, the network cost also increases because more service images are placed on the CDC. Both of the proposed mechanisms perform much worse than the on-demand mechanism because service images are placed near the end devices in the on-demand mechanism with less service images placed. As for the proposed mechanisms, the FC-SP mechanism requires less network cost than the MC-SP mechanism. The reason is that the MC-SP mechanism does not consider the pattern of service demands and places service images on FENs at higher levels of the logical fog network for larger coverage.
The performance of the proposed mechanisms is shown in 
Figure 11 with a varying FEN capacity and number of service types for the L distribution case. We simulated two cases of the FEN capacity, the basic case and the 10 times case. The basic case is the case of the FEN capacity in 
Figure 6b and the 10 times case is the FEN capacity of 10 times that of 
Figure 6b. The number of service types is set to 1000 and 2000.
Figure 11a shows the performance in terms of the number of service images placed on FENs, and 
Figure 11b shows the performance in terms of the number of non-accommodated service requests for the L distribution case. For the larger FEN capacity (i.e., the 10 times case), both MC-SP and FC-SP mechanisms place more service images, but the FC-SP mechanism decreases the number of non-accommodated service requests more significantly than the MC-SP. This indicates that the FC-SP mechanism fully utilizes the advantage of the increased FEN capacity. That is, the FC-SP mechanism accommodates more service requests than the MC-SP mechanism by provisioning more service images on FENs. In addition, as the number of service types increases, more service images are placed and more service requests are accommodated in both of the mechanisms. It is intuitive that more service images are placed for more service types, but the MC-SP mechanism shows a more noticeable increase in the number of service images placed with an insignificant decrease in the number of non-accommodated service requests. This implies that the MC-SP does not perform well in the situation of changed FEN capacities.
 Figure 11c shows the graphs depicting the average network cost of a service request for the L distribution case. As the FEN capacity increases, the network cost decreases in both of the mechanisms. The FC-SP mechanism shows a more significant decrease in the network cost compared to the MC-SP mechanism, especially for more service types. This indicates that the FC-SP mechanism performs better than the MC-SP mechanism even for the case of more service types. Overall, the FC-SP mechanism is better than the MC-SP in utilizing the FEN resources and in adapting to changing environments such as the changes in CDC capacity, FEN capacity, and the number of service types to support.
 For a more concrete evaluation of the performance, we performed simulations for another service demand distribution shown in 
Figure 12 (we call this the U distribution case) which is obtained by using the uniform distribution. This is achieved by using the function np.random.uniform (0, 100, 1000) [
27] where 0 and 100 are the lower and the upper boundary of the output interval, respectively, and 1000 is the number of service types. This function returns a value (we call this a U value) in the half-open output interval [0, 100) for each service type. The U value is used as the probability of assigning a service request for the service type to each end device. That is, the higher the U value of a service type is, the higher the possibility of assigning a service request of the service type to each end device. The U distribution case tends to assign service requests more evenly on service types than the L distribution case. The U distribution case generates 140,525 service requests for the performance evaluation of our mechanisms in a situation with heavy service requests.
The performance of the proposed mechanisms for the U distribution case is depicted in 
Figure 13. We can easily see that the FC-SP mechanism outperforms the MC-SP mechanism in the aspect of all the performance factors. This indicates that the FC-SP mechanism performs better than the MC-SP mechanism even for the case with service requests relatively less biased over the service types (i.e., the U distribution case).
From 
Figure 14, we can observe the performance comparison of our proposed SP mechanisms for the L and the U distribution cases. In 
Figure 14a,b, it is clearly shown that our mechanisms perform better for the L distribution case than for the U distribution case in terms of the number of service images placed and the percentage of non-accommodated service requests. This can be intuitively expected because the U distribution case has about 3.33 times more service requests than the L distribution case. In addition, we can see that the FC-SP mechanism performs very effectively in the sense that it accommodates more service requests than the MC-SP mechanism with many less service images placed, even in the stressful situation (i.e., the U distribution case). 
Figure 14c shows that the average network cost per service request for the U distribution case is lower than that for the L distribution case. The reason for this is that, for the L distribution case, the majority of the service requests are likely covered by higher-level FENs because most of the service requests are biased on a few specific service types, resulting in higher average network cost per service request than the U distribution case.