diff --git a/pyposeidon/schism.py b/pyposeidon/schism.py index 427da1a3..6938366e 100644 --- a/pyposeidon/schism.py +++ b/pyposeidon/schism.py @@ -222,13 +222,13 @@ def config(self, config_file=None, output=False, **kwargs): self.parameters.update(dic) # test rnday - if float(params["CORE"]["rnday"]) * 24 * 3600 > (self.end_date - self.start_date).total_seconds(): + if float(params["CORE"]["rnday"]) * 24 * 3600 > int((self.end_date - self.start_date).total_seconds()): # --------------------------------------------------------------------- logger.warning("rnday larger than simulation range\n") logger.warning( "rnday={} while simulation time is {}\n".format( params["core"]["rnday"], - (self.end_date - self.start_date).total_seconds() / (3600 * 24.0), + int((self.end_date - self.start_date).total_seconds()) / (3600 * 24.0), ) ) # --------------------------------------------------------------------- diff --git a/pyposeidon/utils/cast.py b/pyposeidon/utils/cast.py index f96350d6..690d72dc 100644 --- a/pyposeidon/utils/cast.py +++ b/pyposeidon/utils/cast.py @@ -430,9 +430,10 @@ def run(self, **kwargs): logger.warning("meteo files present\n") # modify param file - rnday_new = (self.sdate - self.rdate).total_seconds() / (3600 * 24.0) + pd.to_timedelta( - self.time_frame - ).total_seconds() / (3600 * 24.0) + sdate_seconds = float((self.sdate - self.rdate).total_seconds()) + time_frame_seconds = float(pd.to_timedelta(self.time_frame).total_seconds()) + rnday_new = sdate_seconds / (3600 * 24.0) + time_frame_seconds / (3600 * 24.0) + hotout_write = int(rnday_new * 24 * 3600 / info["params"]["core"]["dt"]) info["parameters"].update( { diff --git a/pyposeidon/utils/obs.py b/pyposeidon/utils/obs.py index 2f9e27f9..841b37b4 100644 --- a/pyposeidon/utils/obs.py +++ b/pyposeidon/utils/obs.py @@ -61,7 +61,7 @@ def get_obs_data(stations: str | gp.GeoDataFrame, start_time=None, end_time=None if not period: dt = pd.to_datetime(end_time) - pd.to_datetime(start_time) - period = dt.total_seconds() / 3600 / 24 + period = int(dt.total_seconds() / 3600 / 24) data = ioc.get_ioc_data( ioc_metadata=df,