1. Introduction
Traditional energy grids have been heavily dependent on the burning of fossil fuels, such as coal or natural gas, to generate electricity. This type of electricity production therefore has a negative impact on the environment, while also posing geopolitical challenges for countries that must rely upon others for obtaining these vital resources. In addition, energy generation at plants distant from consumers leads to losses in its distribution infrastructure, diminishing efficiency and increasing running costs [
1].
Renewable Energy Sources (RES) emerge as a green, reliable, and economically viable solution for electricity production. Given the replenishable nature of its sources, such as the sun and wind, RES enables citizens and governments to become more self-sufficient, as the energy can be produced on an individual basis in a distributed manner. Distributed Energy Resources (DER) are closer to consumers, which also substantially reduces traditional distribution losses and the energy costs of consumers, which incentivizes the use of RES. As a result, the adoption of renewable energy has significantly increased, with its growth forecast to speed up in the next five years [
2]. Households, office dwellings, and factories also play an increasingly prominent role in this transition [
3], by installing photovoltaic panels to satisfy their own energy needs and injecting their surplus production into the grid. Such end-users are now being designated as prosumers, as they take on the role of both producers and consumers of energy simultaneously.
However, the high penetration of RES poses new difficulties to grid operators in managing and maintaining the necessary grid balance, as there is a time imbalance between peak demand and RES production due to the highly fluctuating operation characteristic of these sources. In addition, at certain times of the year, namely spring and summer, there is an overgeneration risk which may force grid operators to curtail RES or implement negative electricity prices to force demand upwards, leading to higher operating costs and thus reducing both the environmental and economic benefits of renewable sources.
Energy Flexibility Management offers a partial solution to this problem, minimizing the impact of the introduction of RES in energy grids and preserving its economic and environmental benefits. Renewable Energy Communities (REC) offer a powerful framework in which energy sharing between members is possible and where Flexibility Management can be further explored. In this context, Flexigy [
4], the project in which this research work has been conducted, aimed to develop an integrated platform for managing the energy flexibility of consumers and prosumers belonging to a REC.
This paper builds on the three-level smart-grid architecture for REC management introduced in [
5], detailing the algorithms developed, whose main aim is to schedule the energy flexibility of home appliances, considering the member preferences and the consumption profiles of the appliances with the corresponding flexibilities. The scheduling is performed at each of three architectural levels: (i) at the prosumer level (on a single house or office dwelling), (ii) at REC level (to which the prosumer belongs), and (iii) at the grid level. This paper’s contribution focuses on delivering fast and scalable algorithms that do not use excessive computing resources so that they can be applied closer to the end-user on an edge-and-fog low-cost computing platform, while maintaining a high level of optimization with benefits for the users and the environment.
The proposed method is validated using a dataset composed of the energy flexibility profiles, consumption, and production of fifty dwellings. The data were collected during different seasons on real-world appliances during the project. Finally, the results are presented and the benefits of the solution are thoroughly analyzed.
This paper is organized in multiple sections.
Section 2 presents the state-of-the-art concepts and projects related to demand-side response and energy flexibility.
Section 3 gives an overview of the developed system model.
Section 4 details the flex offer scheduling algorithms.
Section 5 presents and discusses the results obtained from a real-world simulation.
Section 6 addresses the main conclusions and future work.
2. State of the Art
The EU has committed to reducing 55% of net greenhouse gas emissions [
6], integrating more than 40% of Renewable Energy Sources (RES) [
7], and improving energy efficiency by 32.5% [
8] by 2030. Critical to achieving these targets is the large-scale penetration of intermittent RES and the increase in the electrification of sectors such as transportation and heating [
9]. Balancing energy supply demand in the RES-dominated energy landscape requires the involvement of individual consumers in Demand-Side Management (DSM) [
10].
The spread of Distributed Energy Resources (DERs), smart IoT home appliances, and advancements in information and communication technologies (ICT) has led to the emergence of smart grids, which enable the participation of individual consumers in existing and emerging electricity markets through DSM applications [
11,
12,
13]. The scientific literature on the state of the art of DSM includes many interesting studies. For example, in [
14], the authors examined the benefits of DSM in smart grids, while [
11] focused on the developments of energy scheduling and communication technologies for DSM. The authors in [
9,
15] regarded the implementation of DSM in smart grids as one of the most innovative strategies for optimizing the use of the existing grid, delaying and avoiding grid expansion, and integrating intermittent RES, while electrifying transport and buildings. Furthermore, Smart Energy Europe (smarten), a European business association integrating the consumer-driven solutions of the clean energy transition, and Det Norske Veritas (DNV) in their Demand-Side Flexibility (DSF) among other benefits, calculated €71 billion and €300 billion, respectively, in direct and indirect cost benefits to the consumers [
16].
Furthermore, the importance of DSF is highlighted by the Clean Energy Package (CEP) issued in June 2019 by the European Union (EU) [
17]. The CEP consists of a set of Directives and Regulations on energy efficiency [
8], RES integration [
8], energy performance in buildings [
18], governance, and common rules for the electricity market [
19]. The CEP has laid down ambitious goals for the coming decades and empowers final energy end users, both consumers and prosumers, to be grouped in Energy Communities (EC) to help Europe in becoming the world’s first carbon-neutral continent by 2050.
Simply put, RECs, as defined in CEP [
17], represent a novel social construct and concept that can enable their members (consumers and prosumers) to share and benefit from local RES and eventually engage in electricity markets. RECs are groups of geographically close citizens (consumers and prosumers), managing a wide range of heterogeneous energy assets, such as RES, storage technologies including home and EV batteries, home appliances, and other types of load. RECs can participate in numerous activities [
9] such as engaging in distributed energy generation as a strategy to reduce costs (self-production and sharing), optimizing the use of renewables for collective self-consumption schemes, and offering flexible services to local system operators in order to avoid grid expansion or other market operators, by taking advantage of the flexibility of several electrical appliances (e.g., water heaters, HVAC systems, dishwashers) and storage. The authors in [
20] present a systematic literature review of the history, definitions, programs, and future development opportunities in Demand Response (DR). In addition, the authors discuss the introduction of smart energy communities as a new DR participant with considerable load flexibility. Regarding the quantification of DSF potential, authors in [
21,
22] analyzed device-level energy consumption data from several different households and concluded that, on average, 50% of the energy demand from the household comes from flexible devices. Furthermore, several studies have demonstrated the demand reduction and shifting potential of flexible energy devices through the scheduling of residential appliances, particularly of wet devices [
23,
24,
25], heat pumps (HP) [
26,
27,
28,
29,
30], and electric vehicles (EV) [
31,
32,
33,
34,
35].
The activation of the DSF can enable the optimization of energy generation and consumption resources by scheduling the DSF, based on electricity generation availability, prices, and user personal preferences. With such a motivation, many schemes for scheduling energy generation and consumption resources have been proposed. For instance, direct centralized control of flexible devices has been widely put forward for optimizing the use of individual and community DERs. This type of centralized control system has been implemented to directly control the energy consumption of devices at an individual or an aggregated level to reduce user cost [
25,
32,
36], to level peak loads [
12,
31,
37], or to generate financial benefits to the distribution utilities [
38]. Authors in [
23] introduced a novel framework enabling system operators to access DR from HVAC systems in a timeframe suitable for operating reserves. In this study, washing machines, dishwashers, and tumble dryers equipped with communication modules were considered smart appliances. In [
12], the authors implemented a power scheduling method to reduce both the electricity cost and Peak-to-Average Ratio (PAR), thus strengthening the stability of the entire electricity system.
Domestic thermal loads such as thermal accumulators and HVAC systems have been the target of research as flexible resources for DR used in ECs. These devices can be used to store excess electricity production such as thermal energy, taking into consideration the limits of user comfort and the capacity of appliances. The authors in [
39] present a peak shaving solution that predicts water usage profiles from dwelling load patterns, computes thermal losses to determine the water temperature in the tank, and consequently forecasts an optimal consumption profile. Moreover, [
40] applies a fuzzy adaptive competitive algorithm as a load control model for scheduling AC units while minimizing the user’s thermal comfort, while [
41] introduces a model predictive control (MPC) algorithm to schedule a dwelling AC unit considering variable weather, occupancy, and electricity prices. [
42] introduces a nonlinear optimization model for the scheduling of typical home appliances with a time-of-use electricity tariff, while [
43] assesses the impacts of time-of-use tariffs on residential electricity demand and peak shifting.
In addition, [
43] approaches residential day-ahead energy scheduling for DR in smart grids by formulating an optimization problem that, based on the service provider’s electricity prices given ahead of time, presents a solution with the desired trade-off between cost and comfort. However, the report only tests six appliances (three schedulable and three non-schedulable), leading to concerns of solution applicability in real-world energy communities with hundreds of scheduling devices which results in major computational and time requirements to solve the optimization problem. This has been one of our main concerns for the algorithms proposed in this paper. In the literature [
11,
12,
23,
24,
25,
26,
29] and [
31,
32,
36,
37,
42,
44,
45], the energy scheduling problem has been solved using many methods such as linear programming, the particle swarm optimization (PSO) method, and game theory. Normally, the equations for most of these optimization problems are nonlinear, so the authors in [
12] prefer approaches such as genetic algorithms to solve this type of optimization problem. Moreover, the authors in [
46] propose an adaptive day-ahead load optimization and control solution with an edge-and-fog Internet of Things (IoT) architecture.
Despite tremendous flexibility potential and energy community members’ readiness to provide flexibility in their energy consumption, several significant challenges exist that have been either only been partially tackled or remain unexplored:
A general representation of the flexibility, generalized to all device types, is lacking.
A simple, modular, and generalized solution/process which can extract flexibility information from all device types with minimal user intervention is still lacking [
47].
Novel, lightweight, scalable, and real-time flexibility scheduling algorithms to manage and optimize individual and community Distributed Energy Resources (DER) need to be developed [
48].
The economic assessment of the benefits of activating demand flexibility in various scenarios, taking into consideration energy exchanges inside the energy community in connection with upstream markets, needs to be investigated.
In the Flexigy project, we tackled the issue of the flexibility representation and extraction challenge by adopting the FlexOffer model (previously introduced in the Mirabel and TOTALFLEX projects [
49]) to describe the energy flexibility which can be aggregated and exchanged across several actors and markets.
As reviewed, various works have addressed small-demand flexibility scheduling. However, most of them rely on heavy optimization algorithms that require large computing resources and may take a long computing time when scheduling real-world energy communities with hundreds or thousands of devices, in multiple communities.
The heuristic approach used in the algorithms proposed in this paper allows for the optimization of energy resources in a distributed edge-and-fog computing architecture with low computational overhead. As such, our median-term goals focus on delivering an integrated platform for the management and optimization of RECs, unifying dwelling-Level DR, user energy flexibility, and peer-to-peer community energy sharing, while maintaining a distributed edge-and-fog architecture with low computational requirements.
4. Flex Offer Scheduling Algorithms
Following the introduced energy flexibility concept, user profiles, and architecture, algorithms for the three scheduling levels are detailed in the following sections.
4.1. Level 1
Level 1 is executed for all FOs from prosumers who have chosen the tactical profile and aim to maximize their energy self-consumption while minimizing the total cost. We assume that the cost of self-consumption is zero. The diagram in
Figure 3 depicts the workflow of the level 1 algorithm.
This level only includes prosumers with a tactical profile, which have self-production capabilities. As such, the first step of level 1 algorithms, which might be running in an edge device inside the prosumer dwelling, is to forecast the day-ahead self-production. Once forecast, the algorithm fetches community and grid prices for the day ahead from the REC fog device. Note that by changing the desired timespan while fetching information (predicted prices and production), the algorithm can easily be changed to schedule the next 48 h, or even only the next 6 h. This means that the algorithm can be re-run to confirm its schedule during the day.
Moreover, a forecast of the dwellings’ unpredictable consumptions is generated so that the system can reserve part of the user production for unpredictable energy consumption (e.g., turning on a computer, using a vacuum cleaner, or turning on the lights). This way, the self-produced energy consumption is always maximized at the prosumer level.
Finally, the production profile is updated according to the scheduled consumption. In the following sections, the algorithms developed to schedule the distinct types of FOs at level 1 are presented.
4.1.1. Level 1 Schedule of Fixed FOs
Algorithm 1 describes the solution designed to schedule fixed FO consumption in an optimized manner by using the prosumer self-produced energy, block 3.2 in
Figure 3. Since self-produced energy is free for the prosumer, it is always more advantageous, for any buyer profile, to use the maximum self-produced energy possible when a FO is of type fixed FO. As such, this algorithm tries to always schedule the maximum forecasted self-produced energy at any given time.
Algorithm 1: schedSelfConsumptionFixedFO algorithm used at Level 1 to schedule Fixed FOs. |
| Input: |
| | fo—Consumption Fixed FO |
| | prod—Multidimensional array containing: (i) user production and, (ii) energy prices for each time slice |
| | prosumer—Prosumer |
| Output: |
| | prod—The updated prosumer production profile |
1 | Function schedSelfConsumFixedFO (fo, prod, prosumer) |
2 | | t <- fo.tes |
3 | | eProfile <- fo.getEProfile2Sched() |
4 | | sched <- new Schedule(fo.tes) |
5 | | For each eSlice in eProfile Do |
6 | | | e2Sched <- getMaxEConsum(prod, t, eSlice) |
7 | | | If e2Sched > 0 Then |
8 | | | | sched.AddSlice(t, e2Schedule) |
9 | | | End if |
10 | | | t <- t + TimeSliceSize |
11 | | End for |
12 | | prod <- scheduleFO(sched, prod, fo) |
13 | | Return prod |
14 | End |
Given that a Fixed FO has no energy flexibility, its earliest start time (tes) is considered the scheduling Time (tschd) (line 2). In line 3 the Fixed Flex Offer consumption profile is fetched from a database to an auxiliary variable—eProfile. Moreover, a new schedule object name sched, is created (line 4), with its start time set to the FO tes.
Next, for each energy slice of the FO energy profile, the algorithm verifies how much energy consumption can be scheduled using self-production (line 6). If some or all the energy can be scheduled using its self-production, a slice is added to the schedule (line 8). This slice specifies the time, energy amount, and price of the scheduled energy consumption. Finally, in the scheduleFO method (line 12), both the FO and the production energy profile are updated, discounting the energy scheduled, and the FO schedule is saved. Note that if fixed FO cannot be fully fulfilled by the self-production of the prosumer at level 1, the remaining energy needs are stated in a transformed fixed FO that will be scheduled at level 2 and, eventually, at level 3.
4.1.2. Level 1 Schedule of Shiftable FOs
Algorithm 2 describes the algorithm designed to schedule shiftable FOs, also at level 1, block 3.3 in
Figure 3. At this level, the biggest concern was not only to maximize self-consumption on all occasions but also that the algorithm should reflect the prosumer buyer profile. In effect, it can be more monetarily rewarding for a user with a cautious buyer profile to schedule the FO with less self-consumption if the price paid for the surplus is significantly less at that slice, instead of having more self-produced energy but ending up paying more for the surplus scheduled at level 2.
As such, the approach shown in Algorithm 2 focuses on prosumers’ buyer profiles, as it heuristically tries to find the best fit for FO consumption.
Algorithm 2: schedSelfConsumpShiftableFO |
| Input: |
| | fo—Consumption Shiftable FO prod—Multidimensional array containing: (i) user production and, (ii) energy prices for each time slice |
| | prosumer—Prosumer |
| Output: |
| | prod—The updated production profile |
1 | Function schedSelfConsumShiftableFO (fo, prod, prosumer) |
2 | | cost <- MAXVALUE |
3 | | sched <- new Schedule(fo.tes) |
4 | | For i = fo.tes; i < fo.tls; i = i + TimeSliceSize Do |
5 | | | t <- i |
6 | | | auxSched <- new Schedule(i) |
7 | | | sum <- 0 |
8 | | | eProfile <- fo.getEProfile2Schedule() |
9 | | | For each eSlice in eProfile Do |
10 | | | | e2Sched <- getMaxEConsum(prod, t, eSlice) |
11 | | | | consumSurplus = eSlice.energy − e2Sched |
12 | | | | sum = sum + checkProfileCost(consumSurplus, t, eSlice, prosumer) |
13 | | | | auxSched.AddSlice(t, e2Sched) |
14 | | | | t <- t + TimeSliceSize |
15 | | | End for |
16 | | | If sum < cost Then |
17 | | | | sched <- auxSched |
18 | | | | cost <- sum |
19 | | | End If |
20 | | End for |
21 | | prod <- scheduleFO(sched, prod, fo) |
22 | | Return prod |
23 | End |
A cycle is executed to check which of the time slices comprised between the FO tes and tls is more financially advantageous for scheduling the start of the FO execution (tsch) (lines 5 to 20).
At the start of the loop, a set of auxiliary variables is created each time a new candidate tsch is evaluated (lines 5 to 8). Next, the solution price is determined by calculating the price of the energy surplus of each time slice (lines 9 to 15). To determine it, the algorithm starts by finding the maximum self-produced energy that can be consumed by the slice and consequently the consumption surplus. Then, with the help of the checkProfileCost method (line 12), the electricity consumption price is summed to the total price of the solution.
The checkProfileCost method is the solution presented in this work to be able to optimize the level 1 self-consumption solution without disregarding either the electricity prices at other levels or the prosumer buyer profiles. This method uses the forecast of day-ahead prices and calculates the cost for the prosumer based on its profile:
For users with a cautious profile, the cost returned at any given time is calculated based on the cost of the surplus energy multiplied by the grid price for that time. As such, an estimate for the scheduling of surplus energy at higher levels is returned.
For users with a community supporter profile, the cost returned at any given time is calculated based on the cost of the surplus energy multiplied by the REC day-ahead prices at that time.
For users with a bold profile, the cost is how much non-renewable energy is consumed in surplus of self-consumption. As such, the method returns the total amount of surplus energy in this case.
Finally, if the cost of the solution being evaluated (either price or amount of surplus energy) is lower than the cost of the previously saved schedule (line 16), both the schedule and cost variables are updated with the new solution values (lines 17 and 18).
After the best schedule is found, the scheduleFO method saves it and updates the FO and the self-production energy profile accordingly, subtracting the energy scheduled at each slice from the slice available energy.
4.1.3. Level 1 Schedule of Elastic FOs
This study also focuses on bringing environmental benefits and optimizing the operational cost of elastic devices such as thermal accumulators and air conditioners by scheduling their day-ahead energy consumption according to their time-of-use tariffs and the prosumer profiles. Future work will be developed concerning battery storage and other forms of elastic energy flexibility. Algorithm 3 details the heuristic algorithm designed to create a FO for elastic devices, which is later scheduled at the same level as a fixed FO.
Algorithm 3: schedElasticDevi |
| Input: |
| | prosumer—The prosumer to which the device belongs |
tMax—Maximum temperature defined by the user to maintain his comfort |
tMin—Minimum temperature defined by the user to maintain his comfort |
tStart—Temperature at the start |
prices—List with the energy self-production values of the user and energy prices of the different grid suppliers available. |
powerCom—average power consumption per time slice. |
| Output: |
| | FO—The created fixed FO for scheduling |
1 | Function generateHeuristicElasticEProfile |
2 | | t <- new Date(0,0,0) |
3 | | temp <- tStart |
4 | | totalCost <- 0 |
5 | | While (auxtime < end) Do |
6 | | | nextCoolDownTime = getNextCoolDownTime(tMin, temp, t) |
7 | | | If isLowestPriceUntilNextCooldown(nextCoolDownTime, prices)Then |
8 | | | | newTemp <- calculateNewTemp() |
9 | | | | If newTemp < tMax Then |
10 | | | | | temp <- heatUp () |
11 | | | | | consump.add(powerCon, t) |
12 | | | | Else |
13 | | | | | temp <- coolDown() |
14 | | | | End |
15 | | | Else |
16 | | | | temp <- coolDown() |
17 | | | End |
18 | | | t <- t + TimeSliceSize |
19 | | End While |
20 | | FO <- new FO(fixed, consumptions) |
21 | | Return FO |
22 | End |
The heuristic approach to solve elastic device scheduling can be simply explained as an attempt to use the thermal appliance as a conditioned thermal battery.
For example, a client has a water heater that must maintain water between a specified comfort range of temperatures, tmin, and tmax. Our approach focuses on heating up the water at the slices with the lowest price before the water cools down below tmin. However, the water cannot be heated up above tmax. If the water is below tmin, the algorithm heats up regardless of the price, until the desired comfort levels have been met.
When a client has self-production, for example, the most cost and environmentally effective way to use his energy resources are to use surplus energy, which is free, to heat up water, successfully storing renewable energy as heat.
Algorithm 3 does exactly that. First, a set of auxiliary variables are created (lines 2 to 4), including a variable holding the actual temperature of the device. Then, in a loop (lines 5 to 19) each time slice is examined, as follows. First, the next cool-down time is calculated (line 6), based on temperature change equations previously inserted on the system for this specific device.
The cooldown time is the predicted time at which it is forecast that the temperature of the water goes below tmin. Note that the calculation of the forecast of the cooldown time can be improved over time, for example with client hot water consumption patterns. This way the algorithm can more efficiently calculate the cooldown time and maintain comfort temperatures, whilst optimizing energy consumption.
Next, the program checks if the current slice price is the lowest by the cooldown time (line 7). If so, energy is used to heat up water, and the new temperature is calculated. Otherwise, no energy is used, and the water continues to cool down (line 13). Finally (lines 20 and 21), a new fixed FO is created and returned to be scheduled with algorithm 1 with the consumptions scheduled by this algorithm. Note that it results in a fixed FO since the start time is already defined, resulting in a FO without time flexibility, but it can maintain some consumption flexibility.
The main result of the level 1 schedule can be a set of unscheduled FOs, together with another set of partially fulfilled FOs, which change from being flexible or elastic to fixed FO. Alternatively, it is also possible that all FOs from a prosumer are fulfilled, and no further scheduling is performed for FOs from this prosumer. A mix of both alternatives is also possible.
4.2. Level 2
Level 2 starts by getting the users’ production surplus to generate a community energy production profile. It then collects and shuffles in random order all unscheduled FOs of level 1. An FO is considered unscheduled when there is still energy left unscheduled. Finally, the FOs pending from the previous level are scheduled according to the prosumer buyer profile and the FO type (steps 1.4, 1.5, and 1.6 in the diagram in
Figure 4).
Note that in this level, the FO scheduling order is randomly selected, addressing the equity problem that may arise from scheduling always in the same order, as the first to be scheduled may benefit more from a large community excess production available than the last (considering that a typical RES does not produce enough energy to satisfy the consumption of all REC members). Note again that by changing the desired timespan while fetching information (community production profile), the algorithm can be easily changed to schedule the desired number of ahead hours.
4.2.1. Level 2 Schedule of Fixed FOs
Algorithm 4 presents the pseudocode designed to schedule fixed FOs at level 2 (block 1.4 in
Figure 4), which are scheduled before other types, given their reduced flexibility. This algorithm takes into account the user profile and schedules energy consumption according to it.
Algorithm 4. schedLevel2FixedFO |
| Input: |
| | fo—Consumption Fixed FO |
| | prod—Multidimensional array containing: (i) community production, (ii) energy prices for each time slice |
| Output: |
| | prod—Updated production profile |
1 | Function schedFixedFO (fo, prod) |
2 | | t <- fo.tes |
3 | | sched <- new Schedule(t) |
4 | | 2eProfile <- fo.getEProfile2Sched() |
5 | | prosumer <- getFOProsumer(fo) |
6 | | For each eSlice in eProfile Do |
7 | | | e2Sched <- eSlice.energy |
8 | | | sched <- schedSlice(t, e2Sched, prosumer, prod, sched) |
9 | | | t <- t + TimeSliceSize |
10 | | End for |
11 | | prod <- scheduleFO(sched, prod, fo) |
12 | | Return prod |
13 | End |
Once again, since a fixed FO has no energy flexibility, its tes is also the resulting scheduling time tsch (line 2). The algorithm then initializes an auxiliary variable with a new schedule object, with its start time set to the FO tes (line 3), the FO energy consumption profile (line 4), and with the user buyer profile (line 5). Next, the algorithm schedules each energy slice of the FO energy profile using the schedSlice method.
The schedSlice method guarantees an adequate energy schedule according to the user profile. It uses the forecast of day-ahead prices and calculates the cost for the prosumer based on their profile:
For users with a cautious profile, the schedule returned at any given time is calculated based on the slice energy multiplied by the lowest price at that time.
For users with a community supporter profile, the schedule returned at any given time is calculated based on the slice energy multiplied by the REC day-ahead prices at that time.
For users with a bold profile, the schedule is calculated based on the slice energy multiplied by the cheapest available renewable energy source.
Finally, in the scheduleFO method, both the FO and the production energy profile are updated, discounting the energy scheduled, and the FO schedule is saved in the database.
4.2.2. Level 2 Schedule of Shiftable FOs
Algorithm 5 describes the pseudocode designed to schedule the level 2 shiftable FOs (block 1.5 in
Figure 4), This algorithm takes into account the user profile and schedules energy consumption by minimizing the cost of the schedule given the user flexibility.
Algorithm 5. schedLevel2ShiftableFO |
| Input: |
| | fo—Consumption Shiftable FO |
| | prod—Multidimensional array containing: (i) community production, (ii) energy prices for each time slice |
| Output: |
| | prod—Updated production profile |
1 | Function schedShiftableFO (fo, prod) |
2 | | consumPrice <- MAXVALUE |
3 | | eProfile <- fo.getEProfile2Schedule() |
4 | | sched <- new Schedule(fo.start) |
5 | | prosumer <- getFOProsumer(fo) |
6 | | For i = fo.tes; i < fo.tls; i = i + TimeSliceSize Do |
7 | | | t <- i |
8 | | | auxSched <- new Schedule(i) |
9 | | | sum <- 0 |
10 | | | eProfile <- fo.getEProfile2Sched() |
11 | | | For each eSlice in eProfile Do |
12 | | | | e2Sched <- eSlice.energy |
13 | | | | auxSched <- schedSlice(t, e2Sched, prosumer, prod, auxSched) |
14 | | | | sum <- sum + auxSched.getPrice(t) |
15 | | | | t <- t + TimeSliceSize |
16 | | | End for |
17 | | | If sum < consumPrice Then |
18 | | | | sched <- auxSched |
19 | | | | consumPrice <- sum |
20 | | | End If |
21 | | End for |
22 | | prod <- scheduleFO(sched, prod, fo) |
23 | | Return prod |
24 | End |
First, a set of auxiliary variables are created. At the start of the loop (lines 6 to 21), a set of auxiliary variables is created each time a new candidate tsch is evaluated (lines 7 to 10). Next, each possible solution price is determined by calculating the price of the energy of each time slice (lines 11 to 16). To determine this, the algorithm uses the schedSlice method presented before. Finally, if the cost of the solution being evaluated is lower than the cost of the previously saved schedule (line 17), both the schedule and cost variables are updated with the new solution values (lines 18 and 19).
After the best schedule is found, the scheduleFO method saves it and updates the FO and the self-production energy profile, accordingly, discounting the energy scheduled, and the FO schedule is saved in the database.
4.2.3. Level 2 Schedule of Elastic FOs
As described previously in
Section 4.1.3. the elastic scheduling algorithms are executed at level 1 for the users with forecasted self-production available. For the elastic devices of all other users, the scheduling is done at level 2. The algorithm used is similar to the one used at level 1, and consequently it will not be described here.
4.3. Level 3
The level 3 algorithms schedule FO at the grid level, but they are out of the scope of this paper as this topic has been extensively researched before.
These algorithms work by aggregating small FOs into large FO which can be scheduled at the grid level or submitted to a flexible market. This schema allows the participation of small consumers in DR, which otherwise would not have a significant impact on energy grid balancing as traditionally energy-intensive industrial users and large customers have by intentionally modifying their consumption patterns.
The authors in [
52] theorize about a voluntary local flexibility market where users sell their flexibility, which is then grouped by energy aggregators and sold, reducing costs for all involved stakeholders.
For example, ref. [
15] introduces an optimal scheduling algorithm based on load constraints linked to the dwelling occupant’s comfort. Similarly, [
16] uses aggregation of energy flexibility expressed by market players as the key to balancing energy supply and demand. After their creation and acceptance, the FOs are aggregated, preserving their flexibility. Afterwards, the scheduling is performed based on forecasts to achieve a greater balance of the grid. Next, the FOs are disaggregated and returned to the prosumer. Once the execution is carried out, billing is conducted and, depending on the benefits of the FO for the utility company, an incentive may be provided to the prosumer.
6. Conclusions
The energy produced from RES has emerged as a green, reliable, and environmentally friendly solution for the replacement of traditional energy production methods, which are heavily dependent on the burning of fossil fuels. Moreover, RES, such as sun and wind, can be individually harnessed by citizens, allowing for energy self-sufficiency, and the reduction of transmission losses. As a result, RECs are emerging as an effective concept and model to empower the active involvement of citizens in the energy transition as promoters of RES and participation in the energy markets.
This paper aimed to contribute to the management, scheduling, and optimization of individual and community energy consumption and production in a REC. It follows a previous REC architecture and introduces heuristic algorithms that aim to address the economic and social needs of different players. The algorithms are organized in a distributed edge-and-fog approach and are designed for low computational overhead.
The test case scenario carried out with 50 REC members aimed to simulate a real-world community, with diverse buyer and supplier profiles, energy flexibility, and production capabilities. The results demonstrate very promising results, for every season of the year, encouraging the use of RES, and helping producers reduce the initial investment pay-out time not only by maximizing the use of self-produced energy but also by selling the energy surplus to other community members at a profitable price. The test case scenario also demonstrated the low computational overhead of the algorithms presented when applied in a decentralized edge-and-fog architecture. These results mean that this service can be applied closer to the end-user in an edge-and-fog low-cost implementation, while maintaining a high level of optimization and benefits for the users.
The algorithms are currently being updated to take into consideration the scheduling of optimized battery energy storage and consumption and the introduction of electric vehicles in a vehicle-to-grid fashion. Future work should evaluate these algorithms against real-world implementations, with a more diversified list of dwellings, appliances, flexibilities, and other seasonal data. Future work should also encompass a strong economic analysis of scenarios for business implementation purposes.