-
Yves Gouriou authored
Ajout de la bilbiothèque CSIRO à SVN (pas nécessaire)
Yves Gouriou authoredAjout de la bilbiothèque CSIRO à SVN (pas nécessaire)
sw_alpha.m 3.07 KiB
function [ALPHA] = sw_alpha(S, T, P, keyword)
% SW_ALPHA Thermal expansion coefficient (alpha)
%================================================================
% SW_ALPHA $Revision: 1.6 $ $Date: 1998/04/21 05:42:10 $
% Copyright (C) CSIRO, Nathan Bindoff 1993.
%
% USAGE: [ALPHA] = alpha(S, T, P, keyword)
%
% [ALPHA] = alpha(S, T, P, 'temp') %default
% [ALPHA] = alpha(S, PTMP, P, 'ptmp')
%
% DESCRIPTION:
% A function to calculate the thermal expansion coefficient.
%
% INPUT:
% S = salinity [psu (PSS-78) ]
% * PTMP = potential temperature [degree C (IPTS-68)]
% * T = temperature [degree C (IPTS-68)]
% P = pressure [db]
% (P may have dims 1x1, mx1, 1xn or mxn for S(mxn) )
%
% keyword = optional string to identify if temp or ptmp passed.
% = No argument defaults to 'temp'
% = 'temp' assumes (S,T,P) passed. Will execute slower
% as ptmp will be calculated internally.
% = 'ptmp' assumes (S,PTMP,P) passed. Will execute faster.
%
% OUTPUT:
% ALPHA = Thermal expansion coeff (alpha) [degree_C.^-1]
%
% AUTHOR: N.L. Bindoff 1993
%
% DISCLAIMER:
% This software is provided "as is" without warranty of any kind.
% See the file sw_copy.m for conditions of use and licence.
%
% REFERENCE:
% McDougall, T.J. 1987. "Neutral Surfaces"
% Journal of Physical Oceanography vol 17 pages 1950-1964,
%
% CHECK VALUE:
% See sw_beta.m amd sw_aonb.m
%================================================================
% Modifications
% 93-04-22. Phil Morgan, Help display modified to suit library
% 93-04-23. Phil Morgan, Input argument checking
% 94-10-15. Phil Morgan, Pass S,T,P and keyword for 'ptmp'
% CHECK INPUT ARGUMENTS
if ~(nargin==3 | nargin==4)
error('sw_alpha.m: requires 3 or 4 input arguments')
end %if
if nargin == 3
keyword = 'temp';
end %if
% CHECK S,T,P dimensions and verify consistent
[ms,ns] = size(S);
[mt,nt] = size(T);
[mp,np] = size(P);
% CHECK THAT S & T HAVE SAME SHAPE
if (ms~=mt) | (ns~=nt)
error('check_stp: S & T must have same dimensions')
end %if
% CHECK OPTIONAL SHAPES FOR P
if mp==1 & np==1 % P is a scalar. Fill to size of S
P = P(1)*ones(ms,ns);
elseif np==ns & mp==1 % P is row vector with same cols as S
P = P( ones(1,ms), : ); % Copy down each column.
elseif mp==ms & np==1 % P is column vector
P = P( :, ones(1,ns) ); % Copy across each row
elseif mp==ms & np==ns % PR is a matrix size(S)
% shape ok
else
error('check_stp: P has wrong dimensions')
end %if
[mp,np] = size(P);
% IF ALL ROW VECTORS ARE PASSED THEN LET US PRESERVE SHAPE ON RETURN.
Transpose = 0;
if mp == 1 % row vector
P = P(:);
T = T(:);
S = S(:);
Transpose = 1;
end %if
%***check_stp
% BEGIN
ALPHA = sw_aonb(S,T,P,keyword).*sw_beta(S,T,P,keyword);
return
%------------------------------------------------------------------------