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

Electrolyzer degradation impacts - added features and fixes #219

Merged
merged 23 commits into from
Oct 20, 2023

Conversation

elenya-grant
Copy link
Collaborator

@elenya-grant elenya-grant commented Sep 1, 2023

PEM_H2_LT_electrolyzer_Clusters.py:

  • Added: correct reduction in hydrogen due to degradation in off-grid cases
  • Added: lifetime performance specs (capacity factor, efficiency, etc)
  • Fixed: fatigue degradation bug if voltage is zero for a whole week
    Future Development Plans:
  • To-do: (may be fixed soon) update lifetime performance specs for grid-connected case
  • To-do: update lifetime performance specs to be per year, rather than a life average
  • To-do: (non-urgent) finish removing unused functions
  • To-do: (non-urgent) change inputs to .yaml file and remove some hard-coded values (turn-down ratio, start-up delay, water usage, BOP energy usage, etc)

*Note that some of the functions in this file are unused or leftover.
Placeholder functions: create_system_for_target_eff(), new_calc_stack_replacement_info(), call_degradation_calculations(), check_aliveness(), make_stack_replacement_schedule(), self.estimate_life()

run_h2_PEM.py:

  • Changed: run_h2_PEM() function to be compatible with new outputs from PEM_H2_LT_electrolyzer_Clusters.py
  • Changed: H2_Results outputs to be reflective of lifetime performance rather than simulation performance
  • Note: I embedded a dictionary in H2_Results called "new_H2_Results" which would be beneficial to switch to eventually
  • Added: clean_up_final_outputs() function so that h2_ts and h2_tot (which are generally very large data frames) are reduced to some key output metrics
  • removed unused imports, moved imports to functions that use them (I can undo this)

Note: unsure what the timeline is on integrating the electrolyzer model from the electrolyzer repository, but it'd be great to understand what inputs, outputs, tools, and capabilities are needed and used from the electrolyzer models in hopp and the electrolyzer repo (so that we can move towards a singular electrolyzer model)

@kbrunik kbrunik requested a review from camirmas September 5, 2023 19:26
@camirmas
Copy link
Collaborator

camirmas commented Sep 6, 2023

If we intend to replace this with electrolyzer, then I'm fine merging this without documentation/testing. But like you said, we'll want to make sure we know what features and tools are needed to make that happen, and have a plan for removing this code

Copy link
Collaborator

@camirmas camirmas left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is my first time looking through the electrolyzer code in HOPP. I'm noticing that there are lot of shared implementation details with NREL/electrolyzer, but that these implementations have a lot of duplicated code and hardcoded values. I'd like to make a push toward bringing NREL/electrolyzer in as soon as possible, and basing new development around that so that we don't diverge further. I have bandwidth to help with this, but need some help navigating the current state of things.

Let's meet up and talk about some followup stuff:

  • add type annotations to classes/functions
  • update docstrings (Google format)
  • identify divergences between NREL/electrolyzer and this model
  • NREL/electrolyzer integration steps

@@ -1,5 +1,8 @@
## Low-Temperature PEM Electrolyzer Model
"""
Author: Elenya Grant
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We don't really need these lines since all your changes will have your name and a timestamp in git anyway

@@ -19,14 +22,13 @@
efficiency):
Energy: 1 kg H2 --> 16 kWh
"""
# Updated as of 10/31/2022
# Updated as of 08/31/2023
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same here

# n_life_offcycles*(np.sum(V_steady_deg_per_ontime_cycle + (V_fatigue_deg_pr_ontime_cycle/len(power_pdf)) + (self.onoff_deg_rate/len(power_pdf))))
#
V_deg_eol = steady_deg[-1]+cycle_deg[-1]+fatigue_deg[-1]
[]
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove

# h2_errors=[error_h2_from_Imax,error_h2_from_check,error_h2_from_IV]
# I_max_vals=[I_max,I_max_check,I_from_IV]
# idx_min_error=np.argmin(h2_errors)
# I_max=I_max_vals[idx_min_error]



Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On L526 you're passing two args to make_stack_replacement_schedule, but it only takes one

@@ -19,14 +22,13 @@
efficiency):
Energy: 1 kg H2 --> 16 kWh
"""
# Updated as of 10/31/2022
# Updated as of 08/31/2023
import math
import numpy as np
import sys
import pandas as pd
from matplotlib import pyplot as plt
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove unused imports: math, matplotlib




[]
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove

new_H2_Results = dict(zip(attribute_specs,attributes))
new_H2_Results.update(dict(zip(sim_specs,sim_performance)))
new_H2_Results.update(dict(zip(life_desc,life_vals)))
annual_avg_performance
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove

import math
import numpy as np
import sys
import pandas as pd
from matplotlib import pyplot as plt
import scipy
from scipy.optimize import fsolve
import rainflow
from scipy import interpolate

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

L47: Python classes should be CamelCase




[]
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove

df = pd.concat([old_life_est.loc[desc],pd.Series(dict(zip(t_eod_desc,t_eod_opt)))])
return df
# return pd.Series(life_data_df)
def estimate_life(self,power_per_stack,V_cell,V_deg,stack_life,time_until_replacement):
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we're going to eventually fix this with autoformatting, but there should always be at least one newline between method definitions

@camirmas
Copy link
Collaborator

I also just noticed that there are some duplicated files in the Electrolyzer_Models dir, can we remove them or do they contain anything that isn't in the electrolysis dir?

@bayc bayc added this to the v1.0 milestone Sep 28, 2023
@bayc bayc added the refactor Associated with the refactor of HOPP label Sep 28, 2023
@bayc bayc self-requested a review October 12, 2023 20:59
@camirmas
Copy link
Collaborator

Merging so we can get our examples finished. Can follow up if more changes are needed.

@camirmas camirmas merged commit f123f41 into NREL:dev/refactor Oct 20, 2023
1 check passed
camirmas added a commit that referenced this pull request Oct 25, 2023
* moved wind plant power generation out of the loop, added solar and storage to profast

* profast for h2 updated for general use

* fully integrated new electrolyzer model and added stack replacement schedule to profast

* run_profast_for_hydrogen modified to use either user-set electrolyzer efficiency or rated electrolyzer model efficiency

* added user-defined electrolyzer parameters to electrolyzer model, hopp_tools_steel has workaround for WY site not added to grid prices and cambium data files

* removed workaround for Wyoming site not added to grid price csv

* Updated a few things in profast for hydrogen interface to make sure grid cases work properly

* moving files into new directory structure and updating __init__.py files

* updating tests to accommodate the new directory structure

* updating h2_analysis script to accommodate new directory structure

* reorganize simple h2 cost model file

* remove degradation boolean as default to function calls

* "fixed up nice path"

* Updated wind farm with new design process (13 percent EOL Degradation and using local wind data for design)

* added user-defined end of life efficiency for electrolyzer, fixed storage cost bug

* added the distributed pressure vessel stuff.

* remove monopile pv storage

* remove monopile test.

* uptime degradation value can be adjusted to reference values

* fixed small typo in uptime recalc call

* Small fix to run_profast_for_hydrogen.py

* Add method for optimizing power

* cleaned up the calls, added new tests per comments on #120

* Corrected typo in output file writing and fixed lcoh breakdown so that it is still correct with stack replacements

* Added solar and battery storage parametric sizing sweep as separate function

* added updates run PEM file

* have optimized PEM controller locally integrated

* fixed optimization script import

* removed unused files, import calls to removed files, and minor bug fix in optimized controller

* working on eco update.

* black reformatting

* Divide optimization into chunks

* Divide a year into chunk

* make pv and battery optional plant compoenents in eco example

* allow user to specify desired mean windspeed

* include onshore substation

* provide mean windspeed at lat lon to ORBIT if user does not speficy

* re-include onshore substation capex

* added changes to make pressure vessel storage at-turbine work.

* eco example should not use hopp_tools

* include test script for h2 cost

* add some plotting code to the pem model for debugging

* electrolyzer/storage nomenclature refactor.

* switch logic on refurbishment costs

* convert to at-turbine storage distinguished by type rather than incorrectly as location.

* continued fixes to get the type/location cleanup done.

* better config setup.

* readding missing files/changes

* updates to CI

* Cleaned up script to function after merge. Still does not report out results for solar-param sweep cases.

* don't allow capacity factor over 1 in cost model, if it is greater than 1 then lower it and raise runtime warning

* fix logic for running with turbine storage capacity as the capacity

* let max in-tower h2 storage determine h2 storage capacity

* set default storage type back to none

* provide access to alternate PEM cost model from Singlitico 2021

* add plotting code to PEM cost model. include minor corrections elsewhere

* include energy from correct sources (grid vs renewable)

* refactoring

* Got solar-storage param sweep cases writing to output files

* partially fixed bug when running parametric sweep with PySAM

* updated local copy of run_PEM_master for optimization code bug fix from previous commit

* Fixed issue causing problems with hybrid-grid cases with both wind and solar

* refactoring, put floris/sam model option in input file, minor cleanup

* Cleaned up a few minor things

* update eco example

* get onshore costs through automatic ORBIT conection. Onshore substation included in export system costs

* Added Wyoming wholesale and retail grid prices

* save precent breakdown of wind farm capex

* var name fix

* Corrected a file to enable WY cases to run; re-defined electrolyzer capacity factor with better definition; added wind plant size estimates as a function of location and grid connectivity scenario for PySAM runs; normalized steel production to 1 M TPY and reported out steel production margin

* added in stack replacement schedule creation, checking if stack has reached end of life during the simulation, and removed bug in fatigue degradation calculation if stack is never turned on

* partially re-organized electrolyzer script to replace current electrolyzer model in the future, hopefully will improve flexibility and readability

* initial skeleton for power electronics model in the future

* modified optimize function of electrolyzer control script to be compatible with HOPP inputs

* reformat plots, generate paths for plots, add onshore substation to plots

* Add new optimization module with cbc solver

* Updated storage costs to make geologic storage costs more accurate at high storage capacities

* Updated electrolyzer costs

* Fix shapes of outputs

* Add test nb

* updating setup.py for new directory structure

* adding ORBIT to requirements

* removing unecessary import

* updating import statements

* updating tests

* updating output typing

* further updating of output types

* Got new off-grid floris cases working and did a substantial overhaul on file naming and output writing

* added grid connected cases to electrolyzer model and removed production delay at start of simulation

* [model] Added ren frac in hybrid cases and ITC for solar & battery

* updated electrolyzer sizing based on wind size and minor fixes for grid-connected electrolysis

* define scenarios adjusted for debuging purposes, no major changes

* implemented a specific grid-connected run function in electrolyzer as temporary workaround

* Added hydrogen production to energy profiles file output

* in debug-format, no major changes

* cleaned up comments

* removed unnecessary personal files

* fixed solar parametric sweep for changes made in hopp_tools_steel.run_H2_PEM_sim and run_profast_for_hydrogen

* define scenarios parameters reset to defaults

* added back in the unused electrolyzer model files (unused electrolyzer code is in hybrid/Electrolyzer_Models, the most recent electrolzyer models are in hybrid/PEM_Model_2Push

* [model] LCA improvements

- typo in run_profast_for_steel.py
- parameters added to definitions in run_profast_for_hydrogen.py and _green_steel_ammonia...py

* [model] changes so that no conflicts with Elenya's merge occur

* First attempt at resolving merge conflicts with Elenya's PR

* Second attempt at resolve conflicts with Elenya's PR

* Third attempt to resolve conflicts with Elenya's PR

* [model] Post-processing LCA script update

* Various updates to improve accuracy of hybrid-grid cases and policy implementations

* Rounded up electrolyzer capacity to nearest 40 MW, and rounded up PySAM wind farm size to nearest multiple of turbine rating

* updating testing requirements for python version

* adding CoolProp to requirements

* adding missing Tankinator file

* adding missing test file for results

* Added grid-connected floris files

* updating pandas method used in test

* limiting CI to python 3.8

* Modified grid-connected floris files to match 516.3MW rating (with 13 percent degradation included)

* Added capex to output files, changed depreciation period, re-ran SMR cases, restructured output file naming, updated stack optimizer to work for Windows machines

* Updated optimization PEM controller so that switching cost is a function of electrolzyer cost and not hard-coded

* Some initial runs

* Some more results

* Distributed scenarios

* adding model input taml template for code sprint

* updating import statements

* updating test_run_hopp_calc.py

* updating pandas append to concat

* Adding input file for dispatch

* Adding dispatch/power_sources input file

* adding fixed_platform.yaml input structure

* updating yaml name

* adding yaml input structures for resource directory

* Updating yaml files to use class names

* Fixed some bugs in ammonia and steel profast scripts and added results database files

* Adding inputs for dispatch power storage

* Adding input file for battery.py

* Adding input file for grid.py

* Adding input file for power_source.py

* Add input file for wind_source.py

* Updated lcoh vs time plot and cleaned up output folder

* Adding input files for hybrid_simulation.py and pv_source.py

* updating hybrid_simulation.yaml

* Adding input file for clustering.py

* Adding input files for layout files

* Adding flicker input files

* Adding input files for reopt and utility_rate

* Adding input file for desal model

* Adding input files for h2 compression

* Adding input files for hydrogen storage modules

* Adding final electrolyzer input files

* update h2 input file

* Updated plotting scripts

* Added electrical losses back into energy_to_electrolyzer for distributed cases

* Base policy and a few sensitivity cases

* Re-ran distributed cases adding back 4.24% of turbine losses

* Updated databases and plotting scripts

* Fixed issue with solar param sweep and updated plotting script to include base policy

* add utilities.py with yaml include capability

* Re-ran wind-PV cases and centralized off-grid wind cases

* Combined new results with relevant old results

* Added hybrid grid wind only cases

* Storage and degradation sensitivity cases

* Updated plotting scripts and results files

* Added profiles and profast outputs for LCA

* Minor changes to LCA script

* Added mid-electrolyzer cost scenario results

* Couple more mid-cost scenario results

* Updated a few plotting scripts and some results

* [model] modified labor cost savings

* Added natural gas price error bars to LCOH barcharts

* updating more import paths

* adding attrs as a requirement

* adding base class structure

* adding base hopp class

* adding a skeleton for hopp_interface

* changing "Examples" directory reference to "examples"

* adding outputs so that the script doesn't break on future runs; will want to update to automatically create results folders if they don't exist

* updating import paths

* updating models from changes in green steel

* building out hopp_interface

* building out hopp.py to use input yaml

* Renaming floris class and moving into directory

* moving example floris input file

* updating CI to run python 3.10; fixing import statement

* adding base classes

* adding logging manager based on floris logging manager

* adding attrs type declaration file

* changing multiprocessing back to multiprocessing_on_dill

* rolling the CI back to pyython 3.8 from 3.10

* Changing typing syntax to be compatible with python 3.8

* Update __init__.py (#194)

I think this line is obsolete

* Test fixes + `green_steel_cleanup` merge (#198)

* Added ORBIT citation and references. Commented each function, citing section/equations used or repurposed from this analysis.

* last comment changes

* reformat plots, generate paths for plots, add onshore substation to plots

* on-turbine pressure vessel visualization. updates to grid only

* fix plot. fix grid-only

* correct power, correct technology usage

* Added Floating Platform Model and testsl

* initial code for custom orbit layout

* use custome layout for ORBIT and FLORIS - IN PROGRESS

* correct visualization given different h2 storage types on turbine

* updates to example simulation file

* Updated Floating Platform Model and tests

* Update to fixed and floating platform models, Add test for Floating, Add example yaml file for floating

* Updated test section to work with ORBIT 1.06

* Fixed equation ref. comment

* Call to SemiTaut Branch in Orbit to pull mooring costs, Update to the variable names to match Orbit Nomenclature in yamls in .py

* Added new plotting script to show all years and locations on the same figure

* Add sources to test files, Update floating cost to match ORBIT Technical report and update to test file

* Added a script to plot regional sensitivity

* Improved regional sensitivity plotting script

* Update to source information for test files

* minor modifications to example

* Remove Project code

* working on refactor... broken scripts.

* examples/H2_Analysis removed, replaced with temp hopp/to_organize submodules.

pushed along to the point that green_steel_ammonia_define_scenarios.py
runs.

* Move LCA_green_steel and ProFAST files to Project repo

* changes induced by move to project repo

* improved project/software splits, coupled with greensteel commit: c9f1eb729dfc824e35e717feb518e902fd0387c1

* Add clarity to depth limitation on example_floating_project.yaml and floating_platform.py

* Remove project codes and move software codes into HOPP/hopp/to_organize or respective directories

* Update import statements and import files that other files depend on

* removing duplicate base.py

* reinstante hopp_for_h2_floris.py

* hotfix to make refactored floris compatible with old run scripts.

* fix hopp_tools_steel

* Update import statements to paths already in repo

* Restore LCA_single_scenario_Profast.py as run_profast_for_hydrogen.py needs it

* Remove Duplicates, update import statements

* Test file restore with history

* Delete Test move

* Rename of Test file move

* Test

* Test 2

* Test

* Move H2_Analysis files to this branch with history

* Test

* Test

* test

* Move H2_Analysis files that keep history from feature/green_steel_ammonia branch

* Test

* Restore run_profast scripts with history

* Move LCA_single_scenario files into to organize and keep history

* Removed files that had no history and replaced them in commit before this

* Updated import statments to restored files with history

* Deleted duplicate files that had no history with them/Replaced in to_organize2

* Update import statements to direct to files in to_organize2

* comments

* moving towards better separation.

* correct how the fixed platform is being used

* check ORBIT for already registered FlexPlatformDesign and FixedPlatformInstallation phases

* Update CI Action to run on PRs (#151)

* Update CI Action to run on PRs

* Add CI Badge to README.md

* Fix failing hybrid test

* correct typo

* remove old print statements

* i think green steel openmdao version is working.

* Revised comments on floating project depth limitations

* sanitizing my branch to match upstream

* restore run rodeo

* move run rodeo

* break out distributed pipe cost.

* mv dist pipe cost.

* working on getting tests running

* working toward reconciliation w/ ckiefer

* removed all of to_organize2, history preserved in to_organize with .

* trying to get tests to run under pytest

* typo fix

* getting more tests running

* improved nrel api handling, trailing whitespace removal.

* add orbit to requirements

* working on getting Avangrid code to run

* correct orbit requirement line

* add pyaml-include to requirements

* adding charles's fix.

* update hopp for h2 floris

* enable scaling wind farm costs to expected wind farm capex

* ignore all pycache directories at all levels

* remove obsolete shapely version spec

* change which desal model is being called

* allow expected_plant_costs to be missing in plant_config

* added option for run_h2_PEM model to use IVcurve model.

* fix conflict w/ pull

* update .gitignore

* less some plots, eco example working.

* remove comments

* Added and changed some files to get green steel code to work

* Fixed an issue with storage ITC in run_profast_for_hydrogen.py

* Cleanup + test fixes (#189)

* Remove redundant resource files

* Fix clustering tests

* Remove unneeded tests

We determined in our last Refactor meeting that these are not real tests and should be removed.

* Limit shapely version

There's currently a range of shapely versions that work for HOPP, and this is reflected in `master`. If we want to loosen this constraint, we'll need to figure out why the tests fail on current versions of the package.

* Fix test_csp imports

* Revert PySAM to 3.0.0

This change broke tests in tests/hopp/test_hybrid, I'm not sure why, but we'll need to revisit if we want to upgrade.

* Fix documentation build

* Disable test_pressure_vessel

* Fix test_custom_financial

* Reorganize tests into tests/hopp

* Disable analysis tests

Met with Kaitlin Brunik (@kbrunik) today to discuss these particular analysis tests. These are based on outdated examples, and need to be re-assessed alongside the code in the holdover `to_organize` directory, which contains a number of files that likely belong as project code rather than usage examples for the repository.

* Update Custom Financial Model (#195)

* pull in changes from pysam_update_capacity

* fix import

* update tests

* undo a commenting

* BatteryStateless (#196)

* pull in changes from pysam_update_capacity

* fix import

* update tests

* add batttery_stateless

* break out create_max_gross_profit_objective by tech

* fix tests

* fix minor comments

* update .gitignore

* Remove more resource files

Another attempt at removing files that are not explicitly used in the code.

* Re-add clobbered changes and fix imports

---------

Co-authored-by: Darice L Guittet <[email protected]>
Co-authored-by: Jared Thomas <[email protected]>

* Revert "Update __init__.py (#194)"

This reverts commit 12ba476.

---------

Co-authored-by: nriccobo <[email protected]>
Co-authored-by: Jared Thomas <[email protected]>
Co-authored-by: Kiefer <[email protected]>
Co-authored-by: Charles Kiefer <[email protected]>
Co-authored-by: Evan <[email protected]>
Co-authored-by: Cory Frontin <[email protected]>
Co-authored-by: Jared Thomas <[email protected]>
Co-authored-by: bayc <[email protected]>
Co-authored-by: Darice L Guittet <[email protected]>

* Refactor SiteInfo (#202)

* Refactor SiteInfo class

* Remove double-negatives in SiteInfo

Everything works the same, but now users will need to specify `wind=False` or `solar=False` in the initialization of `SiteInfo`, rather than modifying the data dictionary with `no_wind` or `no_solar`.

* Update SiteInfo fields and add converter doc

* Merge recent changes on `master` (#209)

* Update CI Action to run on PRs (#151)

* Update CI Action to run on PRs

* Add CI Badge to README.md

* Fix failing hybrid test

* Update Custom Financial Model (#195)

* pull in changes from pysam_update_capacity

* fix import

* update tests

* undo a commenting

* BatteryStateless (#196)

* pull in changes from pysam_update_capacity

* fix import

* update tests

* add batttery_stateless

* break out create_max_gross_profit_objective by tech

* fix tests

* fix minor comments

* Remove nlopt from requirements.txt (#199)

* Modify Wind Layout Parameters (#157)

* change get_evenly_spaced_points_along_border

* update ci.yml

* update ci.yml

* update requirements

* fix flicker heatmap indexing

* Battery max cycles (#203)

* pull in changes from pysam_update_capacity

* fix import

* update tests

* add batttery_stateless

* break out create_max_gross_profit_objective by tech

* fix tests

* fix minor comments

* add battery cycle limits

* fix tests

* fix tests

* fix mutable defaults

---------

Co-authored-by: Darice L Guittet <[email protected]>

* Small updates to get things working with Green Steel

* Small changes to get working with latest version of ProFAST

* Remove network calls from tests (#205)

* Remove network calls from tests

This update removes network calls wherever they exist, and also adds new unit tests for functionality related to API calls.

* Clean up

* Updates so that incentives are applied per year for first 10 years rather than just first year

* Wave model integration (#133)

* reformat plots, generate paths for plots, add onshore substation to plots

* on-turbine pressure vessel visualization. updates to grid only

* fix plot. fix grid-only

* correct power, correct technology usage

* initial code for custom orbit layout

* use custome layout for ORBIT and FLORIS - IN PROGRESS

* correct visualization given different h2 storage types on turbine

* updates to example simulation file

* Adding MHK capabilities, still has bugs.

* Fixed reading resource data in.

* Setting system values in __init__

* Can run system_model

* System model and tests for MHK Wave

* Added cost model to MHKWavePlant

* Added no_wave to dict

* Added wave to HybridSimulation

* Initial attempt at wave dispatch model

* update ci.yml

* add missing requirements

* fix import error

* fix requirements

* fix requirements

* fix requirements

* fix requirements

* fix requirements

* fix requirements

* retire 3.7 in ci.yml

* Removed newline spaces

* Moved wave device config to yaml for tests.

* Fixed hybrid_outputs method for all technologies.

* fixed mhk_wave_source formatting. added checks for power matrix. updated power matrix test.

* added description of file format.

* created seperate mhk cost class.

* Added unit tests and subtests for wave source.

* Updated hybrid test with mhk_wave source reconfiguration.

* updated resource call for clarity.

* removed comments for obsolete dict keys.

* update test_wave.py for recent changes in dev/refactor

* address merge conflict messages in requirements.txt

* update path definition for wave_device.yaml

* use path to test file to begin relative path definition

* use absolute path

* use top hopp path

* expect NotImplementedError when running wave

* updated simulate() to calculate cost and financials for wave.

* updated test_wave with fixtures.

* updating test_hybrid with wave.

* added wave to power_sources in HybridSimulation.

* add check

* changed grid to CustomFinancialModel in test_hybrid_wave_only().

* use owned parameters for aep in power_source.simulate_financials over _system_model parameters to allow override in inherited clases

* added pytest-subtests for CI tests

* use for loops to assign attributes

* created new file for MHKCosts

* remove duplicate code

* generalized  for all technologies.

* Update documentation for MHK

* fixed spacing

---------

Co-authored-by: Jared Thomas <[email protected]>
Co-authored-by: dguittet <[email protected]>
Co-authored-by: Darice <[email protected]>
Co-authored-by: Cameron Irmas <[email protected]>

* bulk hydrogen storage models (#191)

* Added ORBIT citation and references. Commented each function, citing section/equations used or repurposed from this analysis.

* last comment changes

* reformat plots, generate paths for plots, add onshore substation to plots

* on-turbine pressure vessel visualization. updates to grid only

* fix plot. fix grid-only

* correct power, correct technology usage

* Added Floating Platform Model and testsl

* initial code for custom orbit layout

* use custome layout for ORBIT and FLORIS - IN PROGRESS

* correct visualization given different h2 storage types on turbine

* updates to example simulation file

* Updated Floating Platform Model and tests

* Update to fixed and floating platform models, Add test for Floating, Add example yaml file for floating

* Updated test section to work with ORBIT 1.06

* Fixed equation ref. comment

* Call to SemiTaut Branch in Orbit to pull mooring costs, Update to the variable names to match Orbit Nomenclature in yamls in .py

* Added new plotting script to show all years and locations on the same figure

* Add sources to test files, Update floating cost to match ORBIT Technical report and update to test file

* Added a script to plot regional sensitivity

* Improved regional sensitivity plotting script

* Update to source information for test files

* minor modifications to example

* Remove Project code

* working on refactor... broken scripts.

* examples/H2_Analysis removed, replaced with temp hopp/to_organize submodules.

pushed along to the point that green_steel_ammonia_define_scenarios.py
runs.

* Move LCA_green_steel and ProFAST files to Project repo

* changes induced by move to project repo

* improved project/software splits, coupled with greensteel commit: c9f1eb729dfc824e35e717feb518e902fd0387c1

* Add clarity to depth limitation on example_floating_project.yaml and floating_platform.py

* Remove project codes and move software codes into HOPP/hopp/to_organize or respective directories

* Update import statements and import files that other files depend on

* removing duplicate base.py

* reinstante hopp_for_h2_floris.py

* hotfix to make refactored floris compatible with old run scripts.

* fix hopp_tools_steel

* Update import statements to paths already in repo

* Restore LCA_single_scenario_Profast.py as run_profast_for_hydrogen.py needs it

* Remove Duplicates, update import statements

* Test file restore with history

* Delete Test move

* Rename of Test file move

* Test

* Test 2

* Test

* Move H2_Analysis files to this branch with history

* Test

* Test

* test

* Move H2_Analysis files that keep history from feature/green_steel_ammonia branch

* Test

* Restore run_profast scripts with history

* Move LCA_single_scenario files into to organize and keep history

* Removed files that had no history and replaced them in commit before this

* Updated import statments to restored files with history

* Deleted duplicate files that had no history with them/Replaced in to_organize2

* Update import statements to direct to files in to_organize2

* comments

* moving towards better separation.

* correct how the fixed platform is being used

* check ORBIT for already registered FlexPlatformDesign and FixedPlatformInstallation phases

* Update CI Action to run on PRs (#151)

* Update CI Action to run on PRs

* Add CI Badge to README.md

* Fix failing hybrid test

* correct typo

* remove old print statements

* i think green steel openmdao version is working.

* Revised comments on floating project depth limitations

* sanitizing my branch to match upstream

* restore run rodeo

* move run rodeo

* break out distributed pipe cost.

* mv dist pipe cost.

* working on getting tests running

* working toward reconciliation w/ ckiefer

* removed all of to_organize2, history preserved in to_organize with .

* trying to get tests to run under pytest

* typo fix

* getting more tests running

* improved nrel api handling, trailing whitespace removal.

* add orbit to requirements

* working on getting Avangrid code to run

* correct orbit requirement line

* add pyaml-include to requirements

* adding charles's fix.

* update hopp for h2 floris

* enable scaling wind farm costs to expected wind farm capex

* ignore all pycache directories at all levels

* remove obsolete shapely version spec

* change which desal model is being called

* allow expected_plant_costs to be missing in plant_config

* added option for run_h2_PEM model to use IVcurve model.

* fix conflict w/ pull

* update .gitignore

* less some plots, eco example working.

* remove comments

* Adding storage models, tests failing.

* updated tests with fixtures.

* fixed compressor test.

* updated imports

* updated notation for bulk h2 storage models

* changed underground_pipe_storage syntax back to fix import error.

* updated examples

* updated underground pipe storage.

* remove resource files

---------

Co-authored-by: nriccobo <[email protected]>
Co-authored-by: Jared Thomas <[email protected]>
Co-authored-by: Kiefer <[email protected]>
Co-authored-by: Charles Kiefer <[email protected]>
Co-authored-by: Evan <[email protected]>
Co-authored-by: Cory Frontin <[email protected]>
Co-authored-by: Jared Thomas <[email protected]>
Co-authored-by: bayc <[email protected]>
Co-authored-by: Cameron Irmas <[email protected]>

* fixed bug in URL in wind_resource.py for API calls when using a user-specified hub-height (#238)

* HOPP Jupyter Examples (#233)

* updated doc string in site info.

* example Jupyter notebooks.

* add battery spec to technology model

* Electrolyzer degradation impacts - added features and fixes (#219)

* modified run_h2_PEM function for updates made to PEM_H2_LT_electrolyzer_clusters model and moved imports into functions

* updated electrolyzer model to correctly reduce h2 production when degraded and lifetime performance calculations

* removed unused imports

* fixed edge-case bug in fatigue degradation calculation if stack is off for entire week, removed some old functions

* fixed minor bug in new_H2_Results output

* added lifetime performance estimate for grid connected case

* added performance per year of plant life, need to adust for cases when simulation isn't one year

* reformats yearly performance to be aggregated over all clusters

* removed function calls to old functions and removed unnecessary outputs

* adjusted to not throw errors with recent changes in PEM, added more comments and cleaned up

* fixed bug in grid-connected case with new changes

* deleted some old comments maybe?

* updated filepath to run_pem_master

* moved from to_organize/PEM_Model_2Push/ to hydrogen/electrolysis

* deleted to_organize/PEM_Model_2Push files since moved to new location

* removed Electrolyzer_Models/run_h2_clusters.py because it was outdated and incompatible with electrolyzer model it uses

* removed cbc.exe from PEM_Model_2Push folder, will need to point to correct location in optimization_utils_linear

* removed other unused electrolyzer run files

* removed some unused functions and nondescriptive comments

* added turndown ratio as input

* updated a few typos and comments

* Refactored classes + examples (#241)

* Changes to use the TAP API as an alternative option to WTK

* Refactor PVPlant

* Refactor DetailedPVPlant

* Add pytest-subtests

* Update documentation

* Update tests

Opting to leave out tests related to property getters and setters, which are highly coupled with PySAM.

* Update tests

- Removed instance checking, since it's enforcing coupling that we might not have in the future
- Began adding validators

* Update wind_resource.py to correct automatically setting success variable to false

* Update setup

Fixes an issue with pip installs for HOPP when using python >3.8

* Update PV Config interface

* Refactor Grid class

* Add Grid tests

* Update docs to include GridConfig

* updated doc string in site info.

* example Jupyter notebooks.

* Refactor Battery

* Refactor BatteryStateless

* Update Battery/BatteryStateless docs

* Update tests

* Refactor CSP classes

* add battery spec to technology model

* Remove redundant resource files

* Add TAP test; allow users to specify API call

Previously, a resource download would only take place if a file was not found. This change adds a field, `use_api`, that will override to always run the API call even if a file is found.

* remove examples from setup.py

* update floris examples with visuals

* Refactor wave model

* Update Wave docs

* updated floris visualization.

* start of example

* Refactor WindPlant

* Update to convert nested dicts

* Update tests

* Update config structure and tests

* Update WindPlant docs

* Rework configs and set up wind plant for pysam input

I didn't really like the post init hooks in the config classes,
so I moved that code back into the plant classes.

* WIP allow PySAM wind system input file

* WIP update examples

* Add ppa_price and dc_degradation configs

These were previously not configurable via HoppInterface

* Move hopp_interface.py

* Fix Floris financial issue in WindPlant

Fixed a bug where we were accidentally setting the financial
model to None when Floris was being used. We really need tests
for Floris functionality.

* Update dev environment details

* WIP update examples

* added electrolyzer example

* updated examples documentation

* modified wave costs class instance

* updated example 06 config

---------

Co-authored-by: Ruzekowicz <[email protected]>
Co-authored-by: Jenna Ruzekowicz <[email protected]>
Co-authored-by: Cameron Irmas <[email protected]>
Co-authored-by: elenya-grant <[email protected]>

* Update documentation

* Update README

* Add more Python versions to CI

* Fix battery chemistry config

* Remove ECO files and outdated examples, tests

Ultimately the plan is to bring some of these back in as we revamp the examples and complete features related to the ECO project.

* wind_source -> wind_plant

* csp_source -> csp_plant

* wave_source -> wave_plant

* pv_source -> pv_plant

* move plot_tools modules to hopp.tools

* Move battery files; update imports

* Update reqs and RTD config

---------

Co-authored-by: elenya-grant <[email protected]>
Co-authored-by: ereznicek <[email protected]>
Co-authored-by: Evan <[email protected]>
Co-authored-by: bayc <[email protected]>
Co-authored-by: Jared Thomas <[email protected]>
Co-authored-by: Cory Frontin <[email protected]>
Co-authored-by: AbhineetGupta <[email protected]>
Co-authored-by: svijaysh <[email protected]>
Co-authored-by: Jared Thomas <[email protected]>
Co-authored-by: Masha <[email protected]>
Co-authored-by: Cory Frontin <[email protected]>
Co-authored-by: Evan Reznicek <[email protected]>
Co-authored-by: Genevieve Starke <[email protected]>
Co-authored-by: nriccobo <[email protected]>
Co-authored-by: Kiefer <[email protected]>
Co-authored-by: Charles Kiefer <[email protected]>
Co-authored-by: Darice L Guittet <[email protected]>
Co-authored-by: kbrunik <[email protected]>
Co-authored-by: Darice <[email protected]>
Co-authored-by: Ruzekowicz <[email protected]>
Co-authored-by: Jenna Ruzekowicz <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
refactor Associated with the refactor of HOPP
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants