Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Auto test #173

Merged
merged 24 commits into from
Nov 2, 2023
Merged

Auto test #173

merged 24 commits into from
Nov 2, 2023

Conversation

Betristor
Copy link
Collaborator

  1. Run tests using Test package
  2. Compare results with example results
  3. Notify user via email using github actions

Betristor and others added 12 commits August 9, 2023 22:40
checkout submodules.
1. Add threezones, liquid and northsea case test
2. Add keywords ['#skip', 'CompatHelper'] to allow test bypassing to save unnecessary github action
Pair condition judgment. #skip.
notify author about the comparison results
@Betristor Betristor self-assigned this Sep 9, 2023
test when PR is opened to develop
fetch submodule recursively
add email sender from user
dump github context
Add PR comment instead of writing emails
    permissions:
      pull-requests: write
@github-actions
Copy link

github-actions bot commented Sep 9, 2023

Comparing the following directories:
--- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results ---
--- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example ---

Files in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results but not in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example:
CO2_prices_and_penalties.csv
capacityfactor.csv
reliability.csv
Files in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example but not in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results:
reliabilty.csv

Files in both /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results and /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example:

Matching result files: 
nse.csv
time_weights.csv

Mismatched result files: 
ChargingCost.csv
EnergyRevenue.csv
NetRevenue.csv
RegSubsidyRevenue.csv
SubsidyRevenue.csv
capacity.csv
charge.csv
costs.csv
curtail.csv
emissions.csv
power.csv
power_balance.csv
prices.csv
status.csv
storage.csv
storagebal_duals.csv

Sub-directories
  Comparing the following directories:
  --- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results/Results_HSC ---
  --- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example/Results_HSC ---

  Files in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results/Results_HSC but not in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example/Results_HSC:
  HSC_elec_costs.csv
  HSC_h2_transmission_flow.csv
  Files in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example/Results_HSC but not in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results/Results_HSC:
  HSC_G2P_H2_consumption.csv
  HSC_g2p_capacity.csv

  Files in both /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results/Results_HSC and /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/OneZone/Results_Example/Results_HSC:

  No matching result files

  Mismatched result files: 
  HSC_charge.csv
  HSC_costs.csv
  HSC_emissions.csv
  HSC_generation_storage_capacity.csv
  HSC_h2_balance.csv
  HSC_h2_generation_discharge.csv
  HSC_nse.csv
  storage.csv

Comparing the following directories:
--- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results ---
--- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results_Example ---

Files in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results but not in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results_Example:
CO2_prices_and_penalties.csv
capacityfactor.csv
commit.csv
reliability.csv
shutdown.csv
start.csv
Files in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results_Example but not in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results:
reliabilty.csv

Files in both /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results and /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results_Example:

Matching result files: 
nse.csv
time_weights.csv

Mismatched result files: 
ChargingCost.csv
EnergyRevenue.csv
NetRevenue.csv
RegSubsidyRevenue.csv
SubsidyRevenue.csv
capacity.csv
charge.csv
costs.csv
curtail.csv
emissions.csv
flow.csv
network_expansion.csv
power.csv
power_balance.csv
prices.csv
status.csv
storage.csv
storagebal_duals.csv
tlosses.csv

Sub-directories
  Comparing the following directories:
  --- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results/Results_HSC ---
  --- /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results_Example/Results_HSC ---

  Files in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results/Results_HSC but not in /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results_Example/Results_HSC:
  H2Transit
  H2TruckFlow
  H2TruckNumber
  H2TruckState
  HSC_G2P_power_generation.csv
  HSC_elec_costs.csv
  HSC_h2_transmission_flow.csv
  h2_truck_capacity.csv

  Files in both /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results/Results_HSC and /home/runner/work/DOLPHYN/DOLPHYN/Example_Systems/SmallNewEngland/ThreeZones/Results_Example/Results_HSC:

  No matching result files

  Mismatched result files: 
  HSC_G2P_H2_consumption.csv
  HSC_charge.csv
  HSC_costs.csv
  HSC_emissions.csv
  HSC_g2p_capacity.csv
  HSC_generation_storage_capacity.csv
  HSC_h2_balance.csv
  HSC_h2_generation_discharge.csv
  HSC_h2_pipeline_flow.csv
  HSC_h2_pipeline_level.csv
  HSC_nse.csv
  HSC_pipeline_expansion.csv
  storage.csv


@Betristor
Copy link
Collaborator Author

Betristor commented Sep 9, 2023

@RuaridhMacd Finally I got summary successfully generated and posted in the pull request. At first I wnat to have users notified via email but github context won't provide such information. Then I turned to comment on PR to show summary if such a file is generated using add-pr-comment action which will trigger github to send emails via notifications. Till here only two things are left, one is the comparison base, the other is how to format sumary message to have it rendered in a human-friendly way.

Update comment instead of creating a new one and format message in code block
@Betristor
Copy link
Collaborator Author

Betristor commented Sep 10, 2023

@RuaridhMacd Followup: comment will only be updated and wrapped in code block for a human-friendly render. The only thing left is to have comparison carried out based on the outputs of specified results folder. BTW, I changed your compare_results script to file mode of append to allow multi test results record.

Betristor and others added 3 commits September 17, 2023 11:38
retrive cache for comparison
generate results cache for comparison
@Betristor
Copy link
Collaborator Author

@RuaridhMacd At final last, I created a test main helper workflow to have results generated and cached weekly as comparison base. In the test helper workflow, it will seek cached results for comparison and report difference summary in comment.

@Betristor
Copy link
Collaborator Author

@RuaridhMacd Status.csv will report different Solve value even every time the objective value is identical across different runs.

@bennettm bennettm self-requested a review November 1, 2023 17:02
@bennettm bennettm merged commit 163870f into develop Nov 2, 2023
1 check passed
RuaridhMacd pushed a commit that referenced this pull request Nov 16, 2023
* configure highs solver

* change solver option to highs

* check results using compare_results

* test script

* Update Test-OneZone.yml

checkout submodules.

* Update and rename Test-OneZone.yml to TestHelper.yml

1. Add threezones, liquid and northsea case test
2. Add keywords ['#skip', 'CompatHelper'] to allow test bypassing to save unnecessary github action

* Update TestHelper.yml

Pair condition judgment. #skip.

* add test package

* drop output file

* compare results

* Update TestHelper.yml

test PR

* Update TestHelper.yml

notify author about the comparison results

* Update TestHelper.yml

test when PR is opened to develop

* Update TestHelper.yml

fetch submodule recursively

* Update TestHelper.yml

add email sender from user

* Update TestHelper.yml

dump github context

* Update TestHelper.yml

Add PR comment instead of writing emails

* Update TestHelper.yml

    permissions:
      pull-requests: write

* Update TestHelper.yml

* Update TestHelper.yml

Update comment instead of creating a new one and format message in code block

* compare to cached results folders

* Update TestHelper.yml

retrive cache for comparison

* Create TestMainHelper.yml

generate results cache for comparison

* Add arch choice to Ubuntu

---------

Co-authored-by: Mary Bennett <[email protected]>
RuaridhMacd added a commit that referenced this pull request Jan 18, 2024
* Create expression_manipulation

* Fix expression_manipulation file title

* Create expression_manipulation

* Fix expression_manipulation file title

* Correct zone values in h2_pipeline_flow.csv file (#184)

Co-authored-by: Mary Bennett <[email protected]>

* Auto test (#173)

* configure highs solver

* change solver option to highs

* check results using compare_results

* test script

* Update Test-OneZone.yml

checkout submodules.

* Update and rename Test-OneZone.yml to TestHelper.yml

1. Add threezones, liquid and northsea case test
2. Add keywords ['#skip', 'CompatHelper'] to allow test bypassing to save unnecessary github action

* Update TestHelper.yml

Pair condition judgment. #skip.

* add test package

* drop output file

* compare results

* Update TestHelper.yml

test PR

* Update TestHelper.yml

notify author about the comparison results

* Update TestHelper.yml

test when PR is opened to develop

* Update TestHelper.yml

fetch submodule recursively

* Update TestHelper.yml

add email sender from user

* Update TestHelper.yml

dump github context

* Update TestHelper.yml

Add PR comment instead of writing emails

* Update TestHelper.yml

    permissions:
      pull-requests: write

* Update TestHelper.yml

* Update TestHelper.yml

Update comment instead of creating a new one and format message in code block

* compare to cached results folders

* Update TestHelper.yml

retrive cache for comparison

* Create TestMainHelper.yml

generate results cache for comparison

* Add arch choice to Ubuntu

---------

Co-authored-by: Mary Bennett <[email protected]>

* Develop tmr (#172)

* Time matching requirments 3 (#171)

* Modified code to model hourly matching requirement

Modified scripts to model hourly matching requirements

* Fix parameter error in FRCC example

- Up_time and Down_time for therm=1 generator was set to 0 in the FRCC_2021_houryl_1GW_base example case study. This led to an error in generating constraints for thermal_commit.jl
- Added  MaxCapReq = 0  as the default value in configure_settings.jl

* Updated example to include MaxCapTag column

Added MaxCapTag column to allow specifying those generators eligible for maximum capacity constraint

* Modified input data for FRCC cases

* Time matching requirement for electricity based H2 production

Added a policy constraint on the HSC side to model time-matching requirements for H2 production.

User input data:
- Generators_data.csv:  Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) and set qualifying power resources to 1 and rest of the power resources to zero
- HSC_generation.csv: Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) to determine the H2 production resources for which the time matching requirement needs to be enforced.

Features:
- Time matching requirement for electricity based H2 production
- Ability of resources used to meet time matching requirement to also contribute to energy share requirement on the power system side.

* Update generate_model.jl to match main

* Revert "Update generate_model.jl to match main"

This reverts commit ac249b9.

* Update branch with example input files

* Add option to disallow excess sales from TMR resources to participate in ESR constraint

Add a setup option that user can set to 0 or 1 to disallow or allow excess electricity sales from resources contracted for time-matching requirements for H2 production to be counted towards power sector energy share requirements.

---------

Co-authored-by: dharik13 <[email protected]>

* restoring submodule from main

* minor modifications

* made change to account for no CO2 Cap case. Passing in multistage setup variable expected by GenX

* Added new ESR to TMR mapping functionality

TMRs are now not added to all ESR, but only to relavent ESRs

* Added if statement in case excess sales do not go to ESR, reordered generate model

* CO2 cap exception handling

1. Changed generate_model.jl to skip CO2_cap if setup flag for CO2Cap =0
2. Change co2_cap_power_hsc.jl  to skip CO2_cap.jl and co2_cap_hsc.jl if setup flag for CO2Cap  and H2CO2Cap are both zero.

* update configure highs

* removing old version of configure_highs.jl

* check out configure_highs.jl from main

* added missing h2_pipeline expression back

* reverting order of generate_model.jl

* added ESR expression to generate model

* fixed bugs with tmr

* modified settings. Updated tmr to account for case when there is no TMRs in ESRs.

* updated documentation, added example system

* Update write_h2_tmr_prices.jl

* updated documentation

* Edited documentation and removed redundant example

- Removed extra example
- Edited documentation for time_matching_requirement.jl and other files where I found some errors

* Uncommented instantiate package line in make.jl

* Added GenX data documentation changes

copied data_documentation from src/GenX/docs to DOLPHYN/src/docs. did not modify the make.jl to point this file, since this is already resolved in develop.

* Docstring Changes for Correct Output

* Update write_h2_elec_costs.jl

We were attempting to multiply arrays of size: ZxT .* ZxT .* T
Fixed by transposing the final array

---------

Co-authored-by: dharik13 <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Ruaridh Macdonald <[email protected]>

* Create expression_manipulation

* Fix expression_manipulation file title

* Create expression_manipulation

* Fix expression_manipulation file title

* Correct zone values in h2_pipeline_flow.csv file (#184)

Co-authored-by: Mary Bennett <[email protected]>

* Auto test (#173)

* configure highs solver

* change solver option to highs

* check results using compare_results

* test script

* Update Test-OneZone.yml

checkout submodules.

* Update and rename Test-OneZone.yml to TestHelper.yml

1. Add threezones, liquid and northsea case test
2. Add keywords ['#skip', 'CompatHelper'] to allow test bypassing to save unnecessary github action

* Update TestHelper.yml

Pair condition judgment. #skip.

* add test package

* drop output file

* compare results

* Update TestHelper.yml

test PR

* Update TestHelper.yml

notify author about the comparison results

* Update TestHelper.yml

test when PR is opened to develop

* Update TestHelper.yml

fetch submodule recursively

* Update TestHelper.yml

add email sender from user

* Update TestHelper.yml

dump github context

* Update TestHelper.yml

Add PR comment instead of writing emails

* Update TestHelper.yml

    permissions:
      pull-requests: write

* Update TestHelper.yml

* Update TestHelper.yml

Update comment instead of creating a new one and format message in code block

* compare to cached results folders

* Update TestHelper.yml

retrive cache for comparison

* Create TestMainHelper.yml

generate results cache for comparison

* Add arch choice to Ubuntu

---------

Co-authored-by: Mary Bennett <[email protected]>

* Develop tmr (#172)

* Time matching requirments 3 (#171)

* Modified code to model hourly matching requirement

Modified scripts to model hourly matching requirements

* Fix parameter error in FRCC example

- Up_time and Down_time for therm=1 generator was set to 0 in the FRCC_2021_houryl_1GW_base example case study. This led to an error in generating constraints for thermal_commit.jl
- Added  MaxCapReq = 0  as the default value in configure_settings.jl

* Updated example to include MaxCapTag column

Added MaxCapTag column to allow specifying those generators eligible for maximum capacity constraint

* Modified input data for FRCC cases

* Time matching requirement for electricity based H2 production

Added a policy constraint on the HSC side to model time-matching requirements for H2 production.

User input data:
- Generators_data.csv:  Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) and set qualifying power resources to 1 and rest of the power resources to zero
- HSC_generation.csv: Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) to determine the H2 production resources for which the time matching requirement needs to be enforced.

Features:
- Time matching requirement for electricity based H2 production
- Ability of resources used to meet time matching requirement to also contribute to energy share requirement on the power system side.

* Update generate_model.jl to match main

* Revert "Update generate_model.jl to match main"

This reverts commit ac249b9.

* Update branch with example input files

* Add option to disallow excess sales from TMR resources to participate in ESR constraint

Add a setup option that user can set to 0 or 1 to disallow or allow excess electricity sales from resources contracted for time-matching requirements for H2 production to be counted towards power sector energy share requirements.

---------

Co-authored-by: dharik13 <[email protected]>

* restoring submodule from main

* minor modifications

* made change to account for no CO2 Cap case. Passing in multistage setup variable expected by GenX

* Added new ESR to TMR mapping functionality

TMRs are now not added to all ESR, but only to relavent ESRs

* Added if statement in case excess sales do not go to ESR, reordered generate model

* CO2 cap exception handling

1. Changed generate_model.jl to skip CO2_cap if setup flag for CO2Cap =0
2. Change co2_cap_power_hsc.jl  to skip CO2_cap.jl and co2_cap_hsc.jl if setup flag for CO2Cap  and H2CO2Cap are both zero.

* update configure highs

* removing old version of configure_highs.jl

* check out configure_highs.jl from main

* added missing h2_pipeline expression back

* reverting order of generate_model.jl

* added ESR expression to generate model

* fixed bugs with tmr

* modified settings. Updated tmr to account for case when there is no TMRs in ESRs.

* updated documentation, added example system

* Update write_h2_tmr_prices.jl

* updated documentation

* Edited documentation and removed redundant example

- Removed extra example
- Edited documentation for time_matching_requirement.jl and other files where I found some errors

* Uncommented instantiate package line in make.jl

* Added GenX data documentation changes

copied data_documentation from src/GenX/docs to DOLPHYN/src/docs. did not modify the make.jl to point this file, since this is already resolved in develop.

* Docstring Changes for Correct Output

* Update write_h2_elec_costs.jl

We were attempting to multiply arrays of size: ZxT .* ZxT .* T
Fixed by transposing the final array

---------

Co-authored-by: dharik13 <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Ruaridh Macdonald <[email protected]>

* Housecleaning after rebasing from v0.2.2 main branch

* refactor dolphyn for less memory and better performance (#175)

* refactor dolphyn for less memory and better performance

* Revert "compare results"

This reverts commit b473e63.

* Revert "add test package"

This reverts commit 32cebae.

* Revert "change solver from gurobi to highs"

This reverts commit 54b0777.

* Simplifying HSC output writing

- Moved remaining indexes inside value() functions
- Moved if-statements outside loops if they didn't need to be called
- Started using insertcols!() to replace some for-loops on z=1:Z and t=1:T

Testing so far using @benchmark shows 10-30% reduction in memory usage and 5-10% reduction in total model runtime for the SmallNewEngland and NorthSea2030.

* Fix bug in write_h2_storage

Previously got error if either set of indices was empty

* Revert "Revert "compare results""

This reverts commit 31e5db5.

* Revert "Revert "add test package""

This reverts commit 059fe70.

* Revert "Revert "change solver from gurobi to highs""

This reverts commit d2763f8.

---------

Co-authored-by: RuaridhMacd <[email protected]>

* Outputs w std fmt (#182)

* Standard Format for Output Files
Add new files for rebasing

* Update GenX exclusions to avoid conflicts

---------

Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: RuaridhMacd <[email protected]>

* Liquid fuels merge (#178)

* Big intital push

* minor changes

* changed CO2 constraint structure modified generate model and run file

* added comment

* creating ccs rate read in function, adjusting co2 cap file

* Added bar homogenus, removed check for CO2, added min no_commit gen, added startup costs by resource exp

* Added green_h2_share_req, fixed emissions_hsc, reads in blue and green h2, fixed issues w ccs

* fixed issues with ccs

* Big intital push

* minor changes

* changed CO2 constraint structure modified generate model and run file

* added comment

* creating ccs rate read in function, adjusting co2 cap file

* Added bar homogenus, removed check for CO2, added min no_commit gen, added startup costs by resource exp

* Added green_h2_share_req, fixed emissions_hsc, reads in blue and green h2, fixed issues w ccs

* fixed issues with ccs

* emissions cap handling for power + csc without h2

* Debugging

-Modified example
- Updated project toml to include gurobi
- Removed duplication in config settings
- modified configure_gurobi
- modified runtools to include csc
- added choose csc output dir
- modified write_csc_ouputs to match HSC structure
- Fixed bugs in generate_model
- fixed bugs in emissions.jl

* fixed emissions constraint bug

* modified case. Modified write outputs

* Fix new bug in thermal_commit

The behaviour of the sum() function was changed in a new version of JuMP. This has been patched in GenX so I've copied the change here till we decide to update all of GenX.

I also corrected the load file of the CSC/ThreeZones example

* CSC Documentations

Fully completed documentations for CSC incode and doc. Did testing on CSC and updated H2 share policy.

* Fix a bug when CSC is turned off

* Fix to documentations

* Update make.jl

* Fix local liveserver does not update changes error

* Add updated Project.toml

* Fix bugs to CSC documentations

* 203 liquid fuels hsc output writing files merge and optimization (#204)

* Merge HSC output files from Liquid_Fuels to Liquid_Fuels_Merge

* Add codes to reduce redundancy for optimization

* Fixed bugs in write_h2_balance and write_h2_capacity

* Bug fixes for h2

The code has mistakes that prevents it from running. I have made the necessary fixes to review and update the code as necessary. Some of the optimizations implemented that have resulted in errors. More specifically, I have reverted the following files to their older versions (write_g2p_capcity.jl, write_h2_balance_dual.jl, write_p_g2p.jl, write_h2_g2p.jl). As a result, I recommend that once I merge the PR (and merge to develop), you can create a separate PR for optimizing the write outputs files.

---------

Co-authored-by: shaker <[email protected]>

* bug fix in h2_balance, removed repeated lines in generate_model

* flag bug fix

* Added error handling for no csc case settings loading

* fixed typo

* typo fix

* updated example to include ccs_rate

* updated single model, removed incorrect const

* updated default settings

* updated settings

* typo

* updated 3 zone inputs

* updated north sea example

* updates liquid fuel example

---------

Co-authored-by: Ruaridh Macdonald <[email protected]>
Co-authored-by: Junwenlaw <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>

* Syn fuels merge new (#208)

* intial push

* push to debug liquid fuels

- Updated run file
- updated liquid fuel settigns file
- updated default settings
- Updated Generate Model
- Fixed typos in HSC output files
- changed naming conventions in liquid fuel demand
- added choose lf output dir
- updated emissions file

* updated run file and settings

* ovewrote capacity reserve margin to account for h2

* added logfile defaults, added example systems, fixed typo in liquid_fuel_demand_module

* Updated Examples

* default parameter scale to 0 when liquid fuels is on

* Testing and documentations done

* Set parent directory of docs in development mode

* Add minor corrections to the documentation files

* fixed bug in liquid fuel demand, modified configure settings, modified examples.

---------

Co-authored-by: Junwenlaw <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>

* Fix solver configuration process,  add example using Gurobi, swap all to HiGHS

Previously we were silently loading Gurobi, CPLEX, etc if they were installed but not loaded. This meant we didn't have to ask the user to change the solver manually, but led to unusual behaviour (like it never working the first time it's run but then being fine afterwards) and is probably bad practice.

No the user has to define the solver when they create the runfile. It means the "solver" setting is a bit redundant and perhaps misleading. We should decide if we want to keep it or try a different approach.

* Remove code for LiveServer

This crashes doc creation and deployment on GitHub Actions

* Clean-up unused files

* Update Project.toml

* Clean up examples and add summary files to .gitignore

---------

Co-authored-by: Ruaridh Macdonald <[email protected]>
Co-authored-by: bennettm <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Yuheng Zhang <[email protected]>
Co-authored-by: dharik13 <[email protected]>
Co-authored-by: bennettm <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Junwenlaw <[email protected]>
RuaridhMacd added a commit that referenced this pull request Feb 2, 2024
* merge csc and lfsc modules into main (#209)

* Create expression_manipulation

* Fix expression_manipulation file title

* Create expression_manipulation

* Fix expression_manipulation file title

* Correct zone values in h2_pipeline_flow.csv file (#184)

Co-authored-by: Mary Bennett <[email protected]>

* Auto test (#173)

* configure highs solver

* change solver option to highs

* check results using compare_results

* test script

* Update Test-OneZone.yml

checkout submodules.

* Update and rename Test-OneZone.yml to TestHelper.yml

1. Add threezones, liquid and northsea case test
2. Add keywords ['#skip', 'CompatHelper'] to allow test bypassing to save unnecessary github action

* Update TestHelper.yml

Pair condition judgment. #skip.

* add test package

* drop output file

* compare results

* Update TestHelper.yml

test PR

* Update TestHelper.yml

notify author about the comparison results

* Update TestHelper.yml

test when PR is opened to develop

* Update TestHelper.yml

fetch submodule recursively

* Update TestHelper.yml

add email sender from user

* Update TestHelper.yml

dump github context

* Update TestHelper.yml

Add PR comment instead of writing emails

* Update TestHelper.yml

    permissions:
      pull-requests: write

* Update TestHelper.yml

* Update TestHelper.yml

Update comment instead of creating a new one and format message in code block

* compare to cached results folders

* Update TestHelper.yml

retrive cache for comparison

* Create TestMainHelper.yml

generate results cache for comparison

* Add arch choice to Ubuntu

---------

Co-authored-by: Mary Bennett <[email protected]>

* Develop tmr (#172)

* Time matching requirments 3 (#171)

* Modified code to model hourly matching requirement

Modified scripts to model hourly matching requirements

* Fix parameter error in FRCC example

- Up_time and Down_time for therm=1 generator was set to 0 in the FRCC_2021_houryl_1GW_base example case study. This led to an error in generating constraints for thermal_commit.jl
- Added  MaxCapReq = 0  as the default value in configure_settings.jl

* Updated example to include MaxCapTag column

Added MaxCapTag column to allow specifying those generators eligible for maximum capacity constraint

* Modified input data for FRCC cases

* Time matching requirement for electricity based H2 production

Added a policy constraint on the HSC side to model time-matching requirements for H2 production.

User input data:
- Generators_data.csv:  Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) and set qualifying power resources to 1 and rest of the power resources to zero
- HSC_generation.csv: Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) to determine the H2 production resources for which the time matching requirement needs to be enforced.

Features:
- Time matching requirement for electricity based H2 production
- Ability of resources used to meet time matching requirement to also contribute to energy share requirement on the power system side.

* Update generate_model.jl to match main

* Revert "Update generate_model.jl to match main"

This reverts commit ac249b9.

* Update branch with example input files

* Add option to disallow excess sales from TMR resources to participate in ESR constraint

Add a setup option that user can set to 0 or 1 to disallow or allow excess electricity sales from resources contracted for time-matching requirements for H2 production to be counted towards power sector energy share requirements.

---------

Co-authored-by: dharik13 <[email protected]>

* restoring submodule from main

* minor modifications

* made change to account for no CO2 Cap case. Passing in multistage setup variable expected by GenX

* Added new ESR to TMR mapping functionality

TMRs are now not added to all ESR, but only to relavent ESRs

* Added if statement in case excess sales do not go to ESR, reordered generate model

* CO2 cap exception handling

1. Changed generate_model.jl to skip CO2_cap if setup flag for CO2Cap =0
2. Change co2_cap_power_hsc.jl  to skip CO2_cap.jl and co2_cap_hsc.jl if setup flag for CO2Cap  and H2CO2Cap are both zero.

* update configure highs

* removing old version of configure_highs.jl

* check out configure_highs.jl from main

* added missing h2_pipeline expression back

* reverting order of generate_model.jl

* added ESR expression to generate model

* fixed bugs with tmr

* modified settings. Updated tmr to account for case when there is no TMRs in ESRs.

* updated documentation, added example system

* Update write_h2_tmr_prices.jl

* updated documentation

* Edited documentation and removed redundant example

- Removed extra example
- Edited documentation for time_matching_requirement.jl and other files where I found some errors

* Uncommented instantiate package line in make.jl

* Added GenX data documentation changes

copied data_documentation from src/GenX/docs to DOLPHYN/src/docs. did not modify the make.jl to point this file, since this is already resolved in develop.

* Docstring Changes for Correct Output

* Update write_h2_elec_costs.jl

We were attempting to multiply arrays of size: ZxT .* ZxT .* T
Fixed by transposing the final array

---------

Co-authored-by: dharik13 <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Ruaridh Macdonald <[email protected]>

* Create expression_manipulation

* Fix expression_manipulation file title

* Create expression_manipulation

* Fix expression_manipulation file title

* Correct zone values in h2_pipeline_flow.csv file (#184)

Co-authored-by: Mary Bennett <[email protected]>

* Auto test (#173)

* configure highs solver

* change solver option to highs

* check results using compare_results

* test script

* Update Test-OneZone.yml

checkout submodules.

* Update and rename Test-OneZone.yml to TestHelper.yml

1. Add threezones, liquid and northsea case test
2. Add keywords ['#skip', 'CompatHelper'] to allow test bypassing to save unnecessary github action

* Update TestHelper.yml

Pair condition judgment. #skip.

* add test package

* drop output file

* compare results

* Update TestHelper.yml

test PR

* Update TestHelper.yml

notify author about the comparison results

* Update TestHelper.yml

test when PR is opened to develop

* Update TestHelper.yml

fetch submodule recursively

* Update TestHelper.yml

add email sender from user

* Update TestHelper.yml

dump github context

* Update TestHelper.yml

Add PR comment instead of writing emails

* Update TestHelper.yml

    permissions:
      pull-requests: write

* Update TestHelper.yml

* Update TestHelper.yml

Update comment instead of creating a new one and format message in code block

* compare to cached results folders

* Update TestHelper.yml

retrive cache for comparison

* Create TestMainHelper.yml

generate results cache for comparison

* Add arch choice to Ubuntu

---------

Co-authored-by: Mary Bennett <[email protected]>

* Develop tmr (#172)

* Time matching requirments 3 (#171)

* Modified code to model hourly matching requirement

Modified scripts to model hourly matching requirements

* Fix parameter error in FRCC example

- Up_time and Down_time for therm=1 generator was set to 0 in the FRCC_2021_houryl_1GW_base example case study. This led to an error in generating constraints for thermal_commit.jl
- Added  MaxCapReq = 0  as the default value in configure_settings.jl

* Updated example to include MaxCapTag column

Added MaxCapTag column to allow specifying those generators eligible for maximum capacity constraint

* Modified input data for FRCC cases

* Time matching requirement for electricity based H2 production

Added a policy constraint on the HSC side to model time-matching requirements for H2 production.

User input data:
- Generators_data.csv:  Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) and set qualifying power resources to 1 and rest of the power resources to zero
- HSC_generation.csv: Define a column H2_TMR_XXX (e.g. H2_TMR_1, H2_TMR_2 ) to determine the H2 production resources for which the time matching requirement needs to be enforced.

Features:
- Time matching requirement for electricity based H2 production
- Ability of resources used to meet time matching requirement to also contribute to energy share requirement on the power system side.

* Update generate_model.jl to match main

* Revert "Update generate_model.jl to match main"

This reverts commit ac249b9.

* Update branch with example input files

* Add option to disallow excess sales from TMR resources to participate in ESR constraint

Add a setup option that user can set to 0 or 1 to disallow or allow excess electricity sales from resources contracted for time-matching requirements for H2 production to be counted towards power sector energy share requirements.

---------

Co-authored-by: dharik13 <[email protected]>

* restoring submodule from main

* minor modifications

* made change to account for no CO2 Cap case. Passing in multistage setup variable expected by GenX

* Added new ESR to TMR mapping functionality

TMRs are now not added to all ESR, but only to relavent ESRs

* Added if statement in case excess sales do not go to ESR, reordered generate model

* CO2 cap exception handling

1. Changed generate_model.jl to skip CO2_cap if setup flag for CO2Cap =0
2. Change co2_cap_power_hsc.jl  to skip CO2_cap.jl and co2_cap_hsc.jl if setup flag for CO2Cap  and H2CO2Cap are both zero.

* update configure highs

* removing old version of configure_highs.jl

* check out configure_highs.jl from main

* added missing h2_pipeline expression back

* reverting order of generate_model.jl

* added ESR expression to generate model

* fixed bugs with tmr

* modified settings. Updated tmr to account for case when there is no TMRs in ESRs.

* updated documentation, added example system

* Update write_h2_tmr_prices.jl

* updated documentation

* Edited documentation and removed redundant example

- Removed extra example
- Edited documentation for time_matching_requirement.jl and other files where I found some errors

* Uncommented instantiate package line in make.jl

* Added GenX data documentation changes

copied data_documentation from src/GenX/docs to DOLPHYN/src/docs. did not modify the make.jl to point this file, since this is already resolved in develop.

* Docstring Changes for Correct Output

* Update write_h2_elec_costs.jl

We were attempting to multiply arrays of size: ZxT .* ZxT .* T
Fixed by transposing the final array

---------

Co-authored-by: dharik13 <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Ruaridh Macdonald <[email protected]>

* Housecleaning after rebasing from v0.2.2 main branch

* refactor dolphyn for less memory and better performance (#175)

* refactor dolphyn for less memory and better performance

* Revert "compare results"

This reverts commit b473e63.

* Revert "add test package"

This reverts commit 32cebae.

* Revert "change solver from gurobi to highs"

This reverts commit 54b0777.

* Simplifying HSC output writing

- Moved remaining indexes inside value() functions
- Moved if-statements outside loops if they didn't need to be called
- Started using insertcols!() to replace some for-loops on z=1:Z and t=1:T

Testing so far using @benchmark shows 10-30% reduction in memory usage and 5-10% reduction in total model runtime for the SmallNewEngland and NorthSea2030.

* Fix bug in write_h2_storage

Previously got error if either set of indices was empty

* Revert "Revert "compare results""

This reverts commit 31e5db5.

* Revert "Revert "add test package""

This reverts commit 059fe70.

* Revert "Revert "change solver from gurobi to highs""

This reverts commit d2763f8.

---------

Co-authored-by: RuaridhMacd <[email protected]>

* Outputs w std fmt (#182)

* Standard Format for Output Files
Add new files for rebasing

* Update GenX exclusions to avoid conflicts

---------

Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: RuaridhMacd <[email protected]>

* Liquid fuels merge (#178)

* Big intital push

* minor changes

* changed CO2 constraint structure modified generate model and run file

* added comment

* creating ccs rate read in function, adjusting co2 cap file

* Added bar homogenus, removed check for CO2, added min no_commit gen, added startup costs by resource exp

* Added green_h2_share_req, fixed emissions_hsc, reads in blue and green h2, fixed issues w ccs

* fixed issues with ccs

* Big intital push

* minor changes

* changed CO2 constraint structure modified generate model and run file

* added comment

* creating ccs rate read in function, adjusting co2 cap file

* Added bar homogenus, removed check for CO2, added min no_commit gen, added startup costs by resource exp

* Added green_h2_share_req, fixed emissions_hsc, reads in blue and green h2, fixed issues w ccs

* fixed issues with ccs

* emissions cap handling for power + csc without h2

* Debugging

-Modified example
- Updated project toml to include gurobi
- Removed duplication in config settings
- modified configure_gurobi
- modified runtools to include csc
- added choose csc output dir
- modified write_csc_ouputs to match HSC structure
- Fixed bugs in generate_model
- fixed bugs in emissions.jl

* fixed emissions constraint bug

* modified case. Modified write outputs

* Fix new bug in thermal_commit

The behaviour of the sum() function was changed in a new version of JuMP. This has been patched in GenX so I've copied the change here till we decide to update all of GenX.

I also corrected the load file of the CSC/ThreeZones example

* CSC Documentations

Fully completed documentations for CSC incode and doc. Did testing on CSC and updated H2 share policy.

* Fix a bug when CSC is turned off

* Fix to documentations

* Update make.jl

* Fix local liveserver does not update changes error

* Add updated Project.toml

* Fix bugs to CSC documentations

* 203 liquid fuels hsc output writing files merge and optimization (#204)

* Merge HSC output files from Liquid_Fuels to Liquid_Fuels_Merge

* Add codes to reduce redundancy for optimization

* Fixed bugs in write_h2_balance and write_h2_capacity

* Bug fixes for h2

The code has mistakes that prevents it from running. I have made the necessary fixes to review and update the code as necessary. Some of the optimizations implemented that have resulted in errors. More specifically, I have reverted the following files to their older versions (write_g2p_capcity.jl, write_h2_balance_dual.jl, write_p_g2p.jl, write_h2_g2p.jl). As a result, I recommend that once I merge the PR (and merge to develop), you can create a separate PR for optimizing the write outputs files.

---------

Co-authored-by: shaker <[email protected]>

* bug fix in h2_balance, removed repeated lines in generate_model

* flag bug fix

* Added error handling for no csc case settings loading

* fixed typo

* typo fix

* updated example to include ccs_rate

* updated single model, removed incorrect const

* updated default settings

* updated settings

* typo

* updated 3 zone inputs

* updated north sea example

* updates liquid fuel example

---------

Co-authored-by: Ruaridh Macdonald <[email protected]>
Co-authored-by: Junwenlaw <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>

* Syn fuels merge new (#208)

* intial push

* push to debug liquid fuels

- Updated run file
- updated liquid fuel settigns file
- updated default settings
- Updated Generate Model
- Fixed typos in HSC output files
- changed naming conventions in liquid fuel demand
- added choose lf output dir
- updated emissions file

* updated run file and settings

* ovewrote capacity reserve margin to account for h2

* added logfile defaults, added example systems, fixed typo in liquid_fuel_demand_module

* Updated Examples

* default parameter scale to 0 when liquid fuels is on

* Testing and documentations done

* Set parent directory of docs in development mode

* Add minor corrections to the documentation files

* fixed bug in liquid fuel demand, modified configure settings, modified examples.

---------

Co-authored-by: Junwenlaw <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>

* Fix solver configuration process,  add example using Gurobi, swap all to HiGHS

Previously we were silently loading Gurobi, CPLEX, etc if they were installed but not loaded. This meant we didn't have to ask the user to change the solver manually, but led to unusual behaviour (like it never working the first time it's run but then being fine afterwards) and is probably bad practice.

No the user has to define the solver when they create the runfile. It means the "solver" setting is a bit redundant and perhaps misleading. We should decide if we want to keep it or try a different approach.

* Remove code for LiveServer

This crashes doc creation and deployment on GitHub Actions

* Clean-up unused files

* Update Project.toml

* Clean up examples and add summary files to .gitignore

---------

Co-authored-by: Ruaridh Macdonald <[email protected]>
Co-authored-by: bennettm <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Yuheng Zhang <[email protected]>
Co-authored-by: dharik13 <[email protected]>
Co-authored-by: bennettm <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Junwenlaw <[email protected]>

* Update Project.toml to version 0.2.3

---------

Co-authored-by: shakesy94 <[email protected]>
Co-authored-by: bennettm <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Yuheng Zhang <[email protected]>
Co-authored-by: dharik13 <[email protected]>
Co-authored-by: bennettm <[email protected]>
Co-authored-by: Mary Bennett <[email protected]>
Co-authored-by: Junwenlaw <[email protected]>
@RuaridhMacd RuaridhMacd deleted the AutoTest branch February 2, 2024 16:18
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants