roms-tools 1.4.2__py3-none-any.whl → 1.6.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (278) hide show
  1. roms_tools/_version.py +1 -1
  2. roms_tools/setup/boundary_forcing.py +448 -130
  3. roms_tools/setup/datasets.py +186 -52
  4. roms_tools/setup/fill.py +2 -2
  5. roms_tools/setup/initial_conditions.py +217 -70
  6. roms_tools/setup/regrid.py +143 -0
  7. roms_tools/setup/surface_forcing.py +159 -73
  8. roms_tools/setup/tides.py +141 -54
  9. roms_tools/setup/utils.py +229 -62
  10. roms_tools/tests/test_setup/test_boundary_forcing.py +42 -32
  11. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/.zattrs +1 -1
  12. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/.zmetadata +1 -1
  13. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_ALT_CO2_east/0.0.0 +0 -0
  14. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_ALT_CO2_north/0.0.0 +0 -0
  15. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_ALT_CO2_south/0.0.0 +0 -0
  16. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_ALT_CO2_west/0.0.0 +0 -0
  17. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_east/0.0.0 +0 -0
  18. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_north/0.0.0 +0 -0
  19. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_south/0.0.0 +0 -0
  20. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/ALK_west/0.0.0 +0 -0
  21. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_ALT_CO2_east/0.0.0 +0 -0
  22. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_ALT_CO2_north/0.0.0 +0 -0
  23. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_ALT_CO2_south/0.0.0 +0 -0
  24. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_ALT_CO2_west/0.0.0 +0 -0
  25. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_east/0.0.0 +0 -0
  26. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_north/0.0.0 +0 -0
  27. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_south/0.0.0 +0 -0
  28. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DIC_west/0.0.0 +0 -0
  29. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOC_east/0.0.0 +0 -0
  30. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOC_north/0.0.0 +0 -0
  31. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOC_south/0.0.0 +0 -0
  32. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOC_west/0.0.0 +0 -0
  33. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOCr_east/0.0.0 +0 -0
  34. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOCr_north/0.0.0 +0 -0
  35. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOCr_south/0.0.0 +0 -0
  36. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOCr_west/0.0.0 +0 -0
  37. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DON_east/0.0.0 +0 -0
  38. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DON_north/0.0.0 +0 -0
  39. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DON_south/0.0.0 +0 -0
  40. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DON_west/0.0.0 +0 -0
  41. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DONr_east/0.0.0 +0 -0
  42. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DONr_north/0.0.0 +0 -0
  43. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DONr_south/0.0.0 +0 -0
  44. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DONr_west/0.0.0 +0 -0
  45. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOP_east/0.0.0 +0 -0
  46. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOP_north/0.0.0 +0 -0
  47. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOP_south/0.0.0 +0 -0
  48. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOP_west/0.0.0 +0 -0
  49. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOPr_east/0.0.0 +0 -0
  50. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOPr_north/0.0.0 +0 -0
  51. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOPr_south/0.0.0 +0 -0
  52. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/DOPr_west/0.0.0 +0 -0
  53. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Fe_east/0.0.0 +0 -0
  54. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Fe_north/0.0.0 +0 -0
  55. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Fe_south/0.0.0 +0 -0
  56. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Fe_west/0.0.0 +0 -0
  57. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Lig_east/0.0.0 +0 -0
  58. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Lig_north/0.0.0 +0 -0
  59. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Lig_south/0.0.0 +0 -0
  60. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/Lig_west/0.0.0 +0 -0
  61. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NH4_east/0.0.0 +0 -0
  62. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NH4_north/0.0.0 +0 -0
  63. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NH4_south/0.0.0 +0 -0
  64. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NH4_west/0.0.0 +0 -0
  65. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NO3_east/0.0.0 +0 -0
  66. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NO3_north/0.0.0 +0 -0
  67. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NO3_south/0.0.0 +0 -0
  68. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/NO3_west/0.0.0 +0 -0
  69. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/O2_east/0.0.0 +0 -0
  70. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/O2_north/0.0.0 +0 -0
  71. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/O2_south/0.0.0 +0 -0
  72. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/O2_west/0.0.0 +0 -0
  73. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/PO4_east/0.0.0 +0 -0
  74. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/PO4_north/0.0.0 +0 -0
  75. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/PO4_south/0.0.0 +0 -0
  76. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/PO4_west/0.0.0 +0 -0
  77. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/SiO3_east/0.0.0 +0 -0
  78. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/SiO3_north/0.0.0 +0 -0
  79. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/SiO3_south/0.0.0 +0 -0
  80. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/SiO3_west/0.0.0 +0 -0
  81. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatC_east/0.0.0 +0 -0
  82. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatC_north/0.0.0 +0 -0
  83. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatC_south/0.0.0 +0 -0
  84. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatC_west/0.0.0 +0 -0
  85. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatChl_east/0.0.0 +0 -0
  86. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatChl_north/0.0.0 +0 -0
  87. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatChl_south/0.0.0 +0 -0
  88. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatChl_west/0.0.0 +0 -0
  89. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatFe_east/0.0.0 +0 -0
  90. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatFe_north/0.0.0 +0 -0
  91. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatFe_south/0.0.0 +0 -0
  92. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatFe_west/0.0.0 +0 -0
  93. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatP_east/0.0.0 +0 -0
  94. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatP_north/0.0.0 +0 -0
  95. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatP_south/0.0.0 +0 -0
  96. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatP_west/0.0.0 +0 -0
  97. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatSi_east/0.0.0 +0 -0
  98. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatSi_north/0.0.0 +0 -0
  99. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatSi_south/0.0.0 +0 -0
  100. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diatSi_west/0.0.0 +0 -0
  101. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazC_east/0.0.0 +0 -0
  102. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazC_north/0.0.0 +0 -0
  103. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazC_south/0.0.0 +0 -0
  104. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazC_west/0.0.0 +0 -0
  105. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazChl_east/0.0.0 +0 -0
  106. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazChl_north/0.0.0 +0 -0
  107. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazChl_south/0.0.0 +0 -0
  108. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazChl_west/0.0.0 +0 -0
  109. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazFe_east/0.0.0 +0 -0
  110. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazFe_north/0.0.0 +0 -0
  111. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazFe_south/0.0.0 +0 -0
  112. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazFe_west/0.0.0 +0 -0
  113. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazP_east/0.0.0 +0 -0
  114. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazP_north/0.0.0 +0 -0
  115. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazP_south/0.0.0 +0 -0
  116. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/diazP_west/0.0.0 +0 -0
  117. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spC_east/0.0.0 +0 -0
  118. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spC_north/0.0.0 +0 -0
  119. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spC_south/0.0.0 +0 -0
  120. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spC_west/0.0.0 +0 -0
  121. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spCaCO3_east/0.0.0 +0 -0
  122. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spCaCO3_north/0.0.0 +0 -0
  123. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spCaCO3_south/0.0.0 +0 -0
  124. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spCaCO3_west/0.0.0 +0 -0
  125. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spChl_east/0.0.0 +0 -0
  126. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spChl_north/0.0.0 +0 -0
  127. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spChl_south/0.0.0 +0 -0
  128. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spChl_west/0.0.0 +0 -0
  129. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spFe_east/0.0.0 +0 -0
  130. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spFe_north/0.0.0 +0 -0
  131. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spFe_south/0.0.0 +0 -0
  132. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spFe_west/0.0.0 +0 -0
  133. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spP_east/0.0.0 +0 -0
  134. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spP_north/0.0.0 +0 -0
  135. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spP_south/0.0.0 +0 -0
  136. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/spP_west/0.0.0 +0 -0
  137. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/zooC_east/0.0.0 +0 -0
  138. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/zooC_north/0.0.0 +0 -0
  139. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/zooC_south/0.0.0 +0 -0
  140. roms_tools/tests/test_setup/test_data/bgc_boundary_forcing_from_climatology.zarr/zooC_west/0.0.0 +0 -0
  141. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/.zattrs +1 -1
  142. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/.zmetadata +1 -1
  143. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/dust/0.0.0 +0 -0
  144. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/iron/0.0.0 +0 -0
  145. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/nhy/0.0.0 +0 -0
  146. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/nox/0.0.0 +0 -0
  147. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/pco2_air/0.0.0 +0 -0
  148. roms_tools/tests/test_setup/test_data/bgc_surface_forcing.zarr/pco2_air_alt/0.0.0 +0 -0
  149. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/.zattrs +1 -1
  150. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/.zmetadata +1 -1
  151. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/dust/0.0.0 +0 -0
  152. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/iron/0.0.0 +0 -0
  153. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/nhy/0.0.0 +0 -0
  154. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/nox/0.0.0 +0 -0
  155. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/pco2_air/0.0.0 +0 -0
  156. roms_tools/tests/test_setup/test_data/bgc_surface_forcing_from_climatology.zarr/pco2_air_alt/0.0.0 +0 -0
  157. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/.zattrs +1 -1
  158. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/.zmetadata +8 -1
  159. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/abs_time/.zattrs +3 -0
  160. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/salt_east/0.0.0 +0 -0
  161. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/salt_north/0.0.0 +0 -0
  162. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/salt_south/0.0.0 +0 -0
  163. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/salt_west/0.0.0 +0 -0
  164. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/temp_east/0.0.0 +0 -0
  165. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/temp_north/0.0.0 +0 -0
  166. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/temp_south/0.0.0 +0 -0
  167. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/temp_west/0.0.0 +0 -0
  168. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/u_east/0.0.0 +0 -0
  169. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/u_north/0.0.0 +0 -0
  170. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/u_west/0.0.0 +0 -0
  171. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/ubar_east/0.0 +0 -0
  172. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/ubar_north/0.0 +0 -0
  173. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/ubar_west/0.0 +0 -0
  174. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/v_east/0.0.0 +0 -0
  175. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/v_north/0.0.0 +0 -0
  176. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/v_south/0.0.0 +0 -0
  177. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/v_west/0.0.0 +0 -0
  178. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/vbar_east/0.0 +0 -0
  179. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/vbar_north/0.0 +0 -0
  180. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/vbar_south/0.0 +0 -0
  181. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/vbar_west/0.0 +0 -0
  182. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/zeta_east/.zattrs +1 -0
  183. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/zeta_east/0.0 +0 -0
  184. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/zeta_north/.zattrs +1 -0
  185. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/zeta_south/.zattrs +1 -0
  186. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/zeta_south/0.0 +0 -0
  187. roms_tools/tests/test_setup/test_data/boundary_forcing.zarr/zeta_west/.zattrs +1 -0
  188. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/.zattrs +1 -1
  189. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/.zmetadata +1 -1
  190. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/Tair/0.0.0 +0 -0
  191. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/lwrad/0.0.0 +0 -0
  192. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/qair/0.0.0 +0 -0
  193. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/rain/0.0.0 +0 -0
  194. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/swrad/0.0.0 +0 -0
  195. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/uwnd/0.0.0 +0 -0
  196. roms_tools/tests/test_setup/test_data/coarse_surface_forcing.zarr/vwnd/0.0.0 +0 -0
  197. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/.zattrs +1 -1
  198. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/.zmetadata +1 -1
  199. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/Tair/0.0.0 +0 -0
  200. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/lwrad/0.0.0 +0 -0
  201. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/qair/0.0.0 +0 -0
  202. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/rain/0.0.0 +0 -0
  203. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/swrad/0.0.0 +0 -0
  204. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/uwnd/0.0.0 +0 -0
  205. roms_tools/tests/test_setup/test_data/corrected_surface_forcing.zarr/vwnd/0.0.0 +0 -0
  206. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/.zattrs +1 -1
  207. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/.zmetadata +1 -1
  208. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/ALK/0.0.0.0 +0 -0
  209. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/ALK_ALT_CO2/0.0.0.0 +0 -0
  210. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DIC/0.0.0.0 +0 -0
  211. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DIC_ALT_CO2/0.0.0.0 +0 -0
  212. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DOC/0.0.0.0 +0 -0
  213. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DOCr/0.0.0.0 +0 -0
  214. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DON/0.0.0.0 +0 -0
  215. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DONr/0.0.0.0 +0 -0
  216. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DOP/0.0.0.0 +0 -0
  217. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/DOPr/0.0.0.0 +0 -0
  218. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/Fe/0.0.0.0 +0 -0
  219. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/Lig/0.0.0.0 +0 -0
  220. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/NH4/0.0.0.0 +0 -0
  221. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/NO3/0.0.0.0 +0 -0
  222. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/O2/0.0.0.0 +0 -0
  223. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/PO4/0.0.0.0 +0 -0
  224. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/SiO3/0.0.0.0 +0 -0
  225. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diatC/0.0.0.0 +0 -0
  226. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diatChl/0.0.0.0 +0 -0
  227. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diatFe/0.0.0.0 +0 -0
  228. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diatP/0.0.0.0 +0 -0
  229. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diatSi/0.0.0.0 +0 -0
  230. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diazC/0.0.0.0 +0 -0
  231. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diazChl/0.0.0.0 +0 -0
  232. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diazFe/0.0.0.0 +0 -0
  233. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/diazP/0.0.0.0 +0 -0
  234. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/salt/0.0.0.0 +0 -0
  235. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/spC/0.0.0.0 +0 -0
  236. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/spCaCO3/0.0.0.0 +0 -0
  237. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/spChl/0.0.0.0 +0 -0
  238. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/spFe/0.0.0.0 +0 -0
  239. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/spP/0.0.0.0 +0 -0
  240. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/temp/0.0.0.0 +0 -0
  241. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/u/0.0.0.0 +0 -0
  242. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/ubar/0.0.0 +0 -0
  243. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/v/0.0.0.0 +0 -0
  244. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/vbar/0.0.0 +0 -0
  245. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/zeta/0.0.0 +0 -0
  246. roms_tools/tests/test_setup/test_data/initial_conditions_with_bgc_from_climatology.zarr/zooC/0.0.0.0 +0 -0
  247. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/.zattrs +1 -1
  248. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/.zmetadata +1 -1
  249. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/Tair/0.0.0 +0 -0
  250. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/lwrad/0.0.0 +0 -0
  251. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/qair/0.0.0 +0 -0
  252. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/rain/0.0.0 +0 -0
  253. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/swrad/0.0.0 +0 -0
  254. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/uwnd/0.0.0 +0 -0
  255. roms_tools/tests/test_setup/test_data/surface_forcing.zarr/vwnd/0.0.0 +0 -0
  256. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/.zattrs +1 -1
  257. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/.zmetadata +4 -2
  258. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/omega/.zattrs +3 -1
  259. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/pot_Im/0.0.0 +0 -0
  260. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/pot_Re/0.0.0 +0 -0
  261. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/ssh_Im/0.0.0 +0 -0
  262. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/ssh_Re/0.0.0 +0 -0
  263. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/u_Im/0.0.0 +0 -0
  264. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/u_Re/0.0.0 +0 -0
  265. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/v_Im/0.0.0 +0 -0
  266. roms_tools/tests/test_setup/test_data/tidal_forcing.zarr/v_Re/0.0.0 +0 -0
  267. roms_tools/tests/test_setup/test_datasets.py +79 -21
  268. roms_tools/tests/test_setup/test_fill.py +55 -113
  269. roms_tools/tests/test_setup/test_initial_conditions.py +21 -21
  270. roms_tools/tests/test_setup/test_regrid.py +53 -0
  271. roms_tools/tests/test_setup/test_surface_forcing.py +21 -3
  272. roms_tools/tests/test_setup/test_tides.py +1 -1
  273. {roms_tools-1.4.2.dist-info → roms_tools-1.6.0.dist-info}/METADATA +13 -4
  274. {roms_tools-1.4.2.dist-info → roms_tools-1.6.0.dist-info}/RECORD +277 -276
  275. {roms_tools-1.4.2.dist-info → roms_tools-1.6.0.dist-info}/WHEEL +1 -1
  276. roms_tools/setup/mixins.py +0 -227
  277. {roms_tools-1.4.2.dist-info → roms_tools-1.6.0.dist-info}/LICENSE +0 -0
  278. {roms_tools-1.4.2.dist-info → roms_tools-1.6.0.dist-info}/top_level.txt +0 -0
@@ -12,8 +12,10 @@ from roms_tools.setup.utils import (
12
12
  interpolate_from_climatology,
13
13
  get_time_type,
14
14
  convert_cftime_to_datetime,
15
+ one_dim_fill,
15
16
  )
16
17
  from roms_tools.setup.download import download_correction_data
18
+ from roms_tools.setup.fill import LateralFill
17
19
 
18
20
 
19
21
  @dataclass(frozen=True, kw_only=True)
@@ -117,6 +119,8 @@ class Dataset:
117
119
  # Make sure that depth is ascending
118
120
  ds = self.ensure_dimension_is_ascending(ds, dim="depth")
119
121
 
122
+ self.infer_horizontal_resolution(ds)
123
+
120
124
  # Check whether the data covers the entire globe
121
125
  object.__setattr__(self, "is_global", self.check_if_global(ds))
122
126
 
@@ -487,6 +491,34 @@ class Dataset:
487
491
 
488
492
  return ds
489
493
 
494
+ def infer_horizontal_resolution(self, ds: xr.Dataset):
495
+ """Estimate and set the average horizontal resolution of a dataset based on
496
+ latitude and longitude spacing.
497
+
498
+ Parameters
499
+ ----------
500
+ ds : xr.Dataset
501
+ Dataset containing latitude and longitude dimensions.
502
+
503
+ Sets
504
+ ----
505
+ resolution : float
506
+ The average horizontal resolution, derived from the mean spacing
507
+ between points in latitude and longitude.
508
+ """
509
+ lat_dim = self.dim_names["latitude"]
510
+ lon_dim = self.dim_names["longitude"]
511
+
512
+ # Calculate mean difference along latitude and longitude
513
+ lat_resolution = ds[lat_dim].diff(dim=lat_dim).mean(dim=lat_dim)
514
+ lon_resolution = ds[lon_dim].diff(dim=lon_dim).mean(dim=lon_dim)
515
+
516
+ # Compute the average horizontal resolution
517
+ resolution = np.mean([lat_resolution, lon_resolution])
518
+
519
+ # Set the computed resolution as an attribute
520
+ object.__setattr__(self, "resolution", resolution)
521
+
490
522
  def check_if_global(self, ds) -> bool:
491
523
  """Checks if the dataset covers the entire globe in the longitude dimension.
492
524
 
@@ -569,40 +601,31 @@ class Dataset:
569
601
  """
570
602
  pass
571
603
 
572
- def choose_subdomain(
573
- self, latitude_range, longitude_range, margin, straddle, return_subdomain=False
574
- ):
575
- """Selects a subdomain from the xarray Dataset based on specified latitude and
576
- longitude ranges, extending the selection by a specified margin. Handles
577
- longitude conversions to accommodate different longitude ranges.
604
+ def choose_subdomain(self, target_coords, buffer_points=20, return_copy=False):
605
+ """Selects a subdomain from the xarray Dataset based on specified target
606
+ coordinates, extending the selection by a defined buffer. Adjusts longitude
607
+ ranges as necessary to accommodate the dataset's expected range and handles
608
+ potential discontinuities.
578
609
 
579
610
  Parameters
580
611
  ----------
581
- latitude_range : tuple of float
582
- A tuple (lat_min, lat_max) specifying the minimum and maximum latitude values of the subdomain.
583
- longitude_range : tuple of float
584
- A tuple (lon_min, lon_max) specifying the minimum and maximum longitude values of the subdomain.
585
- margin : float
586
- Margin in degrees to extend beyond the specified latitude and longitude ranges when selecting the subdomain.
587
- straddle : bool
588
- If True, target longitudes are expected in the range [-180, 180].
589
- If False, target longitudes are expected in the range [0, 360].
612
+ target_coords : dict
613
+ A dictionary containing the target latitude and longitude coordinates, typically
614
+ with keys "lat", "lon", and "straddle".
615
+ buffer_points : int
616
+ The number of grid points to extend beyond the specified latitude and longitude
617
+ ranges when selecting the subdomain. Defaults to 20.
590
618
  return_subdomain : bool, optional
591
- If True, returns the subset of the original dataset as an xarray Dataset. If False, assigns the subset to `self.ds`.
592
- Defaults to False.
619
+ If True, returns the subset of the original dataset representing the chosen
620
+ subdomain. If False, assigns the subset to `self.ds`. Defaults to False.
593
621
 
594
622
  Returns
595
623
  -------
596
624
  xr.Dataset or None
597
- If `return_subdomain` is True, returns the subset of the original dataset representing the chosen subdomain,
598
- including an extended area to cover one extra grid point beyond the specified ranges. If `return_subdomain` is False,
599
- returns None as the subset is assigned to `self.ds`.
600
-
601
- Notes
602
- -----
603
- This method adjusts the longitude range if necessary to ensure it matches the expected range for the dataset.
604
- It also handles longitude discontinuities that can occur when converting to different longitude ranges.
605
- This is important for avoiding artifacts in the interpolation process.
625
+ Returns the subset of the original dataset as an xarray Dataset if
626
+ `return_subdomain` is True, including an extended area covering additional
627
+ grid points beyond the specified ranges. Returns None if `return_subdomain`
628
+ is False, as the subset is assigned to `self.ds`.
606
629
 
607
630
  Raises
608
631
  ------
@@ -610,13 +633,17 @@ class Dataset:
610
633
  If the selected latitude or longitude range does not intersect with the dataset.
611
634
  """
612
635
 
613
- lat_min, lat_max = latitude_range
614
- lon_min, lon_max = longitude_range
636
+ lat_min = target_coords["lat"].min().values
637
+ lat_max = target_coords["lat"].max().values
638
+ lon_min = target_coords["lon"].min().values
639
+ lon_max = target_coords["lon"].max().values
640
+
641
+ margin = self.resolution * buffer_points
615
642
 
616
643
  if not self.is_global:
617
644
  # Adjust longitude range if needed to match the expected range
618
645
  lon = self.ds[self.dim_names["longitude"]]
619
- if not straddle:
646
+ if not target_coords["straddle"]:
620
647
  if lon.min() < -180:
621
648
  if lon_max + margin > 0:
622
649
  lon_min -= 360
@@ -626,7 +653,7 @@ class Dataset:
626
653
  lon_min -= 360
627
654
  lon_max -= 360
628
655
 
629
- if straddle:
656
+ if target_coords["straddle"]:
630
657
  if lon.max() > 360:
631
658
  if lon_min - margin < 180:
632
659
  lon_min += 360
@@ -637,6 +664,7 @@ class Dataset:
637
664
  lon_max += 360
638
665
 
639
666
  # Select the subdomain
667
+
640
668
  subdomain = self.ds.sel(
641
669
  **{
642
670
  self.dim_names["latitude"]: slice(lat_min - margin, lat_max + margin),
@@ -655,16 +683,109 @@ class Dataset:
655
683
 
656
684
  # Adjust longitudes to expected range if needed
657
685
  lon = subdomain[self.dim_names["longitude"]]
658
- if straddle:
686
+ if target_coords["straddle"]:
659
687
  subdomain[self.dim_names["longitude"]] = xr.where(lon > 180, lon - 360, lon)
660
688
  else:
661
689
  subdomain[self.dim_names["longitude"]] = xr.where(lon < 0, lon + 360, lon)
662
690
 
663
- if return_subdomain:
664
- return subdomain
691
+ if return_copy:
692
+ return Dataset.from_ds(self, subdomain)
665
693
  else:
666
694
  object.__setattr__(self, "ds", subdomain)
667
695
 
696
+ def apply_lateral_fill(self):
697
+ """Apply lateral fill to variables using the dataset's mask and grid dimensions.
698
+
699
+ This method fills masked values in `self.ds` using `LateralFill` based on
700
+ the horizontal grid dimensions. A separate mask (`mask_vel`) is used for
701
+ velocity variables (e.g., `u`, `v`) if available in the dataset.
702
+
703
+ Notes
704
+ -----
705
+ Looping over `self.ds.data_vars` instead of `self.var_names` ensures that each
706
+ dataset variable is filled only once, even if multiple entries in `self.var_names`
707
+ point to the same variable in the dataset.
708
+ """
709
+ lateral_fill = LateralFill(
710
+ self.ds["mask"],
711
+ [self.dim_names["latitude"], self.dim_names["longitude"]],
712
+ )
713
+
714
+ separate_fill_for_velocities = False
715
+ if "mask_vel" in self.ds.data_vars:
716
+ lateral_fill_vel = LateralFill(
717
+ self.ds["mask_vel"],
718
+ [self.dim_names["latitude"], self.dim_names["longitude"]],
719
+ )
720
+ separate_fill_for_velocities = True
721
+
722
+ for var_name in self.ds.data_vars:
723
+ if var_name.startswith("mask"):
724
+ # Skip variables that are mask types
725
+ continue
726
+ elif (
727
+ separate_fill_for_velocities
728
+ and "u" in self.var_names
729
+ and "v" in self.var_names
730
+ and var_name in [self.var_names["u"], self.var_names["v"]]
731
+ ):
732
+ # Apply lateral fill with velocity mask for velocity variables if present
733
+ self.ds[var_name] = lateral_fill_vel.apply(self.ds[var_name])
734
+ else:
735
+ # Apply standard lateral fill for other variables
736
+ self.ds[var_name] = lateral_fill.apply(self.ds[var_name])
737
+
738
+ def extrapolate_deepest_to_bottom(self):
739
+ """Extrapolate deepest non-NaN values to fill bottom NaNs along the depth
740
+ dimension.
741
+
742
+ For each variable with a depth dimension, fills missing values at the bottom by
743
+ propagating the deepest available data downward.
744
+ """
745
+
746
+ if "depth" in self.dim_names:
747
+ for var_name in self.ds.data_vars:
748
+ if self.dim_names["depth"] in self.ds[var_name].dims:
749
+ self.ds[var_name] = one_dim_fill(
750
+ self.ds[var_name], self.dim_names["depth"], direction="forward"
751
+ )
752
+
753
+ @classmethod
754
+ def from_ds(cls, original_dataset: "Dataset", ds: xr.Dataset) -> "Dataset":
755
+ """Substitute the internal dataset of a Dataset object with a new xarray
756
+ Dataset.
757
+
758
+ This method creates a new Dataset instance, bypassing the usual `__init__`
759
+ and `__post_init__` processes. It allows for the direct assignment of the
760
+ provided xarray Dataset (`ds`) to the new instance's `ds` attribute. All
761
+ other attributes from the original dataset instance are copied to the new one.
762
+
763
+ Parameters
764
+ ----------
765
+ original_dataset : Dataset
766
+ The original Dataset instance from which attributes will be copied.
767
+ ds : xarray.Dataset
768
+ The new xarray Dataset to assign to the `ds` attribute of the new instance.
769
+
770
+ Returns
771
+ -------
772
+ Dataset
773
+ A new Dataset instance with the `ds` attribute set to the provided dataset
774
+ and other attributes copied from the original instance.
775
+ """
776
+ # Create a new Dataset instance without calling __init__ or __post_init__
777
+ dataset = cls.__new__(cls)
778
+
779
+ # Directly set the provided dataset as the 'ds' attribute
780
+ object.__setattr__(dataset, "ds", ds)
781
+
782
+ # Copy all other attributes from the original data instance
783
+ for attr in vars(original_dataset):
784
+ if attr != "ds":
785
+ object.__setattr__(dataset, attr, getattr(original_dataset, attr))
786
+
787
+ return dataset
788
+
668
789
 
669
790
  @dataclass(frozen=True, kw_only=True)
670
791
  class TPXODataset(Dataset):
@@ -803,12 +924,17 @@ class TPXODataset(Dataset):
803
924
  """
804
925
 
805
926
  if "depth" in self.var_names.keys():
927
+ ds = self.ds
806
928
  mask = xr.where(self.ds["depth"] > 0, 1, 0)
929
+ ds["mask"] = mask
930
+ ds = ds.drop_vars(["depth"])
807
931
 
808
- for var in self.ds.data_vars:
809
- self.ds[var] = xr.where(mask == 1, self.ds[var], np.nan)
932
+ object.__setattr__(self, "ds", ds)
810
933
 
811
- self.ds["mask"] = mask
934
+ # Remove "depth" from var_names
935
+ updated_var_names = {**self.var_names} # Create a copy of the dictionary
936
+ updated_var_names.pop("depth", None) # Remove "depth" if it exists
937
+ object.__setattr__(self, "var_names", updated_var_names)
812
938
 
813
939
 
814
940
  @dataclass(frozen=True, kw_only=True)
@@ -878,11 +1004,16 @@ class GLORYSDataset(Dataset):
878
1004
  0,
879
1005
  1,
880
1006
  )
881
-
882
- for var in self.ds.data_vars:
883
- self.ds[var] = xr.where(mask == 1, self.ds[var], np.nan)
1007
+ mask_vel = xr.where(
1008
+ self.ds[self.var_names["u"]]
1009
+ .isel({self.dim_names["time"]: 0, self.dim_names["depth"]: 0})
1010
+ .isnull(),
1011
+ 0,
1012
+ 1,
1013
+ )
884
1014
 
885
1015
  self.ds["mask"] = mask
1016
+ self.ds["mask_vel"] = mask_vel
886
1017
 
887
1018
 
888
1019
  @dataclass(frozen=True, kw_only=True)
@@ -1088,9 +1219,6 @@ class CESMBGCDataset(CESMDataset):
1088
1219
  1,
1089
1220
  )
1090
1221
 
1091
- for var in self.ds.data_vars:
1092
- self.ds[var] = xr.where(mask == 1, self.ds[var], np.nan)
1093
-
1094
1222
  self.ds["mask"] = mask
1095
1223
 
1096
1224
 
@@ -1160,9 +1288,6 @@ class CESMBGCSurfaceForcingDataset(CESMDataset):
1160
1288
  1,
1161
1289
  )
1162
1290
 
1163
- for var in self.ds.data_vars:
1164
- self.ds[var] = xr.where(mask == 1, self.ds[var], np.nan)
1165
-
1166
1291
  self.ds["mask"] = mask
1167
1292
 
1168
1293
 
@@ -1260,21 +1385,30 @@ class ERA5Dataset(Dataset):
1260
1385
  )
1261
1386
  )
1262
1387
  cff = cff * qair
1263
- self.ds["qair"] = 0.62197 * (cff / (patm - 0.378 * cff))
1264
- self.ds["qair"].attrs["long_name"] = "Absolute humidity at 2m"
1265
- self.ds["qair"].attrs["units"] = "kg/kg"
1388
+
1389
+ ds = self.ds
1390
+ ds["qair"] = 0.62197 * (cff / (patm - 0.378 * cff))
1391
+ ds["qair"].attrs["long_name"] = "Absolute humidity at 2m"
1392
+ ds["qair"].attrs["units"] = "kg/kg"
1393
+ ds = ds.drop_vars([self.var_names["d2m"]])
1394
+ object.__setattr__(self, "ds", ds)
1266
1395
 
1267
1396
  # Update var_names dictionary
1268
1397
  var_names = {**self.var_names, "qair": "qair"}
1398
+ var_names.pop("d2m")
1269
1399
  object.__setattr__(self, "var_names", var_names)
1270
1400
 
1271
1401
  if "mask" in self.var_names.keys():
1402
+ ds = self.ds
1272
1403
  mask = xr.where(self.ds[self.var_names["mask"]].isel(time=0).isnull(), 0, 1)
1404
+ ds["mask"] = mask
1405
+ ds = ds.drop_vars([self.var_names["mask"]])
1406
+ object.__setattr__(self, "ds", ds)
1273
1407
 
1274
- for var in self.ds.data_vars:
1275
- self.ds[var] = xr.where(mask == 1, self.ds[var], np.nan)
1276
-
1277
- self.ds["mask"] = mask
1408
+ # Remove mask from var_names dictionary
1409
+ var_names = self.var_names
1410
+ var_names.pop("mask")
1411
+ object.__setattr__(self, "var_names", var_names)
1278
1412
 
1279
1413
 
1280
1414
  @dataclass(frozen=True, kw_only=True)
roms_tools/setup/fill.py CHANGED
@@ -15,7 +15,7 @@ class LateralFill:
15
15
  A 2D boolean mask indicating valid points (True) and land points (False).
16
16
  Boundary points are automatically set to land (True).
17
17
  dims : list of str
18
- Dimensions along which to perform the lateral fill. Defaults to ["latitude", "longitude"].
18
+ Dimensions along which to perform the lateral fill.
19
19
  tol : float, optional
20
20
  Tolerance for the iterative solver, determining convergence. Default is 1.0e-4.
21
21
 
@@ -65,7 +65,7 @@ class LateralFill:
65
65
  non-NaN values.
66
66
  """
67
67
  # Apply fill to anomaly field
68
- mean = var.mean(dim=self.dims, skipna=True)
68
+ mean = var.where(self.mask).mean(dim=self.dims, skipna=True)
69
69
  var = var - mean
70
70
 
71
71
  # Setup the right-hand side (RHS): ocean points take their original values, land points are set to 0