libTEOS10.pl
author Andreas Thurnherr <ant@ldeo.columbia.edu>
Mon, 13 Apr 2020 11:06:22 -0400
changeset 40 c1803ae2540f
parent 38 15c603bc4f70
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
38
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     1
#======================================================================
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     2
#                    L I B T E O S 1 0 . P L 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     3
#                    doc: Fri Jan 18 11:09:22 2019
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     4
#                    dlm: Fri Jan 18 23:23:27 2019
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     5
#                    (c) 2019 A.M. Thurnherr
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     6
#                    uE-Info: 144 30 NIL 0 0 72 2 2 4 NIL ofnI
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     7
#======================================================================
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     8
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
     9
# perl wrapper for GSW TEOS-10 libary
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    10
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    11
# Notes:
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    12
#	- requires GSW shared library (currently GSW-C-3.05.0-4)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    13
#	- requires home-grown perl-interface, implementing GSW::
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    14
#	- small subset of functions implemented
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    15
#	- no temperature scale assumed; set PARAM ITS=90|68
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    16
#	- T90*1.00024=T68
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    17
#	- check values calculated with T68
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    18
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    19
# HISTORY:
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    20
#	Jan 18, 2019: - created
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    21
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    22
require "$ANTS/libvec.pl";
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    23
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    24
use strict;
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    25
use GSW;
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    26
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    27
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    28
# ITS-68/-90 conversion
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    29
#	- call once return conversion factor
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    30
#	- divide input temperatures by conversion factor to turn into ITS-90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    31
#	- multiply output temperatures by conv factor to return to original ITS
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    32
#	- optimized for repeat calls
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    33
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    34
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    35
{ # BEGIN STATIC SCOPE
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    36
	my($TCONV);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    37
	sub TCONV90()
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    38
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    39
		return $TCONV if defined($TCONV);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    40
		my($ITS) = &antsRequireParam('ITS');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    41
		if ($ITS == 68) { 		$TCONV = 1.00024;
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    42
		} elsif ($ITS == 90) {	$TCONV = 1;
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    43
		} else {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    44
			croak("$0: illegal PARAM-value ITS=$ITS\n");
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    45
        }
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    46
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    47
} # END STATIC SCOPE
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    48
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    49
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    50
# practical salinity
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    51
#	- input: cond temp press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    52
#	- use units from %cond.unit
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    53
#	- IDENTICAL TO EOS83 VERIFIED
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    54
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    55
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    56
{ my(@fc,$cscale);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    57
	sub salin(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    58
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    59
		my($C,$T,$P) = &antsFunUsage(3,'...','[cond, temp, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    60
									 \@fc,'cond','temp','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    61
		unless (defined($cscale)) {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    62
			my($cu) = &antsRequireParam('cond.unit');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    63
			if    ($cu eq 'S/m')   { $cscale = 10; }
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    64
			elsif ($cu eq 'mS/cm') { $cscale = 1;  }
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    65
			else { croak("$0: illegal PARAM-value cond.unit=$cu\n"); }
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    66
		}									 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    67
		return numbersp($C,$T,$P) ?
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    68
					GSW::gsw_sp_from_c($C*$cscale,$T,$P) :
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    69
					'nan';
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    70
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    71
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    72
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    73
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    74
# conductivity
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    75
#	- input: salin temp press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    76
#	- take units from %cond.unit
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    77
#	- COND(SALIN(COND)) = COND VERIFIED
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    78
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    79
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    80
{ my(@fc,$cscale);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    81
	sub cond(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    82
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    83
		my($S,$T,$P) = &antsFunUsage(3,'...','[salin, temp, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    84
									 \@fc,'salin','temp','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    85
		unless (defined($cscale)) {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    86
			my($cu) = &antsRequireParam('cond.unit');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    87
			if    ($cu eq 'S/m')   { $cscale = 10; }
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    88
			elsif ($cu eq 'mS/cm') { $cscale = 1;  }
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    89
			else { croak("$0: illegal PARAM-value cond.unit=$cu\n"); }
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    90
		}									 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    91
		return numbersp($S,$T,$P) ?
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    92
					GSW::gsw_c_from_sp($S,$T,$P)/$cscale :
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    93
					'nan';
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    94
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    95
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    96
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    97
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    98
# absolute salinity
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
    99
#	- input salin, press, lon, lat
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   100
#	- if %lat/%lon are available, they are used
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   101
#	- otherwise, they must be supplied as arguments
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   102
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   103
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   104
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   105
	sub asalin(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   106
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   107
		my($LON,$LAT,$SP,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   108
		$LON = &antsParam('lon');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   109
		$LAT = &antsParam('lat');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   110
		if (numbersp($LON,$LAT))  {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   111
			($SP,$P) = &antsFunUsage(2,'..','[salin, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   112
									 \@fc,'salin','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   113
		} else {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   114
			($SP,$P,$LON,$LAT) =
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   115
				&antsFunUsage(4,'....','[salin, press, lon, lat]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   116
							  \@fc,'salin','press','lon','lat',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   117
		}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   118
		return numbersp($LON,$LAT,$SP,$P) ?
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   119
					GSW::gsw_sa_from_sp($SP,$P,$LON,$LAT) :
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   120
					'nan';
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   121
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   122
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   123
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   124
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   125
# potential temperature
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   126
#	- DIFFERENCES < 0.0005 degC IN FULL DEPTH PROFILE VIZ [libEOS83.pl]
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   127
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   128
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   129
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   130
	sub theta(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   131
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   132
		my($SA,$T,$P,$Pref) =
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   133
 			&antsFunUsage(4,'....','[asalin, temp, press,] refpress',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   134
						  \@fc,'asalin','temp','press',undef,@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   135
		return 'nan' unless numbersp($SA,$T,$P,$Pref);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   136
		return $T if ($P == $Pref);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   137
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   138
		return GSW::gsw_pt_from_t($SA,$T/$TCONV,$P,$Pref)*$TCONV;
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   139
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   140
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   141
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   142
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   143
# conservative temperature
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   144
#	- input: asalin temp press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   145
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   146
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   147
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   148
	sub ctemp(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   149
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   150
		my($SA,$T,$P) =
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   151
			&antsFunUsage(3,'...','[asalin, temp, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   152
						  \@fc,'asalin','temp','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   153
		return 'nan' unless numbersp($SA,$T,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   154
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   155
		return GSW::gsw_ct_from_t($SA,$T/$TCONV,$P)*$TCONV;
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   156
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   157
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   158
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   159
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   160
# depth
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   161
#	- input: press lat
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   162
#	- if %lat is available, it is used
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   163
#	- CHECKED AGAINS [libEOS83.pl] => DIFF < 0.12m FOR FULL DEPTH PROF
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   164
#	- PRESS(DEPTH(PRESS)) = PRESS VERIFIED
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   165
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   166
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   167
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   168
	sub depth(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   169
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   170
		my($P,$LAT);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   171
		$LAT = &antsParam('lat');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   172
		if (numberp($LAT)) {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   173
			($P) = &antsFunUsage(1,'.','[press]',\@fc,'press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   174
		} else {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   175
			($P,$LAT) = &antsFunUsage(2,'..','[press, lat]',\@fc,'press','lat',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   176
		}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   177
		return numbersp($P,$LAT) ? -1*GSW::gsw_z_from_p($P,$LAT) : 'nan';
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   178
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   179
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   180
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   181
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   182
# press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   183
#	- input: depth lat
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   184
#	- if %lat is available, it is used
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   185
#	- PRESS(DEPTH(PRESS)) = PRESS VERIFIED
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   186
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   187
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   188
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   189
	sub press(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   190
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   191
		my($D,$LAT);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   192
		$LAT = &antsParam('lat');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   193
		if (numberp($LAT)) {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   194
			($D) = &antsFunUsage(1,'.','[depth]',\@fc,'depth',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   195
		} else {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   196
			($D,$LAT) = &antsFunUsage(2,'..','[depth, lat]',\@fc,'depth','lat',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   197
		}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   198
		return numbersp($D,$LAT) ? GSW::gsw_p_from_z(-1*$D,$LAT) : 'nan';
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   199
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   200
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   201
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   202
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   203
# thermal expansion coefficient
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   204
#	- input: asalin ctemp press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   205
#	- ~ 1% higher than homegrown approximation in [libEOS83.pl]
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   206
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   207
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   208
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   209
	sub alpha(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   210
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   211
		my($SA,$TC,$P) =
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   212
			&antsFunUsage(3,'...','[asalin, ctemp, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   213
						  \@fc,'asalin','ctemp','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   214
		return 'nan' unless numbersp($SA,$TC,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   215
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   216
		return GSW::gsw_alpha($SA,$TC/$TCONV,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   217
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   218
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   219
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   220
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   221
# haline contraction coefficient
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   222
#	- input: asalin ctemp press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   223
#	- ~ 0.6% lower than homegrown approximation in [libEOS83.pl]
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   224
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   225
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   226
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   227
	sub beta(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   228
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   229
		my($SA,$TC,$P) =
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   230
			&antsFunUsage(3,'...','[asalin, ctemp, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   231
						  \@fc,'asalin','ctemp','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   232
		return 'nan' unless numbersp($SA,$TC,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   233
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   234
		return GSW::gsw_beta($SA,$TC/$TCONV,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   235
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   236
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   237
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   238
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   239
# in situ density
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   240
#	- input: asalin ctemp press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   241
#	- CHECKED RHO & ALL SIGMA AGAINST [libEOS83.pl] => CONSISTENT PATTERN
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   242
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   243
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   244
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   245
	sub rho(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   246
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   247
		my($SA,$TC,$P) =
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   248
			&antsFunUsage(3,'...','[asalin, ctemp, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   249
						  \@fc,'asalin','ctemp','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   250
		return 'nan' unless numbersp($SA,$TC,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   251
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   252
		return GSW::gsw_rho($SA,$TC/$TCONV,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   253
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   254
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   255
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   256
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   257
# potential density
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   258
#	- input: asalin ctemp
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   259
#	- CHECKED RHO & ALL SIGMA AGAINST [libEOS83.pl] => CONSISTENT PATTERN
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   260
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   261
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   262
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   263
	sub sigma0(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   264
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   265
		my($SA,$TC) = &antsFunUsage(2,'..','[asalin, ctemp]',\@fc,'asalin','ctemp',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   266
		return 'nan' unless numbersp($SA,$TC);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   267
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   268
		return GSW::gsw_sigma0($SA,$TC/$TCONV);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   269
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   270
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   271
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   272
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   273
	sub sigma1(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   274
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   275
		my($SA,$TC) = &antsFunUsage(2,'..','[asalin, ctemp]',\@fc,'asalin','ctemp',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   276
		return 'nan' unless numbersp($SA,$TC);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   277
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   278
		return GSW::gsw_sigma1($SA,$TC/$TCONV);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   279
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   280
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   281
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   282
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   283
	sub sigma2(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   284
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   285
		my($SA,$TC) = &antsFunUsage(2,'..','[asalin, ctemp]',\@fc,'asalin','ctemp',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   286
		return 'nan' unless numbersp($SA,$TC);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   287
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   288
		return GSW::gsw_sigma2($SA,$TC/$TCONV);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   289
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   290
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   291
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   292
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   293
	sub sigma3(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   294
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   295
		my($SA,$TC) = &antsFunUsage(2,'..','[asalin, ctemp]',\@fc,'asalin','ctemp',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   296
		return 'nan' unless numbersp($SA,$TC);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   297
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   298
		return GSW::gsw_sigma3($SA,$TC/$TCONV);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   299
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   300
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   301
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   302
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   303
	sub sigma4(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   304
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   305
		my($SA,$TC) = &antsFunUsage(2,'..','[asalin, ctemp]',\@fc,'asalin','ctemp',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   306
		return 'nan' unless numbersp($SA,$TC);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   307
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   308
		return GSW::gsw_sigma4($SA,$TC/$TCONV);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   309
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   310
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   311
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   312
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   313
# sound speed
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   314
#	- input: asalin ctemp press
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   315
#	- VERIFIED AGAINST [libEOS83.pl]
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   316
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   317
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   318
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   319
	sub sound_speed(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   320
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   321
		my($SA,$TC,$P) =
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   322
			&antsFunUsage(3,'...','[asalin, ctemp, press]',
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   323
						  \@fc,'asalin','ctemp','press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   324
		return 'nan' unless numbersp($SA,$TC,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   325
		my($TCONV) = &TCONV90();					# library uses ITS90
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   326
		return GSW::gsw_sound_speed($SA,$TC/$TCONV,$P);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   327
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   328
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   329
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   330
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   331
# Coriolis parameter
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   332
#	- input: lat
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   333
#	- copied from [libEOS83.pl]
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   334
#----------------------------------------------------------------------
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   335
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   336
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   337
	sub f(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   338
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   339
		my($lat) = &antsFunUsage(1,'f','[lat]',\@fc,'%lat',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   340
		my($Omega) = 7.292e-5;								# Gill (1982)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   341
		return 2 * $Omega * sin(rad($lat));
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   342
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   343
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   344
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   345
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   346
# acceleration due to gravity
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   347
#	- input: press lat
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   348
#	- if %lat is available, it is used
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   349
#	- CHECKED AGAINST [libEOS83.pl] => DIFFERENCES LESS THAN 0.1%
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   350
#---------------------------------------------------------------------- 
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   351
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   352
{ my(@fc);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   353
	sub g(@)
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   354
	{
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   355
		my($P,$LAT);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   356
		$LAT = &antsParam('lat');
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   357
		if (numberp($LAT)) {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   358
			($P) = &antsFunUsage(1,'.','[press]',\@fc,'press',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   359
		} else {
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   360
			($P,$LAT) = &antsFunUsage(2,'..','[press, lat]',\@fc,'press','lat',@_);
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   361
		}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   362
		return numbersp($P,$LAT) ? GSW::gsw_grav($LAT,$P) : 'nan';
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   363
	}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   364
}
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   365
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   366
1;
15c603bc4f70 after UK cruise
Andreas Thurnherr <ant@ldeo.columbia.edu>
parents:
diff changeset
   367