{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "using SpeedyWeather\n",
    "\n",
    "spectral_grid = SpectralGrid(trunc=31, nlev=5)\n",
    "ocean = AquaPlanet(spectral_grid, temp_equator=302, temp_poles=273)\n",
    "land_sea_mask = AquaPlanetMask(spectral_grid)\n",
    "orography = NoOrography(spectral_grid)\n",
    "\n",
    "output = OutputWriter(spectral_grid, PrimitiveWet, output_dt=Hour(1))\n",
    "model = PrimitiveWetModel(; spectral_grid, ocean, land_sea_mask, orography)\n",
    "simulation = initialize!(model)\n",
    "model.feedback.verbose = false # hide\n",
    "run!(simulation, period=Day(30), output=true)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model.atmosphere"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "using SpeedyWeather\n",
    "spectral_grid = SpectralGrid(trunc=170, nlev=1)\n",
    "\n",
    "# construct model with only Held-Suarez forcing, no other physics\n",
    "model = PrimitiveDryModel(;\n",
    "    spectral_grid,\n",
    "\n",
    "    # Held-Suarez forcing and drag\n",
    "    temperature_relaxation = HeldSuarez(spectral_grid),\n",
    "    boundary_layer_drag = LinearDrag(spectral_grid),\n",
    "\n",
    "    # switch off other physics\n",
    "    convection = NoConvection(),\n",
    "    shortwave_radiation = NoShortwave(),\n",
    "    longwave_radiation = NoLongwave(),\n",
    "    vertical_diffusion = NoVerticalDiffusion(),\n",
    "\n",
    "    # switch off surface fluxes (makes ocean/land/land-sea mask redundant)\n",
    "    surface_wind = NoSurfaceWind(),\n",
    "    surface_heat_flux = NoSurfaceHeatFlux(),\n",
    "\n",
    "    # use Earth's orography\n",
    "    orography = EarthOrography(spectral_grid)\n",
    ")\n",
    "\n",
    "simulation = initialize!(model)\n",
    "run!(simulation, period=Day(1), output=true)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "simulation.prognostic_variables.ocean.sea_surface_temperature"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "simulation.prognostic_variables.clock.n_timesteps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sst = simulation.prognostic_variables.ocean.sea_surface_temperature"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "using CairoMakie\n",
    "\n",
    "heatmap(sst, title=\"Sea surface temperature [K]\", colormap=:thermal)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Julia 1.10.3",
   "language": "julia",
   "name": "julia-1.10"
  },
  "language_info": {
   "file_extension": ".jl",
   "mimetype": "application/julia",
   "name": "julia",
   "version": "1.10.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
