Skip to content

Grid-scale li-ion battery optimisation for wholesale market arbitrage, using pytorch implementation of dqn, double dueling dqn and a noisy network dqn.

Notifications You must be signed in to change notification settings

RichardFindlay/battery-optimisation-with-drl

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Optimising Grid-Scale Lithium-ion Batteries with Deep Reinforcement Learning (DRL)

🚀 Blog post on personal website 🔗 Deep Reinforcement Learning for Grid Scale Lithium-ion Battery Optimisation

screenshot of interactive d3.js plot illustrating timeseries performance of Double-Dueling DQN

Project Description 📖:

The repository demonstrates the capabilities of data driven techniques by investigating the novel application of Deep Reinforcement Learning (DRL) to maximising the profit of a battery from wholesale energy arbitrage. Largely based on the codeless academic paper from Cao et al. (2019), the post looks to apply the Deep Q-network (DQN) model introduced by DeepMind in 2015, as well as investigate some the improvements made to the basic architecture. The above figure shows the results from a 10MW/20MWh (2hr) Li-ion battery optimised using a "Double Dueling" DQN method.

Performance Overview 🏎️:

Vanilla, Double-Dueling and a Noisy Network DQN was explored as part of this study, integrating the effects of battery degradation and dynamic efficiency into the reward function to produce a practical foundation to the novel optimisation. For comparison the repository also has a Mixed Integer Linear Programming (MILP) optimisation, with the cumulative profits for the inference year (2019) illustrated below.

til

The Double-Dueling DQN marginally prevailed as the best optimisation technique in the energy arbitrage problem, with even the vanilla DQN agent shown significant uplift over other techniques such as MILP, the opportunities for DRL to such a problem is vast, especially considering the minimal hyper-parameter tuning explored for this novel investigation.

Notes on Code 📓:

Install python dependencies for repository:

$ pip install -r requirements.txt

🏋️ Training for all models was conducted on a Google Colab Pro+ subscription.

Further Work 🔭:

  • Investigate opportunities for stackable revenue streams (Balancing Mechanism, FFR etc.) to be integrated into DQN optimisation.
  • Imply battery sizing during training of DQN model -possibly within the state space- to allow for easier manipulation of configuration scenarios during inference.
  • Opting for a different DRL architectures could allow for the adoption of a continuous action space which could bring about further opportunities for refined performance.
  • Pursuit of temporally higher resolution data to better capture market volatility and arbitrage opportunities for batter

Oppurtunities & To Do 🧪:

  • Code links and references to be validated since re-organisation.
  • Clean code, especially interactive d3 plot.
  • Expanding train-set out-with 1-year (2018) could promote performance.
  • Further validate performance of Pytorch forecasting model and it's integration into the RL environment.

Resources 💎:

About

Grid-scale li-ion battery optimisation for wholesale market arbitrage, using pytorch implementation of dqn, double dueling dqn and a noisy network dqn.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published