A significant share of existing large-scale energy system modelling frameworks are based on mixed-integer linear programming (MILP), as concurrent solvers can efficiently handle very large problems [
26]. This severely limits applicable building modelling options, however, as most detailed physics-based white-box models cannot be integrated directly due to their reliance on non-linear functions [
27]. Similarly, data-driven black-box models typically employ mathematical frameworks that cannot be implemented in a MILP-compatible manner [
8]. Fortunately, simplified grey-box RC-modelling approaches have been shown to sufficiently capture the temperature dynamics in buildings and can be integrated directly into MILP problems [
28]. Although, while RC models are ideal for large-scale energy system model integration, detailed white-box models or data-driven black-box models typically perform better in terms of accuracy, reliability, and adaptability when it comes to building-level MPC applications with access to detailed technical properties and measurement data from the building [
7,
8].
  2.1. Modelled Buildings
Residential buildings make up most of existing building stocks, and as such, are of key interest for building MPC. In terms of the flexibility in space heating demand, the effective thermal mass of the building is a potentially important factor. Thus, this work included both a light wooden-framed detached house (DH) and a heavy concrete apartment block (AB), illustrated in 
Figure 1 and described in more detail in 
Table 1 and 
Table 2, respectively. The modelled buildings were based on the readily made example buildings from the IDA ESBO v1.13 [
30] simulation tool, adhering to the 2012 Finnish regulations [
31]. However, ventilation heat recovery units were disabled for simplicity, as well as to keep the building models identical to the previous IDA ESBO validations [
32].
The IDA ESBO building models were reduced into simplified RC models with only three temperature nodes depicting each building, namely the indoor air and furniture node, and the heavy and light structural mass nodes, illustrated in 
Figure 2. This nodal configuration had the most robust performance in terms of uncertainties related to the structural and solar gain properties in previous IDA ESBO validations [
32], and the same RC models were reused in this work with the addition of a domestic hot water (DHW) tank temperature node to represent its storage capacity. A summary of the key indicators used for validating the RC models against IDA ESBO is presented in 
Table 3. For the sake of brevity, the RC model validation is not reproduced here, and interested readers are instead kindly referred to the aforementioned previous work [
32]. While more accurate RC models could undoubtedly be obtained via state-of-the-art calibration routines [
33] and processed for Backbone, these robust models were chosen for this demonstration as they better represent the intended use case on the energy-system scale, where detailed measurement or simulation data for proper calibration are often lacking. The indoor air and DHW tank node temperatures were constrained between 21 and 25 ℃ and 60 and 90 ℃, respectively, based on the Finnish building code [
34,
35], governing the available flexibility in space and water heating demands.
Time-varying prices make the use of economic MPC more worthwhile, so the buildings were modelled with ground-to-water heat pump (G2WHP) systems for both space and water heating. For simplicity, the G2WHP was modelled using a simple seasonal performance factor (SPF) of 2.5, as suggested by Finnish building code calculation guides for G2WHPs with 60 ℃ hydronic radiator heat distribution systems typical in Finland [
36]. Similarly, the buildings were equipped with ground-source cooling systems with SPF of 30 [
36] to ensure feasible indoor air temperatures during summer. While temperature-dependent coefficients of performance for the heat pumps could be used to improve the accuracy of the modelling, they were purposefully avoided in order to permit calculating a more realistic baseline using Backbone, as explained in 
Section 3.1. The heating and cooling systems were assumed to be sized such that they could handle all heating and cooling demand in the modelled buildings without the need of auxiliary systems.
The G2WHP was also used for pre-heating DHW up to 60 ℃, but topping up to the maximum 90 ℃ permitted for the modelled DHW tanks using resistance heaters reduced the overall SPF to 
. The DHW storage tanks were sized to store roughly two-thirds of the assumed daily DHW demand with the permitted temperature range, resulting in 250 and 3000 L tanks for the modelled detached house and apartment block, respectively. The sizing, heat losses, and other relevant technical properties of the DHW tanks were based on typical values presented in the Finnish building code calculation guides [
35]. It is worth noting that the heat losses from the DHW tanks were assumed to be fully utilisable, contributing to the internal heat gains. While this is not often the case in reality, it simplifies the model and is sufficient for the purpose of this paper.
The internal heat gains and DHW demand profiles were based on simple typical daily profiles in the national calculation guides [
35] presented in 
Figure 3. The internal heat gains include the assumed effect of inhabitants, appliances, and lighting but were aggregated into a single total heat gain profile for simplicity. Using identical profiles for both the modelled detached house (DH) and apartment block (AB) is not ideal, as the profiles are dependent on the building type in reality. However, the identical profiles are acceptable for the purpose of this paper. Meanwhile, the ambient temperatures, solar heat gains, and radiative sky losses were processed using ArchetypeBuildingModel.jl [
37] and PyPSA/atlite [
38] based on weather data from the ERA5 global reanalysis dataset [
39] for the coordinates of the Helsinki-Vantaa airport.
  2.2. Backbone MPC Implementation
Backbone is an open-source MILP-based large-scale energy system modelling framework written in GAMS, primarily developed for solving expansion planning, hydro-thermal scheduling, and unit commitment problems. In order to accommodate such a broad scope of problems, the temporal, stochastic, and system depictions were designed in a generic and adaptable manner, allowing users to define radically different problems via input data and definitions. Here, only the key aspects of Backbone relevant for building-level MPC are presented, and readers interested in further details are kindly referred to the paper by Helistö et al. [
40] containing the full model formulation.
At its core, Backbone is a cost minimisation model, where the objective function depicts the total system costs of generating all the energy required to satisfy the demand in the modelled system, as well as installing new or replacing old assets. As such, Backbone is primarily suited for economic MPC of buildings, although other objectives could also be accommodated either by pricing them in the objective function or by introducing custom constraints to the problem. In this work, Backbone was configured to perform rolling horizon economic optimisation depicting MPC, and it is important to understand the following distinctions going forward:
- Time step t refers to the time indices of the model, and  refers to the length of time step t in hours. In this work, only hourly time resolution was used . 
- Optimisation interval refers to the frequency of the rolling horizon optimisation, e.g., a 6 h interval meant that results were saved for the first six hours of each solve, before moving forward by six hours for the next solve. 
- Optimisation horizon  refers to the set of time steps t in each solve, e.g., with a 36 h horizon, optimal control was always solved for the next 36 h before rolling. 
The key costs for building-scale MPC typically only include the costs of imported energy, reducing the simplified MPC optimisation problem to the following: 
where 
p, 
v, and 
 denote different parameters, variables, and time series, respectively, with their names indicated by the superscript and indices by the subscript. By exploiting Backbone’s generic design, its energy networks can be parameterised to represent building RC models as illustrated in 
Figure 4. The set 
 contains all heating and cooling equipment units 
u, and the set 
 contains all the temperature nodes shown in the same figure. The objective function in Equation (
1) is relatively straightforward, representing the total cost of imported electricity for all units 
 and over the entire optimisation horizon 
, where 
ts_price is the electricity price time series in €/Wh, and the 
gen variable represents the electricity consumed in W by the heating and cooling units. Please note that Equations (
1)–(
5) have been considerably simplified from the full Backbone formulation [
40], omitting unused features such as controlled energy transfer and spill variables, variable and fixed costs related to units and energy transfer, capacity expansion related investment costs and discount factors, as well as forecast and scenario indices and their weights.
When implementing simple building RC models within Backbone via the energy balance constraint in Equation (
2), the 
state variables represent the temperature of the building nodes in K, the 
energyCapacity parameter depicts the heat capacity of said nodes in Wh/K, while the 
diffCoeff determines the heat transfer coefficients between them in W/K. The heating equipment are depicted simply using the 
gen [W] variables, either adding energy when heating or removing energy when cooling. Here, the subsets 
 and 
 are used to indicate which nodes 
 and units 
u are connected to the energy balance on the current node 
n, as illustrated by 
Figure 4. Unfortunately, Backbone does not have dedicated parameters for supporting building-specific interactions such as heat losses into the ambient air, solar gains, or internal heat gains in Equation (
2), requiring them to be pre-processed to fit into Backbone’s data structure. The ambient temperature interaction can be separated into its indoor-air and ambient-air-temperature-dependent constituents and implemented via a combination of the 
selfDischargeLoss [W/K] parameter and the 
influx [W] time series. Similarly, since solar and internal heat gains are assumed independent of the variables, their effects can be added to the 
influx time series as well. For readers interested in further details on the building RC model processing for Backbone, please refer to the ArchetypeBuildingModel.jl online documentation [
37].
The energy conversion constraint in Equation (
3) governs the operation of the heating and cooling units 
, namely the G2WHP and ground-source cooling, by enforcing a fixed ratio between the input and output energy of each unit. In Backbone, the 
slope parameter represents the heat rate of unit 
u, which is the inverse of its efficiency, or the SPF in our case. Here, it is worth noting that space heating and water heating using the G2WHP are treated as independent units as shown in 
Figure 4 for simplicity. Furthermore, since the ground-source cooling system unit is removing heat from the indoor air node, its 
slope parameter and thus also its 
gen variable are negative.
Equation (
4) sets the bounds for the 
state variables between the given 
lowerLimit [K] and 
upperLimit [K] parameter values. While all of the temperature nodes presented in 
Figure 4 were constrained for computational reasons, the limits for the light and heavy structure nodes were set loose enough not to impact the operation of the MPC, leaving the interior air and DHW tank temperature limits discussed in 
Section 2.1 to govern the flexibility available to the MPC. Similarly, Equation (
5) sets the upper bounds for the electricity import 
gen variables via the 
capacity [W] parameters based on the assumed system sizing discussed in 
Section 2.1.
For the simulations presented in 
Section 3, Backbone was configured to perform 8736 h rolling horizon optimisations depicting the MPC of the modelled buildings. Essentially, the MPC optimisation problem presented in Equations (
1)–(
5) was solved for the desired optimisation horizon 
, the resulting optimal values for the 
state and 
gen variables were fixed for the chosen optimisation interval, and the problem was rolled forward by the interval to be resolved for the next horizon. In order for the rolling horizon optimisation to obtain results for the last hours of the simulation, the horizon can extend beyond the current year. Backbone deals with this by recycling data from the beginning of the year to make up for the missing information, which can result in unrealistic swings in electricity prices and ambient conditions. Thus, the length of the simulations was limited to 8736 h to avoid “overshooting” the year when using a 168 h optimisation interval, as well as to mitigate any potential impacts of the end of the year on the results.