Skip to content

GSY DEX Off-Chain Storage

The off-chain storage component of the GSY DEX is designed to store various types of data that are crucial to the platform's operation but do not need to be recorded on the blockchain, thereby enhancing scalability and efficiency. The off-chain storage can be accessed by both off-chain workers and on-chain logic. A computational reference (hash) is allocated to each bid and offer to ensure minimal transaction throughput on the blockchain and maximal data privacy for participants in the energy exchange (e.g. members of a local energy community), while providing full transparency and functionality of matching and execution for each trade transacted via the on-chain Order Book (part of GSY DEX Node). Importantly, final price and energy verification for each trade is performed on-chain. The GSY DEX Off-Chain Storage implementation is grounded in Grid Singularity’s concept of Symbiotic Energy Markets, inspired by mycorrhizal networks. Importantly, while intended for the energy sector, the GSY DEX Off-Chain Storage can also support other industry applications, contributing to both the Energy Web and the wider Polkadot innovation ecosystem.

Off-chain workers (also termed mycos in the GSY DEX architecture design) are an integral part of the node (in this case the GSY Node), which execute long-running and possibly non-deterministic tasks, such as encryption, decryption, and signing of data, CPU-intensive computations or enumeration or aggregation of on-chain data (for more see the related Substrate wiki page). They are automatically created when a blockchain node is deployed, running operations at the end of each block that this node validates. The difference compared to a smart contract or a pallet, is that the off-chain worker has its own runtime, synchronised with the node runtime. Since the code is shared, off-chain workers can immediately access the blockchain, without HTTP or any other protocol. This is a safer and more efficient way to interact with the blockchain compared to Oracles, which is the conventional way of integrating off-chain with on-chain data. Notably, Oracles are not part of the blockchain but an external service that continuously performs actions based on new blocks that the blockchain generates, potentially compromising blockchain security by making it dependent on Oracle security. As a separate service, Oracles also need dedicated scaling if the number of blockchain validators increases which is not the case with off-chain workers.

The off-chain storage comprises four distinct components (substorages):

  • GSY DEX Grid Topology Storage: contains information about the physical grid structure, such as the location and configuration of nodes, as well as the interconnections between energy assets, which enable the GSY DEX to both verify the eligibility of the assets for trading, and to facilitate performance analytics that involve the topology of the grid.
  • GSY DEX Measurements Storage: stores the energy consumption and generation data from energy assets. Accurate measurement data is essential for validating and executing energy trades, managing grid stability, and optimising energy consumption and generation patterns.
  • GSY DEX Trades Storage: stores all energy trades of the GSY DEX, which are required in order to maintain and update the trade status to facilitate trade execution, as well as for analytics, auditing the trading behaviour of the user energy assets, and historical market analysis.
  • GSY DEX Order Book Storage: This storage component holds all the orders inserted in the respective market, including bids and offers issued by participants, along with metadata generated for each order.

Each of the off-chain storage components is associated with proprietary, component-specific database tables, and exposed to other GSY DEX system components via HTTP REST endpoints to facilitate common operations and streamline access to data. This approach ensures that other GSY DEX system components can read, update and save information related to each storage component. Furthermore, separating the data in different components restricts data dependencies and thereby optimises data management, including by enabling efficient database migration and other operations on the database tables’ schema. Data storage segmentation also facilitates partial data transfer to other data storages in the future system upgrades. Off-chain storage workers’ role is to ensure that off-chain storage subcomponents, namely the GSY DEX Grid Topology Storage and the GSY DEX Measurements Storage, securely receive the required data such as asset-level generation and consumption, and that the GSY DEX Trades Storage and the GSY DEX Order Book Storage can support and improve performance of the matching operation based on a set of preferred energy attributes.

alt_text

Figure 1: GSY DEX Off-Chain Storage - GSY Node Communication Flow.

GSY DEX Off-Chain Storage Communication Protocol

The GSY Node stores the order and trade information in the GSY DEX Off-Chain Storage by leveraging off-chain workers as described above, which perform HTTP requests on behalf of the Node. Notably, the GSY Node saves the bids and offers in the GSY DEX Order Book Storage and the trades in the GSY DEX Trades Storage in order to make them available for other system services, namely those performed by the GSY DEX Analytics Engine and the GSY DEX Matching Engine. These other GSY DEX system components all leverage the same HTTP REST API as the GSY Node to access the GSY DEX Off-Chain Storage.

The GSY DEX Analytics Engine requires access specifically to the GSY DEX Grid Topology Storage and the GSY DEX Trades Storage to retrieve data to calculate the select performance indicators to monitor individual and aggregate performance of energy assets in the exchange.

The GSY DEX Matching Engine, in turn requires access specifically to the GSY DEX Order Book Storage to retrieve the open offers and bids in order to perform the market supply and demand matching operation.

alt_text

Figure 2: GSY DEX Off-Chain Storage Dataflow.

GSY DEX Grid Topology Storage

The GSY DEX Grid Topology (Off-Chain) Storage is responsible for persisting the data pertaining to grid topology (also referred to as ontology), which is required for data access management and exchange (energy trade) facilitation. The following data is stored in the GSY DEX Grid Topology (Off-Chain) Storage:

  • Energy asset information, consisting of nameplate parameters for each energy asset participating in the energy exchange, which serve to verify that the values of energy offers and bids submitted by each asset do not surpass the energy values that can be physically consumed or produced by the asset. Attributes assigned to energy generation, consumption and storage assets also serve to define preferences with regards to energy use, technically enabling a wider array of user choices (multi-attribute bids and offers) in markets that facilitate a broader scope of market participation.
  • Grid topology description: defining how the assets are structured and grouped, and providing the location and nameplate parameters of electrical devices that form the electrical grid, namely circuit breakers and voltage transformers. Its main purpose is to form the rules for asset trading (for example, for intra-community trading, only assets from the same community would be permitted to trade). The topology information is also required for the GSY DEX Execution Engine operation, enabling it to verify whether the traded energy is actually produced by the assets, and that the trade can be performed without compromising the resilience and the stability of the grid.

GSY DEX Measurements Storage

The GSY DEX Measurements Storage is responsible for persisting energy measurements and forecasts for assets defined in GSY DEX Grid Topology in the form of time series data, with predefined time resolution, with default 15-min resolution.

The main purpose of energy forecasts is to facilitate and enhance the operation of trading agents, facilitating a more accurate and efficient order submission for the assets that they manage based on improved predictions. Importantly, the GSY DEX will use the asset forecasts to set an upper limit to the sum of the energy of all open orders in the exchange, obliging the exchange participants to not post energy orders which sum to a greater volume than the forecasted energy.

Measurements are also required for the GSY DEX Execution Engine operation, in order to verify whether the energy produced or consumed by the energy assets is accurately reflected by the energy trades of these assets, and to assign penalties to assets that sold energy that they did not produce.

GSY DEX Trades Storage

The GSY DEX Trades Storage is responsible for storing the successful energy trades for all assets that participate in the energy exchange, along with the associated metadata. It streamlines access to the trade information for:

  • Asset aggregators or trading agents that are responsible for managing one or multiple assets, enabling them to reconfigure the asset trading strategy based on historical information relating to the past energy trades for these assets
  • The GSY DEX Analytics Engine, which needs the information related to the energy trades to generate more elaborate analytics to monitor the performance of the exchange overall and the trading assets individually.
  • Payment services, which require access to the energy trades in order to modify the token balances of the seller and the buyer of energy, thereby performing the financial settlement for the energy trades.

GSY DEX Order Book Storage

The GSY DEX Order Book Storage is responsible for storing all offers and bids posted on the GSY DEX, both open and closed. It should include all information that was posted as part of the bid and the offer, along with metadata that is automatically generated by the GSY DEX.

The main purposes for persisting the offers and bids are the following:

  • Report historical offers and bids to all exchange participants, along with all the associated information and the final status (open, traded, deleted);
  • Enable the operation of the GSY DEX Matching Engine by providing a list of open offers and open bids, which represent the energy demand that is currently requested, and the energy supply that is currently offered in the exchange, respectively.

GSY DEX Off-Chain Storage Database

The GSY DEX Off-Chain Storage Database is the off-chain storage component responsible for persisting the off-chain data required for the correct operation of the GSY DEX. This operation presents a consequential challenge due to the volume of required data points and the requirement to persist and report these data for long periods of time. Furthermore, significant computation will need to be performed on these data, which in turn contribute to the computational effort required by the blockchain nodes for data processing. To circumvent these limitations, these data points are not saved in the blockchain, but in the off-chain database, facilitating storage of data of arbitrary size, and the related performance of more computationally intensive operations.

To ensure optimal performance, stability and scalability of the GSY DEX, the off-chain storage database type of choice is MongoDB, a NoSQL document-oriented database, capable of storing and fetching large data volumes. One of its main advantages is horizontal scaling, enabled by sharding, which is a method of distributing data across multiple servers, with each server containing a subset of the data (shard). That way, the total workload capacity of the database is not limited by the resources of a single server. Whenever the server resources become exhausted, a new server can be added to the sharded cluster to extend the total capacity and balance the database load, ensuring efficient computation of increased data volumes. Redundancy and high availability to ensure data security are facilitated by the use of replica sets, which copies part of the data to different database servers, thus providing a level of fault tolerance against the loss of a single database server.

GSY DEX Off-Chain Database Schema

Each data type required for the operation of the GSY DEX is modelled and structured as a MongoDB Document, both to correctly organise the data and to facilitate and accelerate the expected queries that will be executed on the data. The data types that are persisted in the database for each storage subcomponent are listed below.

Grid Topology Storage Database Schema

The Grid Topology Storage will store all assets using the same data type, with optional arguments applied to differentiate the asset type and position, creating and persisting a hierarchical layered representation of the electrical grid. Different topology types will support different arguments, accommodating generation, consumption and storage assets (namely PVs, Heat Pumps, Loads and Batteries), as well as electrical devices that form the electrical grid (Smart Metres, Voltage Transformers and Circuit Breakers), along with the Area type that is used in order to group different assets. Topology connections are modelled using the “children” argument, which is available only for Area type (also termed Market or Submarket), Voltage Transformer and Circuit Breaker types, and accept a list of asset uuids.

{
   "type": "Load",
   "nonce": 3,
   "uuid": "load_uuid",
   "name": "Home 1 Consumption",
   "community_uuid": 13,
   "creation_time": 1546300800,
   "max_consumption_kWh": 5,
   "coordinates": [43.2, 45],
   "children": []
 }

Figure 3: Example of GSY DEX Off-Chain Grid Topology Storage Load.

{
   "type": "VoltageTransformer",
   "nonce": 3,
   "uuid": 5,
   "name": "Home 1 Consumption",
   "community_uuid": 13,
   "creation_time": 1546300800,
   "max_power_rating_kW": 20,
   "coordinates": [43.2, 45],
   "children": ["load_uuid"]
 }

Figure 4: Example of a voltage transformer in the GSY DEX Off-Chain Grid Topology Storage.

Measurements Storage Database Schema

The Measurements Storage will persist forecasts and measurements, using the same data type. The type data entry attribute is used to differentiate between forecasts and measurements, thereby allowing the database to select only forecasts or measurements, depending on the user interest. Furthermore, type, asset_uuid and time_slot data entries are indexed, in order to accelerate queries that select forecasts or measurements for a select asset and period of time.

{
   "type": "Forecast",
   "nonce": 3,
   "asset_uuid": 5,
   "community_uuid": 13,
   "time_slot": 2,
   "creation_time": 1546300800,
   "energy_consumption_kWh": 1.2,
   "energy_production_kWh": 0,
}

Figure 5: Example of a forecast in the GSY DEX Off-Chain Measurements Storage.

{
   "type": "Measurement",
   "nonce": 2,
   "asset_uuid": 1,
   "community_uuid": 13,
   "time_slot": 2,
   "creation_time": 1546300800,
   "energy_consumption_kWh": 10.2,
   "energy_production_kWh": 0.3,
}

Figure 6: Example of a measurement in the GSY DEX Off-Chain Measurements Storage.

Order Book Storage Database Schema

Bids and offers are saved using the same data type. Similar to the other storage subcomponents, type data entry attribute in the JSON document is used in order to differentiate between offers and bids, thus allowing the user to filter for either one. Moreover, type, asset_uuid, market_uuid and time_slot data entries are indexed, in order to accelerate queries that select bids or offers for a select asset, market and time slot.

{
   "type": "Bid",
   "nonce": 2,
   "asset_uuid": 1,
   "market_uuid": 1,
   "time_slot": 2,
   "creation_time": 1546300800,
   "bid_component": {
       "buyer": "aabc",
       "energy": 10,
       "energy_rate": 1
   }
}

Figure 7: Example of a bid in the GSY DEX Off-Chain Order Book Storage.

{
   "type": "Offer",
   "nonce": 1,
   "asset_uuid": 1,
   "market_uuid": 1,
   "time_slot": 1,
   "creation_time": 1546300800,
   "offer_component": {
       "seller": "bbcd",
       "energy": 10,
       "energy_rate": 1
   }
}

Figure 8: Example of an offer in the GSY DEX Off-Chain Order Book Storage.

Trades Storage Database Schema

Trades are also saved using JSON documents in a similar format as the Order. The same fields as for the Order Book Storage will need to be indexed, namely asset_uuid, market_uuid and time_slot, thus speeding up the selection of the trades for one asset / market / time slot.

{
   "type": "Trade",
   "nonce": 2,
   "asset_uuid": 1,
   "market_uuid": 1,
   "time_slot": 2,
   "creation_time": 1546300800,
   "energy": 10,
   "energy_rate": 1,
   "bid_component": {
       "buyer": "aabc",
       "energy": 10,
       "energy_rate": 1
   },
   "offer_component": {
       "seller": "deca",
       "energy": 10,
       "energy_rate": 1
   },
}

Figure 9: Example of a trade in the GSY DEX Off-Chain Order Book Storage.

HTTP REST API Schema

Each storage subcomponent is exposed via separate REST endpoints for operations that are most commonly required by the users of the GSY DEX Off-Chain Storage API. GET and POST requests are supported to facilitate reading of database entries, as well as the creation of new database entries.

Grid Topology Storage API Schema

The Grid Topology Storage uses the dedicated endpoint

/grid-topology

In order to both fetch and create new entries. The endpoint supports both GET and POST HTTP requests, and the accepted input data format is similar to the database schema:

POST /grid-topology
[{
   "type": "VoltageTransformer",
   "nonce": 3,
   "uuid": 5,
   "name": "Home 1 Consumption",
   "community_uuid": 13,
   "creation_time": 1546300800,
   "max_power_rating_kW": 20,
   "children": [{
      "type": "Load",
      "nonce": 3,
      "uuid": "load_uuid",
      "name": "Home 1 Consumption",
      "creation_time": 1546300800,
      "max_consumption_kWh": 5,
      "children": []
    }
 }]

Figure 10: Example of GSY DEX Off-Chain Grid Topology REST API POST.

Measurements Storage API Schema

The Measurements Storage uses one dedicated endpoint for forecasts:

/forecasts

and one for measurements:

/measurements

Both endpoints support GET and POST HTTP requests, in order to be able to both fetch and create forecasts / measurements. The accepted input data format is similar to the database schema in both cases:

POST /forecasts
{
   "type": "Forecast",
   "nonce": 3,
   "asset_uuid": 5,
   "community_uuid": 13,
   "time_slot": 2,
   "creation_time": 1546300800,
   "energy": 1.2,
}
POST /measurements
{
   "type": "Measurement",
   "nonce": 2,
   "asset_uuid": 1,
   "community_uuid": 13,
   "time_slot": 2,
   "creation_time": 1546300800,
   "energy": 10.2,
}

Figure 11: Example of GSY DEX Off-Chain Measurements Storage REST API POST.

Order Book Storage API Schema

The Order Book Storage uses the dedicated endpoint

/orders

In order to both fetch and create new entries. The endpoint supports both GET and POST HTTP request, and the accepted input data format is similar to the database schema:

POST /orders/
[{
   "type": "Bid",
   "nonce": 2,
   "asset_uuid": 1,
   "market_uuid": 1,
   "time_slot": 2,
   "creation_time": 1546300800,
   "bid_component": {
       "buyer": "aabc",
       "energy": 10,
       "energy_rate": 1
   }
}]
POST /orders/
[{
   "type": "Offer",
   "nonce": 1,
   "asset_uuid": 1,
   "market_uuid": 1,
   "time_slot": 1,
   "creation_time": 1546300800,
   "offer_component": {
       "seller": "bbcd",
       "energy": 10,
       "energy_rate": 1
   }
}]

Figure 12: Example of the GSY DEX Off-Chain Order Book REST API POST.

Trades Storage API Schema

The Trades Storage uses the dedicated endpoint

/trades

in order to both fetch and create new entries. The endpoint supports both GET and POST HTTP request, and the accepted input data format is similar to the database schema:

POST /trades
[{
   "type": "Trade",
   "nonce": 2,
   "asset_uuid": 1,
   "market_uuid": 1,
   "time_slot": 2,
   "creation_time": 1546300800,
   "energy": 10,
   "energy_rate": 1,
   "bid_component": {
       "buyer": "aabc",
       "energy": 10,
       "energy_rate": 1
   },
   "offer_component": {
       "seller": "deca",
       "energy": 10,
       "energy_rate": 1
   },
}]

Figure 13: Example of the GSY DEX Off-Chain Trades Storage REST API POST.