From c0bba2abdb464842cb8532fcda2a456d5abee719 Mon Sep 17 00:00:00 2001 From: Lee de Mora Date: Wed, 3 Jul 2024 15:00:15 +0100 Subject: [PATCH] revised foc calculation --- bgcval2/functions/circulation.py | 31 +++++++++++++++++++++---------- 1 file changed, 21 insertions(+), 10 deletions(-) diff --git a/bgcval2/functions/circulation.py b/bgcval2/functions/circulation.py index fd8c02f..77442da 100644 --- a/bgcval2/functions/circulation.py +++ b/bgcval2/functions/circulation.py @@ -354,8 +354,6 @@ def AMOC26N(nc, keys, **kwargs): return atlmoc.max() - - def fov_sa(nc, keys, **kwargs): # Fov/Mov defined in Jackson 2023 as: # We also use diagnostics of the overturning component of the Atlantic freshwater transport (Fov). @@ -449,14 +447,29 @@ def fov_sa(nc, keys, **kwargs): for (z, y, x), thk in maenumerate(xarea): la = lats[y, x] xarea[z, y, x] = thk * zonal_distances[la] - xarea_sum = xarea.sum(axis=(0,2)) + #xarea_sum = xarea.sum(axis=(0,2)) + xarea_sum2 = xarea.sum(axis=2) + + # Vbar = SUM( vo(x)*thickcello(x)*dx) / SUM( thickcello*dx) + + vobar = (vo* xarea).sum(2) / xarea_sum2 + + print('vobar', vobar.shape, vobar.min(), vobar.max()) + + sobar = (sal0* xarea).sum(2) / xarea_sum2 + print('sobar', sobar.shape, sobar.min(), sobar.max()) + + + vsbar = (vobar*sobar * xarea_sum2).sum(1) + print('vsbar', vsbar.shape, vsbar.min(), vsbar.max()) + + total = vsbar.mean() # Take the zonal sum of the meridional velocity, the normalised salinity and the cross sectional area - total = vo * sal0 * xarea + #total = vo * sal0 * xarea # Calculate the cross sectional total, then divide by the total cross section area - total = total.sum(axis=(0, 2))/xarea_sum - + #total = total.sum(axis=(0, 2))/xarea_sum #print('total', {f:True for f in total.compressed()}.keys()) #pyplot.pcolormesh(vo[0] * sal0[0] * xarea[0]) @@ -466,17 +479,15 @@ def fov_sa(nc, keys, **kwargs): #pyplot.close() # Take the mean in the meridional area - total = total.mean() + #total = total.mean() # Apply factors from paper. output = (-1./sal_ref) * total print(output) - #assert 0 + assert 0 return output - - def AEU(nc, keys, **kwargs): """ Calculate the Atlantic Equatorial Undercurrent