source: issm/trunk-jpl/src/c/shared/Elements/Cuffey.cpp@ 17457

Last change on this file since 17457 was 17457, checked in by Mathieu Morlighem, 11 years ago

NEW: added Cuffey.cpp

File size: 2.2 KB
Line 
1/* \file Cuffey.cpp
2 * \brief figure out B of ice for a certain temperature
3 * INPUT function B=Cuffey(temperature)
4 * where rigidigty (in s^(1/3)Pa) is the flow law paramter in the flow law sigma=B*e(1/3) (Cuffey, p75).
5 */
6
7#include <math.h>
8
9#include "../Numerics/types.h"
10
11IssmDouble Cuffey(IssmDouble temperature){
12
13 /*output: */
14 IssmDouble B,T;
15
16 /*Switch to celsius from Kelvin: */
17 T=temperature-273.15;
18
19 if(T<=-45.0){
20 B=1.e+8*(-0.000396645116301*pow(T+50.,3)+ 0.013345579471334*pow(T+50.,2) -0.356868703259105*(T+50.)+7.272363035371383);
21 }
22 else if((T>=-45.0) && (T<=-40.0)){
23 B=1.e+8*(-0.000396645116301*pow(T+45.,3)+ 0.007395902726819*pow(T+45.,2) -0.253161292268336*(T+45.)+5.772078366321591);
24 }
25 else if((T>=-40.0) && (T<=-35.0)){
26 B=1.e+8*(0.000408322072669*pow(T+40.,3)+ 0.001446225982305*pow(T+40.,2) -0.208950648722716*(T+40.)+4.641588833612773);
27 }
28 else if((T>=-35.0) && (T<=-30.0)){
29 B=1.e+8*(-0.000423888728124*pow(T+35.,3)+ 0.007571057072334*pow(T+35.,2) -0.163864233449525*(T+35.)+3.684031498640382);
30 }
31 else if((T>=-30.0) && (T<=-25.0)){
32 B=1.e+8*(0.000147154327025*pow(T+30.,3)+ 0.001212726150476*pow(T+30.,2) -0.119945317335478*(T+30.)+3.001000667185614);
33 }
34 else if((T>=-25.0) && (T<=-20.0)){
35 B=1.e+8*(-0.000193435838672*pow(T+25.,3)+ 0.003420041055847*pow(T+25.,2) -0.096781481303861*(T+25.)+2.449986525148220);
36 }
37 else if((T>=-20.0) && (T<=-15.0)){
38 B=1.e+8*(0.000219771255067*pow(T+20.,3)+ 0.000518503475772*pow(T+20.,2) -0.077088758645767*(T+20.)+2.027400665191131);
39 }
40 else if((T>=-15.0) && (T<=-10.0)){
41 B=1.e+8*(-0.000653438900191*pow(T+15.,3)+ 0.003815072301777*pow(T+15.,2) -0.055420879758021*(T+15.)+1.682390865739973);
42 }
43 else if((T>=-10.0) && (T<=-5.0)){
44 B=1.e+8*(0.000692439419762*pow(T+10.,3) -0.005986511201093 *pow(T+10.,2) -0.066278074254598*(T+10.)+1.418983411970382);
45 }
46 else if((T>=-5.0) && (T<=-2.0)){
47 B=1.e+8*(-0.000132282004110*pow(T+5.,3) +0.004400080095332*pow(T+5.,2) -0.074210229783403*(T+5.)+ 1.024485188140279);
48 }
49 else{
50 B=1.e+8*(-0.000132282004110*pow(T+2.,3) +0.003209542058346*pow(T+2.,2) -0.051381363322371*(T+2.)+ 0.837883605537096);
51 }
52
53 /*B cannot be negative!*/
54 if(B<0) B=1.e+6;
55
56 return B;
57}
Note: See TracBrowser for help on using the repository browser.