Skip to content

Commit

Permalink
Merge pull request #97 from schism-dev/bugfix/param
Browse files Browse the repository at this point in the history
Bugfix/param
  • Loading branch information
cuill authored Sep 11, 2023
2 parents ccbc8d8 + d1e583c commit 45795d2
Show file tree
Hide file tree
Showing 3 changed files with 90 additions and 0 deletions.
1 change: 1 addition & 0 deletions pyschism/driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -288,6 +288,7 @@ def __init__(
# set opt
self.param.opt.start_date = start_date
self.param.opt.ics = 2 if self.config.hgrid.crs.is_geographic is True else 1
self.param.opt.ncor = 1 if self.param.opt.ics == 2 else 0
self.param.opt.dramp = dramp
self.param.opt.drampbc = drampbc
self.param.opt.dramp_ss = dramp_ss
Expand Down
1 change: 1 addition & 0 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,7 @@ def run(self):
'xarray',
'xmltodict',
'zarr',
'appdirs',
],
entry_points={'console_scripts': ['pyschism = pyschism.__main__:main']},
tests_require=['nose'],
Expand Down
88 changes: 88 additions & 0 deletions tests/test_param_ncor.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
#! /usr/bin/env python
from datetime import datetime, timedelta
import logging
import os
import pathlib
import shutil
import tarfile
import tempfile
import unittest
import urllib.request
import f90nml

from pyschism import dates
from pyschism.mesh import Hgrid, Vgrid
from pyschism.driver import ModelConfig


logging.basicConfig(level=logging.INFO, force=True)


class ModelConfigurationTestCase(unittest.TestCase):

def test_ncor_zero(self):

hgrid=Hgrid.open('https://raw.githubusercontent.com/geomesh/test-data/main/NWM/hgrid.ll', crs='epsg:26918')

config = ModelConfig(
hgrid,
)

# create reference dates
spinup_time = timedelta(days=0.)
start_date=datetime(2023,9,10)

# create a coldstart object
coldstart = config.coldstart(
start_date=start_date,
end_date=start_date + timedelta(days=3.),
timestep=150.,
dramp=spinup_time,
dramp_ss=spinup_time,
drampwind=spinup_time,
nspool=timedelta(hours=1),
elev=True,
dahv=True,
)

with tempfile.TemporaryDirectory() as tempdir:
coldstart.write(tempdir, overwrite=True)

nml = f90nml.read(f'{tempdir}/param.nml')
assert('ncor' in nml['opt'])
assert(nml['opt']['ncor'] == 0)

def test_ncor_one(self):

hgrid=Hgrid.open('https://raw.githubusercontent.com/geomesh/test-data/main/NWM/hgrid.ll', crs='epsg:4326')

config = ModelConfig(
hgrid,
)

# create reference dates
spinup_time = timedelta(days=0.)
start_date=datetime(2023,9,10)

# create a coldstart object
coldstart = config.coldstart(
start_date=start_date,
end_date=start_date + timedelta(days=3.),
timestep=150.,
dramp=spinup_time,
dramp_ss=spinup_time,
drampwind=spinup_time,
nspool=timedelta(hours=1),
elev=True,
dahv=True,
)

with tempfile.TemporaryDirectory() as tempdir:
coldstart.write(tempdir, overwrite=True)

nml = f90nml.read(f'{tempdir}/param.nml')
assert('ncor' in nml['opt'])
assert(nml['opt']['ncor'] == 1)

if __name__ == '__main__':
unittest.main()

0 comments on commit 45795d2

Please sign in to comment.