From a669ef8c035e851b6f54731196d64b67fa0c4ebe Mon Sep 17 00:00:00 2001 From: Erik Kluzek Date: Tue, 5 Dec 2023 08:35:47 -0700 Subject: [PATCH 01/16] Bring PE layouts from ekluzek/derecho1, removing the S layouts --- cime_config/config_pes.xml | 414 +++++++++++++++++++++++++++++++++---- 1 file changed, 374 insertions(+), 40 deletions(-) diff --git a/cime_config/config_pes.xml b/cime_config/config_pes.xml index d391f2b9d1..974e176109 100644 --- a/cime_config/config_pes.xml +++ b/cime_config/config_pes.xml @@ -113,6 +113,43 @@ + + + + none + + -1 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + @@ -224,39 +261,113 @@ + + + + none + + -1 + -12 + -12 + -12 + -12 + -12 + -12 + -12 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + + + + + none + + -1 + -11 + -11 + -11 + -11 + -11 + -11 + -11 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + none - -4 - -4 - -4 - -4 - -4 - -4 - -4 - -4 + -4 + -4 + -4 + -4 + -4 + -4 + -4 + -4 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 - 0 - 0 - 0 - 0 - 0 - 0 - 0 - 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 @@ -298,6 +409,80 @@ + + + + none + + -1 + -14 + -14 + -14 + -14 + -14 + -14 + -14 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + + + + + none + + -1 + -11 + -11 + -11 + -11 + -11 + -11 + -11 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + @@ -409,6 +594,80 @@ + + + + none + + -1 + -5 + -5 + -5 + -5 + -5 + -5 + -5 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + + + + + none + + -1 + -20 + -20 + -20 + -20 + -20 + -20 + -20 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + @@ -757,14 +1016,14 @@ -48 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - 2 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 0 @@ -831,14 +1090,14 @@ -48 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - 2 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 0 @@ -1077,6 +1336,44 @@ + + + + none + + -1 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + + + + @@ -1189,6 +1486,43 @@ + + + + none + + -1 + -14 + -14 + -14 + -14 + -14 + -14 + -14 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + + + 0 + -1 + -1 + -1 + -1 + -1 + -1 + -1 + + + + From 89709e9b9209f89faa3537dbccf60b40bc06b78a Mon Sep 17 00:00:00 2001 From: Erik Kluzek Date: Tue, 5 Dec 2023 09:40:26 -0700 Subject: [PATCH 02/16] First pass at moving cheyenne tests to derecho, and also removing gnu tests on derecho (change to intel if only gnu was run) --- cime_config/testdefs/testlist_clm.xml | 504 ++++++++++---------- cime_config/testdefs/testlist_clm_nuopc.xml | 420 ++++++++-------- 2 files changed, 434 insertions(+), 490 deletions(-) diff --git a/cime_config/testdefs/testlist_clm.xml b/cime_config/testdefs/testlist_clm.xml index 90f5573537..b5ec791eb8 100644 --- a/cime_config/testdefs/testlist_clm.xml +++ b/cime_config/testdefs/testlist_clm.xml @@ -2,7 +2,7 @@ - + @@ -10,8 +10,8 @@ - - + + @@ -19,8 +19,8 @@ - - + + @@ -28,7 +28,7 @@ - + @@ -37,8 +37,7 @@ - - + @@ -46,7 +45,7 @@ - + @@ -55,7 +54,7 @@ - + @@ -63,7 +62,7 @@ - + @@ -71,7 +70,7 @@ - + @@ -80,7 +79,7 @@ - + @@ -89,8 +88,8 @@ - - + + @@ -124,7 +123,7 @@ - + @@ -132,7 +131,7 @@ - + @@ -141,7 +140,7 @@ - + @@ -150,7 +149,7 @@ - + @@ -158,7 +157,7 @@ - + @@ -166,7 +165,7 @@ - + @@ -174,8 +173,7 @@ - - + @@ -183,7 +181,7 @@ - + @@ -191,7 +189,7 @@ - + @@ -199,8 +197,7 @@ - - + @@ -208,8 +205,7 @@ - - + @@ -217,7 +213,7 @@ - + @@ -233,7 +229,7 @@ - + @@ -242,7 +238,7 @@ - + @@ -251,7 +247,7 @@ - + @@ -259,7 +255,7 @@ - + @@ -267,7 +263,7 @@ - + @@ -275,7 +271,7 @@ - + @@ -283,8 +279,8 @@ - - + + @@ -292,7 +288,7 @@ - + @@ -300,8 +296,7 @@ - - + @@ -309,7 +304,7 @@ - + @@ -317,7 +312,7 @@ - + @@ -325,8 +320,8 @@ - - + + @@ -342,7 +337,7 @@ - + @@ -367,7 +362,7 @@ - + @@ -375,10 +370,8 @@ - - - - + + @@ -386,7 +379,7 @@ - + @@ -394,7 +387,7 @@ - + @@ -402,7 +395,7 @@ - + @@ -410,7 +403,7 @@ - + @@ -418,8 +411,7 @@ - - + @@ -427,7 +419,7 @@ - + @@ -436,7 +428,7 @@ - + @@ -445,7 +437,7 @@ - + @@ -454,8 +446,8 @@ - - + + @@ -473,7 +465,7 @@ - + @@ -481,7 +473,7 @@ - + @@ -489,8 +481,7 @@ - - + @@ -498,7 +489,7 @@ - + @@ -506,7 +497,7 @@ - + @@ -524,7 +515,7 @@ - + @@ -532,7 +523,7 @@ - + @@ -548,7 +539,7 @@ - + @@ -596,7 +587,7 @@ - + @@ -605,7 +596,7 @@ - + @@ -614,7 +605,7 @@ - + @@ -623,8 +614,8 @@ - - + + @@ -632,7 +623,7 @@ - + @@ -640,7 +631,7 @@ - + @@ -648,7 +639,7 @@ - + @@ -657,8 +648,7 @@ - - + @@ -667,7 +657,7 @@ - + @@ -676,7 +666,7 @@ - + @@ -684,8 +674,7 @@ - - + @@ -694,7 +683,7 @@ - + @@ -703,8 +692,8 @@ - - + + @@ -712,7 +701,7 @@ - + @@ -721,8 +710,8 @@ - - + + @@ -730,7 +719,7 @@ - + @@ -738,7 +727,7 @@ - + @@ -747,7 +736,7 @@ - + @@ -757,7 +746,7 @@ - + @@ -765,7 +754,7 @@ - + @@ -774,8 +763,8 @@ - - + + @@ -784,7 +773,7 @@ - + @@ -794,7 +783,7 @@ - + @@ -802,7 +791,7 @@ - + @@ -811,7 +800,7 @@ - + @@ -820,7 +809,7 @@ - + @@ -829,7 +818,7 @@ - + @@ -838,7 +827,7 @@ - + @@ -847,7 +836,7 @@ - + @@ -855,10 +844,8 @@ - - - - + + @@ -866,7 +853,7 @@ - + @@ -875,8 +862,7 @@ - - + @@ -884,7 +870,7 @@ - + @@ -892,7 +878,7 @@ - + @@ -908,8 +894,7 @@ - - + @@ -917,7 +902,7 @@ - + @@ -926,7 +911,7 @@ - + @@ -934,7 +919,7 @@ - + @@ -943,7 +928,7 @@ - + @@ -951,7 +936,7 @@ - + @@ -960,7 +945,7 @@ - + @@ -969,7 +954,7 @@ - + @@ -978,7 +963,7 @@ - + @@ -987,7 +972,7 @@ - + @@ -997,7 +982,7 @@ - + @@ -1006,7 +991,7 @@ - + @@ -1015,7 +1000,7 @@ - + @@ -1032,7 +1017,7 @@ - + @@ -1041,7 +1026,7 @@ - + @@ -1050,7 +1035,7 @@ - + @@ -1060,7 +1045,7 @@ - + @@ -1069,7 +1054,7 @@ - + @@ -1078,7 +1063,7 @@ - + @@ -1087,8 +1072,8 @@ - - + + @@ -1097,8 +1082,8 @@ - - + + @@ -1106,8 +1091,8 @@ - - + + @@ -1124,7 +1109,7 @@ - + @@ -1143,7 +1128,7 @@ - + @@ -1151,7 +1136,7 @@ - + @@ -1159,7 +1144,7 @@ - + @@ -1169,7 +1154,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1178,7 +1163,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1187,7 +1172,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1196,7 +1181,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1205,7 +1190,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1214,7 +1199,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1248,7 +1233,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1257,8 +1242,7 @@ for ERS test as otherwise it won't work for a sub-day test" - - + @@ -1266,12 +1250,10 @@ for ERS test as otherwise it won't work for a sub-day test" - - + - + - @@ -1287,7 +1269,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1305,10 +1287,10 @@ for ERS test as otherwise it won't work for a sub-day test" - - - - + + + + @@ -1316,9 +1298,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - - + + @@ -1326,7 +1307,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1334,8 +1315,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -1352,8 +1333,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -1362,8 +1343,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -1372,7 +1353,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1381,7 +1362,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1400,7 +1381,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1408,7 +1389,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1416,7 +1397,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1424,7 +1405,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1432,9 +1413,8 @@ for ERS test as otherwise it won't work for a sub-day test" - + - @@ -1442,7 +1422,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1450,7 +1430,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1458,17 +1438,16 @@ for ERS test as otherwise it won't work for a sub-day test" - - + - + - + @@ -1476,7 +1455,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1501,8 +1480,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -1511,25 +1490,25 @@ for ERS test as otherwise it won't work for a sub-day test" - + - + - + - + - + @@ -1537,7 +1516,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1546,7 +1525,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1555,8 +1534,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -1565,8 +1544,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -1574,7 +1553,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1592,7 +1571,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1600,7 +1579,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1609,7 +1588,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1617,7 +1596,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1626,9 +1605,8 @@ for ERS test as otherwise it won't work for a sub-day test" - + - @@ -1636,7 +1614,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1645,7 +1623,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1654,7 +1632,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1663,7 +1641,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1672,7 +1650,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1680,9 +1658,8 @@ for ERS test as otherwise it won't work for a sub-day test" - + - @@ -1690,7 +1667,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1698,9 +1675,8 @@ for ERS test as otherwise it won't work for a sub-day test" - + - @@ -1708,7 +1684,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1716,10 +1692,9 @@ for ERS test as otherwise it won't work for a sub-day test" - + - - + @@ -1727,7 +1702,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1735,7 +1710,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1743,8 +1718,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -1752,7 +1727,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1760,7 +1735,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1768,7 +1743,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1776,8 +1751,7 @@ for ERS test as otherwise it won't work for a sub-day test" - - + @@ -1785,7 +1759,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1816,7 +1790,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1827,7 +1801,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1838,7 +1812,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1850,7 +1824,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1862,7 +1836,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1873,7 +1847,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1881,7 +1855,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1889,7 +1863,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1897,7 +1871,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1906,7 +1880,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1914,7 +1888,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1922,7 +1896,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1930,7 +1904,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1939,7 +1913,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1947,7 +1921,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1956,7 +1930,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1964,7 +1938,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1972,7 +1946,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1980,7 +1954,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1988,7 +1962,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -1997,7 +1971,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -2005,9 +1979,9 @@ for ERS test as otherwise it won't work for a sub-day test" - - - + + + @@ -2016,8 +1990,8 @@ for ERS test as otherwise it won't work for a sub-day test" - - + + @@ -2027,7 +2001,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -2037,7 +2011,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -2047,7 +2021,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -2057,7 +2031,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -2067,7 +2041,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -2078,7 +2052,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + @@ -2089,7 +2063,7 @@ for ERS test as otherwise it won't work for a sub-day test" - + diff --git a/cime_config/testdefs/testlist_clm_nuopc.xml b/cime_config/testdefs/testlist_clm_nuopc.xml index cbe0473539..024cae2a4b 100644 --- a/cime_config/testdefs/testlist_clm_nuopc.xml +++ b/cime_config/testdefs/testlist_clm_nuopc.xml @@ -2,7 +2,7 @@ - + @@ -10,7 +10,7 @@ - + @@ -19,8 +19,7 @@ - - + @@ -28,7 +27,7 @@ - + @@ -36,7 +35,7 @@ - + @@ -44,7 +43,7 @@ - + @@ -53,7 +52,7 @@ - + @@ -86,7 +85,7 @@ - + @@ -94,7 +93,7 @@ - + @@ -102,7 +101,7 @@ - + @@ -110,7 +109,7 @@ - + @@ -118,7 +117,7 @@ - + @@ -126,8 +125,7 @@ - - + @@ -135,7 +133,7 @@ - + @@ -143,7 +141,7 @@ - + @@ -159,8 +157,7 @@ - - + @@ -168,8 +165,7 @@ - - + @@ -185,7 +181,7 @@ - + @@ -201,7 +197,7 @@ - + @@ -210,7 +206,7 @@ - + @@ -218,7 +214,7 @@ - + @@ -226,7 +222,7 @@ - + @@ -234,7 +230,7 @@ - + @@ -242,7 +238,7 @@ - + @@ -250,7 +246,7 @@ - + @@ -259,7 +255,7 @@ - + @@ -267,8 +263,7 @@ - - + @@ -276,7 +271,7 @@ - + @@ -284,7 +279,7 @@ - + @@ -292,7 +287,7 @@ - + @@ -308,8 +303,8 @@ - - + + @@ -334,7 +329,7 @@ - + @@ -342,10 +337,8 @@ - - - - + + @@ -353,7 +346,7 @@ - + @@ -361,7 +354,7 @@ - + @@ -369,7 +362,7 @@ - + @@ -377,7 +370,7 @@ - + @@ -385,8 +378,7 @@ - - + @@ -394,7 +386,7 @@ - + @@ -403,7 +395,7 @@ - + @@ -412,7 +404,7 @@ - + @@ -421,7 +413,7 @@ - + @@ -438,7 +430,7 @@ - + @@ -446,7 +438,7 @@ - + @@ -454,8 +446,7 @@ - - + @@ -463,7 +454,7 @@ - + @@ -471,7 +462,7 @@ - + @@ -479,7 +470,6 @@ - @@ -488,7 +478,7 @@ - + @@ -496,7 +486,7 @@ - + @@ -512,7 +502,7 @@ - + @@ -560,7 +550,7 @@ - + @@ -569,7 +559,7 @@ - + @@ -578,7 +568,7 @@ - + @@ -587,7 +577,7 @@ - + @@ -595,7 +585,7 @@ - + @@ -603,7 +593,7 @@ - + @@ -611,8 +601,8 @@ - - + + @@ -621,8 +611,7 @@ - - + @@ -631,7 +620,7 @@ - + @@ -640,8 +629,7 @@ - - + @@ -650,7 +638,7 @@ - + @@ -659,7 +647,7 @@ - + @@ -667,7 +655,7 @@ - + @@ -676,7 +664,7 @@ - + @@ -684,7 +672,7 @@ - + @@ -693,7 +681,7 @@ - + @@ -703,7 +691,7 @@ - + @@ -711,7 +699,7 @@ - + @@ -720,8 +708,8 @@ - - + + @@ -730,7 +718,7 @@ - + @@ -740,7 +728,7 @@ - + @@ -748,7 +736,7 @@ - + @@ -757,7 +745,7 @@ - + @@ -766,7 +754,7 @@ - + @@ -775,7 +763,7 @@ - + @@ -784,7 +772,7 @@ - + @@ -792,10 +780,8 @@ - - - - + + @@ -803,7 +789,7 @@ - + @@ -811,8 +797,7 @@ - - + @@ -820,7 +805,7 @@ - + @@ -828,7 +813,7 @@ - + @@ -844,8 +829,7 @@ - - + @@ -853,7 +837,7 @@ - + @@ -862,7 +846,7 @@ - + @@ -870,7 +854,7 @@ - + @@ -886,7 +870,7 @@ - + @@ -894,7 +878,7 @@ - + @@ -903,7 +887,7 @@ - + @@ -912,7 +896,7 @@ - + @@ -921,7 +905,7 @@ - + @@ -931,7 +915,7 @@ - + @@ -940,7 +924,7 @@ - + @@ -949,7 +933,7 @@ - + @@ -966,7 +950,7 @@ - + @@ -975,7 +959,7 @@ - + @@ -984,7 +968,7 @@ - + @@ -994,7 +978,7 @@ - + @@ -1003,7 +987,7 @@ - + @@ -1012,7 +996,7 @@ - + @@ -1021,7 +1005,7 @@ - + @@ -1030,7 +1014,7 @@ - + @@ -1038,7 +1022,7 @@ - + @@ -1046,7 +1030,7 @@ - + @@ -1062,8 +1046,7 @@ - - + @@ -1074,7 +1057,6 @@ - @@ -1083,7 +1065,7 @@ - + @@ -1091,7 +1073,7 @@ - + @@ -1101,7 +1083,6 @@ - @@ -1110,7 +1091,6 @@ - @@ -1127,7 +1107,7 @@ - + @@ -1136,8 +1116,8 @@ - - + + @@ -1145,12 +1125,10 @@ - - + - + - @@ -1166,7 +1144,7 @@ - + @@ -1184,9 +1162,9 @@ - - - + + + @@ -1194,8 +1172,7 @@ - - + @@ -1203,7 +1180,7 @@ - + @@ -1211,7 +1188,7 @@ - + @@ -1228,7 +1205,7 @@ - + @@ -1237,8 +1214,8 @@ - - + + @@ -1247,7 +1224,7 @@ - + @@ -1256,7 +1233,7 @@ - + @@ -1274,7 +1251,7 @@ - + @@ -1282,7 +1259,7 @@ - + @@ -1291,7 +1268,7 @@ - + @@ -1299,7 +1276,7 @@ - + @@ -1307,9 +1284,8 @@ - + - @@ -1317,7 +1293,7 @@ - + @@ -1325,7 +1301,7 @@ - + @@ -1333,17 +1309,16 @@ - - + - + - + @@ -1351,7 +1326,7 @@ - + @@ -1376,7 +1351,7 @@ - + @@ -1384,7 +1359,7 @@ - + @@ -1393,7 +1368,7 @@ - + @@ -1402,7 +1377,7 @@ - + @@ -1411,7 +1386,7 @@ - + @@ -1419,7 +1394,7 @@ - + @@ -1437,7 +1412,7 @@ - + @@ -1445,7 +1420,7 @@ - + @@ -1454,7 +1429,7 @@ - + @@ -1462,7 +1437,7 @@ - + @@ -1471,9 +1446,8 @@ - + - @@ -1481,7 +1455,7 @@ - + @@ -1490,7 +1464,7 @@ - + @@ -1499,7 +1473,7 @@ - + @@ -1508,7 +1482,7 @@ - + @@ -1517,7 +1491,7 @@ - + @@ -1525,9 +1499,8 @@ - + - @@ -1535,7 +1508,7 @@ - + @@ -1543,9 +1516,8 @@ - + - @@ -1553,7 +1525,7 @@ - + @@ -1561,9 +1533,8 @@ - + - @@ -1571,7 +1542,7 @@ - + @@ -1579,7 +1550,7 @@ - + @@ -1587,7 +1558,7 @@ - + @@ -1595,7 +1566,7 @@ - + @@ -1603,7 +1574,7 @@ - + @@ -1611,7 +1582,7 @@ - + @@ -1619,8 +1590,7 @@ - - + @@ -1628,7 +1598,7 @@ - + @@ -1659,7 +1629,7 @@ - + @@ -1670,7 +1640,7 @@ - + @@ -1681,7 +1651,7 @@ - + @@ -1693,7 +1663,7 @@ - + @@ -1705,7 +1675,7 @@ - + @@ -1716,7 +1686,7 @@ - + @@ -1724,7 +1694,7 @@ - + @@ -1732,7 +1702,7 @@ - + @@ -1740,7 +1710,7 @@ - + @@ -1750,7 +1720,7 @@ - + @@ -1759,7 +1729,7 @@ - + @@ -1767,7 +1737,7 @@ - + @@ -1775,7 +1745,7 @@ - + @@ -1785,7 +1755,7 @@ - + @@ -1793,7 +1763,7 @@ - + @@ -1803,7 +1773,7 @@ - + @@ -1811,7 +1781,7 @@ - + @@ -1819,7 +1789,7 @@ - + @@ -1827,7 +1797,7 @@ - + @@ -1835,7 +1805,7 @@ - + @@ -1843,7 +1813,7 @@ - + @@ -1851,7 +1821,7 @@ - + @@ -1860,7 +1830,7 @@ - + @@ -1870,7 +1840,7 @@ - + @@ -1880,7 +1850,7 @@ - + @@ -1890,7 +1860,7 @@ - + @@ -1900,7 +1870,7 @@ - + From 991bccafcfb674dad17780df2c492fef41b5fd61 Mon Sep 17 00:00:00 2001 From: Erik Kluzek Date: Tue, 5 Dec 2023 09:56:49 -0700 Subject: [PATCH 03/16] Remove tools and add a note about it --- tools/README | 291 +-- tools/README.filecopies | 38 - tools/README.testing | 58 - tools/contrib/README | 48 - tools/contrib/SpinupStability.ncl | 791 -------- tools/contrib/modify_singlept_site | 391 ---- tools/contrib/run_clm_historical | 365 ---- tools/contrib/run_clmtowers | 356 ---- tools/contrib/singlept | 375 ---- tools/contrib/ssp_anomaly_forcing_smooth | 343 ---- tools/contrib/subset_surfdata | 141 -- tools/mkmapdata/README | 87 - tools/mkmapdata/createXMLEntries.pl | 116 -- tools/mkmapdata/mkmapdata.sh | 561 ------ tools/mkmapdata/mknoocnmap.pl | 302 --- tools/mkmapdata/mkunitymap.ncl | 166 -- tools/mkmapdata/mvNimport.sh | 75 - tools/mkmapdata/regridbatch.sh | 105 - tools/mkmapdata/regridgeyser.sh | 87 - tools/mkmapdata/rmdups.ncl | 131 -- tools/mkmapgrids/README | 22 - tools/mkmapgrids/mkscripgrid.ncl | 188 -- tools/mkprocdata_map/README | 152 -- tools/mkprocdata_map/README.filedescriptions | 25 - tools/mkprocdata_map/mkprocdata_map_all | 202 -- .../mkprocdata_map_functions.bash | 57 - tools/mkprocdata_map/mkprocdata_map_wrap | 250 --- tools/mkprocdata_map/src/Filepath | 1 - tools/mkprocdata_map/src/Makefile | 10 - tools/mkprocdata_map/src/Makefile.common | 360 ---- tools/mkprocdata_map/src/Mkdepends | 327 --- tools/mkprocdata_map/src/Srcfiles | 8 - tools/mkprocdata_map/src/constMod.F90 | 11 - tools/mkprocdata_map/src/fileutils.F90 | 282 --- tools/mkprocdata_map/src/fmain.F90 | 78 - tools/mkprocdata_map/src/gridmapMod.F90 | 289 --- tools/mkprocdata_map/src/mkprocdata_map.F90 | 525 ----- tools/mkprocdata_map/src/nanMod.F90 | 41 - tools/mkprocdata_map/src/shr_file_mod.F90 | 164 -- tools/mkprocdata_map/src/shr_kind_mod.F90 | 19 - tools/mksurfdata_map/Makefile.data | 266 --- tools/mksurfdata_map/README | 73 - tools/mksurfdata_map/README.developers | 227 --- ..._timeseries_hist_78pfts_simyr1850-2015.txt | 332 ---- tools/mksurfdata_map/mksurfdata.pl | 871 -------- tools/mksurfdata_map/mksurfdata_map.namelist | 54 - .../single_point_dynpft_files/README | 4 - ...imeseries_smallvilleIA_hist_simyr1850-1855 | 23 - ...eries_smallvilleIA_hist_simyr1850-1855.txt | 6 - tools/mksurfdata_map/src/CMakeLists.txt | 43 - tools/mksurfdata_map/src/Filepath | 1 - tools/mksurfdata_map/src/Makefile | 10 - tools/mksurfdata_map/src/Makefile.common | 360 ---- tools/mksurfdata_map/src/Mkdepends | 327 --- tools/mksurfdata_map/src/README.unit_testing | 9 - tools/mksurfdata_map/src/Srcfiles | 40 - tools/mksurfdata_map/src/fileutils.F90 | 254 --- tools/mksurfdata_map/src/mkVICparamsMod.F90 | 187 -- .../mksurfdata_map/src/mkagfirepkmonthMod.F90 | 263 --- tools/mksurfdata_map/src/mkchecksMod.F90 | 233 --- tools/mksurfdata_map/src/mkdiagnosticsMod.F90 | 410 ---- tools/mksurfdata_map/src/mkdomainMod.F90 | 962 --------- tools/mksurfdata_map/src/mkfileMod.F90 | 566 ------ tools/mksurfdata_map/src/mkgdpMod.F90 | 134 -- .../mksurfdata_map/src/mkglacierregionMod.F90 | 124 -- tools/mksurfdata_map/src/mkglcmecMod.F90 | 796 -------- tools/mksurfdata_map/src/mkgridmapMod.F90 | 935 --------- tools/mksurfdata_map/src/mkharvestMod.F90 | 1098 ----------- tools/mksurfdata_map/src/mkindexmapMod.F90 | 762 ------- tools/mksurfdata_map/src/mklaiMod.F90 | 444 ----- tools/mksurfdata_map/src/mklanwatMod.F90 | 509 ----- tools/mksurfdata_map/src/mkncdio.F90 | 558 ------ tools/mksurfdata_map/src/mkpctPftTypeMod.F90 | 626 ------ tools/mksurfdata_map/src/mkpeatMod.F90 | 136 -- .../mksurfdata_map/src/mkpftConstantsMod.F90 | 43 - tools/mksurfdata_map/src/mkpftMod.F90 | 1257 ------------ tools/mksurfdata_map/src/mkpftUtilsMod.F90 | 257 --- tools/mksurfdata_map/src/mksoilMod.F90 | 1265 ------------ tools/mksurfdata_map/src/mksoilUtilsMod.F90 | 224 --- tools/mksurfdata_map/src/mksoildepthMod.F90 | 159 -- tools/mksurfdata_map/src/mksurfdat.F90 | 1631 --------------- tools/mksurfdata_map/src/mktopostatsMod.F90 | 176 -- .../src/mkurbanparCommonMod.F90 | 354 ---- tools/mksurfdata_map/src/mkurbanparMod.F90 | 749 ------- tools/mksurfdata_map/src/mkutilsMod.F90 | 197 -- tools/mksurfdata_map/src/mkvarctl.F90 | 91 - tools/mksurfdata_map/src/mkvarpar.F90 | 33 - tools/mksurfdata_map/src/mkvocefMod.F90 | 218 -- tools/mksurfdata_map/src/nanMod.F90 | 41 - tools/mksurfdata_map/src/shr_const_mod.F90 | 58 - tools/mksurfdata_map/src/shr_file_mod.F90 | 1023 ---------- tools/mksurfdata_map/src/shr_kind_mod.F90 | 19 - tools/mksurfdata_map/src/shr_log_mod.F90 | 13 - tools/mksurfdata_map/src/shr_string_mod.F90 | 1753 ----------------- tools/mksurfdata_map/src/shr_sys_mod.F90 | 352 ---- tools/mksurfdata_map/src/shr_timer_mod.F90 | 425 ---- tools/mksurfdata_map/src/test/CMakeLists.txt | 6 - .../src/test/mkgridmap_test/CMakeLists.txt | 4 - .../src/test/mkgridmap_test/test_mkgridmap.pf | 114 -- .../src/test/mkindexmap_test/CMakeLists.txt | 4 - .../test/mkindexmap_test/test_mkindexmap.pf | 251 --- .../src/test/mkpctPftType_test/CMakeLists.txt | 4 - .../mkpctPftType_test/test_mkpctPftType.pf | 253 --- .../src/test/mkpftUtils_test/CMakeLists.txt | 8 - .../test_adjust_total_veg_area.pf | 59 - .../mkpftUtils_test/test_convert_from_p2g.pf | 151 -- .../src/test/mkpftmod_test/CMakeLists.txt | 9 - .../src/test/mkpftmod_test/test_pftInit.pf | 297 --- .../src/test/mkpftmod_test/test_pft_oride.pf | 127 -- .../src/test/mkpftmod_test/test_pftrun.pf | 204 -- .../src/test/mksoilUtils_test/CMakeLists.txt | 7 - .../test_dominant_soil_color.pf | 140 -- .../src/unit_test_stubs/abort.F90 | 25 - .../src/unit_test_stubs/mkncdio.F90 | 223 --- tools/mksurfdata_map/unit_testers/Filepath | 2 - tools/mksurfdata_map/unit_testers/Makefile | 10 - tools/mksurfdata_map/unit_testers/README | 6 - tools/mksurfdata_map/unit_testers/Srcfiles | 32 - .../unit_testers/test_mkchecksMod.F90 | 101 - .../unit_testers/test_mkdomainMod.F90 | 95 - .../unit_testers/test_mkgridmapMod.F90 | 664 ------- .../unit_testers/test_mkharvest.F90 | 316 --- .../unit_testers/test_mkindexmapMod.F90 | 676 ------- .../unit_testers/test_mkncdio.F90 | 82 - .../unit_testers/test_mksurfdata_map.F90 | 54 - .../unit_testers/test_mkurbanparMod.F90 | 75 - .../unit_testers/test_mkutilsMod.F90 | 112 -- .../mksurfdata_map/unit_testers/test_mod.F90 | 339 ---- tools/ncl_scripts/README | 23 - tools/ncl_scripts/README.getregional | 35 - tools/ncl_scripts/getco2_historical.ncl | 196 -- tools/ncl_scripts/getregional_datasets.ncl | 268 --- tools/ncl_scripts/getregional_datasets.pl | 375 ---- tools/ncl_scripts/sample_inlist | 18 - tools/ncl_scripts/sample_inlist_0.5popd | 22 - tools/ncl_scripts/sample_inlist_T62 | 23 - tools/ncl_scripts/sample_inlist_ndep | 22 - tools/ncl_scripts/sample_outlist | 14 - tools/ncl_scripts/sample_outlist_0.5popd | 14 - tools/ncl_scripts/sample_outlist_T62 | 16 - tools/ncl_scripts/sample_outlist_ndep | 15 - 141 files changed, 11 insertions(+), 35299 deletions(-) delete mode 100644 tools/README.filecopies delete mode 100644 tools/README.testing delete mode 100644 tools/contrib/README delete mode 100644 tools/contrib/SpinupStability.ncl delete mode 100755 tools/contrib/modify_singlept_site delete mode 100755 tools/contrib/run_clm_historical delete mode 100755 tools/contrib/run_clmtowers delete mode 100755 tools/contrib/singlept delete mode 100755 tools/contrib/ssp_anomaly_forcing_smooth delete mode 100755 tools/contrib/subset_surfdata delete mode 100644 tools/mkmapdata/README delete mode 100755 tools/mkmapdata/createXMLEntries.pl delete mode 100755 tools/mkmapdata/mkmapdata.sh delete mode 100755 tools/mkmapdata/mknoocnmap.pl delete mode 100644 tools/mkmapdata/mkunitymap.ncl delete mode 100755 tools/mkmapdata/mvNimport.sh delete mode 100755 tools/mkmapdata/regridbatch.sh delete mode 100755 tools/mkmapdata/regridgeyser.sh delete mode 100644 tools/mkmapdata/rmdups.ncl delete mode 100644 tools/mkmapgrids/README delete mode 100644 tools/mkmapgrids/mkscripgrid.ncl delete mode 100644 tools/mkprocdata_map/README delete mode 100644 tools/mkprocdata_map/README.filedescriptions delete mode 100755 tools/mkprocdata_map/mkprocdata_map_all delete mode 100644 tools/mkprocdata_map/mkprocdata_map_functions.bash delete mode 100755 tools/mkprocdata_map/mkprocdata_map_wrap delete mode 100644 tools/mkprocdata_map/src/Filepath delete mode 100644 tools/mkprocdata_map/src/Makefile delete mode 100644 tools/mkprocdata_map/src/Makefile.common delete mode 100755 tools/mkprocdata_map/src/Mkdepends delete mode 100644 tools/mkprocdata_map/src/Srcfiles delete mode 100644 tools/mkprocdata_map/src/constMod.F90 delete mode 100644 tools/mkprocdata_map/src/fileutils.F90 delete mode 100644 tools/mkprocdata_map/src/fmain.F90 delete mode 100644 tools/mkprocdata_map/src/gridmapMod.F90 delete mode 100644 tools/mkprocdata_map/src/mkprocdata_map.F90 delete mode 100644 tools/mkprocdata_map/src/nanMod.F90 delete mode 100644 tools/mkprocdata_map/src/shr_file_mod.F90 delete mode 100644 tools/mkprocdata_map/src/shr_kind_mod.F90 delete mode 100644 tools/mksurfdata_map/Makefile.data delete mode 100644 tools/mksurfdata_map/README delete mode 100644 tools/mksurfdata_map/README.developers delete mode 100644 tools/mksurfdata_map/landuse_timeseries_hist_78pfts_simyr1850-2015.txt delete mode 100755 tools/mksurfdata_map/mksurfdata.pl delete mode 100644 tools/mksurfdata_map/mksurfdata_map.namelist delete mode 100644 tools/mksurfdata_map/single_point_dynpft_files/README delete mode 100644 tools/mksurfdata_map/single_point_dynpft_files/README.landuse_timeseries_smallvilleIA_hist_simyr1850-1855 delete mode 100644 tools/mksurfdata_map/single_point_dynpft_files/landuse_timeseries_smallvilleIA_hist_simyr1850-1855.txt delete mode 100644 tools/mksurfdata_map/src/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/Filepath delete mode 100644 tools/mksurfdata_map/src/Makefile delete mode 100644 tools/mksurfdata_map/src/Makefile.common delete mode 100755 tools/mksurfdata_map/src/Mkdepends delete mode 100644 tools/mksurfdata_map/src/README.unit_testing delete mode 100644 tools/mksurfdata_map/src/Srcfiles delete mode 100644 tools/mksurfdata_map/src/fileutils.F90 delete mode 100644 tools/mksurfdata_map/src/mkVICparamsMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkagfirepkmonthMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkchecksMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkdiagnosticsMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkdomainMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkfileMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkgdpMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkglacierregionMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkglcmecMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkgridmapMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkharvestMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkindexmapMod.F90 delete mode 100644 tools/mksurfdata_map/src/mklaiMod.F90 delete mode 100644 tools/mksurfdata_map/src/mklanwatMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkncdio.F90 delete mode 100644 tools/mksurfdata_map/src/mkpctPftTypeMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkpeatMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkpftConstantsMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkpftMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkpftUtilsMod.F90 delete mode 100644 tools/mksurfdata_map/src/mksoilMod.F90 delete mode 100644 tools/mksurfdata_map/src/mksoilUtilsMod.F90 delete mode 100644 tools/mksurfdata_map/src/mksoildepthMod.F90 delete mode 100644 tools/mksurfdata_map/src/mksurfdat.F90 delete mode 100644 tools/mksurfdata_map/src/mktopostatsMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkurbanparCommonMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkurbanparMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkutilsMod.F90 delete mode 100644 tools/mksurfdata_map/src/mkvarctl.F90 delete mode 100644 tools/mksurfdata_map/src/mkvarpar.F90 delete mode 100644 tools/mksurfdata_map/src/mkvocefMod.F90 delete mode 100644 tools/mksurfdata_map/src/nanMod.F90 delete mode 100644 tools/mksurfdata_map/src/shr_const_mod.F90 delete mode 100644 tools/mksurfdata_map/src/shr_file_mod.F90 delete mode 100644 tools/mksurfdata_map/src/shr_kind_mod.F90 delete mode 100644 tools/mksurfdata_map/src/shr_log_mod.F90 delete mode 100644 tools/mksurfdata_map/src/shr_string_mod.F90 delete mode 100644 tools/mksurfdata_map/src/shr_sys_mod.F90 delete mode 100644 tools/mksurfdata_map/src/shr_timer_mod.F90 delete mode 100644 tools/mksurfdata_map/src/test/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/test/mkgridmap_test/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/test/mkgridmap_test/test_mkgridmap.pf delete mode 100644 tools/mksurfdata_map/src/test/mkindexmap_test/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/test/mkindexmap_test/test_mkindexmap.pf delete mode 100644 tools/mksurfdata_map/src/test/mkpctPftType_test/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/test/mkpctPftType_test/test_mkpctPftType.pf delete mode 100644 tools/mksurfdata_map/src/test/mkpftUtils_test/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/test/mkpftUtils_test/test_adjust_total_veg_area.pf delete mode 100644 tools/mksurfdata_map/src/test/mkpftUtils_test/test_convert_from_p2g.pf delete mode 100644 tools/mksurfdata_map/src/test/mkpftmod_test/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/test/mkpftmod_test/test_pftInit.pf delete mode 100644 tools/mksurfdata_map/src/test/mkpftmod_test/test_pft_oride.pf delete mode 100644 tools/mksurfdata_map/src/test/mkpftmod_test/test_pftrun.pf delete mode 100644 tools/mksurfdata_map/src/test/mksoilUtils_test/CMakeLists.txt delete mode 100644 tools/mksurfdata_map/src/test/mksoilUtils_test/test_dominant_soil_color.pf delete mode 100644 tools/mksurfdata_map/src/unit_test_stubs/abort.F90 delete mode 100644 tools/mksurfdata_map/src/unit_test_stubs/mkncdio.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/Filepath delete mode 100644 tools/mksurfdata_map/unit_testers/Makefile delete mode 100644 tools/mksurfdata_map/unit_testers/README delete mode 100644 tools/mksurfdata_map/unit_testers/Srcfiles delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkchecksMod.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkdomainMod.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkgridmapMod.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkharvest.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkindexmapMod.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkncdio.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mksurfdata_map.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkurbanparMod.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mkutilsMod.F90 delete mode 100644 tools/mksurfdata_map/unit_testers/test_mod.F90 delete mode 100644 tools/ncl_scripts/README delete mode 100644 tools/ncl_scripts/README.getregional delete mode 100644 tools/ncl_scripts/getco2_historical.ncl delete mode 100644 tools/ncl_scripts/getregional_datasets.ncl delete mode 100755 tools/ncl_scripts/getregional_datasets.pl delete mode 100644 tools/ncl_scripts/sample_inlist delete mode 100644 tools/ncl_scripts/sample_inlist_0.5popd delete mode 100644 tools/ncl_scripts/sample_inlist_T62 delete mode 100644 tools/ncl_scripts/sample_inlist_ndep delete mode 100644 tools/ncl_scripts/sample_outlist delete mode 100644 tools/ncl_scripts/sample_outlist_0.5popd delete mode 100644 tools/ncl_scripts/sample_outlist_T62 delete mode 100644 tools/ncl_scripts/sample_outlist_ndep diff --git a/tools/README b/tools/README index 780e9f6e91..9525065724 100644 --- a/tools/README +++ b/tools/README @@ -1,285 +1,16 @@ -$CTSMROOT/tools/README Jun/08/2018 +$CTSMROOT/tools/README Dec/05/2023 -CLM tools for analysis of CLM history files -- or for creation or -modification of CLM input files. - -I. General directory structure: +IMPORTANT NOTE: Normally tools for creating input datasets for CLM +such as surface dataset creation would be here. As well as post processing +or other utility side line tools. However, we are only supporting +tools for later versions of the code. The tools should all work to create +or process datasets from these versions. - $CTSMROOT/tools - mksurfdata_map --- Create surface datasets. - (NOTE: interpinic now longer included as now an online capability in CLM) +Therefore if you need any tools here checkout: - mkmapgrids ------- Create regular lat/lon SCRIP grid files needed by mkmapdata - mkmapdata -------- Create SCRIP mapping data from SCRIP grid files (uses ESMF) - mkprocdata_map --- Convert output unstructured grids into a 2D format that - can be plotted easily - ncl_scripts ------ NCL post or pre processing scripts. +ctsm5.1.dev158 or later and use it - contrib ---------- Miscellaneous tools for pre or post processing of CTSM. - Typically these are contributed by anyone who has something - they think might be helpful to the community. They may not - be as well tested or supported as other tools. - - cime-tools ($CIMEROOT/tools/) (CIMEROOT is ../cime for a CTSM checkout and ../../../cime for a CESM checkout) - $CIMEROOT/mapping/gen_domain_files - gen_domain ------- Create data model domain datasets from SCRIP mapping datasets. - -II. Notes on building/running for each of the above tools: - - Each tool that has FORTRAN source code (mksurfdata_map and mkprocdata_map) has the following files: - - README ------- Specific help for using the specific tool and help on specific - files in that directory. - src/Filepath ----- List of directories needed to build the tool - (some files in ../src directories are required). - src/Makefile ----- GNU Makefile to build the tool - (these are identical between tools. - src/Macros.custom Customization of make macros for the particular tool in question - src/Srcfiles ----- List of source files that are needed. - src/Mkdepends ---- Dependency generator program - - mkmapdata, mkmapgrids and ncl_scripts only contain scripts so don't have the above build files. - - Most tools have copies of files from other directories -- see the README.filecopies - file for more information on this. - - Tools may also have files with the directory name followed by namelist to provide sample namelists. - - .namelist ------ Namelist to create a global file. - - These files are also used by the test scripts to test the tools (see the - README.testing) file. - - NOTE: Be sure to change the path of the datasets references by these namelists to - point to where you have exported your CESM inputdata datasets. - - To build: - - cd - setenv INC_NETCDF - setenv LIB_NETCDF - gmake - - The process will create a file called "Depends" which has the dependencies - for the build of each file on other files. - - By default some codes may be compiled non-optimized - so that you can use the debugger, and with bounds-checking, and float trapping on. - To speed up do the following... - - gmake OPT=TRUE (by default already on for interpinic and mksurfdata_map) - - Also some of the tools allow for OpenMP shared memory parallelism - (such as interpinic and mksurfdata) with - - gmake SMP=TRUE - - To run a program with a namelist: - - ./program < namelist - - To get help on running a program with command line options (e.g., interpinic): - - ./program - - To run a program built with SMP=TRUE: - - setenv OMP_NUM_THREADS= - - run normally as above - -III. Process sequence to create input datasets needed to run CLM - - 1.) Create SCRIP grid files (if needed) - - a.) For standard resolutions these files will already be created. (done) - - b.) To create regular lat-lon regional/single-point grids run mknoocnmap.pl - - This will create both SCRIP grid files and a mapping file that will - be valid if the region includes NO ocean whatsoever (so you can skip step 2). - You can also use this script to create SCRIP grid files for a region - (or even a global grid) that DOES include ocean if you use step 2 to - create mapping files for it (simply discard the non-ocean map created by - this script). - - Example, for single-point over Boulder Colorado. - - cd mkmapdata - ./mknoocnmap.pl -p 40,255 -n 1x1_boulderCO - - c.) General case - - You'll need to convert or create SCRIP grid files on your own (using scripts - or other tools) for the general case where you have an unstructured grid, or - a grid that is not regular in latitude and longitude. - - example format - ================== - netcdf fv1.9x2.5_090205 { - dimensions: - grid_size = 13824 ; - grid_corners = 4 ; - grid_rank = 2 ; - variables: - double grid_center_lat(grid_size) ; - grid_center_lat:units = "degrees" ; - double grid_center_lon(grid_size) ; - grid_center_lon:units = "degrees" ; - double grid_corner_lat(grid_size, grid_corners) ; - grid_corner_lat:units = "degrees" ; - double grid_corner_lon(grid_size, grid_corners) ; - grid_corner_lon:units = "degrees" ; - int grid_dims(grid_rank) ; - int grid_imask(grid_size) ; - grid_imask:units = "unitless" ; - - 2.) Create ocean to atmosphere mapping file (if needed) - - a.) Standard resolutions (done) - - If this is a standard resolution with a standard ocean resolution -- this - step is already done, the files already exist. - - b.) Region without Ocean (done in step 1.b) - - IF YOU RAN mknoocnmap.pl FOR A REGION WITHOUT OCEAN THIS STEP IS ALREADY DONE. - - c.) New atmosphere or ocean resolution - - If the region DOES include ocean, use $CIMEROOT/tools/mapping/gen_domain_files/gen_maps.sh to create a - mapping file for it. - - Example: - - cd $CIMEROOT/tools/mapping/gen_domain_files - ./gen_maps.sh -focn -fatm -nocn -natm - - - 3.) Add SCRIP grid file(s) created in (1) into XML database in CLM (optional) - - See the "Adding New Resolutions or New Files to the build-namelist Database" - Chapter in the CLM User's Guide - - http://www.cesm.ucar.edu/models/cesm1.0/clm/models/lnd/clm/doc/UsersGuide/book1.html - - If you don't do this step, you'll need to specify the file to mkmapdata - in step (3) using the "-f" option. - - 4.) Create mapping files for use by mksurfdata_map with mkmapdata - (See mkmapdata/README for more help on doing this) - - - this step uses the results of (1) that were entered into the XML database - by step (3). If you don't enter datasets in, you need to specify the - SCRIP grid file using the "-f" option to mkmapdata.sh. - - Example: to generate all necessary mapping files for the ne30np4 grid - - cd mkmapdata - ./mkmapdata.sh -r ne30np4 - - 5.) Add mapping file(s) created in step (4) into XML database in CLM (optional) - - See notes on doing this in step (3) above. - Edit ../bld/namelist_files/namelist_defaults_clm.xml to incorporate new - mapping files. - - If you don't do this step, you'll need to specify the grid resolution name - and file creation dates to mksurfdata_map in step (5) below. - - 6.) Convert map of ocean to atm for use by DATM and CLM with gen_domain - (See $CIMEROOT/tools/mapping/README for more help on doing this) - - - gen_domain uses the map from step (2) (or previously created CESM maps) - - Example: - - cd $CIMEROOT/tools/mapping/gen_domain_files/src - gmake - cd .. - setenv CDATE 090206 - setenv OCNGRIDNAME gx1v6 - setenv ATMGRIDNAME fv1.9x2.5 - setenv MAPFILE $CSMDATA/cpl/cpl6/map_${OCNGRIDNAME}_to_${ATMGRIDNAME}_aave_da_${CDATE}.nc - ./gen_domain -m $MAPFILE -o $OCNGRIDNAME -l $ATMGRIDNAME - - Normally for I compsets running CLM only you will discard the ocean domain - file, and only use the atmosphere domain file for datm and as the fatmlndfrc - file for CLM. Output domain files will be named according to the input OCN/LND - gridnames. - - 7.) Create surface datasets with mksurfdata_map - (See mksurfdata_map/README for more help on doing this) - - - Run mksurfdata_map/mksurfdata.pl - - This step uses the results of step (4) entered into the XML database - in step (5). - - If datasets were NOT entered into the XML database, set the resolution - to "usrspec" and use the "-usr_gname", and "-usr_gdate" options. - - Example: for 0.9x1.25 resolution - - cd mksurfdata_map/src - gmake - cd .. - ./mksurfdata.pl -r 0.9x1.25 - - NOTE that surface dataset will be used by default for fatmgrid - and it will - contain the lat,lon,edges and area values for the atm grid - ASSUMING that - the atm and land grid are the same - - 8.) Interpolate initial conditions using interpinic (optional) - (See interpinic/README for more help on doing this) - - 9.) Add new files to XML data or using user_nl_clm (optional) - - See notes on doing this in step (3) above. - -IV. Example of creating single-point datasets without entering into XML database. - - Here we apply the process described in III. for a single-point dataset - where we don't enter the datasets into the XML database (thus skipping - steps 3, 5 and 9), but use the needed command line options to specify where the - files are. This also skips step (2) since step 1 creates the needed mapping file. - We also skip step (8) and do NOT create a finidat file. - - 0.) Set name of grid to use and the creation date to be used later... - setenv GRIDNAME 1x1_boulderCO - setenv CDATE `date +%y%m%d` - 1.) SCRIP grid and atm to ocn mapping file - cd mkmapdata - ./mknoocnmap.pl -p 40,255 -n $GRIDNAME - # Set pointer to MAPFILE that will be used in step (6) - setenv MAPFILE `pwd`/map_${GRIDNAME}_noocean_to_${GRIDNAME}_nomask_aave_da_${CDATE}.nc - cd ../.. - 2.) skip - 3.) skip - 4.) Mapping files needed for mksurfdata_map - cd mkmapdata - setenv GRIDFILE ../mkmapgrids/SCRIPgrid_${GRIDNAME}_nomask_${CDATE}.nc - ./mkmapdata.sh -r $GRIDNAME -f $GRIDFILE -t regional - cd ../.. - 5.) skip - 6.) Generate domain file for datm and CLM - cd $CIMEROOT/tools/mapping/gen_domain_files/src - gmake - cd .. - setenv OCNDOM domain.ocn_noocean.nc - setenv ATMDOM domain.lnd.{$GRIDNAME}_noocean.nc - ./gen_domain -m $MAPFILE -o $OCNDOM -l $ATMDOM - 7.) Create surface dataset for CLM - cd mksurfdata_map/src - gmake - cd .. - ./mksurfdata.pl -r usrspec -usr_gname $GRIDNAME -usr_gdate $CDATE - 8.) skip - 9.) skip - -V. Notes on which input datasets are needed for CLM - - global or regional/single-point grids - - need fsurdata and fatmlndfrc - - fsurdata ---- from mksurfdata_map in step (III.7) - fatmlndfrc -- use the domain.lnd file from gen_domain in step (III.6) +Let us know if you run into issues here by posting to the CESM Forum +or sending email to ctsm-software@ucar.edu + https://bb.cgd.ucar.edu/cesm/forums/ctsm-clm-mosart-rtm.134/ diff --git a/tools/README.filecopies b/tools/README.filecopies deleted file mode 100644 index 5ab2bc96d1..0000000000 --- a/tools/README.filecopies +++ /dev/null @@ -1,38 +0,0 @@ -tools/README.filecopies May/26/2011 - -There are several files that are copies of the original files from -either CTSM src/main, cime/src/share/utils, -cime/src/share/unit_test_stubs, or copies from other tool -directories. By having copies the tools can all be made stand-alone, -but any changes to the originals will have to be put into the tool -directories as well. - -I. Files that are IDENTICAL: - - 1. csm_share files copied that should be identical to cime/share/utils: - - shr_kind_mod.F90 - shr_const_mod.F90 - shr_log_mod.F90 - shr_timer_mod.F90 - shr_string_mod.F90 - shr_file_mod.F90 - - 2. csm_share files copied that should be identical to cime/share/csm_share/unit_testers: - - test_mod.F90 - -II. Files with differences - - 1. csm_share files copied with differences: - - shr_sys_mod.F90 - Remove mpi abort and reference to shr_mpi_mod.F90. - - 2. CTSM src/utils files with differences: - - fileutils.F90 --- Remove use of masterproc and spmdMod and endrun in abortutils. - - 3. Files in mksurfdata_map - - mkvarpar.F90 - nanMod.F90 diff --git a/tools/README.testing b/tools/README.testing deleted file mode 100644 index 9c386a3b26..0000000000 --- a/tools/README.testing +++ /dev/null @@ -1,58 +0,0 @@ -tools/README.testing May/23/2011 - -There is automated testing for all of the tools and scripts under this tools directory. -The tests are in the test/tools directory and are any of the scripts -that have "tools" in the name. There are several assumptions made in order for the -testing to work. - - -1.) Executable name is the same as the directory name - -The name of the executable program is the same as the directory name of the tool. - -2.) Build works the same for any Fortran tools - -The build for any Fortran tools should work the same way, with the same options -and required files for it. The files: Makefile, Mkdepends, Filepath and Srcfile -are expected to exist in the tool "src" sub-directory. To make maintaining these files easier -in general the Makefile and Mkdepends files should be kept identical other than -default settings for OPT and SMP and the output executable name. - -Options to the Makefile: - - LIB_NETCDF --- Library directory location of NetCDF. (defaults to /usr/local/lib) - INC_NETCDF --- Include directory location of NetCDF. (defaults to /usr/local/include) - MOD_NETCDF --- Module directory location of NetCDF. (defaults to $LIB_NETCDF) - USER_FC ------ Allow user to override the default Fortran compiler specified in Makefile. - USER_FCTYP --- Allow user to override the default type of Fortran compiler - (Linux and USER_FC=ftn only). - USER_CC ------ Allow user to override the default C compiler specified in Makefile - (Linux only). - USER_LINKER -- Allow user to override the default linker specified in Makefile. - SMP ---------- Shared memory Multi-processing (TRUE or FALSE) [default is FALSE] - OPT ---------- Use optimized options. (TRUE or FALSE) - -3.) Successful completion of the tool ends with "Successfully ..." - -After the tool completes it should have an unique string telling of the -successful completion of the file that is searchable in the log file starting -with "Successfully ". If this string isn't found in the log file, it -will be assumed by the test setup that the test failed. - -4.) NetCDF files are created or modified - -It is assumed that NetCDF files are created and/or modified by the process. And if -NetCDF files are NOT created -- something went wrong. For some scripts that copy files -to other locations this means an "-nomv" option needs to be invoked (and one provided) -so that it leaves the files created in the current directory. - -5.) Namelist examples exist .* namelist files - -To specify options for the running of the tool, sample namelist files -are provided or a sample run options file. These files can EITHER be in the -tool directory OR the ../../test/tools/nl_files directory. - -6.) Specific tests for run scripts - -For tools that have scripts to create namelists and run the tool for you, there -are customized tests to run these tools. diff --git a/tools/contrib/README b/tools/contrib/README deleted file mode 100644 index bae1b51ca9..0000000000 --- a/tools/contrib/README +++ /dev/null @@ -1,48 +0,0 @@ -$CTSMROOT/tools/contrib/README Jan/24/2019 - -The purpose of this directory is for users of CTSM to contribute scripts for pre or post processing or -case management of CTSM that others might find useful. The script should have some documentation made -available before adding it. These scripts may not be as well tested or supported as other CTSM -tools. They are also ONLY assumed to work on the NCAR supercomputer. So paths will be hardwired to -assume NCAR directory structures. - -The python scripts require the following settings before running on cheyenne: -(Currently that's the singlept and subset_surfdata scripts) - -module load python/2.7.14 -ncar_pylib - -Brief description of scripts: - -run_clm_historical - does all the setup and submission required to do a 1850-2010 CLM - historical simulation in three separate submissions - v1 - Andrew Slater+Dave Lawrence, 8/2015 - -subset_surfdata - create regional domain, surface data, and rtm directional files by - extracting data from global datasets - v1 - Sean Swenson 8/2015 - -singlept - create single point domain, surface data, and datm forcing files by - extracting data from global datasets - v1 - Sean Swenson 8/2015 - -SpinupStability.ncl - This script assesses the equilibrium state of a spinup run - works on either monthly or annual mean history files - Keith Oleson 7/2016 - -run_clmtowers - This script will run any number of flux tower sites. - It's based on having created surface datasets with PTCLM. - v1 - Keith Oleson, 8/2015 - -ssp_anomaly_forcing_smooth - This script creates anomaly forcing for CMIP6 SSP scenarios that - can be used to run CTSM in CESM with datm. - v0 -- Sean Swenson - v1 - Peter Lawrence 3/2020 - - - diff --git a/tools/contrib/SpinupStability.ncl b/tools/contrib/SpinupStability.ncl deleted file mode 100644 index 9f0eb30302..0000000000 --- a/tools/contrib/SpinupStability.ncl +++ /dev/null @@ -1,791 +0,0 @@ -; NCL script -; SpinupStability_v8.ncl -; Script to examine stability of spinup simulation. -; This version operates on either monthly mean or multi-annual mean multi-variable history files -; Keith Oleson, Jan 2019 - -load "$NCARG_ROOT/lib/ncarg/nclscripts/csm/gsn_code.ncl" -load "$NCARG_ROOT/lib/ncarg/nclscripts/csm/gsn_csm.ncl" -load "$NCARG_ROOT/lib/ncarg/nclscripts/csm/contributed.ncl" -load "$NCARG_ROOT/lib/ncarg/nclscripts/csm/shea_util.ncl" - -begin - - print ("=========================================") - print ("Start Time: "+systemfunc("date") ) - print ("=========================================") - -;=======================================================================; -; This script produces a page of plots of various variables that are evaluated -; as to whether they are spunup or not. A summary of variables in equilibrium -; and/or in disequilibrium is also produced to standard out. The postscript output -; is $caseid_spinup.ps in the pwd. -; The variables examined are TOTECOSYSC,TOTSOMC,TOTVEGC,TLAI,GPP,TWS,H2OSNO. -; The percentage of land area in TOTECOSYSC disequilibrium is also examined (not for single point). -; Thresholds are defined below (i.e., global_thresh_*) and can be changed for individual -; variables. -; To run this script, just enter in your case name and username below. -; AND set the annual_hist flag to True if your case has annual mean history files or set -; annual_hist flag to False if your case has monthly mean history files. -; AND set the region (supported options: Global, Arctic, SPT). -; AND set the subper (subsampling period in years, number of years that atm forcing repeats). -; The script assumes that your history files are in /glade/scratch/$username/archive/$caseid/lnd/hist -;=======================================================================; - -; GLOBAL EXAMPLE - caseid = "clm50_release-clm5.0.15_2deg_GSWP3V1_1850AD" - username = "oleson" - annual_hist = True - region = "Global" ; Global, Arctic, or SPT (single point) - subper = 20 ; Subsampling period in years - -; SPT (single point) EXAMPLE -; caseid = "clm50_release-clm5.0.15_SPT_GSWP3V1_1850spin" -; username = "oleson" -; annual_hist = True -; region = "SPT" ; Global, Arctic, or SPT (single point) -; subper = 20 ; Subsampling period in years - - do_plot = True -; do_plot = False -;=======================================================================; - - data_dir = "/glade/scratch/"+username+"/archive/"+caseid+"/lnd/hist/" - if ( systemfunc("test -d "+data_dir+"; echo $?" ) .ne. 0 )then - print( "Input directory does not exist or not found: "+data_dir ); - print( "Make sure username and caseid and base directory is set correctly" ) - status_exit( -1 ) - end if - -; Thresholds - if (region .eq. "SPT") then - glob_thresh_totecosysc = 0.02 ; global threshold for TOTECOSYSC equilibrium (delta MgC / yr) - glob_thresh_totsomc = 0.02 ; global threshold for TOTSOMC equilibrium (delta MgC / yr) - glob_thresh_totvegc = 0.02 ; global threshold for TOTVEGC equilibrium (delta MgC / yr) - glob_thresh_tlai = 0.02 ; global threshold for TLAI equilibrium (delta m2/m2 / yr) - glob_thresh_gpp = 0.02 ; global threshold for GPP equilibrium (delta MgC / yr) - glob_thresh_tws = 0.001 ; global threshold for TWS equilibrium (delta m / yr) - glob_thresh_h2osno = 1.0 ; global threshold for H2OSNO equilibrium (delta mm / yr) - glob_thresh_area = 3.0 ; global threshold percent area with TOTECOSYSC disequilibrium gt 1 g C/m2/yr (not used) - totecosysc_thresh = 1. ; disequilibrium threshold for individual gridcells (gC/m2/yr) (not used) - else - glob_thresh_totecosysc = 0.02 ; global threshold for TOTECOSYSC equilibrium (delta PgC / yr) - glob_thresh_totsomc = 0.02 ; global threshold for TOTSOMC equilibrium (delta PgC / yr) - glob_thresh_totvegc = 0.02 ; global threshold for TOTVEGC equilibrium (delta PgC / yr) - glob_thresh_tlai = 0.02 ; global threshold for TLAI equilibrium (delta m2/m2 / yr) - glob_thresh_gpp = 0.02 ; global threshold for GPP equilibrium (delta PgC / yr) - glob_thresh_tws = 0.001 ; global threshold for TWS equilibrium (delta m / yr) - glob_thresh_h2osno = 1.0 ; global threshold for H2OSNO equilibrium (delta mm / yr) - glob_thresh_area = 3.0 ; global threshold percent area with TOTECOSYSC disequilibrium gt 1 g C/m2/yr - totecosysc_thresh = 1. ; disequilibrium threshold for individual gridcells (gC/m2/yr) - end if - - if (annual_hist) then - fls = systemfunc("ls " + data_dir + caseid+".clm2.h0.*-*-*-*"+".nc") - else - fls = systemfunc("ls " + data_dir + caseid+".clm2.h0.*-*"+".nc") - end if - flsdims = dimsizes(fls) - - if (annual_hist) then - lstfile = addfile(fls(flsdims-1),"r") - else - lstfile = addfile(fls(flsdims-12),"r") ;last month (DEC) of any year has mdate for next year - ;so grab JAN of last year - end if - - if (annual_hist) then - lstyrdim = dimsizes(lstfile->mcdate) - mcdate_lst = lstfile->mcdate(lstyrdim-1) - else - mcdate_lst = lstfile->mcdate - end if - lstyr = toint(mcdate_lst)/10000 - - fstfile = addfile(fls(0),"r") - if (annual_hist) then - mcdate_fst = fstfile->mcdate(0) - else - mcdate_fst = fstfile->mcdate - end if - fstyr = toint(mcdate_fst)/10000 - - yearplt = ispan(fstyr,lstyr,subper) - yearpltrev = yearplt(::-1) - year = ispan(fstyr,lstyr,subper) - fstyr - nyrs = dimsizes(year) - if (subper .eq. 1) then - yearpltmid = ispan(fstyr+subper/2,yearplt(nyrs-2),subper) - else - yearpltmid = ispan(fstyr+subper/2,yearplt(nyrs-1),subper) - end if - -; Build an array of monthly indices - monstr = new(nyrs*12,"integer") - do i = 0,nyrs-1 - monstr(i*12:i*12+11) = ispan(year(i)*12,year(i)*12+11,1) - end do - -; Add the data files together - if (annual_hist) then - data = addfiles(fls, "r") - ListSetType (data, "cat") - else - data = addfiles(fls(monstr), "r") - end if - -; Convert to annual means if required - if (annual_hist) then - if (region .eq. "SPT") then - totecosysc = data[:]->TOTECOSYSC(year,:) - totsomc = data[:]->TOTSOMC(year,:) - totvegc = data[:]->TOTVEGC(year,:) - tlai = data[:]->TLAI(year,:) - gpp = data[:]->GPP(year,:) - tws = data[:]->TWS(year,:) - if (isfilevar(data[0],"H2OSNO")) then - h2osno = data[:]->H2OSNO(year,:) - else - h2osno = tws - h2osno = h2osno@_FillValue - end if - else - totecosysc = data[:]->TOTECOSYSC(year,:,:) - totsomc = data[:]->TOTSOMC(year,:,:) - totvegc = data[:]->TOTVEGC(year,:,:) - tlai = data[:]->TLAI(year,:,:) - gpp = data[:]->GPP(year,:,:) - tws = data[:]->TWS(year,:,:) - if (isfilevar(data[0],"H2OSNO")) then - h2osno = data[:]->H2OSNO(year,:,:) - else - h2osno = tws - h2osno = h2osno@_FillValue - end if - end if - else - totecosysc = month_to_annual(data[:]->TOTECOSYSC,1) - totsomc = month_to_annual(data[:]->TOTSOMC,1) - totvegc = month_to_annual(data[:]->TOTVEGC,1) - tlai = month_to_annual(data[:]->TLAI,1) - gpp = month_to_annual(data[:]->GPP,1) - if (isfilevar(data[0],"TWS")) then - tws = month_to_annual(data[:]->TWS,1) - else - tws = gpp - tws = tws@_FillValue - end if - if (isfilevar(data[0],"H2OSNO")) then - h2osno = month_to_annual(data[:]->H2OSNO,1) - else - h2osno = tws - h2osno = h2osno@_FillValue - end if - end if - lat = data[0]->lat - nlat = dimsizes(lat) - lon = data[0]->lon - nlon = dimsizes(lon) - landfrac = data[0]->landfrac - area = data[0]->area - aream = area*1.e6 - landarea = landfrac*aream - if (region .eq. "SPT") then - gtoXg = 1e-12 ;Tg - units = "Tg C" - else - gtoXg = 1e-15 ;Pg - units = "Pg C" - end if - secinyr = 60.*60.*24.*365. - -; TOTECOSYSC - if (region .eq. "SPT") then - landareaC = conform_dims(dimsizes(totecosysc),landarea,(/1/)) ; conforming dimensions of landarea to totecosysc - else - landareaC = conform_dims(dimsizes(totecosysc),landarea,(/1,2/)) ; conforming dimensions of landarea to totecosysc - end if - totecosysc_area = totecosysc*landareaC ; correcting totecosysc for total land area - totecosysc_Xg = totecosysc_area*gtoXg ; g to Xg - if (region .eq. "SPT") then - totecosysc_glob = dim_sum_n(totecosysc_Xg, (/1/)) ; sums over single point - else - totecosysc_glob = dim_sum_n(totecosysc_Xg, (/1,2/)) ; sums over all latitudes - end if - totecosysc_glob!0 = "year" - totecosysc_glob&year = yearplt - totecosysc_glob_del = new(nyrs-1,"float") - do i = 0,nyrs-2 - totecosysc_glob_del(i) = (totecosysc_glob(i+1) - totecosysc_glob(i))/subper - end do - totecosysc_glob_del!0 = "year" - totecosysc_glob_del&year = yearpltmid - indx = where(abs(totecosysc_glob_del) .lt. glob_thresh_totecosysc,1,0) - if (all(indx .eq. 1)) then - totecosysc_glob_equil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - totecosysc_glob_equil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - totecosysc_glob_equil = -999 - end if - end if - totecosysc_glob_equil@_FillValue = -999 - delete(indx) - -; Land area not in TOTECOSYSC equilibrium - if (region .ne. "SPT") then - landarea_noequil = new((/nyrs-1,nlat,nlon/),"float") - do i = 0,nyrs-2 - landarea_noequil(i,:,:) = where((totecosysc(i+1,:,:) - totecosysc(i,:,:))/subper .gt. totecosysc_thresh, landarea, 0.) - end do - perc_landarea_noequil = 100.*(dim_sum_n(landarea_noequil,(/1,2/))/sum(landarea)) - indx = where(abs(perc_landarea_noequil) .lt. glob_thresh_area,1,0) - if (all(indx .eq. 1)) then - perc_landarea_glob_noequil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - perc_landarea_glob_noequil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - perc_landarea_glob_noequil = -999 - end if - end if - perc_landarea_glob_noequil@_FillValue = -999 - delete(indx) - totecosysc_1_map = where(landarea_noequil(nyrs-2,:,:) .ne. 0.,(totecosysc(nyrs-1,:,:)-totecosysc(nyrs-2,:,:))/subper,totecosysc@_FillValue) - totecosysc_1_map!0 = "lat" - totecosysc_1_map&lat = lat - totecosysc_1_map!1 = "lon" - totecosysc_1_map&lon = lon - totecosysc_2_map = where(landarea_noequil(nyrs-3,:,:) .ne. 0.,(totecosysc(nyrs-2,:,:)-totecosysc(nyrs-3,:,:))/subper,totecosysc@_FillValue) - copy_VarCoords(totecosysc_1_map,totecosysc_2_map) - end if - -; TOTSOMC - totsomc_area = totsomc*landareaC ; correcting totsomc for total land area - totsomc_Xg = totsomc_area*gtoXg ; g to Xg - if (region .eq. "SPT") then - totsomc_glob = dim_sum_n(totsomc_Xg, (/1/)) ; sums over single point - else - totsomc_glob = dim_sum_n(totsomc_Xg, (/1,2/)) ; sums over all latitudes - end if - totsomc_glob!0 = "year" - totsomc_glob&year = yearplt - totsomc_glob_del = new(nyrs-1,"float") - do i = 0,nyrs-2 - totsomc_glob_del(i) = (totsomc_glob(i+1) - totsomc_glob(i))/subper - end do - totsomc_glob_del!0 = "year" - totsomc_glob_del&year = yearpltmid - indx = where(abs(totsomc_glob_del) .lt. glob_thresh_totsomc,1,0) - if (all(indx .eq. 1)) then - totsomc_glob_equil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - totsomc_glob_equil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - totsomc_glob_equil = -999 - end if - end if - totsomc_glob_equil@_FillValue = -999 - delete(indx) - -; TOTVEGC - totvegc_area = totvegc*landareaC ; correcting totvegc for total land area - totvegc_Xg = totvegc_area*gtoXg ; g to Xg - if (region .eq. "SPT") then - totvegc_glob = dim_sum_n(totvegc_Xg, (/1/)) ; sums over single point - else - totvegc_glob = dim_sum_n(totvegc_Xg, (/1,2/)) ; sums over all latitudes - end if - totvegc_glob!0 = "year" - totvegc_glob&year = yearplt - totvegc_glob_del = new(nyrs-1,"float") - do i = 0,nyrs-2 - totvegc_glob_del(i) = (totvegc_glob(i+1) - totvegc_glob(i))/subper - end do - totvegc_glob_del!0 = "year" - totvegc_glob_del&year = yearpltmid - indx = where(abs(totvegc_glob_del) .lt. glob_thresh_totvegc,1,0) - if (all(indx .eq. 1)) then - totvegc_glob_equil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - totvegc_glob_equil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - totvegc_glob_equil = -999 - end if - end if - totvegc_glob_equil@_FillValue = -999 - delete(indx) - -; TLAI - areasum = sum(area*landfrac) - areaL = area*landfrac - if (region .eq. "SPT") then - landareaL = conform_dims(dimsizes(tlai),areaL,(/1/)) ; conforming dimensions of areaL to tlai - tlai_glob = dim_sum_n(tlai*landareaL/areasum,(/1/)) ; weighted tlai - else - landareaL = conform_dims(dimsizes(tlai),areaL,(/1,2/)) ; conforming dimensions of areaL to tlai - tlai_glob = dim_sum_n(tlai*landareaL/areasum,(/1,2/)) ; weighted global tlai - end if - tlai_glob!0 = "year" - tlai_glob&year = yearplt - tlai_glob_del = new(nyrs-1,"float") - do i = 0,nyrs-2 - tlai_glob_del(i) = (tlai_glob(i+1) - tlai_glob(i))/subper - end do - tlai_glob_del!0 = "year" - tlai_glob_del&year = yearpltmid - indx = where(abs(tlai_glob_del) .lt. glob_thresh_tlai,1,0) - if (all(indx .eq. 1)) then - tlai_glob_equil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - tlai_glob_equil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - tlai_glob_equil = -999 - end if - end if - tlai_glob_equil@_FillValue = -999 - delete(indx) - -; GPP - gpp_area = gpp*landareaC ; correcting gpp for total land area - gpp_Xg = gpp_area*gtoXg*secinyr ; g to Xg and sec to yrs - if (region .eq. "SPT") then - gpp_glob = dim_sum_n(gpp_Xg, (/1/)) ; sums over single point - else - gpp_glob = dim_sum_n(gpp_Xg, (/1,2/)) ; sums over all latitudes - end if - gpp_glob!0 = "year" - gpp_glob&year = yearplt - gpp_glob_del = new(nyrs-1,"float") - do i = 0,nyrs-2 - gpp_glob_del(i) = (gpp_glob(i+1) - gpp_glob(i))/subper - end do - gpp_glob_del!0 = "year" - gpp_glob_del&year = yearpltmid - indx = where(abs(gpp_glob_del) .lt. glob_thresh_gpp,1,0) - if (all(indx .eq. 1)) then - gpp_glob_equil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - gpp_glob_equil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - gpp_glob_equil = -999 - end if - end if - gpp_glob_equil@_FillValue = -999 - delete(indx) - -; TWS - if (isfilevar(data[0],"TWS")) then - - if (region .eq. "SPT") then - tws_glob = (dim_sum_n(tws*landareaL/areasum,(/1/)))/1.e3 ; weighted tws (meters) - else - tws_glob = (dim_sum_n(tws*landareaL/areasum,(/1,2/)))/1.e3 ; weighted global tws (meters) - end if - tws_glob!0 = "year" - tws_glob&year = yearplt - tws_glob_del = new(nyrs-1,"float") - do i = 0,nyrs-2 - tws_glob_del(i) = (tws_glob(i+1) - tws_glob(i))/subper - end do - tws_glob_del!0 = "year" - tws_glob_del&year = yearpltmid - indx = where(abs(tws_glob_del) .lt. glob_thresh_tws,1,0) - if (all(indx .eq. 1)) then - tws_glob_equil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - tws_glob_equil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - tws_glob_equil = -999 - end if - end if - tws_glob_equil@_FillValue = -999 - delete(indx) - - else - tws_glob_equil = new(1,typeof(yearplt),-999) - tws_glob_equil = -999 - if (region .eq. "SPT") then - tws_glob = new(dimsizes(dim_sum_n(tws,(/1/))),typeof(tws),-999) - else - tws_glob = new(dimsizes(dim_sum_n(tws,(/1,2/))),typeof(tws),-999) - end if - tws_glob = -999 - tws_glob_del = new(nyrs-1,"float",-999.) - tws_glob_del = -999. - end if - -; H2OSNO - if (isfilevar(data[0],"H2OSNO")) then - - if (region .eq. "SPT") then - h2osno_glob = dim_sum_n(h2osno*landareaL/areasum,(/1/)) ; weighted h2osno (mm) - else - h2osno_glob = dim_sum_n(h2osno*landareaL/areasum,(/1,2/)) ; weighted global h2osno (mm) - end if - h2osno_glob!0 = "year" - h2osno_glob&year = yearplt - h2osno_glob_del = new(nyrs-1,"float") - do i = 0,nyrs-2 - h2osno_glob_del(i) = (h2osno_glob(i+1) - h2osno_glob(i))/subper - end do - h2osno_glob_del!0 = "year" - h2osno_glob_del&year = yearpltmid - indx = where(abs(h2osno_glob_del) .lt. glob_thresh_h2osno,1,0) - if (all(indx .eq. 1)) then - h2osno_glob_equil = yearplt(0) - else - if (.not.(all(indx .eq. 0)) .and. indx(dimsizes(indx)-1) .ne. 0) then - indxrev = indx(::-1) - do i = 0,dimsizes(indxrev)-1 - if (indxrev(i) .eq. 0) then - h2osno_glob_equil = yearpltrev(i-1) - break - end if - end do - delete(indxrev) - else - h2osno_glob_equil = -999 - end if - end if - h2osno_glob_equil@_FillValue = -999 - delete(indx) - - else - h2osno_glob_equil = -999 - h2osno_glob_equil = new(1,typeof(yearplt),-999) - h2osno_glob_equil = -999 - if (region .eq. "SPT") then - h2osno_glob = new(dimsizes(dim_sum_n(h2osno,(/1/))),typeof(h2osno),-999) - else - h2osno_glob = new(dimsizes(dim_sum_n(h2osno,(/1,2/))),typeof(h2osno),-999) - end if - h2osno_glob = -999 - h2osno_glob_del = new(nyrs-1,"float",-999.) - h2osno_glob_del = -999. - end if - -;===============================Plotting====================================; - if (do_plot) then - -; wks_type = "png" -; wks_type@wkWidth = 2500 -; wks_type@wkHeight = 2500 -; wks_type = "x11" - wks_type = "ps" -; wks_type = "pdf" - wks = gsn_open_wks (wks_type, caseid+"_Spinup") - gsn_define_colormap(wks, "ViBlGrWhYeOrRe") - - plot = new(13,"graphic") - - resP = True -; resP@gsnMaximize = True - resP@gsnPaperOrientation = "portrait" - resP@gsnFrame = False - resP@gsnDraw = True - resP@txString = caseid + " Annual Mean " - resP@gsnPanelXWhiteSpacePercent = 2. - resP@gsnPanelCenter = False -; resP@gsnPanelDebug = True - - res = True - res@gsnFrame = False - res@gsnDraw = False - res@xyLineThicknessF = 2 - - polyres1 = True - polyres1@gsLineDashPattern = 16 - polyres2 = True - polyres2@gsLineDashPattern = 2 - - res@tiXAxisString = " " - res@tiYAxisString = units - res@tiMainString = "TOTECOSYSC" - plot(0) = gsn_csm_xy(wks,yearplt,totecosysc_glob,res) - - res@tiYAxisString = units - res@tiMainString = "Delta TOTECOSYSC " + "EqYr: "+totecosysc_glob_equil - res@trYMaxF = 0.2 - res@trYMinF = -0.2 - plot(1) = gsn_csm_xy(wks,yearpltmid,totecosysc_glob_del,res) - prim1 = gsn_add_polyline(wks,plot(1),(/0.,yearpltmid(nyrs-2)/),(/0.,0./),polyres1) - prim2 = gsn_add_polyline(wks,plot(1),(/0.,yearpltmid(nyrs-2)/),(/-glob_thresh_totecosysc,-glob_thresh_totecosysc/),polyres2) - prim3 = gsn_add_polyline(wks,plot(1),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_totecosysc,glob_thresh_totecosysc/),polyres2) - - delete(res@trYMaxF) - delete(res@trYMinF) - res@tiYAxisString = units - res@tiMainString = "TOTSOMC" - plot(2) = gsn_csm_xy(wks,yearplt,totsomc_glob,res) - - res@tiYAxisString = units - res@tiMainString = "Delta TOTSOMC " + "EqYr: "+totsomc_glob_equil - res@trYMaxF = 0.2 - res@trYMinF = -0.2 - plot(3) = gsn_csm_xy(wks,yearpltmid,totsomc_glob_del,res) - prim4 = gsn_add_polyline(wks,plot(3),(/0.,yearpltmid(nyrs-2)/),(/0.,0./),polyres1) - prim5 = gsn_add_polyline(wks,plot(3),(/0.,yearpltmid(nyrs-2)/),(/-glob_thresh_totsomc,-glob_thresh_totsomc/),polyres2) - prim6 = gsn_add_polyline(wks,plot(3),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_totsomc,glob_thresh_totsomc/),polyres2) - - delete(res@trYMaxF) - delete(res@trYMinF) - res@tiYAxisString = units - res@tiMainString = "TOTVEGC" - plot(4) = gsn_csm_xy(wks,yearplt,totvegc_glob,res) - - res@tiYAxisString = units - res@tiMainString = "Delta TOTVEGC " + "EqYr: "+totvegc_glob_equil - res@trYMaxF = 0.2 - res@trYMinF = -0.2 - plot(5) = gsn_csm_xy(wks,yearpltmid,totvegc_glob_del,res) - prim7 = gsn_add_polyline(wks,plot(5),(/0.,yearpltmid(nyrs-2)/),(/0.,0./),polyres1) - prim8 = gsn_add_polyline(wks,plot(5),(/0.,yearpltmid(nyrs-2)/),(/-glob_thresh_totvegc,-glob_thresh_totvegc/),polyres2) - prim9 = gsn_add_polyline(wks,plot(5),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_totvegc,glob_thresh_totvegc/),polyres2) - - delete(res@trYMaxF) - delete(res@trYMinF) - res@tiYAxisString = "m ~S~2~N~ m~S~-2~N~" - res@tiMainString = "TLAI" - plot(6) = gsn_csm_xy(wks,yearplt,tlai_glob,res) - - res@tiYAxisString = "m ~S~2~N~ m~S~-2~N~" - res@tiMainString = "Delta TLAI " + "EqYr: "+tlai_glob_equil - res@trYMaxF = 0.2 - res@trYMinF = -0.2 - plot(7) = gsn_csm_xy(wks,yearpltmid,tlai_glob_del,res) - prim10 = gsn_add_polyline(wks,plot(7),(/0.,yearpltmid(nyrs-2)/),(/0.,0./),polyres1) - prim11 = gsn_add_polyline(wks,plot(7),(/0.,yearpltmid(nyrs-2)/),(/-glob_thresh_tlai,-glob_thresh_tlai/),polyres2) - prim12 = gsn_add_polyline(wks,plot(7),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_tlai,glob_thresh_tlai/),polyres2) - - delete(res@trYMaxF) - delete(res@trYMinF) - res@tiYAxisString = units+" yr~S~-1~N~" - res@tiMainString = "GPP" - plot(8) = gsn_csm_xy(wks,yearplt,gpp_glob,res) - - res@tiYAxisString = units+" yr~S~-1~N~" - res@tiXAxisString = "Spinup Year" - res@tiMainString = "Delta GPP " + "EqYr: "+gpp_glob_equil - res@trYMaxF = 0.2 - res@trYMinF = -0.2 - plot(9) = gsn_csm_xy(wks,yearpltmid,gpp_glob_del,res) - prim13 = gsn_add_polyline(wks,plot(9),(/0.,yearpltmid(nyrs-2)/),(/0.,0./),polyres1) - prim14 = gsn_add_polyline(wks,plot(9),(/0.,yearpltmid(nyrs-2)/),(/-glob_thresh_gpp,-glob_thresh_gpp/),polyres2) - prim15 = gsn_add_polyline(wks,plot(9),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_gpp,glob_thresh_gpp/),polyres2) - - delete(res@trYMaxF) - delete(res@trYMinF) - res@tiYAxisString = "m" - res@tiMainString = "TWS" - plot(10) = gsn_csm_xy(wks,yearplt,tws_glob,res) - - res@tiYAxisString = "m" - res@tiMainString = "Delta TWS " + "EqYr: "+tws_glob_equil - res@trYMaxF = 0.05 - res@trYMinF = -0.05 - plot(11) = gsn_csm_xy(wks,yearpltmid,tws_glob_del,res) - prim16 = gsn_add_polyline(wks,plot(11),(/0.,yearpltmid(nyrs-2)/),(/0.,0./),polyres1) - prim17 = gsn_add_polyline(wks,plot(11),(/0.,yearpltmid(nyrs-2)/),(/-glob_thresh_tws,-glob_thresh_tws/),polyres2) - prim18 = gsn_add_polyline(wks,plot(11),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_tws,glob_thresh_tws/),polyres2) - - if (region .ne. "SPT") then - res@tiYAxisString = "%" - res@tiMainString = "% Land Area in TOTECOSYSC Disequil " + "EqYr: "+perc_landarea_glob_noequil - res@trYMaxF = 80.0 - res@trYMinF = 0.0 - plot(12) = gsn_csm_xy(wks,yearpltmid,perc_landarea_noequil,res) - prim19 = gsn_add_polyline(wks,plot(12),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_area,glob_thresh_area/),polyres2) - end if - - gsn_panel(wks,plot,(/4,4/),resP) - - if (region .ne. "SPT") then - delete(plot) - resc = True ; turn on plotting options - resc@gsnSpreadColors = True ; spans all colors in colormap - resc@cnFillMode = "RasterFill" ; raster mode - resc@cnFillOn = True ; turn on color fill - resc@cnLinesOn = False ; turn off contour lines - resc@cnLineLabelsOn = False ; turn off contour line labels - resc@cnLevelSelectionMode = "ExplicitLevels" - resc@mpProjection = "robinson" ; Robinson grid projection - if (region .eq. "Arctic") then - resc@mpLimitMode = "LatLon" - resc@mpMinLatF = 50. - resc@mpMaxLatF = 85. - resc@mpMinLonF = -180. - resc@mpMaxLonF = -95. - resc@gsnAddCyclic = False - resc@mpProjection = "CylindricalEquidistant" - end if - resc@gsnDraw = True - resc@gsnFrame = False - resc@lbAutoManage = False - resc@lbLabelFontHeightF = 0.010 - resc@txFontHeightF = 0.008 - resc@cnLevels = (/-5.0,-4.0,-3.0,-2.0,-1.0,0.0,1.0,2.0,3.0,4.0,5.0/) - resc@gsnLeftString = "gC m~S~-2~N~" - resc@gsnRightString = "" - - resc@vpXF = 0.30 ; position and sizes - resc@vpYF = 0.28 ; for XY plot - resc@vpWidthF = 0.30 - resc@vpHeightF = 0.30 - resc@gsnCenterString = "TOTECOSYSC Disequil Yr " + yearplt(nyrs-1) + " - " + yearplt(nyrs-2) - plot = gsn_csm_contour_map(wks,totecosysc_1_map,resc) - - resc@vpXF = 0.65 ; position and sizes - resc@vpYF = 0.28 ; for XY plot - resc@vpWidthF = 0.30 - resc@vpHeightF = 0.30 - resc@gsnCenterString = "TOTECOSYSC Disequil Yr " + yearplt(nyrs-2) + " - " + yearplt(nyrs-3) - plot = gsn_csm_contour_map(wks,totecosysc_2_map,resc) - - end if - - frame(wks) - delete(plot) - plot = new(2,"graphic") - - delete(res@trYMaxF) - delete(res@trYMinF) - res@tiYAxisString = "mm" - res@tiMainString = "H2OSNO" - plot(0) = gsn_csm_xy(wks,yearplt,h2osno_glob,res) - - res@tiYAxisString = "mm" - res@tiMainString = "Delta H2OSNO " + "EqYr: "+h2osno_glob_equil - res@trYMaxF = 5.0 - res@trYMinF = -5.0 - plot(1) = gsn_csm_xy(wks,yearpltmid,h2osno_glob_del,res) - prim20 = gsn_add_polyline(wks,plot(1),(/0.,yearpltmid(nyrs-2)/),(/0.,0./),polyres1) - prim21 = gsn_add_polyline(wks,plot(1),(/0.,yearpltmid(nyrs-2)/),(/-glob_thresh_h2osno,-glob_thresh_h2osno/),polyres2) - prim22 = gsn_add_polyline(wks,plot(1),(/0.,yearpltmid(nyrs-2)/),(/glob_thresh_h2osno,glob_thresh_h2osno/),polyres2) - - gsn_panel(wks,plot,(/4,4/),resP) - frame(wks) - - end if ; end do_plot - -; Equilibrium summary - print((/"======================================================================="/)) - print((/"======================================================================="/)) - print((/"EQUILIBRIUM SUMMARY"/)) - print((/"======================================================================="/)) - if (.not.(ismissing(totecosysc_glob_equil))) then - print((/"TOTECOSYSC is in equilibrium. Eq. Yr. = "+totecosysc_glob_equil/)) - else - print((/"FATAL: TOTECOSYSC is NOT in equilibrium"/)) - end if - if (.not.(ismissing(totsomc_glob_equil))) then - print((/"TOTSOMC is in equilibrium. Eq. Yr. = "+totsomc_glob_equil/)) - else - print((/"FATAL: TOTSOMC is NOT in equilibrium"/)) - end if - if (.not.(ismissing(totvegc_glob_equil))) then - print((/"TOTVEGC is in equilibrium. Eq. Yr. = "+totvegc_glob_equil/)) - else - print((/"FATAL: TOTVEGC is NOT in equilibrium"/)) - end if - if (.not.(ismissing(tlai_glob_equil))) then - print((/"TLAI is in equilibrium. Eq. Yr. = "+tlai_glob_equil/)) - else - print((/"FATAL: TLAI is NOT in equilibrium"/)) - end if - if (.not.(ismissing(gpp_glob_equil))) then - print((/"GPP is in equilibrium. Eq. Yr. = "+gpp_glob_equil/)) - else - print((/"FATAL: GPP is NOT in equilibrium"/)) - end if - if (.not.(ismissing(tws_glob_equil))) then - print((/"TWS is in equilibrium. Eq. Yr. = "+tws_glob_equil/)) - else - print((/"WARNING: TWS is NOT in equilibrium or is missing"/)) - end if - if (.not.(ismissing(h2osno_glob_equil))) then - print((/"H2OSNO is in equilibrium. Eq. Yr. = "+h2osno_glob_equil/)) - else - print((/"WARNING: H2OSNO is NOT in equilibrium or is missing"/)) - end if - if (region .ne. "SPT") then - if (.not.(ismissing(perc_landarea_glob_noequil))) then - print((/"At least "+(100.-glob_thresh_area)+" percent of the land surface is in TOTECOSYSC equilibrium. Eq. Yr. = "+perc_landarea_glob_noequil/)) - print((/"Percent of the land surface not in equilibrium ("+sprintf("%6.2f",perc_landarea_noequil(nyrs-2))+"% )"/)) - else - print((/"FATAL: Not enough of the land surface is in equilibrium ("+sprintf("%6.2f",perc_landarea_noequil(nyrs-2))+"% > "+sprintf("%6.2f",glob_thresh_area)+"%)"/)) - end if - if (.not.(ismissing(totecosysc_glob_equil)) .and. \ - .not.(ismissing(totsomc_glob_equil)) .and. \ - .not.(ismissing(totvegc_glob_equil)) .and. \ - .not.(ismissing(tlai_glob_equil)) .and. \ - .not.(ismissing(gpp_glob_equil)) .and. \ - .not.(ismissing(perc_landarea_glob_noequil))) then - print((/"Congratulations! Your simulation is in equilibrium"/)) - else - print((/"FATAL: Your simulation is not in equilibrium, 8 hours have been deducted from your PTO bank, try again"/)) - end if - print((/"======================================================================="/)) - end if - - print ("=========================================") - print ("Finish Time: "+systemfunc("date") ) - print ("=========================================") - print ("Successfully ran the script") - -end diff --git a/tools/contrib/modify_singlept_site b/tools/contrib/modify_singlept_site deleted file mode 100755 index 4345109ca4..0000000000 --- a/tools/contrib/modify_singlept_site +++ /dev/null @@ -1,391 +0,0 @@ -#! /usr/bin/env python -import sys -import string -import subprocess -from getpass import getuser -import numpy as np -import netCDF4 as netcdf4 -import xarray as xr - -def mprint(mstr): - vnum=sys.version_info[0] - if vnum == 3: - print(mstr) - if vnum == 2: - print mstr - -''' -#------------------------------------------------------------------# -#--------------------- Instructions -----------------------------# -#------------------------------------------------------------------# -After creating a single point surface data file from a global -surface data file, use this script to overwrite some fields with -site-specific data. -''' - -myname = getuser() -#-- Create single point CLM surface data file -create_surfdata = True - -#-- specify site from which to extract data ---------- -sitename='US-Ha1' - -#-- Site level data directory ------------------------ -site_dir='../PTCLM/PTCLM_sitedata/' - -#-- Specify original file -fsurf = '/glade/scratch/'+myname+'/single_point/surfdata_0.9x1.25_16pfts_CMIP6_simyr1850_287.8_42.5_c170706.nc' - -#-- Output directory --------------------------------- -dir_output='/glade/scratch/'+myname+'/single_point/' - -#-- Specify new file name ----------------------------- -command='date "+%y%m%d"' -x2=subprocess.Popen(command,stdout=subprocess.PIPE,shell='True') -x=x2.communicate() -timetag = x[0].strip() -fsurf2 = dir_output + 'surfdata_0.9x1.25_16pfts_CMIP6_simyr2000_'+sitename+'_site.c'+timetag+'.nc' - -#== End User Mods ===================================== - -#site_code,pft_f1,pft_c1,pft_f2,pft_c2,pft_f3,pft_c3,pft_f4,pft_c4,pft_f5,pft_c5 -pftfile =site_dir+'PTCLMDATA_pftdata.txt' -#site_code,name,state,lon,lat,elev,startyear,endyear,alignyear,timestep,campaign -sitefile=site_dir+'PTCLMDATA_sitedata.txt' -#site_code,soil_depth,n_layers,layer_depth,layer_sand%,layer_clay% -soilfile=site_dir+'PTCLMDATA_soildata.txt' - -#-- Raw datafiles ------------------------ -rawdatafile = '../mksurfdata_map/mksurfdata_map.namelist' - -mstr='Checking for data for site: '+sitename -mprint(mstr) - -#-- Read raw datafiles ------------------------ -with open(rawdatafile, 'r') as t1: - for tmp in t1: - x=tmp.split('=') - if x[0].strip() == 'mksrf_fsoitex': - fsoitex = x[1].strip() - fsoitex = fsoitex.strip("'") - if x[0].strip() == 'mksrf_forganic': - forganic = x[1].strip() - forganic = forganic.strip("'") - if x[0].strip() == 'mksrf_flakwat': - flakwat= x[1].strip() - flakwat= flakwat.strip("'") - if x[0].strip() == 'mksrf_fwetlnd': - fwetlnd = x[1].strip() - fwetlnd = fwetlnd.strip("'") - if x[0].strip() == 'mksrf_fmax': - fmax = x[1].strip() - fmax = fmax.strip("'") - if x[0].strip() == 'mksrf_fglacier': - fglacier= x[1].strip() - fglacier= fglacier.strip("'") - if x[0].strip() == 'mksrf_fglacierregion': - fglacierregion= x[1].strip() - fglacierregion= fglacierregion.strip("'") - if x[0].strip() == 'mksrf_fvocef': - fvocef= x[1].strip() - fvocef= fvocef.strip("'") - if x[0].strip() == 'mksrf_furbtopo': - furbtopo = x[1].strip() - furbtopo = furbtopo.strip("'") - if x[0].strip() == 'mksrf_fgdp': - fgdp = x[1].strip() - fgdp = fgdp.strip("'") - if x[0].strip() == 'mksrf_fpeat': - fpeat = x[1].strip() - fpeat = fpeat.strip("'") - if x[0].strip() == 'mksrf_fsoildepth': - fsoildepth= x[1].strip() - fsoildepth= fsoildepth.strip("'") - if x[0].strip() == 'mksrf_fabm': - fabm = x[1].strip() - fabm = fabm.strip("'") - if x[0].strip() == 'mksrf_ftopostats': - ftopostats = x[1].strip() - ftopostats = ftopostats.strip("'") - if x[0].strip() == 'mksrf_fvic': - fvic = x[1].strip() - fvic = fvic.strip("'") - if x[0].strip() == 'mksrf_fch4': - fch4 = x[1].strip() - fch4 = fch4.strip("'") - if x[0].strip() == 'mksrf_furban': - furban = x[1].strip() - furban = furban.strip("'") - if x[0].strip() == 'mksrf_fvegtyp': - fvegtyp= x[1].strip() - fvegtyp= fvegtyp.strip("'") - if x[0].strip() == 'mksrf_fhrvtyp': - fhrvtyp= x[1].strip() - fhrvtyp= fhrvtyp.strip("'") - if x[0].strip() == 'mksrf_fsoicol': - fsoicol = x[1].strip() - fsoicol = fsoicol.strip("'") - if x[0].strip() == 'mksrf_flai': - flai = x[1].strip() - flai = flai.strip("'") - -#Open site file and extract data -site_found = False -with open(sitefile, 'r') as t1: - for tmp in t1: - x=tmp.split(',') - if x[0] == sitename: - site_found = True - site_header = tmp - name = x[1] - state = x[2] - plon = np.float32(x[3]) - plat = np.float32(x[4]) - elev = np.float32(x[5]) - startyear= np.int32(x[6]) - endyear = np.int32(x[7]) - alignyear= np.int32(x[8]) - timestep = np.float32(x[9]) - campaign = x[10] - exit - -if not site_found: - mprint('No site matching '+sitename+' was found') - stop -else: - mprint(site_header) - -# convert longitude to east if needed -if plon < 0: - plon+=360.0 - -#-- Open pft file and extract data --------------------------------- -site_found = False -with open(pftfile, 'r') as t1: - for tmp in t1: - x=tmp.split(',') - if x[0] == sitename: - site_found = True - pft_f1= np.int32(x[1]) - pft_c1= np.int32(x[2]) - pft_f2= np.int32(x[3]) - pft_c2= np.int32(x[4]) - pft_f3= np.int32(x[5]) - pft_c3= np.int32(x[6]) - pft_f4= np.int32(x[7]) - pft_c4= np.int32(x[8]) - pft_f5= np.int32(x[9]) - pft_c5= np.int32(x[10]) - exit - - -#-- Open soil file and extract data --------------------------------- -site_found = False -with open(soilfile, 'r') as t1: - for tmp in t1: - x=tmp.split(',') - if x[0] == sitename: - site_found = True - soil_depth = np.float32(x[1]) - n_layers = np.int32(x[2]) - layer_depth = np.float32(x[3]) - layer_sand_pct = np.float32(x[4]) - layer_clay_pct = np.float32(x[5]) - exit - -#-- create surface data file -------------------------------------- -##2 -if create_surfdata: - f1 = xr.open_dataset(fsurf) - # expand dimensions - #f1 = f1.expand_dims(['lsmlat','lsmlon']) - - # create 1d variables - lon0=np.asarray(f1['LONGXY'][0,:]) - lon=xr.DataArray(lon0,name='lon',dims='lsmlon',coords={'lsmlon':lon0}) - lat0=np.asarray(f1['LATIXY'][:,0]) - lat=xr.DataArray(lat0,name='lat',dims='lsmlat',coords={'lsmlat':lat0}) - #f2=f1.assign({'lon':lon,'lat':lat}) - # the above doesn't work now - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - - # make gridcell entirely natural vegetation *or* entirely crop - new_pct_natveg = 0. - new_pct_crop = 0. - if np.logical_and( - np.any([pft_f1,pft_f2,pft_f3,pft_f4,pft_f5]), - np.any([(pft_c1 < 15),(pft_c2 < 15),(pft_c3 < 15),(pft_c4 < 15),(pft_c5 < 15)])): - new_pct_natveg = 100. - if np.logical_and( - np.any([pft_f1,pft_f2,pft_f3,pft_f4,pft_f5]), - np.any([(pft_c1 >= 15),(pft_c2 >= 15),(pft_c3 >= 15),(pft_c4 >= 15),(pft_c5 >= 15)])): - new_pct_crop = 100. - - if new_pct_natveg == new_pct_crop: - print 'both natveg and crop set to 100, exiting' - stop - - #-- Remove non-vegetated landunits --------------------------------- - f2['PCT_NATVEG'] = new_pct_natveg - f2['PCT_CROP'] = new_pct_crop - f2['PCT_LAKE'] = 0. - f2['PCT_WETLAND'] = 0. - f2['PCT_URBAN'] = 0. - f2['PCT_GLACIER'] = 0. - - #-- Overwrite global data with raw data ---------------------------- - f2['LONGXY'] = plon - f2['LATIXY'] = plat - - #-- Soil texture - r1 = xr.open_dataset(fsoitex) - plonc = plon - if plonc > 180.0: - plonc -= 360.0 - - # set coordinates (seems to require 'lon' and 'lat' to recognize... - r1=r1.rename({'LON':'lon','LAT':'lat'}) - r1.set_coords(['lon','lat'],inplace=True) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - # extract sand/clay profiles for given mapunit - mapunit = np.int32(r2['MAPUNITS']) - - f2['PCT_SAND'][:,0,0] = np.asarray(r2['PCT_SAND'][:,mapunit]) - f2['PCT_CLAY'][:,0,0] = np.asarray(r2['PCT_CLAY'][:,mapunit]) - - r1.close() ; r2.close() - - #-- Organic - r1 = xr.open_dataset(forganic) - r1=r1.rename({'LON':'lon','LAT':'lat'}) - r1.set_coords(['lon','lat'],inplace=True) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['ORGANIC'][:,0,0] = np.asarray(r2['ORGANIC']) - r1.close() ; r2.close() - - #-- Fmax - r1 = xr.open_dataset(fmax) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['FMAX'] = np.asarray(r2['FMAX']) - r1.close() ; r2.close() - - #-- VOC - r1 = xr.open_dataset(fvocef) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['EF1_BTR'] = np.asarray(r2['ef_btr']) - f2['EF1_CRP'] = np.asarray(r2['ef_crp']) - f2['EF1_FDT'] = np.asarray(r2['ef_fdt']) - f2['EF1_FET'] = np.asarray(r2['ef_fet']) - f2['EF1_GRS'] = np.asarray(r2['ef_grs']) - f2['EF1_SHR'] = np.asarray(r2['ef_shr']) - r1.close() ; r2.close() - - #-- GDP - r1 = xr.open_dataset(fgdp) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['gdp'] = np.asarray(r2['gdp']) - r1.close() ; r2.close() - - #-- Peat - r1 = xr.open_dataset(fpeat) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['peatf'] = np.asarray(r2['peatf']) - r1.close() ; r2.close() - - #-- Soil Depth - r1 = xr.open_dataset(fsoildepth) - # create 1d variables - lon0=np.asarray(r1['LONGXY'][0,:]) - lon=xr.DataArray(lon0,name='lon',dims='lon',coords={'lon':lon0}) - lat0=np.asarray(r1['LATIXY'][:,0]) - lat=xr.DataArray(lat0,name='lat',dims='lat',coords={'lat':lat0}) - r1['lon'] = lon - r1['lat'] = lat - r1=r1.rename({'lsmlon':'lon','lsmlat':'lat'}) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['zbedrock'] = np.asarray(r2['Avg_Depth_Median']) - #f2['zbedrock'] = np.asarray(r2['Avg_Depth_Mean']) - r1.close() ; r2.close() - - #-- ABM - r1 = xr.open_dataset(fabm) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['abm'] = np.asarray(r2['abm']) - r1.close() ; r2.close() - - #-- SLOPE - r1 = xr.open_dataset(ftopostats) - rlon=np.asarray(r1['LONGITUDE']) - rlat=np.asarray(r1['LATITUDE']) - # extract gridcell closest to plon/plat (data are 1-d) (lon [0,360]) - k1 = np.argmin(np.power(rlon - plon,2)+np.power(rlat - plat,2)) - f2['SLOPE'] = np.asarray(r1['SLOPE'][k1]) - r1.close() ; r2.close() - - #-- VIC - r1 = xr.open_dataset(fvic) - r1=r1.rename({'lsmlon':'lon','lsmlat':'lat'}) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['Ws'] = np.asarray(r2['Ws']) - f2['Dsmax'] = np.asarray(r2['Dsmax']) - f2['Ds'] = np.asarray(r2['Ds']) - r1.close() ; r2.close() - - #-- Methane - r1 = xr.open_dataset(fch4) - # create 1d variables - lon0=np.asarray(r1['LONGXY'][0,:]) - lon=xr.DataArray(lon0,name='lon',dims='lon',coords={'lon':lon0}) - lat0=np.asarray(r1['LATIXY'][:,0]) - lat=xr.DataArray(lat0,name='lat',dims='lat',coords={'lat':lat0}) - r1['lon'] = lon - r1['lat'] = lat - r1=r1.rename({'lsmlon':'lon','lsmlat':'lat'}) - # extract gridcell closest to plon/plat (this file is [0,360] - r2 = r1.sel(lon=plon,lat=plat,method='nearest') - f2['P3'] = np.asarray(r2['P3']) - f2['ZWT0'] = np.asarray(r2['ZWT0']) - f2['F0'] = np.asarray(r2['F0']) - r1.close() ; r2.close() - - #-- Soil Color - r1 = xr.open_dataset(fsoicol) - r1=r1.rename({'LON':'lon','LAT':'lat'}) - r1.set_coords(['lon','lat'],inplace=True) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - f2['SOIL_COLOR'] = np.asarray(r2['SOIL_COLOR']) - r1.close() ; r2.close() - - #-- LAI / Height - r1 = xr.open_dataset(flai) - r1=r1.rename({'LON':'lon','LAT':'lat'}) - r1.set_coords(['lon','lat'],inplace=True) - # extract gridcell closest to plonc/plat - r2 = r1.sel(lon=plonc,lat=plat,method='nearest') - - # ignoring crop, i.e. excluding index 15 - f2['MONTHLY_HEIGHT_BOT'][:,0:15,0,0] = np.asarray(r2['MONTHLY_HEIGHT_BOT'][:,0:15]) - f2['MONTHLY_HEIGHT_TOP'][:,0:15,0,0] = np.asarray(r2['MONTHLY_HEIGHT_TOP'][:,0:15]) - f2['MONTHLY_LAI'][:,0:15,0,0] = np.asarray(r2['MONTHLY_LAI'][:,0:15]) - f2['MONTHLY_SAI'][:,0:15,0,0] = np.asarray(r2['MONTHLY_SAI'][:,0:15]) - r1.close() ; r2.close() - - #-- Close output file - # mode 'w' overwrites file - f2.to_netcdf(path=fsurf2, mode='w') - mprint('created file '+fsurf2) - f1.close(); f2.close(); f2.close() - mprint('successfully created surface data file: '+fsurf2) - diff --git a/tools/contrib/run_clm_historical b/tools/contrib/run_clm_historical deleted file mode 100755 index d161f1c43b..0000000000 --- a/tools/contrib/run_clm_historical +++ /dev/null @@ -1,365 +0,0 @@ -#!/bin/csh - -######################################################################################### -# -# - Execute this script to do a CLM historical simulation from 1850 - 2014. This -# script will complete all the changes required at year 1901 to deal with the -# fact that met forcing data does not go back to 1850. -# -# - Unmodified script will do the following. -# Part 1: Simulation 1: 1850 - 1870 (21 years) using repeated 1901-1920 forcing -# Part 2: Simulation 2: 1871 - 1900 (30 years) using repeated 1901-1920 forcing -# Part 3: Simulation 3+4+5+6: 1901-1988 (four 22 year) simulations using 1901-1988 forcing -# Part 4: Simulation 7: 1989-2004 (one 16 year) branch simulation w/daily output using 1989-2004 forcing -# Part 5: Simulation 8: 2005-2014 (one 10 year) branch simulation w/daily & subdaily output using 2005-2014 forcing -# -# - Script assumes that simulation can run at least 30 years within a 12 hour block on -# Cheyenne. To find the timing in an equivalent sample run, look in the timing -# directory and grep as follows > grep 'simulated_years/day' cesm_timing* -# -# - In the env_batch.xml file for the case.run group ensure the following: -# that way you can use up to 12:00 hours of wall-clock computer time per run block -# -# - This script assumes that env_mach_pes.xml has been setup and case.setup has already been run -# -# - This script makes use of user_nl_datm1901-1920 and user_nl_datm1901-2014 -# -# - Before submitting script, make a copy of your modified or unmodified user_nl_clm file -# into "original_user_nl_clm". This should only contain namelist items that will not change throughout -# the run. -# Create a file called user_nl_clm_histdaily that contains the desired history output namelist items -# for the 1989-2004 simulation -# Create a file called user_nl_clm_histsubdaily that contains the desired history output namelist items -# for the 2005-2014 simulation -# -# - The atm data files start in 1901, so with : -# ALIGN year of 1901, (this is in units of RUN or simulation years) -# START year of 1901, (this is in units of FORCE'ing data years) -# -# RUN Year : 1850 ... 1860 1861 ... 1870 ... 1880 1881 ... 1890 ... 1900 1901 ... 2014 -# FORCE Year : 1910 ... 1920 1901 ... 1910 ... 1920 1901 ... 1910 ... 1920 1901 ... 2014 -# -# - The script could be broken up into several parts if you want to check the initial set of -# simulations. -# -# - Written by Andrew Slater - Late July, 2015; aslater@kryos.colorado.edu -# - Modified by Dave Lawrence, August, 2015 -# - Updated with better check that run has also been archived to short term - Dave Lawrence -# October, 2015 -# - Updated to adjust for the fact that the model is now slower - Keith Oleson December, 2016 -# ./run_clm_historical.v5.csh ! > & run_historical.out & -# - Extend to 2014 and obtain daily & sub-daily output for end of run - Keith Oleson January, 2018 -# ./run_clm_historical.v6.csh ! > & run_historical.out & -# - Modify history output for CMIP6 - Keith Oleson January, 2019 -# ./run_clm_historical.v7.csh ! > & run_historical.out & -######################################################################################### - -######################################################################################### -# PART 1 -######################################################################################### -# -# This portion does the initial setup and the initial 21 year run (1850-1870) -# -######################################################################################### - -# --- CASENAME is your case name -set CASENAME = 'clm50_release-clm5.0.15_2deg_GSWP3V1_hist' - -# --- Set the user namelist file. -cp original_user_nl_clm user_nl_clm - -# --- Ensure that the env_run.xml file has the correct content -# Since this particular run won't go for 51 years in 12 hours (as in v4 script), set it up for 21 years first -./xmlchange RUN_TYPE=startup -./xmlchange RUN_STARTDATE=1850-01-01 -./xmlchange STOP_OPTION=nyears -./xmlchange STOP_N=21 -./xmlchange CONTINUE_RUN=FALSE -./xmlchange RESUBMIT=0 -./xmlchange DATM_CLMNCEP_YR_ALIGN=1901 -./xmlchange DATM_CLMNCEP_YR_START=1901 -./xmlchange DATM_CLMNCEP_YR_END=1920 - -# need to use user_nl_datm files to get years right -cp user_nl_datm1901-1920 user_nl_datm - -# --- Check that you end up using the correct env_run.xml file -set nenvr = `ls -1 env_run*.xml | wc -l` -if ($nenvr > 1) then - echo 'There is more than one file of the type env_run*.xml' - echo 'There should only be one such file' - exit -endif - -# --- If you have not already built the code, then do so now -#./case.clean_build -qcmd -- ./case.build - -# --- Now submit the job and let it run -./case.submit - -######################################################################################### -# PART 2 -######################################################################################### -# -# This portion checks to see if the 1850-1870 portion of the run is done (or it waits -# 10 minutes before checking again). -# -# This will then start the run from 1871 (hence the CONTINUE_RUN=TRUE) and do one 30 year -# simulation -# -# The new values for env_run.xml are put in place -# Then submit the job -# -######################################################################################### - - -set WDIR = '/glade/scratch/'$USER'/'$CASENAME'/run/' -set DONE_RUNA = 0 -set DONE_ARCHIVE = 0 -set RESTART_FILE = $WDIR$CASENAME'.clm2.r.1871-01-01-00000.nc' - -# --- Check if the first set of simulations have completed and the data archived (every ten minutes) -while ($DONE_RUNA == 0) - if (-e $RESTART_FILE) then - set DONE_RUNA = 1 - echo '1850-1870 run is complete' - while ($DONE_ARCHIVE == 0) - set nh0 = `ls -l $WDIR/*clm2.h0.* | egrep -c '^-'` - echo $nh0 - if ($nh0 == 1) then - set DONE_ARCHIVE = 1 - echo 'Files have been archived' - else - sleep 600 - date - endif - else - sleep 600 - date - endif -end - -# These are the proper settings to let this script continue the run through 1900 -./xmlchange STOP_N=30 -./xmlchange CONTINUE_RUN=TRUE - -# --- Now submit the job and let it run -./case.submit - -######################################################################################### -# PART 3 -######################################################################################### -# -# This portion checks to see if the 1871-1900 portion of the run is done (or it waits -# 10 minutes before checking again). It then removes (or rather moves and renames) the -# datm files so that the model will use the full array of data from 1901-2014. -# This part runs with forcing data files that actually exist for 1901-2014 -# -# This will start the run from 1901 (hence the CONTINUE_RUN=TRUE) and do four 22 year -# simulations: 1901 + 4*22 - 1 = 1988 (minus 1 because we do 1901) -# -# The new values for env_run.xml are put in place -# Then submit the job -# -######################################################################################### - - -set WDIR = '/glade/scratch/'$USER'/'$CASENAME'/run/' -set DDIR = $WDIR'restart_dump/' -set DONE_RUNA = 0 -set DONE_ARCHIVE = 0 -set RESTART_FILE = $WDIR$CASENAME'.clm2.r.1901-01-01-00000.nc' - -# --- Check if the first set of simulations have completed and the data archived (every ten minutes) -while ($DONE_RUNA == 0) - if (-e $RESTART_FILE) then - set DONE_RUNA = 1 - echo '1850-1900 run is complete' - while ($DONE_ARCHIVE == 0) - set nh0 = `ls -l $WDIR/*clm2.h0.* | egrep -c '^-'` - echo $nh0 - if ($nh0 == 1) then - set DONE_ARCHIVE = 1 - echo 'Files have been archived' - else - sleep 600 - date - endif - else - sleep 600 - date - endif -end - -# --- If the first two sets of simulations are done, move the datm files and compress them -if (! -d $DDIR) then - mkdir $DDIR -endif -mv -i $WDIR$CASENAME.datm.rs1*.bin $DDIR -gzip $DDIR$CASENAME*.bin - -# Since this particular run won't go for 55 years in 12 hours, do this in four 22 year chunks, thus -# we have to resubmit the job 3 times. -./xmlchange STOP_OPTION=nyears -./xmlchange STOP_N=22 -./xmlchange DATM_CLMNCEP_YR_ALIGN=1901 -./xmlchange DATM_CLMNCEP_YR_START=1901 -./xmlchange DATM_CLMNCEP_YR_END=2014 -./xmlchange CONTINUE_RUN=TRUE -./xmlchange RESUBMIT=3 - -# need to use user_nl_datm files to get years right -cp user_nl_datm1901-2014 user_nl_datm - -# --- Check that you end up using the correct env_run.xml file -set nenvr = `ls -1 env_run*.xml | wc -l` -if ($nenvr > 1) then - echo 'There is more than one file of the type env_run*.xml' - echo 'There should only be one such file' - exit -endif - -# --- Now submit the job and let it run -./case.submit - -######################################################################################### -# PART 4 -######################################################################################### -# -# This portion checks to see if the 1901-1988 part of the run is complete -# and then runs the model for 1989-2004 as a branch run to get daily output -# -######################################################################################### - -set DONE_RUNA = 0 -set DONE_ARCHIVE = 0 -set RESTART_FILE = $WDIR$CASENAME'.clm2.r.1989-01-01-00000.nc' - -# --- Check if the second set of simulations have completed and the data archived (every ten minutes) -while ($DONE_RUNA == 0) - if (-e $RESTART_FILE) then - set DONE_RUNA = 1 - echo '1901-1989 run is complete' - while ($DONE_ARCHIVE == 0) - set nh0 = `ls -l $WDIR/*clm2.h0.* | egrep -c '^-'` - echo $nh0 - if ($nh0 == 1) then - set DONE_ARCHIVE = 1 - echo 'Files have been archived' - else - sleep 600 - date - endif - else - sleep 600 - date - endif -end - -# --- Ensure that the env_run.xml file has the correct content -./xmlchange RUN_TYPE=branch -./xmlchange RUN_REFCASE={$CASENAME} -./xmlchange RUN_REFDATE=1989-01-01 -./xmlchange STOP_OPTION=nyears -./xmlchange STOP_N=16 -./xmlchange CONTINUE_RUN=FALSE -./xmlchange RESUBMIT=0 - -# --- Add in the daily output streams -# --- Reset the user namelist file. -cp original_user_nl_clm user_nl_clm - -# --- Add in the daily history output items -cat user_nl_clm_histdaily >> user_nl_clm - -# --- Now submit the job and let it run -./case.submit - -######################################################################################### -# PART 5 -######################################################################################### -# -# This portion checks to see if the 1989-2004 part of the run is complete -# and then runs the model for 2005-2014 as a branch run to get daily and subdaily output -# -######################################################################################### - -set DONE_RUNA = 0 -set DONE_ARCHIVE = 0 -set RESTART_FILE = $WDIR$CASENAME'.clm2.r.2005-01-01-00000.nc' - -# --- Check if the second set of simulations have completed and the data archived (every ten minutes) -while ($DONE_RUNA == 0) - if (-e $RESTART_FILE) then - set DONE_RUNA = 1 - echo '1989-2004 run is complete' - while ($DONE_ARCHIVE == 0) - set nh0 = `ls -l $WDIR/*clm2.h0.* | egrep -c '^-'` - echo $nh0 - if ($nh0 == 1) then - set DONE_ARCHIVE = 1 - echo 'Files have been archived' - else - sleep 600 - date - endif - else - sleep 600 - date - endif -end - -# --- Ensure that the env_run.xml file has the correct content -./xmlchange RUN_TYPE=branch -./xmlchange RUN_REFCASE={$CASENAME} -./xmlchange RUN_REFDATE=2005-01-01 -./xmlchange STOP_OPTION=nyears -./xmlchange STOP_N=10 -./xmlchange CONTINUE_RUN=FALSE -./xmlchange RESUBMIT=0 - -# --- Add in the subdaily output streams -# --- Reset the user namelist file. -cp original_user_nl_clm user_nl_clm - -# --- Add in the daily history output items -cat user_nl_clm_histdaily >> user_nl_clm - -# --- Add in the subdaily history output items -cat user_nl_clm_histsubdaily >> user_nl_clm - -# --- Now submit the job and let it run -./case.submit - -######################################################################################### -# -# This portion checks to see if the 2005-2014 part of the run is complete -# and ends the script -# -######################################################################################### - -set DONE_RUNA = 0 -set DONE_ARCHIVE = 0 -set RESTART_FILE = $WDIR$CASENAME'.clm2.r.2015-01-01-00000.nc' - -# --- Check if the second set of simulations have completed and the data archived (every ten minutes) -while ($DONE_RUNA == 0) - if (-e $RESTART_FILE) then - set DONE_RUNA = 1 - echo '2005-2014 run is complete' - while ($DONE_ARCHIVE == 0) - set nh0 = `ls -l $WDIR/*clm2.h0.* | egrep -c '^-'` - echo $nh0 - if ($nh0 == 1) then - set DONE_ARCHIVE = 1 - echo 'Files have been archived' - else - sleep 600 - date - endif - else - sleep 600 - date - endif -end diff --git a/tools/contrib/run_clmtowers b/tools/contrib/run_clmtowers deleted file mode 100755 index 59b276260f..0000000000 --- a/tools/contrib/run_clmtowers +++ /dev/null @@ -1,356 +0,0 @@ -#!/bin/csh -f -# -# run_clmtowers.csh -# Purpose: This script will run any number of flux tower sites. You will need to -# run the script for each spinup and post spinup set of simulations (i.e., -# for BGC on, run it separately for AD, PostAD, and post spinup simulations; -# for BGC off, run it separately for spinup and post spinup simulations) -# You will need to do two things: -# 1. Copy this script into $Clm_Tag_Dir/tools/shared/PTCLM -# where $Clm_Tag_Dir is the location of your clm tag -# 2. Set up a directory structure where you can put any sourcemods you might want. -# These sourcemods will be copied into the appropriate case directory. -# The structure is up to you but here is an example: -# cd $Clm_Tag_Dir/tools/shared/PTCLM -# mkdir SourceMods -# mkdir SourceMods/clm4_5 -# mkdir SourceMods/clm5_0 -# mkdir SourceMods/clm4_5/BASE ; This might contain any sourcemods that you want -# ; to use in your clm4_5 control experiment -# mkdir SourceMods/clm5_0/BASE ; This might contain any sourcemods that you want -# ; to use in your clm5_0 control experiment -# mkdir SourceMods/clm4_5/EXP1 ; This might contain any sourcemods that you want -# ; to use in your first clm4_5 experiment -# mkdir SourceMods/clm5_0/EXP1 ; This might contain any sourcemods that you want -# ; to use in your first clm5_0 experiment -# Author: Keith Oleson -# Last Revised: Jan 24 2019 -# Last CLM Tag that this worked on: release-clm5.0.12 -# Warning: This script is complicated and does not have good (any) error checking currently. -# You might want to ask me for a quick tutorial before using this. -# -# ASSUMES that PTCLMmkdata has already been run for the tower sites chosen below -# (Surface datasets and shell commands have already been created) -# To run this script on cheyenne: qcmd -- ./run_clmtowers.csh >&! run_clmtowers.out & -# - -set pwd=`pwd` - -# =================================Start User Mods================================ -# Pick a compset (these are the only two compsets supported, they are both SP compsets -# but BGC will be added if requested below) -#set compset = I1PtClm45SpGs -set compset = I1PtClm50SpGs -if ($compset == I1PtClm45SpGs) then - set model = clm4_5 -else - set model = clm5_0 -endif - -# Set location of your run directories -set rundata = /glade/scratch/oleson -# Set the location of your CLM tag -set Clm_Tag_Dir = /glade/work/oleson/release-clm5.0.12 -# Set the location of your surface datasets and shell commands that were generated by PTCLM. -# This will not necessarily be in the same location as the CLM tag that you are running above -#set User_Mods_Dir = /glade/scratch/oleson/release-clm5.0.12 # This is my version for SP simulations -set User_Mods_Dir = /glade/scratch/oleson/release-clm5.0.12.BGC # This is my version for BGC simulations - -# What sites to run? -# These are the sites that can be evaluated with some combination of level 2 data and synthesis (gap-filled) data -#set sites = ( US-Var US-Bo1 US-UMB US-Brw US-ARM US-Ho1 US-Me4 US-Me2 US-Dk3 US-NR1 DE-Tha ES-ES1 FL-Hyy CA-Man BR-Sa3 BR-Sa1 IT-Cpz US-Dk2 US-MOz US-WCr US-MMS US-Ha1 BE-Vie IT-Col CA-Let US-FPe FL-Kaa US-IB1 US-Ne3 CA-Qfo BR-Sa1LBA BR-Sa3LBA BR-Ma1LBA BR-RJA BR-Ji1 CA-Obs CA-Ojp CA-Ca1 CA-Oas US-Dk1) -#set startyear = ( 2000 1996 1999 1998 2000 1996 1996 2002 1998 1998 1998 1999 1997 1994 2001 2002 2001 2003 2004 1998 1999 1991 1997 1996 1998 2000 2000 2005 2001 2004 2002 2001 2000 2000 1999 2000 2000 1998 1997 2001) -#set endyear = ( 2007 2008 2006 2006 2007 2004 2000 2010 2005 2007 2003 2005 2005 2003 2003 2004 2005 2005 2007 2006 2007 2006 2005 2001 2007 2007 2005 2007 2006 2006 2004 2003 2005 2002 2001 2006 2006 2006 2006 2005) -# Or you could just do one site -set sites = ( US-Var ) -set startyear = ( 2000 ) -set endyear = ( 2007 ) - -set BGC = "ON" # ON or OFF - -# USER MODS FOR BGC ON -# For BGC on, the sequence of simulations is AD spinup (300 years), -# PostAD spinup (100 years), -# post spinup (the number of tower years with atmospheric forcing) -# For BGC on, AD spinup is SPINUP_P1=TRUE, SPINUP_P2=FALSE -# PostAD spinup is SPINUP_P1=TRUE, SPINUP_P2=TRUE -# post spinup is SPINUP_P1=FALSE, SPINUP_P2=FALSE - -if ($BGC == ON) then - setenv SPINUP_P1 "TRUE" - setenv SPINUP_P2 "TRUE" -endif - -# For BGC on, you could use these for either type of spinup (AD or PostAD) -if ($BGC == ON) then - if ($SPINUP_P1 == TRUE) then - if ($model == clm5_0) then - set newcase = spinclm50conr12AD - set clonecase = spinclm50conr12pAD - else - if ($model == clm4_5) then - set newcase = spinclm45conr12AD - set clonecase = spinclm45conr12pAD - endif - endif - endif -endif - -# For BGC on, you could use these for post spinup (the number of tower years with atmospheric forcing) -# You should change the "r12" for the clonecase to whatever tag you are using (e.g., r12 is used here to -# denote release-clm5.0.12) and/or add some designation for your particular experiment with that tag (e.g., -# conclm50r12wspinbgc) -if ($BGC == ON) then - if ($SPINUP_P1 == FALSE) then - if ($model == clm5_0) then - set newcase = spinclm50conr12pAD - set clonecase = conclm50r12wspinbgc - else - if ($model == clm4_5) then - set newcase = spinclm45conr12pAD - set clonecase = conclm45r12wspinbgc - endif - endif - endif -endif - -# USER MODS FOR BGC OFF -# For BGC off, the sequence of simulations is normal spinup (32 years) -# post spinup (the number of tower years with atmospheric forcing) -# For BGC off, normal spinup is SPINUP_P1=TRUE, SPINUP_P2=FALSE -# post spinup is SPINUP_P1=FALSE, SPINUP_P2=FALSE -if ($BGC == OFF) then - setenv SPINUP_P1 "FALSE" - setenv SPINUP_P2 "FALSE" -endif - -# For BGC off, use these for either normal spinup or post spinup -# You should change the "r12" for the clonecase to whatever tag you are using (e.g., r12 is used here to -# denote release-clm5.0.12) and/or add some designation for your particular experiment with that tag (e.g., -# conclm50r12wspinsp) -if ($BGC == OFF) then - if ($model == clm5_0) then - set newcase = spinclm50conr12sp - set clonecase = conclm50r12wspinsp - else - if ($model == clm4_5) then - set newcase = spinclm45conr12sp - set clonecase = conclm45r12wspinsp - endif - endif -endif - -# These sourcemods will be copied into every case directory (you will need to setup a -# directory structure for your sourcemods, see instructions at top of script) -set sourcemods_dir = {$Clm_Tag_Dir}/tools/PTCLM/SourceMods/ -echo $sourcemods_dir -set sourcemods = {$sourcemods_dir}{$model}/BASE/*.F90 -echo $sourcemods - -# Set some namelist options if required -# If you set any of these you will need to also set them below (search on namelist_opts) -#set namelist_opts1 = "paramfile='/glade/p/cgd/tss/people/oleson/modify_param/CLM5_SP_ens_dec_5D_mcalib_psi50BET3_BETKr9_Cropkrmax5e-10_calmbboptleafcn.nc'" -#set namelist_opts2 = "baseflow_scalar= 0.001d00" -# BGC -#set namelist_opts3 = "pot_hmn_ign_counts_alpha= 0.012d00" -#set namelist_opts4 = "cli_scale= 0.022d00" -#set namelist_opts5 = "boreal_peatfire_c= 0.2d-4" - -# =================================End User Mods================================ - -@ cnt = 1 -foreach mysite ( $sites ) - @ numyears = $endyear[$cnt] - $startyear[$cnt] + 1 - if ($SPINUP_P1 == TRUE) then - @ numfour = $numyears / 4 - # If have three years or less (numfour = 0) just repeat first year - # unless first year is leap year then use next year. - # Since just using one year that is not a leap year we can use - # an alignyear of 1 and endyear is the startyear - if ( $numfour == 0 ) then - if ( $startyear[$cnt] % 4 == 0 ) then - @ startyears = $startyear[$cnt] + 1 - @ endyears = $startyears - else - @ endyears = $startyear[$cnt] - @ startyears = $endyears - endif - @ alignyear = 1 - endif - if ( $numfour != 0 ) then - @ startyears = $startyear[$cnt] - @ endyears = $startyear[$cnt] + $numfour * 4 - 1 - @ alignyear = $startyear[$cnt] - endif - echo $endyear[$cnt] - echo $endyears - echo $startyears - echo $alignyear - endif - cd {$Clm_Tag_Dir}/cime/scripts - if ($SPINUP_P1 == FALSE) then - set casename = ${clonecase}_${mysite}_$compset - ./create_clone --case $casename --clone ${newcase}_${mysite}_${compset} - else - if ($BGC == ON && $SPINUP_P2 == TRUE) then - set casename = ${clonecase}_${mysite}_$compset - echo $casename - ./create_clone --case $casename --clone ${newcase}_${mysite}_${compset} - else - set casename = ${newcase}_${mysite}_$compset - ./create_newcase --user-mods-dir {$User_Mods_Dir}/tools/PTCLM/mydatafiles/1x1pt_${mysite} --case $casename --mach cheyenne --compset $compset --res CLM_USRDAT --project P93300041 --run-unsupported - endif - endif - cd {$Clm_Tag_Dir}/cime/scripts/${casename} - ./xmlchange --id PIO_TYPENAME --val netcdf - ./xmlchange --id PIO_REARRANGER --val 1 - if ($SPINUP_P1 == FALSE) then - rm -f cesm.stderr* - rm -f cesm.stdout* - rm -f STATUS.out - ./xmlchange --id STOP_OPTION --val nyears - ./xmlchange --id STOP_N --val $numyears - ./xmlchange --id RUN_STARTDATE --val $startyear[$cnt]-01-01 - ./xmlchange --id DATM_CLMNCEP_YR_ALIGN --val $startyear[$cnt] - ./xmlchange --id DATM_CLMNCEP_YR_START --val $startyear[$cnt] - ./xmlchange --id DATM_CLMNCEP_YR_END --val $endyear[$cnt] - ./xmlchange --id CALENDAR --val GREGORIAN - if ($BGC == ON) then - ./xmlchange --id CLM_BLDNML_OPTS --val "-mask navy -bgc bgc -crop" - ./xmlchange --id CLM_ACCELERATED_SPINUP --val "off" - endif - else - if ($BGC == ON && $SPINUP_P2 == TRUE) then - rm -f cesm.stderr* - rm -f cesm.stdout* - rm -f STATUS.out - ./xmlchange --id STOP_OPTION --val nyears - ./xmlchange --id STOP_N --val 100 - ./xmlchange --id CLM_BLDNML_OPTS --val "-mask navy -bgc bgc -crop" - ./xmlchange --id CLM_ACCELERATED_SPINUP --val "off" - else - ./xmlchange --id STOP_OPTION --val nyears - if ($BGC == ON) then - ./xmlchange --id STOP_N --val 300 - else - ./xmlchange --id STOP_N --val 32 - endif - if ($alignyear == 1) then - ./xmlchange --id RUN_STARTDATE --val 000{$alignyear}-01-01 - else - ./xmlchange --id RUN_STARTDATE --val $startyear[$cnt]-01-01 - endif - ./xmlchange --id DATM_CLMNCEP_YR_ALIGN --val $alignyear - ./xmlchange --id DATM_CLMNCEP_YR_START --val $startyears - ./xmlchange --id DATM_CLMNCEP_YR_END --val $endyears - if ($alignyear == 1) then - ./xmlchange --id CALENDAR --val NO_LEAP - endif - if ($BGC == ON) then - ./xmlchange --id CLM_BLDNML_OPTS --val "-mask navy -bgc bgc -crop" - ./xmlchange --id CLM_ACCELERATED_SPINUP --val "on" - endif - endif - endif - if ($mysite == BR-Sa1LBA || $mysite == BR-Sa3LBA || $mysite == BR-Ma1LBA || $mysite == BR-RJA || $mysite == BR-Ji1) then - if ($SPINUP_P1 == FALSE) then - rm -f user_datm.streams.txt.CLM1PT.CLM_USRDAT - endif - endif - ./xmlchange --id MAX_TASKS_PER_NODE --val 1 - ./xmlchange --id MAX_MPITASKS_PER_NODE --val 1 - ./case.setup - ./preview_namelists - # Have to force this for some reason - if ($SPINUP_P1 == FALSE) then - ./xmlchange --id DATM_CLMNCEP_YR_END --val $endyear[$cnt] - ./preview_namelists - endif - if ( $status != 0 )then - echo "CESM_SETUP FAIL $status" >> ./STATUS.out - exit -1 - else - echo "CESM_SETUP PASS" >> ./STATUS.out - endif - if ($SPINUP_P1 == TRUE && $BGC == ON) then - sed "/BSUB -R/d" ./.case.run > tmp.run - ./xmlchange --subgroup case.run --id JOB_WALLCLOCK_TIME --val 5:59 -# ./xmlchange --subgroup case.run --id JOB_QUEUE --val regular - ./xmlchange --subgroup case.run --id JOB_QUEUE --val share - ./xmlchange --subgroup case.run --id PROJECT --val P93300041 - else - sed "/BSUB -R/d" ./.case.run > tmp.run -# ./xmlchange --subgroup case.run --id JOB_QUEUE --val regular - ./xmlchange --subgroup case.run --id JOB_WALLCLOCK_TIME --val 5:59 - ./xmlchange --subgroup case.run --id JOB_QUEUE --val share - ./xmlchange --subgroup case.run --id PROJECT --val P93300041 - endif - mv tmp.run ./.case.run - chmod u+x ./.case.run - cp $sourcemods SourceMods/src.clm - echo $mysite - if ($mysite == BR-Sa1LBA || $mysite == BR-Sa3LBA || $mysite == BR-Ma1LBA || $mysite == BR-RJA || $mysite == BR-Ji1) then - cp CaseDocs/datm.streams.txt.CLM1PT.CLM_USRDAT ./user_datm.streams.txt.CLM1PT.CLM_USRDAT - chmod u+wx ./user_datm.streams.txt.CLM1PT.CLM_USRDAT - sed "s/RH /QBOT /g" user_datm.streams.txt.CLM1PT.CLM_USRDAT > tmp.user_datm.streams.txt.CLM1PT.CLM_USRDAT - sed "s/ rh/ shum/g" tmp.user_datm.streams.txt.CLM1PT.CLM_USRDAT > tmp2.user_datm.streams.txt.CLM1PT.CLM_USRDAT - rm -f tmp.user_datm.streams.txt.CLM1PT.CLM_USRDAT - mv tmp2.user_datm.streams.txt.CLM1PT.CLM_USRDAT ./user_datm.streams.txt.CLM1PT.CLM_USRDAT - endif - if ($SPINUP_P1 == FALSE) then - sed "/taxmode = 'cycle','cycle'/d" user_nl_datm > tmp.user_nl_datm - mv tmp.user_nl_datm ./user_nl_datm - sed "s/hist_nhtfrq = 0/hist_nhtfrq = 0,1/g" ./user_nl_clm > tmp.user_nl_clm - sed "s/hist_mfilt = 1200/hist_mfilt = 1,350400/g" ./tmp.user_nl_clm > tmp2.user_nl_clm - rm -f tmp.user_nl_clm - sed "/finidat/d" ./tmp2.user_nl_clm > tmp3.user_nl_clm - rm -f tmp2.user_nl_clm - if ($BGC == ON) then - echo " hist_fincl2 = 'FSDS','FLDS','FSR','FSA','FIRE','FIRA','FSH','FCTR','FCEV','FGEV','FGR','FGR12','FSM','TSOI','COSZEN','RAIN','SNOW','H2OSOI','WA','ZWT','GPP','NEE','ELAI','BTRAN','TV','RSSUN','RSSHA','FSH_G','RHAF','RH_LEAF','RH','T10','TG','SABG','SABV'" >> tmp3.user_nl_clm - else - if ($model == clm5_0) then - echo " hist_fincl2 = 'FSDS','FLDS','FSR','FSA','FIRE','FIRA','FSH','FCTR','FCEV','FGEV','FGR','FGR12','FSM','TSOI','COSZEN','RAIN','SNOW','H2OSOI','WA','ZWT','ELAI','BTRAN','FPSN','TV','RSSUN','RSSHA','FSH_G','RHAF','RH_LEAF','RH','T10','TG','SABG','SABV','VEGWP'" >> tmp3.user_nl_clm - else - echo " hist_fincl2 = 'FSDS','FLDS','FSR','FSA','FIRE','FIRA','FSH','FCTR','FCEV','FGEV','FGR','FGR12','FSM','TSOI','COSZEN','RAIN','SNOW','H2OSOI','WA','ZWT','ELAI','BTRAN','FPSN','TV','RSSUN','RSSHA','FSH_G','RHAF','RH_LEAF','RH','T10','TG','SABG','SABV'" >> tmp3.user_nl_clm - endif - endif - set finidat=`ls -1 $rundata/${newcase}_${mysite}_${compset}/run/${newcase}_${mysite}_${compset}.clm?.r.*.nc | tail -1` - echo $finidat - echo " finidat = '$finidat'" >> tmp3.user_nl_clm - mv tmp3.user_nl_clm ./user_nl_clm - else - if ($BGC == ON && $SPINUP_P2 == TRUE) then - set finidat=`ls -1 $rundata/${newcase}_${mysite}_${compset}/run/${newcase}_${mysite}_${compset}.clm?.r.*.nc | tail -1` - echo $finidat - echo " finidat = '$finidat'" >> user_nl_clm - else - echo "taxmode = 'cycle','cycle'" >> user_nl_datm -# echo $namelist_opts1 >> user_nl_clm -# echo $namelist_opts2 >> user_nl_clm -# echo $namelist_opts3 >> user_nl_clm -# echo $namelist_opts4 >> user_nl_clm -# echo $namelist_opts5 >> user_nl_clm - if ($BGC == ON) then - sed "s/hist_mfilt = 1200/hist_mfilt = 12000/g" ./user_nl_clm > tmp.user_nl_clm - echo " hist_fincl1 = 'TOTECOSYSC', 'TOTECOSYSN', 'TOTSOMC', 'TOTSOMN', 'TOTVEGC', 'TOTVEGN', 'TLAI', 'GPP', 'CPOOL', 'NPP', 'TWS', 'FSH', 'FCTR', 'FCEV', 'FGEV', 'QRUNOFF', 'ZWT', 'NEE', 'NEP'" >> tmp.user_nl_clm - mv tmp.user_nl_clm ./user_nl_clm - endif - endif - endif - ./case.build - if ( $status != 0 )then - echo "BUILD FAIL $status" >> ./STATUS.out - exit -1 - else - echo "BUILD PASS" >> ./STATUS.out - endif - ./case.submit - if ( $status != 0 )then - echo "SUBMIT FAIL $status" >> ./STATUS.out - exit -1 - else - echo "SUBMIT PASS" >> ./STATUS.out - endif - cd $pwd - @ cnt++ -end diff --git a/tools/contrib/singlept b/tools/contrib/singlept deleted file mode 100755 index 076e67453b..0000000000 --- a/tools/contrib/singlept +++ /dev/null @@ -1,375 +0,0 @@ -#! /usr/bin/env python -# -# singlept -# -# Script to extract a single grid point from global datasets -# - -# Import libraries -import sys -import os -from getpass import getuser -import string -import subprocess -import numpy as np -import xarray as xr - -def error( desc ): - "error function" - mprint( "ERROR:: "+desc ) - os.abort() - -def mprint(mstr): - "Print function whether python-2 or python-3" - # six.py or import __future__ print_function could be used instead... - vnum=sys.version_info[0] - if vnum == 3: - print(mstr) - if vnum == 2: - print mstr - -def AddTagToFilename(filename, tag): - "Add a tag to a filename" - # Expects file to end with [._]cYYMMDD.nc or [._]YYMMDD.nc - # Add the tag to just before that ending part - basename = os.path.basename(filename) - cend = -10 - if ( basename[cend] == "c" ): - cend = cend - 1 - if ( (basename[cend] != ".") and (basename[cend] != "_") ): - error( "Trouble figuring out where to add tag to filename:"+filename ) - return( basename[:cend]+"_"+tag+basename[cend:] ) - -mprint( "singlept script to extract out a single point from the global CTSM inputdata datasets\n" ) -myname=getuser() -pwd=os.getcwd() -mprint("User = "+myname) -mprint("Current directory = "+pwd+"\n") - -''' -#------------------------------------------------------------------# -#--------------------- Instructions -----------------------------# -#------------------------------------------------------------------# -load the following into your local environment -module load python/2.7.14 -ncar_pylib - -After creating a case using a global compset, run preview_namelist. -From the resulting lnd_in file in the run directory, find the name -of the domain file, and the surface data file. -From the datm streams files (e.g. datm.streams.txt.CLMGSWP3v1.Precip) -find the name of the datm forcing data domain file and forcing files. -Use these file names as the sources for the single point files to -be created (see below). - -After running this script, point to the new CLM domain and surface -dataset using the user_nl_clm file in the case directory. In addition, -copy the datm.streams files to the case directory, with the prefix -'user_', e.g. user_datm.streams.txt.CLMGSWP3v1.Precip. Change the -information in the user_datm.streams* files to point to the single -point datm data (domain and forcing files) created using this script. - -The domain file is not set via user_nl_clm, but requires changing -LND_DOMAIN and ATM_DOMAIN (and their paths) in env_run.xml. - -Using single point forcing data requires specifying the nearest -neighbor mapping algorithm for the datm streams (usually they are -the first three in the list) in user_nl_datm: mapalgo = 'nn','nn','nn', -..., where the '...' can still be 'bilinear', etc, depending on the -other streams that are being used, e.g. aerosols, anomaly forcing, -bias correction. - -The file env_mach_pes.xml should be modified to specify a single -processor. The mpi-serial libraries should also be used, and can be -set in env_build.xml by changing "MPILIB" to "mpi-serial" prior to -setting up the case. - -The case for the single point simulation should have river routing -and land ice models turned off (i.e. the compset should use stub -models SROF and SGLC) - -to run the script -./singlept -deactivate # to remove NPL from environment - -''' - -# Set control flags - -#-- Setup by default to run for Harvard Forest - -#-- Specify point to extract -plon = 287.8 -plat = 42.5 - -#-- Create regional CLM domain file -create_domain = True -#-- Create CLM surface data file -create_surfdata = True -#-- Create CLM surface data file -create_landuse = True -#-- Create single point DATM atmospheric forcing data -create_datm = False -datm_syr=1901 -datm_eyr=2014 - -#-- Modify landunit structure -overwrite_single_pft = True -dominant_pft = 7 #BETr -zero_nonveg_landunits= True -uniform_snowpack = True -no_saturation_excess = True - -#-- Specify input and output directories -dir_output='/glade/scratch/'+myname+'/single_point/' -if ( not os.path.isdir( dir_output ) ): - os.mkdir( dir_output ) -dir_inputdata='/glade/p/cesmdata/cseg/inputdata/' -dir_clm_forcedata='/glade/p/cgd/tss/CTSM_datm_forcing_data/' -dir_input_datm=dir_clm_forcedata+'/atm_forcing.datm7.GSWP3.0.5d.v1.c170516/' -dir_output_datm=dir_output + 'datmdata/' -if ( not os.path.isdir( dir_output_datm ) ): - os.mkdir( dir_output_datm ) - -#-- Set input and output filenames -tag=str(plon)+'_'+str(plat) - -#-- Set time stamp -command='date "+%y%m%d"' -x2=subprocess.Popen(command,stdout=subprocess.PIPE,shell='True') -x=x2.communicate() -timetag = x[0].strip() - -#-- Specify land domain file --------------------------------- -fdomain = dir_inputdata+'share/domains/domain.lnd.fv0.9x1.25_gx1v7.151020.nc' -fdomain2 = dir_output + AddTagToFilename( fdomain, tag ) - -#-- Specify surface data file -------------------------------- -fsurf = dir_inputdata+'lnd/clm2/surfdata_map/surfdata_0.9x1.25_16pfts_CMIP6_simyr1850_c170706.nc' -fsurf2 = dir_output + AddTagToFilename( fsurf, tag ) - -#-- Specify landuse file ------------------------------------- -fluse = dir_inputdata+'lnd/clm2/surfdata_map/landuse.timeseries_0.9x1.25_hist_16pfts_Irrig_CMIP6_simyr1850-2015_c170824.nc' -fluse2 = dir_output + AddTagToFilename( fluse, tag ) - -#-- Specify datm domain file --------------------------------- -fdatmdomain = dir_clm_forcedata+'atm_forcing.datm7.GSWP3.0.5d.v1.c170516/domain.lnd.360x720_gswp3.0v1.c170606.nc' -fdatmdomain2 = dir_output_datm+AddTagToFilename( fdatmdomain, tag ) - -#-- Create CTSM domain file -if create_domain: - mprint( "Open: "+fdomain ) - f1 = xr.open_dataset(fdomain) - # create 1d coordinate variables to enable sel() method - lon0=np.asarray(f1['xc'][0,:]) - lat0=np.asarray(f1['yc'][:,0]) - lon=xr.DataArray(lon0,name='lon',dims='ni',coords={'ni':lon0}) - lat=xr.DataArray(lat0,name='lat',dims='nj',coords={'nj':lat0}) - # assign() not working on cheyenne - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - f2.reset_coords(['xc','yc'],inplace=True) - # extract gridcell closest to plon/plat - f3 = f2.sel(ni=plon,nj=plat,method='nearest') - # expand dimensions - f3 = f3.expand_dims(['nj','ni']) - - wfile=fdomain2 - # mode 'w' overwrites file - f3.to_netcdf(path=wfile, mode='w') - mprint('created file '+fdomain2) - f1.close(); f2.close(); f3.close() - -#-- Create CTSM surface data file -if create_surfdata: - mprint( "Open: "+fsurf ) - f1 = xr.open_dataset(fsurf) - # create 1d variables - lon0=np.asarray(f1['LONGXY'][0,:]) - lon=xr.DataArray(lon0,name='lon',dims='lsmlon',coords={'lsmlon':lon0}) - lat0=np.asarray(f1['LATIXY'][:,0]) - lat=xr.DataArray(lat0,name='lat',dims='lsmlat',coords={'lsmlat':lat0}) - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - # extract gridcell closest to plon/plat - f3 = f2.sel(lsmlon=plon,lsmlat=plat,method='nearest') - # expand dimensions - f3 = f3.expand_dims(['lsmlat','lsmlon']) - - # modify surface data properties - if overwrite_single_pft: - f3['PCT_NAT_PFT'][:,:,:] = 0 - f3['PCT_NAT_PFT'][:,:,dominant_pft] = 100 - if zero_nonveg_landunits: - f3['PCT_NATVEG'][:,:] = 100 - f3['PCT_CROP'][:,:] = 0 - f3['PCT_LAKE'][:,:] = 0. - f3['PCT_WETLAND'][:,:] = 0. - f3['PCT_URBAN'][:,:,] = 0. - f3['PCT_GLACIER'][:,:] = 0. - if uniform_snowpack: - f3['STD_ELEV'][:,:] = 20. - if no_saturation_excess: - f3['FMAX'][:,:] = 0. - - # specify dimension order - #f3 = f3.transpose(u'time', u'cft', u'natpft', u'lsmlat', u'lsmlon') - f3 = f3.transpose(u'time', u'cft', u'lsmpft', u'natpft', u'nglcec', u'nglcecp1', u'nlevsoi', u'nlevurb', u'numrad', u'numurbl', 'lsmlat', 'lsmlon') - # mode 'w' overwrites file - f3.to_netcdf(path=fsurf2, mode='w') - mprint('created file '+fsurf2) - f1.close(); f2.close(); f3.close() - - ''' this is buggy; can't re-write a file within the same session - # modify new surface data file - if overwrite_single_pft: - f1 = xr.open_dataset(fsurf2) - f1['PCT_NAT_PFT'][:,:,:] = 0 - f1['PCT_NAT_PFT'][:,:,dominant_pft] = 100 - f1.to_netcdf(path='~/junk.nc', mode='w') - #f1.to_netcdf(path=fsurf2, mode='w') - f1.close() - if zero_nonveg_landunits: - #f1 = xr.open_dataset(fsurf2) - f1 = xr.open_dataset('~/junk.nc') - f1['PCT_NATVEG'] = 100 - f1['PCT_CROP'] = 0 - f1['PCT_LAKE'] = 0. - f1['PCT_WETLAND'] = 0. - f1['PCT_URBAN'] = 0. - f1['PCT_GLACIER'] = 0. - #f1.to_netcdf(path=fsurf2, mode='w') - f1.to_netcdf(path='~/junk2.nc', mode='w') - f1.close() - ''' -#-- Create CTSM transient landuse data file -if create_landuse: - mprint( "Open: "+fluse ) - f1 = xr.open_dataset(fluse) - # create 1d variables - lon0=np.asarray(f1['LONGXY'][0,:]) - lon=xr.DataArray(lon0,name='lon',dims='lsmlon',coords={'lsmlon':lon0}) - lat0=np.asarray(f1['LATIXY'][:,0]) - lat=xr.DataArray(lat0,name='lat',dims='lsmlat',coords={'lsmlat':lat0}) - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - # extract gridcell closest to plon/plat - f3 = f2.sel(lsmlon=plon,lsmlat=plat,method='nearest') - - # expand dimensions - f3 = f3.expand_dims(['lsmlat','lsmlon']) - # specify dimension order - #f3 = f3.transpose('time','lat','lon') - f3 = f3.transpose(u'time', u'cft', u'natpft', u'lsmlat', u'lsmlon') - #f3['YEAR'] = f3['YEAR'].squeeze() - - # revert expand dimensions of YEAR - year = np.squeeze(np.asarray(f3['YEAR'])) - x = xr.DataArray(year, coords={'time':f3['time']}, dims='time', name='YEAR') - x.attrs['units']='unitless' - x.attrs['long_name']='Year of PFT data' - f3['YEAR'] = x - #print(x) - #mprint(f3) - #stop - # mode 'w' overwrites file - f3.to_netcdf(path=fluse2, mode='w') - mprint('created file '+fluse2) - f1.close(); f2.close(); f3.close() - -#-- Create single point atmospheric forcing data -if create_datm: - #-- create datm domain file - mprint( "Open: "+fdatmdomain ) - f1 = xr.open_dataset(fdatmdomain) - # create 1d coordinate variables to enable sel() method - lon0=np.asarray(f1['xc'][0,:]) - lat0=np.asarray(f1['yc'][:,0]) - lon=xr.DataArray(lon0,name='lon',dims='ni',coords={'ni':lon0}) - lat=xr.DataArray(lat0,name='lat',dims='nj',coords={'nj':lat0}) - - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - f2.reset_coords(['xc','yc'],inplace=True) - # extract gridcell closest to plon/plat - f3 = f2.sel(ni=plon,nj=plat,method='nearest') - # expand dimensions - f3 = f3.expand_dims(['nj','ni']) - - wfile=fdatmdomain2 - # mode 'w' overwrites file - f3.to_netcdf(path=wfile, mode='w') - mprint('created file '+fdatmdomain2) - f1.close(); f2.close(); f3.close() - - #-- specify subdirectory names and filename prefixes - solrdir = 'Solar/' - precdir = 'Precip/' - tpqwldir = 'TPHWL/' - prectag = 'clmforc.GSWP3.c2011.0.5x0.5.Prec.' - solrtag = 'clmforc.GSWP3.c2011.0.5x0.5.Solr.' - tpqwtag = 'clmforc.GSWP3.c2011.0.5x0.5.TPQWL.' - - #-- create data files - infile=[] - outfile=[] - for y in range(datm_syr,datm_eyr+1): - ystr=str(y) - for m in range(1,13): - mstr=str(m) - if m < 10: - mstr='0'+mstr - - dtag=ystr+'-'+mstr - - fsolar=dir_input_datm+solrdir+solrtag+dtag+'.nc' - fsolar2=dir_output_datm+solrtag+tag+'.'+dtag+'.nc' - fprecip=dir_input_datm+precdir+prectag+dtag+'.nc' - fprecip2=dir_output_datm+prectag+tag+'.'+dtag+'.nc' - ftpqw=dir_input_datm+tpqwldir+tpqwtag+dtag+'.nc' - ftpqw2=dir_output_datm+tpqwtag+tag+'.'+dtag+'.nc' - - infile+=[fsolar,fprecip,ftpqw] - outfile+=[fsolar2,fprecip2,ftpqw2] - - nm=len(infile) - for n in range(nm): - mprint(outfile[n]+'\n') - file_in = infile[n] - file_out = outfile[n] - - - f1 = xr.open_dataset(file_in) - # create 1d coordinate variables to enable sel() method - lon0=np.asarray(f1['LONGXY'][0,:]) - lat0=np.asarray(f1['LATIXY'][:,0]) - lon=xr.DataArray(lon0,name='lon',dims='lon',coords={'lon':lon0}) - lat=xr.DataArray(lat0,name='lat',dims='lat',coords={'lat':lat0}) - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - f2.reset_coords(['LONGXY','LATIXY'],inplace=True) - # extract gridcell closest to plon/plat - f3 = f2.sel(lon=plon,lat=plat,method='nearest') - # expand dimensions - f3 = f3.expand_dims(['lat','lon']) - # specify dimension order - f3 = f3.transpose(u'scalar','time','lat','lon') - - # mode 'w' overwrites file - f3.to_netcdf(path=file_out, mode='w') - f1.close(); f2.close(); f3.close() - - - mprint('datm files written to: '+dir_output_datm) - -mprint( "\nSuccessfully ran script\n\n" ) diff --git a/tools/contrib/ssp_anomaly_forcing_smooth b/tools/contrib/ssp_anomaly_forcing_smooth deleted file mode 100755 index fa2350bcb9..0000000000 --- a/tools/contrib/ssp_anomaly_forcing_smooth +++ /dev/null @@ -1,343 +0,0 @@ -#! /usr/bin/env python -# -# ssp_anomaly_forcing_smooth -# -# Create anomoly forcing datasets for SSP scenarios that can be used by CESM datm model -# -import sys -import os -import string -import subprocess -import datetime -import numpy as np -import matplotlib.pyplot as plt -import netCDF4 as netcdf4 -from scipy import interpolate - -# load proper modules first, i.e. -# cheyenne -''' -module load python/2.7.16 -ncar_pylib -#module load numpy/1.12.0 -#module load matplotlib/2.0.0 -#module load scipy/0.18.1 -#module load intel/16.0.3 -#module load ncarcompilers/0.3.5 -#module load netcdf/4.4.1.1 -#module load netcdf4-python/1.2.7 -''' - -# caldera / geyser - -''' -module load python/2.7.7 -module load numpy/1.11.0 -module load pyside/1.1.2 -module load matplotlib/1.5.1 -module load scipy/0.18.1 -module load netcdf4python/1.2.4 -''' - -#------------------------------------------------------- -""" - -This script creates CLM anomaly forcing data - -""" -#------------------------------------------------------- - -#-- end of function definitions --------------------------------- -#0 - -print( "Create anomoly forcing data that can be used by CTSM in CESM" ) -# Input and output directories make sure they exist -datapath = "/glade/p/cgd/tss/historyfiles/" # Path on cheyenne -spath = './' -if ( os.path.exists(datapath) ): - print( "Input data directory:"+datapath ) -else: - sys.exit( "Could not find input directory: "+datapath ) -if ( os.path.exists(spath) ): - print( "Output data directory:"+spath ) -else: - sys.exit( "Could not find output directory: "+spath ) - -# Settings to run with -today = datetime.date.today() -creationdate = "_c"+today.strftime( "%Y%m%d" ) -historydate = today.strftime( "%a %b %d %Y" ) -sspnum = 4 -smoothsize = 5 - -hist_case = 'b.e21.BHIST.f09_g17.CMIP6-historical.010' - -if sspnum == 1: - # SSP1-26 - ssptag = 'SSP1-2.6' - fut_case = 'b.e21.BSSP126cmip6.f09_g17.CMIP6-SSP1-2.6.001' -elif sspnum == 2: - # SSP3-70 - ssptag = 'SSP3-7.0' - fut_case = 'b.e21.BSSP370cmip6.f09_g17.CMIP6-SSP3-7.0.001' -elif sspnum == 3: - # SSP5-85 - ssptag = 'SSP5-8.5' - fut_case = 'b.e21.BSSP585cmip6.f09_g17.CMIP6-SSP5-8.5.001' -elif sspnum == 4: - # SSP2-45 - ssptag = 'SSP2-4.5' - fut_case = 'b.e21.BSSP245cmip6.f09_g17.CMIP6-SSP2-4.5.001' -else: - sys.exit( "sspnum is out of range: "+sspnum ) - -sspoutdir = 'anomaly_forcing/CMIP6-'+ssptag - -outdir = spath + sspoutdir -if ( not os.path.exists(outdir) ): - os.makedirs( outdir ) - -print( "Output specific data directory :"+outdir ) - - -hist_yrstart = 2000 -hist_yrend = 2014 -hist_nyrs = hist_yrend - hist_yrstart + 1 - -fut1_yrstart = 2015 -fut1_yrend = 2064 -fut1_nyrs = fut1_yrend - fut1_yrstart + 1 - -fut2_yrstart = 2065 -fut2_yrend = 2100 -fut2_nyrs = fut2_yrend - fut2_yrstart + 1 - -fut_yrstart = 2015 -fut_yrend = 2100 -fut_nyrs = fut_yrend - fut_yrstart + 1 - -tot_yrstart = 2000 -tot_yrend = 2100 -tot_nyrs = tot_yrend - tot_yrstart + 1 - -nmo = 12 -histnm = nmo*hist_nyrs -futnm = nmo*fut_nyrs -totnm = nmo*tot_nyrs -outnm = nmo*fut_nyrs - -dpath = datapath -dfile = '/lnd/proc/tseries/month_1/' -hdir = dpath+hist_case+dfile -fdir = dpath+fut_case+dfile - -# Check that directories exist -if ( os.path.exists(hdir) ): - print( "Data file directory:"+hdir ) -else: - sys.exit( "Could not find directory: "+hdir ) -if ( os.path.exists(fdir) ): - print( "Data file directory:"+fdir ) -else: - sys.exit( "Could not find directory: "+fdir ) - -print( "\n\n\n" ) - -# needed to use QBOT and U10, not using V and U(for sfcwind) -field_in = [ 'TBOT', 'RAIN', 'SNOW', 'FSDS', 'FLDS', 'QBOT', 'PBOT'] -field_combine = [ 0, 1, 1, 0, 0, 0, 0] -field_out = [ 'tas', 'pr', 'pr', 'rsds', 'rlds', 'huss', 'ps'] -units = [ 'K', ' ', ' ', ' ', ' ', 'kg/kg', 'Pa'] -units_disp = [ 'K', 'mm/s', 'mm/s', 'W m!U-2!N', 'W m!U-2!N', 'kg/kg', 'Pa'] -anomsf = ['anomaly','scale factor','scale factor','scale factor','scale factor','anomaly','anomaly'] - -nfields = len(field_in) - -#-- Read coordinates -landfile = hdir+hist_case+'.clm2.h0.TBOT.'+str(hist_yrstart)+'01-'+str(hist_yrend)+'12.nc' -if ( os.path.exists(landfile) ): - print( "Land File: "+landfile ) -else: - sys.exit( "Could not find land file: "+landfile ) - -f1 = netcdf4.Dataset(landfile, 'r') -landfrac=np.asfarray(f1.variables['landfrac'][:,:],np.float64) -landmask=np.asfarray(f1.variables['landmask'][:,:],np.float64) -area=np.asfarray(f1.variables['area'][:,:],np.float64) -lon = np.asfarray(f1.variables['lon'][:],np.float64) -lat = np.asfarray(f1.variables['lat'][:],np.float64) -nlat = lat.size -nlon = lon.size -f1.close() -ind=np.where(landfrac > 1.e10) -landfrac[ind]=0 - -#-- Loop over forcing fields ------------------------------------ -fieldskip = 0 -for f in range(nfields): - # read in last ten years of historical data ------------------ - - infieldname1 = field_in[f] - infieldcombine1 = field_combine[f] - if ((infieldcombine1 == 1 and fieldskip == 0) or (infieldcombine1 == 0 and fieldskip == 0)): - hvarfile1 = hdir+hist_case+'.clm2.h0.'+infieldname1+'.'+str(hist_yrstart)+'01-'+str(hist_yrend)+'12.nc' - fvarfile1 = fdir+fut_case+'.clm2.h0.'+infieldname1+'.'+str(fut1_yrstart)+'01-'+str(fut1_yrend)+'12.nc' - fvarfile2 = fdir+fut_case+'.clm2.h0.'+infieldname1+'.'+str(fut2_yrstart)+'01-'+str(fut2_yrend)+'12.nc' - hf1 = netcdf4.Dataset(hvarfile1, 'r') - ff1 = netcdf4.Dataset(fvarfile1, 'r') - ff2 = netcdf4.Dataset(fvarfile2, 'r') - hvarvalues1 = np.asfarray(hf1.variables[infieldname1][:],np.float64) - htime1 = np.asfarray(hf1.variables['time'][:],np.float64) - print( 'Reading: ' + hvarfile1 ) - fvarvalues1 = np.asfarray(ff1.variables[infieldname1][:],np.float64) - ftime1 = np.asfarray(ff1.variables['time'][:],np.float64) - long_name = ff1.variables[field_in[f]].long_name - print( 'Reading: ' + fvarfile1 ) - fvarvalues2 = np.asfarray(ff2.variables[infieldname1][:],np.float64) - ftime2 = np.asfarray(ff2.variables['time'][:],np.float64) - print( 'Reading: ' + fvarfile2 ) - hf1.close() - ff1.close() - ff2.close() - if (infieldcombine1 == 1): - infieldname2 = field_in[f+1] - infieldcombine2 = field_combine[f+1] - hvarfile2 = hdir+hist_case+'.clm2.h0.'+infieldname2+'.'+str(hist_yrstart)+'01-'+str(hist_yrend)+'12.nc' - fvarfile3 = fdir+fut_case+'.clm2.h0.'+infieldname2+'.'+str(fut1_yrstart)+'01-'+str(fut1_yrend)+'12.nc' - fvarfile4 = fdir+fut_case+'.clm2.h0.'+infieldname2+'.'+str(fut2_yrstart)+'01-'+str(fut2_yrend)+'12.nc' - hf2 = netcdf4.Dataset(hvarfile2, 'r') - ff3 = netcdf4.Dataset(fvarfile3, 'r') - ff4 = netcdf4.Dataset(fvarfile4, 'r') - hvarvalues1 = hvarvalues1 + np.asfarray(hf2.variables[infieldname2][:],np.float64) - print( 'Reading: ' + hvarfile2 ) - fvarvalues1 = fvarvalues1 + np.asfarray(ff3.variables[infieldname2][:],np.float64) - print( 'Reading: ' + fvarfile3 ) - fvarvalues2 = fvarvalues2 + np.asfarray(ff4.variables[infieldname2][:],np.float64) - print( 'Reading: ' + fvarfile4 ) - hf2.close() - ff3.close() - ff4.close() - fieldskip = 1 - - allvarvalues = np.concatenate((hvarvalues1,fvarvalues1,fvarvalues2),axis=0) - alltime = np.concatenate((htime1,ftime1,ftime2),axis=0) - ftime = np.concatenate((ftime1,ftime2),axis=0) - outtime = ftime - 16 - histavgvalues = np.zeros((nmo,nlat,nlon)) - histavgcount = np.zeros((nmo)) - runningavgvalues = np.zeros((nlat,nlon)) - runningavgcount = 0.0 - outputvarvalues = np.zeros((outnm,nlat,nlon)) - - for hmonthindex in range(histnm): - havgmonthnum = (hmonthindex) % 12 + 1 - havgmonthindex = havgmonthnum - 1 - histavgvalues[havgmonthindex,:,:] = histavgvalues[havgmonthindex,:,:] * histavgcount[havgmonthindex] - histavgvalues[havgmonthindex,:,:] = histavgvalues[havgmonthindex,:,:] + allvarvalues[hmonthindex,:,:] - histavgcount[havgmonthindex] = histavgcount[havgmonthindex] + 1.0 - histavgvalues[havgmonthindex,:,:] = histavgvalues[havgmonthindex,:,:] / histavgcount[havgmonthindex] - - for fmonthindex in range(futnm): - allmonthindex = fmonthindex + histnm - allyearindex = int(allmonthindex / nmo) - favgmonthnum = (allmonthindex) % 12 + 1 - favgmonthindex = favgmonthnum - 1 - - firstmonthindex = allmonthindex - nmo * smoothsize - if allyearindex <= (tot_nyrs - smoothsize): - lastmonthindex = allmonthindex + nmo * smoothsize - else: - lastmonthindex = allmonthindex + nmo * (tot_nyrs - allyearindex) - - runningavgvalues = 0.0 - runningavgcount = 0.0 - for smonthindex in range(firstmonthindex,lastmonthindex,nmo): - runningavgvalues = runningavgvalues * runningavgcount - runningavgvalues = runningavgvalues + allvarvalues[smonthindex,:,:] - runningavgcount = runningavgcount + 1.0 - runningavgvalues = runningavgvalues / runningavgcount - - climoavgvalues = histavgvalues[favgmonthindex,:,:] - if anomsf[f] == 'anomaly': - anomvalues = runningavgvalues - climoavgvalues - - if anomsf[f] == 'scale factor': - anomvalues = np.ones((nlat,nlon),dtype=np.float64) - - nonzeroindex = np.where(climoavgvalues != 0.0) - anomvalues[nonzeroindex] = runningavgvalues[nonzeroindex]/climoavgvalues[nonzeroindex] - - max_scale_factor = 5. - if field_in[f] == 'FSDS': - max_scale_factor = 2. - overmaxindex=np.where(anomvalues > max_scale_factor) - anomvalues[overmaxindex] = max_scale_factor - - outputvarvalues[fmonthindex,:,:] = anomvalues - - # create netcdf file --------------------------------- - - outfilename = outdir + '/'+'af.'+field_out[f]+'.cesm2.'+ssptag+'.'+str(fut_yrstart)+'-'+str(fut_yrend)+creationdate+'.nc' - print( 'Creating: ' + outfilename ) - outfile = netcdf4.Dataset(outfilename, 'w') - - outfile.source_file1 = hvarfile1 - outfile.source_file2 = fvarfile1 - outfile.source_file3 = fvarfile2 - outfile.title = 'anomaly forcing data' - outfile.note1 = 'Anomaly/scale factors calculated relative to ' \ - +str(hist_yrstart)+'-'+str(hist_yrend) \ - +' climatology from CESM2 historical simulation (case name: '+hist_case+')' - outfile.note2 = ssptag+' '+str(fut_yrstart)+'-'+str(fut_yrend) \ - +' from CESM simulations (case names: '+fut_case[0]+' and '+fut_case[1]+')' - outfile.smoothsize = str(smoothsize) - outfile.history = historydate + ": created by "+sys.argv[0] - stdout = os.popen( "git describe" ) - outfile.gitdescribe = stdout.read().rstrip() - - outfile.createDimension('lat', size=int(nlat)) - outfile.createDimension('lon', size=int(nlon)) - outfile.createDimension('time', size=None) - - wtime = outfile.createVariable('time',np.float64,('time',)) - wlat = outfile.createVariable('lat',np.float64,('lat',)) - wlon = outfile.createVariable('lon',np.float64,('lon',)) - wmask = outfile.createVariable('landmask',np.int32,('lat','lon')) - warea = outfile.createVariable('area',np.float64,('lat','lon')) - wfrac = outfile.createVariable('landfrac',np.float64,('lat','lon')) - wvar = outfile.createVariable(field_out[f],np.float64,('time','lat','lon'),fill_value=np.float64(1.e36)) - - wtime.units = 'days since ' + str(fut_yrstart) + '-01-01 00:00:00' - wlon.units = 'degrees' - wlat.units = 'degrees' - wvar.units = units[f] - warea.units = 'km2' - wfrac.units = 'unitless' - wmask.units = 'unitless' - - #wtime.long_name = 'Months since January '+str(fut_yrstart) - wtime.long_name = 'days since ' + str(fut_yrstart) + '-01-01 00:00:00' - wlon.long_name = 'Longitude' - wlat.long_name = 'Latitude' - wvar.long_name = str(long_name)+' '+anomsf[f] - warea.long_name = 'Grid cell area' - wfrac.long_name = 'Grid cell land fraction' - wmask.long_name = 'Grid cell land mask' - - wtime.calendar = 'noleap' - - # write to file -------------------------------------------- - #wtime[:] = month - wtime[:] = outtime - wlon[:] = lon - wlat[:] = lat - wmask[:,:] = landmask - wfrac[:,:] = landfrac - warea[:,:] = area - wvar[:,:,:] = outputvarvalues - - else: - fieldskip = 0 - - -print( "\n\nSuccessfully made anomoly forcing datasets\n" ) diff --git a/tools/contrib/subset_surfdata b/tools/contrib/subset_surfdata deleted file mode 100755 index 4dbcbf3468..0000000000 --- a/tools/contrib/subset_surfdata +++ /dev/null @@ -1,141 +0,0 @@ -#! /usr/bin/env python -import sys -import os -from getpass import getuser -import string -import subprocess -import numpy as np -import xarray as xr - -def mprint(mstr): - vnum=sys.version_info[0] - if vnum == 3: - print(mstr) - if vnum == 2: - print mstr - -myname=getuser() -pwd=os.getcwd() -mprint(myname) -mprint(pwd) - -#creates regional surface dataset and domain file - -#-- Specify input and output directories -dir_output='/glade/scratch/'+myname+'/regional/' - -#-- Create regional CLM domain file -create_domain = True -#-- Create CLM surface data file -create_surfdata = True -#-- Create CLM surface data file -create_landuse = False - -tagnum=1 -if tagnum == 1: - tag='S.America' - - ln1=275. - ln2=330. - lt1=-40. - lt2=15. - -if tagnum == 2: - tag='Western.US' - - ln1=284. - ln2=296. - lt1=44. - lt2=53. - -#-- Set time stamp -command='date "+%y%m%d"' -x2=subprocess.Popen(command,stdout=subprocess.PIPE,shell='True') -x=x2.communicate() -timetag = x[0].strip() - -#-- Specify land domain file --------------------------------- -fdomain = '/glade/p/cesmdata/cseg/inputdata/share/domains/domain.lnd.fv1.9x2.5_gx1v7.170518.nc' -#fdomain2 = dir_output + 'domain.lnd.fv0.9x1.25_gx1v6.'+tag+'.090309.nc' -fdomain2 = dir_output + 'domain.lnd.fv1.9x2.5_gx1v7.'+tag+'_170518.nc' - -#-- Specify surface data file -------------------------------- -fsurf = '/glade/p/cesmdata/cseg/inputdata/lnd/clm2/surfdata_map/surfdata_1.9x2.5_78pfts_CMIP6_simyr1850_c170824.nc' -#fsurf2 = dir_output + 'surfdata_0.9x1.25_16pfts_CMIP6_simyr2000_'+tag+'.c170706.nc' -fsurf2 = dir_output + 'surfdata_1.9x2.5_78pfts_CMIP6_simyr1850_'+tag+'_c170824.nc' - -#-- Specify landuse file ------------------------------------- -fluse = '/glade/p/cesmdata/cseg/inputdata/lnd/clm2/surfdata_map/landuse.timeseries_1.9x2.5_hist_78pfts_CMIP6_simyr1850-2015_c170824.nc' -fluse2 = dir_output + 'landuse.timeseries_1.9x2.5_hist_78pfts_CMIP6_simyr1850-2015_'+tag+'.c170824.nc' - -#-- Create CTSM domain file -if create_domain: - f1 = xr.open_dataset(fdomain) - # create 1d coordinate variables to enable sel() method - lon0=np.asarray(f1['xc'][0,:]) - lat0=np.asarray(f1['yc'][:,0]) - lon=xr.DataArray(lon0,name='lon',dims='ni',coords={'ni':lon0}) - lat=xr.DataArray(lat0,name='lat',dims='nj',coords={'nj':lat0}) - # assign() not working on cheyenne - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - f2.reset_coords(['xc','yc'],inplace=True) - - # subset longitude and latitude arrays - xind=np.where((lon >= ln1) & (lon <= ln2))[0] - yind=np.where((lat >= lt1) & (lat <= lt2))[0] - f3=f2.isel(nj=yind,ni=xind) - - wfile=fdomain2 - # mode 'w' overwrites file - f3.to_netcdf(path=wfile, mode='w') - mprint('created file '+fdomain2) - f1.close(); f2.close(); f3.close() - -#-- Create CTSM surface data file -if create_surfdata: - f1 = xr.open_dataset(fsurf) - # create 1d variables - lon0=np.asarray(f1['LONGXY'][0,:]) - lon=xr.DataArray(lon0,name='lon',dims='lsmlon',coords={'lsmlon':lon0}) - lat0=np.asarray(f1['LATIXY'][:,0]) - lat=xr.DataArray(lat0,name='lat',dims='lsmlat',coords={'lsmlat':lat0}) - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - # subset longitude and latitude arrays - xind=np.where((lon >= ln1) & (lon <= ln2))[0] - yind=np.where((lat >= lt1) & (lat <= lt2))[0] - f3=f2.isel(lsmlat=yind,lsmlon=xind) - - # mode 'w' overwrites file - f3.to_netcdf(path=fsurf2, mode='w') - mprint('created file '+fsurf2) - f1.close(); f2.close(); f3.close() - -#-- Create CTSM transient landuse data file -if create_landuse: - f1 = xr.open_dataset(fluse) - # create 1d variables - lon0=np.asarray(f1['LONGXY'][0,:]) - lon=xr.DataArray(lon0,name='lon',dims='lsmlon',coords={'lsmlon':lon0}) - lat0=np.asarray(f1['LATIXY'][:,0]) - lat=xr.DataArray(lat0,name='lat',dims='lsmlat',coords={'lsmlat':lat0}) - #f2=f1.assign({'lon':lon,'lat':lat}) - f2=f1.assign() - f2['lon'] = lon - f2['lat'] = lat - # subset longitude and latitude arrays - xind=np.where((lon >= ln1) & (lon <= ln2))[0] - yind=np.where((lat >= lt1) & (lat <= lt2))[0] - f3=f2.isel(lsmlat=yind,lsmlon=xind) - # mode 'w' overwrites file - f3.to_netcdf(path=fluse2, mode='w') - mprint('created file '+fluse2) - f1.close(); f2.close(); f3.close() - - - diff --git a/tools/mkmapdata/README b/tools/mkmapdata/README deleted file mode 100644 index f2a0b793db..0000000000 --- a/tools/mkmapdata/README +++ /dev/null @@ -1,87 +0,0 @@ -$CTSMROOT/tools/mkmapdata/README Jun/08/2018 - -The routines in this directory create a mapping dataset from -SCRIP grid files to map from one grid to another. These mapping files -are used by either CLM or mksurfdata_map to regrid from one resolution -to another. - -The script uses ESMF and requires that ESMF be built and the path -for ESMF binary files (using the program ESMF_RegridWeightGen) -be given as input to the script. You need to build at least -two versions, one with mpiuni and one with mpi. Both versions -also need to be built with NetCDF rather than the default -IO version. - -Currently uses: ESMF7.1.0r - -Do the following for help with the different options to the script... - - ./mkmapdata.sh -help - -The following steps provide a method to create the executable -and generate the grid map dataset: - -0) Background tasks you only have to do once - - a.) Export the input SCRIP grid files for the resolutions you'll need - - Most of these files are on the Subversion inputdata server at... - - https://svn-ccsm-inputdata.cgd.ucar.edu/trunk/inputdata/lnd/clm2/mappingdata/grids/ - - Supported machines also have a copy on the CESM DIN_LOC_ROOT location - for that machine. - - b.) Obtain and build the versions of ESMF required for this script - -The version needs to support ESMF_RegridWeightGen and support the -options passed to it in the mkmapdata.sh script. As such it needs -to be built with NetCDF. You also need to build at least one -version with mpiuni and one with an mpi library. You also need -a version that supports the options: --netcdf4, --64bit_offset -and --src_type UGRID. - - http://www.earthsystemmodeling.org/ - -You may need more than one version to do everything above. On cheyenne -we use ESMF7.1.0r. - -The version of NetCDF used with ESMF needs to be version 4.1 or higher -and compiled with the NetCDF4 file format enabled (with HDF5 compression). -That will enable the --netcdf4 and --64bit_offset options to be used. - -1) cd to this directory - -2) Create map dataset(s) - Option A.) Use mkmapdata.sh directly - run script(e.g.): (see header of mkmapdata.sh for other environment that can be set) - - Example for standard resolutions - ./mkmapdata.sh -r 10x15 - Example for non-standard resolutions where you provide an input SCRIP grid file. - ./mkmapdata.sh -f - - Option B.) Alternatively, run regridbatch.sh to run mkmapdata.sh for a bunch of - different resolutions. - - Option C.) Alternatively, run mknoocnmap.pl to create a single-point/regional - map for an area without ocean. - - ./mknoocnmap.pl -help # for help on this script - -3) move (and rename if appropriate) generated map datasets - to $DIN_LOC_ROOT/lnd/clm/mappingdata/maps, etc. - - -Important files: - - regridbatch.sh ------- Script to run mkmapdata.sh for many resolutions on cheyenne - regriddav.sh --------- Script to run mkmapdata.sh for many resolutions on the DAV cluster (Casper) - mvNimport.sh --------- Script to copy and import mapping files in for many resolutions - mkmapdata.sh --------- Script to create mapping datasets for a given resolution - - mknoocnmap.pl -------- Script to create unity mapping dataset for single-point - or regional studies over land-only (no ocean). - mkunitymap.ncl ------- NCL script to create a unity map -- ran by above script - rmdups.ncl ----------- NCL script to remove duplicate mapping points - diff --git a/tools/mkmapdata/createXMLEntries.pl b/tools/mkmapdata/createXMLEntries.pl deleted file mode 100755 index c65e6888f7..0000000000 --- a/tools/mkmapdata/createXMLEntries.pl +++ /dev/null @@ -1,116 +0,0 @@ -#!/usr/bin/env perl - -# Creates a file giving XML entries for all the mapping files in the -# current directory (mapping_entries.txt). Also creates another file -# giving commands to move these files to the inputdata space -# (mv_cmds.sh). -# -# Should be run with no arguments. -# -# See also bld/namelist_files/createMapEntry.pl, and mvNimport.sh in -# the current directory for scripts that share some of the -# functionality of this script. - -# Bill Sacks -# March, 2013 - -use strict; - -# ---------------------------------------------------------------------- -# FUNCTIONS -# ---------------------------------------------------------------------- - -# Given a map filename, returns a hash giving the resolutions and -# masks implicit in that filename. -# Inputs: -# - filename -# Output: -# - hash containing: -# - filename -# - from_res -# - from_mask -# - to_res -# - to_mask -# Or does a bare return if the filename doesn't match the expected pattern -sub get_resolutions_and_masks { - my $filename = shift; - - # The following match assumes that the destination mask is - # "nomask". This match will tolerate underscores in the - # destination grid (e.g., 5x5_amazon), but be careful about - # underscores in the source grid or source mask! - if ($filename =~ m/^map_(.*)_(.*)_to_(.*)_nomask/) { - my $from_res=$1; - my $from_mask=$2; - my $to_res=$3; - my $to_mask="nomask"; - - my %info = (filename => $filename, - from_res => $from_res, - from_mask => $from_mask, - to_res => $to_res, - to_mask => $to_mask); - - return %info; - } - else { - return; - } -} - - -# ---------------------------------------------------------------------- -# PARAMETERS DEFINED HERE -# ---------------------------------------------------------------------- - -my $CSMDATA = "/glade/p/cesm/cseg/inputdata"; -my $maps_dir = "lnd/clm2/mappingdata/maps"; # directory where mapping files are stored within the inputdata directory - -# ---------------------------------------------------------------------- -# BEGIN MAIN PROGRAM -# ---------------------------------------------------------------------- - -my @files = glob "map*.nc"; - -# Make a hash containing all of the files at each destination resolution. -# The keys of the hash are destination resolutions; the values are -# references to arrays of hash references, where these low-level -# hashes are the return values of get_resolutions_and_masks. -my %dest_resols; -foreach my $file (@files) { - my %info = get_resolutions_and_masks($file); - if (%info) { - my $to_res = $info{'to_res'}; - push @{$dest_resols{$to_res}}, \%info; - } - else { - warn "WARNING: $file doesn't match expected mapping filename pattern; skipping\n"; - } -} - -open MAP_ENTRIES, ">", "mapping_entries.txt"; -open MV_CMDS, ">", "mv_cmds.sh"; - -# Output xml entries (and mv commands) grouped by destination resolution -foreach my $to_res (sort keys %dest_resols) { - my $full_maps_dir = "$maps_dir/$to_res"; - - foreach my $info_ref (@{$dest_resols{$to_res}}) { - my $filename = ${$info_ref}{'filename'}; - my $from_res = ${$info_ref}{'from_res'}; - my $from_mask = ${$info_ref}{'from_mask'}; - my $to_res = ${$info_ref}{'to_res'}; - my $to_mask = ${$info_ref}{'to_mask'}; - - print MV_CMDS "mv $filename $CSMDATA/$full_maps_dir/$filename\n"; - print MAP_ENTRIES "$full_maps_dir/$filename\n"; - } - - # Print blank line between destination grids - print MAP_ENTRIES "\n"; -} - -system "chmod", "755", "mv_cmds.sh"; -close MAP_ENTRIES; -close MV_CMDS; diff --git a/tools/mkmapdata/mkmapdata.sh b/tools/mkmapdata/mkmapdata.sh deleted file mode 100755 index b5d26ead9b..0000000000 --- a/tools/mkmapdata/mkmapdata.sh +++ /dev/null @@ -1,561 +0,0 @@ -#!/bin/bash -#---------------------------------------------------------------------- -# -# mkmapdata.sh -# -# Create needed mapping files for mksurfdata_map and CLM. -# -# Example to run for an output resolution of 4x5 -# -# mkmapdata.sh -r 4x5 -# -# valid arguments: -# -f Input grid filename -# -t Output type, supported values are [regional, global] -# -r Output resolution -# -b use batch mode (not default) -# -l list mapping files required (so can use check_input_data to get them) -# -d debug usage -- display mkmapdata that will be run but don't execute them -# -v verbose usage -- log more information on what is happening -# -h displays this help message -# -# You can also set the following env variables: -# -# ESMFBIN_PATH - Path to ESMF binaries -# CSMDATA ------ Path to CESM input data -# MPIEXEC ------ Name of mpirun executable -# REGRID_PROC -- Number of MPI processors to use -# -#---------------------------------------------------------------------- -echo $0 -dir=${0%/*} -if [ "$dir" = "$0" ];then - dir="." -fi -outfilelist="clm.input_data_list" -default_res="10x15" - -#---------------------------------------------------------------------- -# SET SOME DEFAULTS -- if not set via env variables outside - -if [ -z "$CSMDATA" ]; then - CSMDATA=/glade/p/cesm/cseg/inputdata -fi -#---------------------------------------------------------------------- -# Usage subroutine -usage() { - echo "" - echo "**********************" - echo "usage:" - echo "./mkmapdata.sh" - echo "" - echo "valid arguments: " - echo "[-f|--gridfile ] " - echo " Full pathname of model SCRIP grid file to use " - echo " This variable should be set if this is not a supported grid" - echo " This variable will override the automatic generation of the" - echo " filename generated from the -res argument " - echo " the filename is generated ASSUMING that this is a supported " - echo " grid that has entries in the file namelist_defaults_ctsm.xml" - echo " the -r|--res argument MUST be specied if this argument is specified" - echo "[-r|--res ]" - echo " Model output resolution (default is $default_res)" - echo "[-t|--gridtype ]" - echo " Model output grid type" - echo " supported values are [regional,global], (default is global)" - echo "[-b|--batch]" - echo " Toggles batch mode usage (and run with mpi). If you want to run in batch mode" - echo " you need to have a separate batch script for a supported machine" - echo " that calls this script interactively - you cannot submit this" - echo " script directly to the batch system" - echo "[-l|--list]" - echo " List mapping files required (use check_input_data to get them)" - echo " also writes data to $outfilelist" - echo "[-d|--debug]" - echo " Toggles debug-only (don't actually run mkmapdata just echo what would happen)" - echo "[-h|--help] " - echo " Displays this help message" - echo "[-v|--verbose]" - echo " Toggle verbose usage -- log more information on what is happening " - echo "[--fast]" - echo " Toggle fast maps only -- only create the maps that can be done quickly " - echo "" - echo " You can also set the following env variables:" - echo " ESMFBIN_PATH - Path to ESMF binaries " - echo " (default is determined by machine running on)" - echo " CSMDATA ------ Path to CESM input data" - echo " (default is $CSMDATA)" - echo " MPIEXEC ------ Name of mpirun executable" - echo " (default is determined by machine running on)" - echo " REGRID_PROC -- Number of MPI processors to use" - echo " (default is $REGRID_PROC)" - echo "" - echo "**defaults can be determined on the machines: cheyenne or casper" - echo "" - echo "**pass environment variables by preceding above commands " - echo " with 'env var1=setting var2=setting '" - echo "**********************" -} -#---------------------------------------------------------------------- -# runcmd subroutine -#---------------------------------------------------------------------- - -runcmd() { - cmd=$@ - if [ -z "$cmd" ]; then - echo "No command given to the runcmd function" - exit 3 - fi - if [ "$verbose" = "YES" ]; then - echo "$cmd" - fi - if [ "$debug" != "YES" ]; then - ${cmd} - rc=$? - else - rc=0 - fi - if [ $rc != 0 ]; then - echo "Error status returned from mkmapdata script" - exit 4 -undo - fi - return 0 -} - -#---------------------------------------------------------------------- -# Process input arguments -#---------------------------------------------------------------------- - -interactive="YES" -debug="no" -res="default" -type="global" -phys="clm4_5" -verbose="no" -list="no" -outgrid="" -gridfile="default" -fast="no" - -while [ $# -gt 0 ]; do - case $1 in - -v|-V) - verbose="YES" - ;; - -b|--batch) - interactive="NO" - ;; - -d|--debug) - debug="YES" - ;; - --fast) - fast="YES" - ;; - -l|--list) - debug="YES" - list="YES" - ;; - -r|--res) - res=$2 - shift - ;; - -f|--gridfile) - gridfile=$2 - shift - ;; - -t|--gridtype) - type=$2 - shift - ;; - -h|--help ) - usage - exit 0 - ;; - * ) - echo "ERROR:: invalid argument sent in: $2" - usage - exit 1 - ;; - esac - shift -done - -echo "Script to create mapping files required by mksurfdata_map" - -#---------------------------------------------------------------------- -# Determine output scrip grid file -#---------------------------------------------------------------------- - -# Set general query command used below -QUERY="$dir/../../bld/queryDefaultNamelist.pl -silent -namelist clmexp " -QUERY="$QUERY -justvalue -options sim_year=2000 -csmdata $CSMDATA" -echo "query command is $QUERY" - -echo "" -DST_EXTRA_ARGS="" -if [ "$gridfile" != "default" ]; then - GRIDFILE=$gridfile - echo "Using user specified scrip grid file: $GRIDFILE" - if [ "$res" = "default" ]; then - echo "When user specified grid file is given you MUST set the resolution (as the name of your grid)\n"; - exit 1 - fi - - # For now, make some assumptions about user-specified grids -- - # that they are SCRIP format, and small enough to not require - # large file support for the output mapping file. In the future, - # we may want to provide command-line options to allow the user to - # override these defaults. - DST_LRGFIL="none" - DST_TYPE="SCRIP" -else - if [ "$res" = "default" ]; then - res=$default_res - fi - - QUERYARGS="-res $res -options lmask=nomask" - - # Find the output grid file for this resolution using the XML database - QUERYFIL="$QUERY -var scripgriddata $QUERYARGS -onlyfiles" - if [ "$verbose" = "YES" ]; then - echo $QUERYFIL - fi - GRIDFILE=`$QUERYFIL` - echo "Using default scrip grid file: $GRIDFILE" - - # Determine extra information about the destination grid file - DST_LRGFIL=`$QUERY -var scripgriddata_lrgfile_needed $QUERYARGS` - DST_TYPE=`$QUERY -var scripgriddata_type $QUERYARGS` - if [ "$DST_TYPE" = "UGRID" ]; then - # For UGRID, we need extra information: the meshname variable - dst_meshname=`$QUERY -var scripgriddata_meshname $QUERYARGS` - DST_EXTRA_ARGS="$DST_EXTRA_ARGS --dst_meshname $dst_meshname" - fi -fi - -if [ "$type" = "global" ] && [ `echo "$res" | grep -c "1x1_"` = 1 ]; then - echo "This is a regional resolution and yet it is being run as global, set type with '-t' option\n"; - exit 1 -fi -if [ "$type" = "global" ] && [ `echo "$res" | grep -c "5x5_"` = 1 ]; then - echo "This is a regional resolution and yet it is being run as global, set type with '-t' option\n"; - exit 1 -fi -echo "Output grid resolution is $res" -if [ -z "$GRIDFILE" ]; then - echo "Output grid file was NOT found for this resolution: $res\n"; - exit 1 -fi - -if [ "$list" = "YES" ]; then - echo "outgrid = $GRIDFILE" - echo "outgrid = $GRIDFILE" > $outfilelist -elif [ ! -f "$GRIDFILE" ]; then - echo "Input SCRIP grid file does NOT exist: $GRIDFILE\n"; - echo "Make sure CSMDATA environment variable is set correctly" - exit 1 -fi - -#---------------------------------------------------------------------- -# Determine all input grid files and output file names -#---------------------------------------------------------------------- - -if [ "$phys" = "clm4_5" ]; then - grids=( \ - "0.5x0.5_AVHRR" \ - "0.25x0.25_MODIS" \ - "0.5x0.5_MODIS" \ - "3x3min_LandScan2004" \ - "3x3min_MODIS-wCsp" \ - "3x3min_USGS" \ - "5x5min_nomask" \ - "5x5min_IGBP-GSDP" \ - "5x5min_ISRIC-WISE" \ - "5x5min_ORNL-Soil" \ - "10x10min_nomask" \ - "10x10min_IGBPmergeICESatGIS" \ - "3x3min_GLOBE-Gardner" \ - "3x3min_GLOBE-Gardner-mergeGIS" \ - "0.9x1.25_GRDC" \ - "360x720cru_cruncep" \ - "1km-merge-10min_HYDRO1K-merge-nomask" \ - ) - -else - echo "ERROR: Unknown value for phys: $phys" - exit 1 -fi - -# Set timestamp for names below -CDATE="c"`date +%y%m%d` - -# Set name of each output mapping file -# First determine the name of the input scrip grid file -# for each of the above grids -declare -i nfile=1 -for gridmask in ${grids[*]} -do - grid=${gridmask%_*} - lmask=${gridmask#*_} - - QUERYARGS="-res $grid -options lmask=$lmask,glc_nec=10 " - - QUERYFIL="$QUERY -var scripgriddata $QUERYARGS -onlyfiles" - if [ "$verbose" = "YES" ]; then - echo $QUERYFIL - fi - INGRID[nfile]=`$QUERYFIL` - if [ "$list" = "YES" ]; then - echo "ingrid = ${INGRID[nfile]}" - echo "ingrid = ${INGRID[nfile]}" >> $outfilelist - fi - - OUTFILE[nfile]=map_${grid}_${lmask}_to_${res}_nomask_aave_da_$CDATE.nc - - # Determine extra information about the source grid file - SRC_EXTRA_ARGS[nfile]="" - SRC_LRGFIL[nfile]=`$QUERY -var scripgriddata_lrgfile_needed $QUERYARGS` - SRC_TYPE[nfile]=`$QUERY -var scripgriddata_type $QUERYARGS` - if [ "${SRC_TYPE[nfile]}" = "UGRID" ]; then - # For UGRID, we need extra information: the meshname variable - src_meshname=`$QUERY -var scripgriddata_meshname $QUERYARGS` - SRC_EXTRA_ARGS[nfile]="${SRC_EXTRA_ARGS[nfile]} --src_meshname $src_meshname" - fi - - nfile=nfile+1 -done - -#---------------------------------------------------------------------- -# Determine supported machine specific stuff -#---------------------------------------------------------------------- - -hostname=`hostname` -if [ -n "$NERSC_HOST" ]; then - hostname=$NERSC_HOST -fi -echo "Hostname = $hostname" -case $hostname in - ##cheyenne - cheyenne* | r* ) - . /glade/u/apps/ch/opt/lmod/8.1.7/lmod/lmod/init/bash - if [ -z "$REGRID_PROC" ]; then - REGRID_PROC=36 - fi - if [ interactive = "YES" ]; then - REGRID_PROC=1 - fi - esmfvers=8.0.0 - intelvers=19.0.5 - module purge - module load intel/$intelvers - module load esmf_libs - module load esmf_libs/$esmfvers - module load ncl - module load nco - - if [[ $REGRID_PROC > 1 ]]; then - mpi=mpi - module load mpt/2.22 - else - mpi=uni - fi - module load esmf-${esmfvers}-ncdfio-${mpi}-O - if [ -z "$ESMFBIN_PATH" ]; then - ESMFBIN_PATH=`grep ESMF_APPSDIR $ESMFMKFILE | awk -F= '{print $2}'` - fi - if [ -z "$MPIEXEC" ]; then - MPIEXEC="mpiexec_mpt -np $REGRID_PROC" - fi - ;; - - ## DAV - pronghorn* | casper* ) - . /glade/u/apps/ch/opt/lmod/7.2.1/lmod/lmod/init/bash - if [ -z "$REGRID_PROC" ]; then - REGRID_PROC=8 - fi - if [ interactive = "YES" ]; then - REGRID_PROC=1 - fi - echo "REGRID_PROC=$REGRID_PROC" - esmfvers=7.1.0r - intelvers=17.0.1 - module purge - module load intel/$intelvers - if [ $? != 0 ]; then - echo "Error doing module load: intel/$intelvers" - exit 1 - fi - module load ncl - module load nco - module load netcdf - module load ncarcompilers - - module load esmflibs/$esmfvers - if [ $? != 0 ]; then - echo "Error doing module load: esmflibs/$esmfvers" - exit 1 - fi - - if [[ $REGRID_PROC > 1 ]]; then - mpi=mpi - echo "MPI option is NOT currently available" - exit 1 - else - mpi=uni - fi - module load esmf-${esmfvers}-ncdfio-${mpi}-O - if [ $? != 0 ]; then - echo "Error doing module load: esmf-${esmfvers}-ncdfio-${mpi}-O" - exit 1 - fi - if [ -z "$ESMFBIN_PATH" ]; then - ESMFBIN_PATH=`grep ESMF_APPSDIR $ESMFMKFILE | awk -F= '{print $2}'` - fi - echo "ESMFMKFILE: $ESMFMKFILE" - echo "LD_LIBRARY_PATH: $LD_LIBRARY_PATH" - - if [ -z "$MPIEXEC" ]; then - MPIEXEC="mpiexec -n $REGRID_PROC" - fi - ;; - - ##no other machine currently supported - *) - echo "Machine $hostname NOT recognized" - ;; - -esac - -# Error checks -if [ ! -d "$ESMFBIN_PATH" ]; then - echo "Path to ESMF binary directory does NOT exist: $ESMFBIN_PATH" - echo "Set the environment variable: ESMFBIN_PATH" - exit 1 -fi - -#---------------------------------------------------------------------- -# Generate the mapping files needed for surface dataset generation -#---------------------------------------------------------------------- - -# Resolve interactive or batch mode command -# NOTE - if you want to run in batch mode - you need to have a separate -# batch file that calls this script interactively - you cannot submit -# this script to the batch system - -if [ "$interactive" = "NO" ]; then - echo "Running in batch mode using MPI" - if [ -z "$MPIEXEC" ]; then - echo "Name of MPI exec to use was NOT set" - echo "Set the environment variable: MPIEXEC" - exit 1 - fi - if [ ! -x `which ${MPIEXEC%% *}` ]; then - echo "The MPIEXEC pathname given is NOT an executable: ${MPIEXEC%% *}" - echo "Set the environment variable: MPIEXEC or run in interactive mode without MPI" - exit 1 - fi - mpirun=$MPIEXEC - echo "Running in batch mode" -else - mpirun="" -fi - -ESMF_REGRID="$ESMFBIN_PATH/ESMF_RegridWeightGen" -if [ ! -x "$ESMF_REGRID" ]; then - echo "ESMF_RegridWeightGen does NOT exist in ESMF binary directory: $ESMFBIN_PATH\n" - echo "Upgrade to a newer version of ESMF with this utility included" - echo "Set the environment variable: ESMFBIN_PATH" - exit 1 -fi - -# Remove previous log files -rm PET*.Log - -# -# Now run the mapping for each file, checking that input files exist -# and then afterwards that the output mapping file exists -# -declare -i nfile=1 -until ((nfile>${#INGRID[*]})); do - echo "Creating mapping file: ${OUTFILE[nfile]}" - echo "From input grid: ${INGRID[nfile]}" - echo "For output grid: $GRIDFILE" - echo " " - if [ -z "${INGRID[nfile]}" ] || [ -z "$GRIDFILE" ] || [ -z "${OUTFILE[nfile]}" ]; then - echo "Either input or output grid or output mapping file is NOT set" - exit 3 - fi - if [ ! -f "${INGRID[nfile]}" ]; then - echo "Input grid file does NOT exist: ${INGRID[nfile]}" - if [ ! "$list" = "YES" ]; then - exit 2 - fi - fi - if [ ! -f "$GRIDFILE" ]; then - echo "Output grid file does NOT exist: $GRIDFILE" - exit 3 - fi - - # Determine what (if any) large file support is needed. Use the - # most extreme large file support needed by either the source file - # or the destination file. - if [ "$DST_LRGFIL" = "netcdf4" ] || [ "${SRC_LRGFIL[nfile]}" = "netcdf4" ]; then - lrgfil="--netcdf4" - elif [ "$DST_LRGFIL" = "64bit_offset" ] || [ "${SRC_LRGFIL[nfile]}" = "64bit_offset" ]; then - lrgfil="--64bit_offset" - elif [ "$DST_LRGFIL" = "none" ] && [ "${SRC_LRGFIL[nfile]}" = "none" ]; then - lrgfil="" - else - echo "Unknown LRGFIL type:" - echo "DST_LRGFIL = $DST_LRGFIL" - echo "SRC_LRGFIL = ${SRC_LRGFIL[nfile]}" - exit 4 - fi - - # Skip if file already exists - if [ -f "${OUTFILE[nfile]}" ]; then - echo "Skipping creation of ${OUTFILE[nfile]} as already exists" - # Skip if large file and Fast mode is on - elif [ "$fast" = "YES" ] && [ "${SRC_LRGFIL[nfile]}" = "netcdf4" ]; then - echo "Skipping creation of ${OUTFILE[nfile]} as fast mode is on so skipping large files in NetCDF4 format" - else - - cmd="$mpirun $ESMF_REGRID --ignore_unmapped -s ${INGRID[nfile]} " - cmd="$cmd -d $GRIDFILE -m conserve -w ${OUTFILE[nfile]}" - if [ $type = "regional" ]; then - cmd="$cmd --dst_regional" - fi - - cmd="$cmd --src_type ${SRC_TYPE[nfile]} ${SRC_EXTRA_ARGS[nfile]} --dst_type $DST_TYPE $DST_EXTRA_ARGS" - cmd="$cmd $lrgfil" - - runcmd $cmd - - if [ "$debug" != "YES" ] && [ ! -f "${OUTFILE[nfile]}" ]; then - echo "Output mapping file was NOT created: ${OUTFILE[nfile]}" - exit 6 - fi - # add some metadata to the file - HOST=`hostname` - history="$ESMF_REGRID" - runcmd "ncatted -a history,global,a,c,"$history" ${OUTFILE[nfile]}" - runcmd "ncatted -a hostname,global,a,c,$HOST -h ${OUTFILE[nfile]}" - runcmd "ncatted -a logname,global,a,c,$LOGNAME -h ${OUTFILE[nfile]}" - - # check for duplicate mapping weights - newfile="rmdups_${OUTFILE[nfile]}" - runcmd "rm -f $newfile" - runcmd "env MAPFILE=${OUTFILE[nfile]} NEWMAPFILE=$newfile ncl $dir/rmdups.ncl" - if [ -f "$newfile" ]; then - runcmd "mv $newfile ${OUTFILE[nfile]}" - fi - fi - - nfile=nfile+1 -done - -echo "Successffully created needed mapping files for $res" - -exit 0 diff --git a/tools/mkmapdata/mknoocnmap.pl b/tools/mkmapdata/mknoocnmap.pl deleted file mode 100755 index 5438c8bcd3..0000000000 --- a/tools/mkmapdata/mknoocnmap.pl +++ /dev/null @@ -1,302 +0,0 @@ -#!/usr/bin/env perl -# -# mknoocnmap.pl Erik Kluzek -# Dec/07/2011 -# -# Create SCRIP grid and mapping files for a single-point or region -# that is assumed to be a land land-only region. -# -use Cwd; -use strict; -use English; -use IO::File; -use Getopt::Long; - -# -# Global constants -# -my $degsiz = 0.1; - -#----------------------------------------------------------------------------------------------- -# Set the directory that contains this scripts. If the command was issued using a -# relative or absolute path, that path is in $ProgDir. Otherwise assume the -# command was issued from the current working directory. - -(my $ProgName = $0) =~ s!(.*)/!!; # name of this script -my $ProgDir = $1; # name of directory containing this script -- may be a - # relative or absolute path, or null if the script - # is in - # the user's PATH -my $cmdline = "@ARGV"; # Command line arguments to script -my $cwd = getcwd(); # current working directory -my $scrdir; # absolute pathname of directory that contains this script -my $nm = "${ProgName}::"; # name to use if script dies -if ($ProgDir) { - $scrdir = absolute_path($ProgDir); -} else { - $scrdir = $cwd; -} - - -#----------------------------------------------------------------------------------------------- - -sub usage { - die < Center latitude,longitude of the grid to create. - -name [-or -n] Name to use to describe point - -OPTIONS - -dx Size of total grid in degrees in longitude direction - (default is $degsiz) - -dy Size of total grid in degrees in latitude direction - (default is $degsiz) - -silent [or -s] Make output silent - -help [or -h] Print usage to STDOUT. - -verbose [or -v] Make output more verbose. - -nx Number of longitudes (default is 1) - -ny Number of latitudes (default is 1) -EOF -} - -#----------------------------------------------------------------------------------------------- - -sub get_latlon { -# -# Return the latitude and longitude of the input string and validate it -# - my $string = shift; - my $desc = shift; - my $dx = shift; - my $dy = shift; - - my $lat = undef; - my $lon = undef; - my $valreal1 = "[+-]?[0-9]*\.?[0-9]*[EedDqQ]?[0-9+-]*"; - - if ( $string =~ /^($valreal1)\s*,\s*($valreal1)$/ ) { - $lat = $1; - $lon = $2; - } else { - die <<"EOF"; -** $ProgName - Error in entering latitude/longitude for $desc ** -EOF - } - if ( $dx <= 0.0 || $dx > 360. ) { - die <<"EOF"; -** $ProgName - Bad value for dx (=$dx) for $desc ** - } - if ( $dy <= 0.0 || $dy > 180. ) { - die <<"EOF"; -** $ProgName - Bad value for dy (=$dy) for $desc ** - } - if ( ($lat < -90.+$dy/2.0) || ($lat > 90.0-$dy/2.0) ) { - die <<"EOF"; -** $ProgName - Bad value for latitude (=$lat) for $desc ** -EOF - } - if ( ($lon < $dx/2.0) || ($lon > 360.0-$dx/2.0) ) { - die <<"EOF"; -** $ProgName - Bad value for longitude (=$lat) for $desc ** -EOF - } - return( $lat, $lon ); - -} - -#------------------------------------------------------------------------------- - -sub absolute_path { -# -# Convert a pathname into an absolute pathname, expanding any . or .. characters. -# Assumes pathnames refer to a local filesystem. -# Assumes the directory separator is "/". -# - my $path = shift; - my $cwd = getcwd(); # current working directory - my $abspath; # resulting absolute pathname - -# Strip off any leading or trailing whitespace. (This pattern won't match if -# there's embedded whitespace. - $path =~ s!^\s*(\S*)\s*$!$1!; - -# Convert relative to absolute path. - - if ($path =~ m!^\.$!) { # path is "." - return $cwd; - } elsif ($path =~ m!^\./!) { # path starts with "./" - $path =~ s!^\.!$cwd!; - } elsif ($path =~ m!^\.\.$!) { # path is ".." - $path = "$cwd/.."; - } elsif ($path =~ m!^\.\./!) { # path starts with "../" - $path = "$cwd/$path"; - } elsif ($path =~ m!^[^/]!) { # path starts with non-slash character - $path = "$cwd/$path"; - } - - my ($dir, @dirs2); - my @dirs = split "/", $path, -1; # The -1 prevents split from stripping trailing nulls - # This enables correct processing of the input "/". - - # Remove any "" that are not leading. - for (my $i=0; $i<=$#dirs; ++$i) { - if ($i == 0 or $dirs[$i] ne "") { - push @dirs2, $dirs[$i]; - } - } - @dirs = (); - - # Remove any "." - foreach $dir (@dirs2) { - unless ($dir eq ".") { - push @dirs, $dir; - } - } - @dirs2 = (); - - # Remove the "subdir/.." parts. - foreach $dir (@dirs) { - if ( $dir !~ /^\.\.$/ ) { - push @dirs2, $dir; - } else { - pop @dirs2; # remove previous dir when current dir is .. - } - } - if ($#dirs2 == 0 and $dirs2[0] eq "") { return "/"; } - $abspath = join '/', @dirs2; - return( $abspath ); -} - -#------------------------------------------------------------------------------- - -# Process command-line options - -my %opts = ( - ctr => undef, - help => undef, - name => undef, - nx => 1, - ny => 1, - dx => $degsiz, - dy => $degsiz, - silent => 0, - verbose => 0, - ); - -GetOptions( - "p|centerpoint=s" => \$opts{'ctr'}, - "n|name=s" => \$opts{'name'}, - "nx=i" => \$opts{'nx'}, - "ny=i" => \$opts{'ny'}, - "dx=f" => \$opts{'dx'}, - "dy=f" => \$opts{'dy'}, - "h|help" => \$opts{'help'}, - "s|silent" => \$opts{'silent'}, - "v|verbose" => \$opts{'verbose'}, -) or usage(); - -# Check for unparsed arguments -if (@ARGV) { - print "ERROR: unrecognized arguments: @ARGV\n"; - usage(); -} - -if ( $opts{'verbose'} && $opts{'silent'} ) { - print "ERROR: Can NOT set both silent and verbose at once!\n"; - usage(); -} -my $printlev; -if ( $opts{'verbose'} ) { - $printlev = 2; -} elsif ( $opts{'silent'} ) { - $printlev = 0; -} else { - $printlev = 1; -} - -if ( ! defined($opts{'ctr'}) ) { - print "ERROR: MUST set the center point\n"; - usage(); -} -if ( ! defined($opts{'name'}) ) { - print "ERROR: MUST set the name of the point\n"; - usage(); -} -my $name = $opts{'name'}; - -my ($lat,$lon) = get_latlon( $opts{'ctr'}, $name, $opts{'dx'}, $opts{'dy'} ); -my $S_lat = $lat - $opts{'dy'}/2.0; -my $N_lat = $lat + $opts{'dy'}/2.0; -my $W_lon = $lon - $opts{'dx'}/2.0; -my $E_lon = $lon + $opts{'dx'}/2.0; - -my $nx = $opts{'nx'}; -my $ny = $opts{'ny'}; -if ( $opts{'nx'} < 1 ) { - print "ERROR: nx MUST be greater than or equal to 1\n"; - usage(); -} -if ( $opts{'ny'} < 1 ) { - print "ERROR: ny MUST be greater than or equal to 1\n"; - usage(); -} - -#----------------------------------------------------------------------------------------------- -my $print; -if ( $printlev > 1 ) { - $print = "PRINT=TRUE"; -} - -# Creation date -my $cdate = `date +%y%m%d`; chomp( $cdate ); - -if ( $printlev > 0 ) { - print "\n\nCreate SCRIP grid and mapping files for a single-point\n"; -} -# land grid... -my $GITDES = `cd $scrdir; git describe; cd -`; -$GITDES =~ s/\n//g; -my $grddir = absolute_path( "$scrdir/../mkmapgrids" ); -my $cwd = getcwd(); -my $datdir = $grddir; -if ( $cwd ne $scrdir ) { - $datdir = $cwd; -} -my $grid1 = "$datdir/SCRIPgrid_${name}_nomask_c${cdate}.nc"; -my $cmdenv = "env S_LAT=$S_lat W_LON=$W_lon N_LAT=$N_lat E_LON=$E_lon " . - "NX=$nx NY=$ny PTNAME=$name GITDES=$GITDES $print "; - -my $cmd = "$cmdenv GRIDFILE=$grid1 ncl $scrdir/../mkmapgrids/mkscripgrid.ncl"; -if ( $printlev > 0 ) { - print "Create land SCRIP gridfile\n"; - print "Execute: $cmd\n"; -} -system( $cmd ); - -# ocean grid... -my $grid2 = "$datdir/SCRIPgrid_${name}_noocean_c${cdate}.nc"; -my $cmd = "$cmdenv GRIDFILE=$grid2 IMASK=0 ncl $scrdir/../mkmapgrids/mkscripgrid.ncl"; -if ( $printlev > 0 ) { - print "Create ocean SCRIP gridfile\n"; - print "Execute: $cmd\n"; -} -system( $cmd ); - -# Now create a unity mapping between the two... -# Note reversal of grid1 & grid2, because we want an ocean -> land -# mapping file -my $mapfile = "$datdir/map_${name}_noocean_to_${name}_nomask_aave_da_${cdate}.nc"; -my $cmd = "env GRIDFILE1=$grid2 GRIDFILE2=$grid1 MAPFILE=$mapfile " . - "GITDES=$GITDES $print ncl $scrdir/mkunitymap.ncl"; - -if ( $printlev > 0 ) { - print "Create unity mapping file between the two gridfile\n"; - print "Execute: $cmd\n"; -} -system( $cmd ); - -if ( $printlev > 0 ) { - print "\n\nSuccessfully created grid/mapping files for single-point\n"; -} diff --git a/tools/mkmapdata/mkunitymap.ncl b/tools/mkmapdata/mkunitymap.ncl deleted file mode 100644 index 7570f7eedd..0000000000 --- a/tools/mkmapdata/mkunitymap.ncl +++ /dev/null @@ -1,166 +0,0 @@ -; -; mkunitymap.ncl -; -; Create a unity map file either between two identical grids or between two -; grids that do NOT intersect at all. -; -; Erik Kluzek -; Dec/07/2011 -; -load "$NCARG_ROOT/lib/ncarg/nclscripts/csm/contributed.ncl" -begin - ; Set a few constants needed later - cdate = systemfunc( "date +%y%m%d" ); - ldate = systemfunc( "date" ); - ; =========================================================================================================== - ; - ; IMPORTANT NOTE: EDIT THE FOLLOWING TO CUSTOMIZE or use ENV VARIABLE SETTINGS - ; Edit the following as needed to interpolate to a new resolution. - gridfile1 = getenv("GRIDFILE1"); ; Get name of the first SCRIP grid file - gridfile2 = getenv("GRIDFILE2"); ; Get name of the second SCRIP grid file - - outfilename = getenv("MAPFILE"); ; Get name of the output mapping file - - print_str = getenv("PRINT"); ; Do Extra printing for debugging - - gitdescribe = getenv("GITDES"); ; Git describe from the source clone - - if ( ismissing(gridfile1) )then - print( "ERROR: GRIDFILE1 is missing!" ); - exit - end if - if ( ismissing(gridfile2) )then - print( "ERROR: GRIDFILE2 is missing!" ); - exit - end if - if ( ismissing(outfilename) )then - print( "ERROR: MAPFILE is missing!" ); - exit - end if - if ( ismissing(print_str) )then - printn = False; - else - if ( print_str .eq. "TRUE" )then - printn = True; - else - printn = False; - end if - end if - - if ( ismissing(gitdescribe) )then - gitdescribe = systemfunc( "git describe" ) - end if - - ; - ; Open up the input grid files - ; - nca = addfile( gridfile1, "r" ); - ncb = addfile( gridfile2, "r" ); - - system( "/bin/rm -f "+outfilename ); - if ( printn )then - print( "output mapping file to create: "+outfilename ); - end if - nc = addfile( outfilename, "c" ); - ; - ; Define dimensions - ; - n_a = dimsizes( nca->grid_center_lat ); - n_b = dimsizes( ncb->grid_center_lat ); - if ( n_a .ne. n_b )then - print( "ERROR: dimensions of input SCRIP grid files is NOT the same!" ); - exit - end if - if ( any(ncb->grid_imask .ne. 1.0d00) )then - print( "ERROR: the mask of the second file isn't identically 1!" ); - print( "(second file should be land grid file)"); - exit - end if - chkvars = (/ "grid_center_lat", "grid_center_lon", "grid_corner_lat", "grid_corner_lon" /); - do i = 1, dimsizes(chkvars)-1 - if ( any(nca->$chkvars(i)$ .ne. ncb->$chkvars(i)$) )then - print( "ERROR: the grid variables are different between the two files!: "+chkvars(i) ); - exit - end if - end do - n_s = n_a; - dimnames = (/ "n_a", "n_b", "n_s", "nv_a", "nv_b", "num_wgts", "src_grid_rank", "dst_grid_rank" /); - dsizes = (/ n_a, n_b, n_a, 4, 4, 1, 2, 2/); - is_unlim = (/ False, False, False, False, False, False, False, False /); - filedimdef( nc, dimnames, dsizes, is_unlim ); - - ; - ; Define grid dimensions - ; - filevardef( nc, "src_grid_dims", "integer", (/ "src_grid_rank" /)) - nc->src_grid_dims = (/nca->grid_dims/) - filevardef( nc, "dst_grid_dims", "integer", (/ "dst_grid_rank" /)) - nc->dst_grid_dims = (/ncb->grid_dims/) - - ; - ; Define variables - ; - cvars = (/ "yc", "xc", "yv", "xv", "mask" /); - gvars = (/ "grid_center_lat", "grid_center_lon", "grid_corner_lat", "grid_corner_lon", "grid_imask" /); - - do i = 0, dimsizes(cvars)-1 - var = cvars(i)+"_a"; - if ( cvars(i) .eq. "yv" .or. cvars(i) .eq. "xv" )then - dnamesa = (/ "n_a", "nv_a" /); - dnamesb = (/ "n_b", "nv_b" /); - else - dnamesa = (/ "n_a" /); - dnamesb = (/ "n_b" /); - end if - filevardef ( nc, var, typeof(nca->$gvars(i)$), dnamesa ); - filevarattdef ( nc, var, nca->$gvars(i)$ ); - nc->$var$ = (/ nca->$gvars(i)$ /); - var = cvars(i)+"_b"; - filevardef ( nc, var, typeof(nca->$gvars(i)$), dnamesb ); - filevarattdef ( nc, var, ncb->$gvars(i)$ ); - nc->$var$ = (/ ncb->$gvars(i)$ /); - delete( dnamesa ); - delete( dnamesb ); - end do - filevardef ( nc, "area_a", "double", (/ "n_a" /) ); - filevardef ( nc, "area_b", "double", (/ "n_b" /) ); - filevardef ( nc, "frac_a", "double", (/ "n_a" /) ); - filevardef ( nc, "frac_b", "double", (/ "n_b" /) ); - ; - ; Attributes - ; - nc->area_a@units = "square radians"; - nc->frac_a@units = "unitless"; - nc->area_b@units = nc->area_a@units; - nc->frac_b@units = nc->frac_a@units; - nc@conventions = "NCAR-CESM"; - nc@domain_a = gridfile1; - nc@domain_b = gridfile2; - nc@grid_file_src = gridfile1; - nc@grid_file_dst = gridfile2; - nc@title = "SCRIP mapping file between identical grids without ocean"; - nc@history = ldate+": create using mkunitymap.ncl"; - nc@Version = gitdescribe; - - ; - ; Fraction - ; - nc->frac_a = int2dble( (/nc->mask_a/) ); - nc->frac_b = int2dble( (/nc->mask_b/) ); - ; - ; Area - ; - nc->area_a = gc_qarea( nc->yv_a(:,:), nc->xv_a(:,:) ); - nc->area_b = gc_qarea( nc->yv_b(:,:), nc->xv_b(:,:) ); - ; - ; Weights - ; - filevardef ( nc, "col", "integer", (/ "n_s" /) ); - filevardef ( nc, "row", "integer", (/ "n_s" /) ); - filevardef ( nc, "S", "double", (/ "n_s" /) ); - - nc->col = ispan( 1, n_s, 1 ); - nc->row = nc->col; - nc->S = 1.0d00; - -end diff --git a/tools/mkmapdata/mvNimport.sh b/tools/mkmapdata/mvNimport.sh deleted file mode 100755 index 184a3fac25..0000000000 --- a/tools/mkmapdata/mvNimport.sh +++ /dev/null @@ -1,75 +0,0 @@ -#!/bin/bash -# -# -# Batch script to move and import mapping files to inputdata -# for several resolutions. -# - -#---------------------------------------------------------------------- - -if [ -z "$CSMDATA" ]; then - CSMDATA=/fis/cgd/cseg/csm/inputdata -fi - -if [ ! -d "$CSMDATA" ]; then - echo "Environment variable CSMDATA is not set to a valid directory!" - exit 1 -fi - -mapdir="lnd/clm2/mappingdata/maps" -if [ ! -d "$CSMDATA/$mapdir" ]; then - echo "Environment variable CSMDATA is not set to a valid inputdata directory!" - exit 1 -fi - -if [ -z "$SVN_INP_DIR" ]; then - SVN_INP_DIR=https://svn-ccsm-inputdata.cgd.ucar.edu/trunk/inputdata -fi - -if [ $# -gt 0 ]; then - resols="" - for arg in $@; do - resols="$resols $arg" - done -else - echo "Run for all valid resolutions" - resols=`../bld/queryDefaultNamelist.pl -res list -silent` -fi -echo "Move and import mapping files for this list of resolutions: $resols" - -#---------------------------------------------------------------------- - -for res in $resols; do - echo "Move and import mapping files for: $res" - dir=$mapdir/$res - #---------------------------------------------------------------------- - files=(map_*${res}*_aave_da_c??????.nc) - if [ ${#files[*]} -lt 2 ]; then - echo "No mappingfiles found for $res" - exit 2 - else - if [ ! -d "$CSMDATA/$dir" ]; then - echo "Create mapping directory: $CSMDATA/$dir" - mkdir $CSMDATA/$dir - svn mkdir $SVN_INP_URL/$dir -m "Create mapping directory for $res" - fi - for file in ${files[*]}; do - echo "Copy and import file $file" - cp -p $file $CSMDATA/$dir - if [ $? -ne 0 ]; then - echo "Problem copying file: $file" - exit 3 - fi - chmod 0444 $CSMDATA/$dir/$file - if [ $? -ne 0 ]; then - echo "Problem chmod on file: $file" - exit 4 - fi - svn import $CSMDATA/$dir/$file $SVN_INP_DIR/$dir/$file -m "Mapping file for $res" - if [ $? -ne 0 ]; then - echo "Problem doing svn import on file: $file" - exit 4 - fi - done - fi -done diff --git a/tools/mkmapdata/regridbatch.sh b/tools/mkmapdata/regridbatch.sh deleted file mode 100755 index 7f266d4b66..0000000000 --- a/tools/mkmapdata/regridbatch.sh +++ /dev/null @@ -1,105 +0,0 @@ -#!/bin/bash -# -# -# Batch script to submit to create mapping files for all standard -# resolutions. If you provide a single resolution via "$RES", only -# that resolution will be used. In that case: If it is a regional or -# single point resolution, you should set '#PBS -n' to 1, and be sure -# that '-t regional' is specified in cmdargs. -# -# cheyenne specific batch commands: -#PBS -A P93300606 -#PBS -N regrid -#PBS -q regular -#PBS -l select=4:ncpus=2:mpiprocs=2:mem=109GB -#PBS -l walltime=2:00:00 -#PBS -j oe -#PBS -me -#PBS -V -#PBS -S /bin/bash - -#---------------------------------------------------------------------- -# Set parameters -#---------------------------------------------------------------------- - -#---------------------------------------------------------------------- -# Begin main script -#---------------------------------------------------------------------- - -if [ -z "$RES" ]; then - echo "Run for all valid resolutions" - resols=`../../bld/queryDefaultNamelist.pl -res list -silent` - if [ ! -z "$GRIDFILE" ]; then - echo "When GRIDFILE set RES also needs to be set for a single resolution" - exit 1 - fi -else - resols="$RES" -fi -if [ -z "$GRIDFILE" ]; then - grid="" -else - if [[ ${#resols[@]} > 1 ]]; then - echo "When GRIDFILE is specificed only one resolution can also be given (# resolutions ${#resols[@]})" - echo "Resolutions input is: $resols" - exit 1 - fi - grid="-f $GRIDFILE" -fi - -if [ -z "$MKMAPDATA_OPTIONS" ]; then - echo "Run with standard options" - options=" " -else - options="$MKMAPDATA_OPTIONS" -fi -echo "Create mapping files for this list of resolutions: $resols" - -#---------------------------------------------------------------------- - -for res in $resols; do - echo "Create mapping files for: $res" -#---------------------------------------------------------------------- - cmdargs="-r $res $grid $options" - - # For single-point and regional resolutions, tell mkmapdata that - # output type is regional - if [[ `echo "$res" | grep -c "1x1_"` -gt 0 || `echo "$res" | grep -c "5x5_"` -gt 0 ]]; then - res_type="regional" - else - res_type="global" - fi - # Assume if you are providing a gridfile that the grid is regional - if [ $grid != "" ];then - res_type="regional" - fi - - cmdargs="$cmdargs -t $res_type" - - echo "$res_type" - if [ "$res_type" = "regional" ]; then - echo "regional" - # For regional and (especially) single-point grids, we can get - # errors when trying to use multiple processors - so just use 1. - # We also do NOT set batch mode in this case, because some - # machines (e.g., yellowstone) do not listen to REGRID_PROC, so to - # get a single processor, we need to run mkmapdata.sh in - # interactive mode. - regrid_num_proc=1 - else - echo "global" - regrid_num_proc=8 - if [ ! -z "$LSFUSER" ]; then - echo "batch" - cmdargs="$cmdargs -b" - fi - if [ ! -z "$PBS_O_WORKDIR" ]; then - cd $PBS_O_WORKDIR - cmdargs="$cmdargs -b" - fi - fi - - echo "args: $cmdargs" - echo "time env REGRID_PROC=$regrid_num_proc ./mkmapdata.sh $cmdargs\n" - time env REGRID_PROC=$regrid_num_proc ./mkmapdata.sh $cmdargs -done diff --git a/tools/mkmapdata/regridgeyser.sh b/tools/mkmapdata/regridgeyser.sh deleted file mode 100755 index 82a4615dcd..0000000000 --- a/tools/mkmapdata/regridgeyser.sh +++ /dev/null @@ -1,87 +0,0 @@ -#!/bin/bash -# -# -# Batch script to submit to create mapping files for all standard -# resolutions. If you provide a single resolution via "$RES", only -# that resolution will be used. In that case: If it is a regional or -# single point resolution, you should set '#SBATCH -n' to 1, and be sure -# that '-t regional' is specified in cmdargs. -# -# geyser specific batch commands: -#SBATCH -J regrid # job name -#SBATCH -n 8 -#SBATCH --ntasks-per-node=8 -#SBATCH --mem=450G -#SBATCH -t 03:00:00 -#SBATCH -A P93300606 -#SBATCH -p dav -#SBATCH -e regrid.%J.out # output filename -#SBATCH -o regrid.%J.err # error filename -# -# To submit this script: -# -# sbatch regridgeyser.sh -# -## IMPORTANT NOTE: -# -# environment variables can NOT be passed into DAV -# queues. Hence, this script MUST be edited to select -# what resolution to run for. - -#---------------------------------------------------------------------- -# Set parameters -#---------------------------------------------------------------------- -export RES=1x1_brazil - -#---------------------------------------------------------------------- -# Begin main script -#---------------------------------------------------------------------- - -if [ -z "$RES" ]; then - echo "Run for all valid resolutions" - resols=`../../bld/queryDefaultNamelist.pl -res list -silent` -else - resols="$RES" -fi -echo "Create mapping files for this list of resolutions: $resols" - -#---------------------------------------------------------------------- - -for res in $resols; do - echo "Create mapping files for: $res" -#---------------------------------------------------------------------- - cmdargs="-r $res" - - # For single-point and regional resolutions, tell mkmapdata that - # output type is regional - if [[ `echo "$res" | grep -c "1x1_"` -gt 0 || `echo "$res" | grep -c "5x5_"` -gt 0 ]]; then - res_type="regional" - else - res_type="global" - fi - - cmdargs="$cmdargs -t $res_type" - - echo "$res_type" - if [ "$res_type" = "regional" ]; then - echo "regional" - # For regional and (especially) single-point grids, we can get - # errors when trying to use multiple processors - so just use 1. - # We also do NOT set batch mode in this case, because some - # machines (e.g., yellowstone) do not listen to REGRID_PROC, so to - # get a single processor, we need to run mkmapdata.sh in - # interactive mode. - regrid_num_proc=1 - else - echo "global" - regrid_num_proc=$SLURM_NTASKS - if [ ! -z "$SLURM_JOB_ACCOUNT" ]; then - echo "batch" - cmdargs="$cmdargs -b" - fi - fi - - echo "args: $cmdargs" - echo "time env REGRID_PROC=$regrid_num_proc ./mkmapdata.sh $cmdargs\n" - time env REGRID_PROC=$regrid_num_proc ./mkmapdata.sh $cmdargs -done diff --git a/tools/mkmapdata/rmdups.ncl b/tools/mkmapdata/rmdups.ncl deleted file mode 100644 index d5fff40d53..0000000000 --- a/tools/mkmapdata/rmdups.ncl +++ /dev/null @@ -1,131 +0,0 @@ -; -; Remove duplicate weights from a mapping file. -; -; Mark Taylor (converted for use by CLM mkmapdata by Erik Kluzek) -; Sep/01/2011 -; -load "$NCARG_NCARG/nclscripts/csm/gsn_code.ncl" -load "$NCARG_NCARG/nclscripts/csm/gsn_csm.ncl" -load "$NCARG_NCARG/nclscripts/csm/contributed.ncl" -begin - ; =========================================================================================================== - ; - ; IMPORTANT NOTE: EDIT THE FOLLOWING TO CUSTOMIZE or use ENV VARIABLE SETTINGS - ; Edit the following as needed - ; - ; Input mapping file to remove duplicate weights from a mapping file - ; - mapfile = getenv("MAPFILE") ; Get the mapping file - newmapfile = getenv("NEWMAPFILE") ; The new mapping file to create - logname = getenv("LOGNAME") ; Logname of user running the script - - if ( ismissing(mapfile) )then - print( "You did NOT enter an input mapping file to convert" ) - status_exit( -1 ) - end if - if ( ismissing(newmapfile) )then - sdate = systemfunc( "date +%y%m%d" ); - newmapfile = mapfile+"_c"+sdate+".nc"; - end if - ; =========================================================================================================== - - if ( systemfunc("test -f "+mapfile+"; echo $?" ) .ne. 0 )then - print( "Input file does not exist or not found: "+mapfile ); - status_exit( -1 ) - end if - print("map file: "+mapfile) - f = addfile(mapfile,"r") ; Open netCDF files. - - - n_s = dimsizes(f->col) - if ( n_s .eq. 0 )then - print( "n_s is size zero, so no overlap points just return: " ); - exit - end if - - n_b = dimsizes(f->area_b) - n_a = dimsizes(f->area_a) - print("n_s = "+n_s+" max(row)="+max(f->row)+" max(col)="+max(f->col)) - - - - row = f->row - col = f->col - - - print("checking for dups, sorting...") - hash = new( n_s, double ) - hash = col - hash= hash + row*n_b - index1d=dim_pqsort(hash,1) - row2=row(index1d) - col2=col(index1d) - S=f->S - print("zeroing out any dups...") - ndups=0 - i0=0 - do i=1,n_s-1 - if ( (col2(i) .eq. col2(i0)) .and. (row2(i) .eq. row2(i0))) then - iorig1 = index1d(i0) - iorig2 = index1d(i) - ;print("dup row: "+row2(i)+" "+row2(i0)+" "+row(iorig1)+" "+row(iorig2)) - ;print("dup col: "+col2(i)+" "+col2(i0)+" "+col(iorig1)+" "+col(iorig2)) - ;print("removing "+iorig2+" keeping "+iorig1) - S(iorig1)=S(iorig1)+S(iorig2) - S(iorig2)=0 - ndups=ndups+1 - ; dont increment i0 - else - i0=i - end if - end do - delete(row2) - delete(col2) - if ( ndups .gt. 0) then - print("ndups = "+ndups) - print("compacting S...") - ns2 = n_s-ndups - S2 = new( ns2, double) - row2= new( ns2, integer) - col2 = new( ns2, integer) - ns2=0 - do i=0,n_s-1 - if (S(i) .ne. 0) then - S2(ns2)=S(i) - row2(ns2)=row(i) - col2(ns2)=col(i) - ns2=ns2+1 - end if - end do - print("removed "+ndups+" dups") - delete(S) - delete(row) - delete(col) - S=S2 - row=row2 - col=col2 - n_s = ns2 - print("writing new netcdf file") - cmdout = systemfunc("ncks -O -x -v S,row,col "+mapfile+" "+newmapfile) - nco = addfile(newmapfile,"rw") ; Open netCDF files. - nco->S = S - nco->row = row - nco->col = col - ldate = systemfunc( "date" ); - nco@history = nco@history + ":"+ldate + ": "; - nco@history = nco@history + " Removed duplicate weights from mapping file with: rmdups.ncl " - nco@rmdups_Logname = logname; - nco@rmdups_mod_date = ldate; - nco@rmdups_version = systemfunc( "git describe" ); - - print("Successfully removed duplicate weights from mapping file" ); - - else - - print("No duplicate weights to remove from mapping file" ); - - end if - - - -end diff --git a/tools/mkmapgrids/README b/tools/mkmapgrids/README deleted file mode 100644 index cc6d2cb644..0000000000 --- a/tools/mkmapgrids/README +++ /dev/null @@ -1,22 +0,0 @@ -$CTSMROOT/tools/mkmapgrids/README June08/2018 - -NCL script to create a SCRIP grid file for a regular lat/lon grid. - -To use the script, set the following environment variables - -Required (or defaults to a single point over Boulder Colorado) - -PTNAME ! name of your grid -S_LAT ! Southern latitude corner -N_LAT ! Northern latitude corner -E_LON ! Eastern longitude corner -W_LON ! Western longitude corner - -Optional: - -NX ! Number of grid points along longitude (default 1) -NY ! Number of grid points along latitude (default 1) -IMASK ! 0 or 1, mask to use if all points are active or not (default active) -PRINT ! TRUE/FALSE do extra verbose printing or not (default FALSE) -GRIDFILE ! Output filename - diff --git a/tools/mkmapgrids/mkscripgrid.ncl b/tools/mkmapgrids/mkscripgrid.ncl deleted file mode 100644 index 0cbd1a8960..0000000000 --- a/tools/mkmapgrids/mkscripgrid.ncl +++ /dev/null @@ -1,188 +0,0 @@ -; -; mkscripgrid.ncl -; -; Create SCRIP grid and mapping file for a land-only point or region. -; Requires NCL 6.1.0 or later for the ESMF regridding functions -; -; Erik Kluzek -; Dec/07/2011 -; -load "$NCARG_ROOT/lib/ncarg/nclscripts/csm/contributed.ncl" -load "$NCARG_ROOT/lib/ncarg/nclscripts/esmf/ESMF_regridding.ncl" -begin - ; =========================================================================================================== - ; Set a few constants needed later - cdate = systemfunc( "date +%y%m%d" ); - ldate = systemfunc( "date" ); - ; - ; IMPORTANT NOTE: EDIT THE FOLLOWING TO CUSTOMIZE or use ENV VARIABLE SETTINGS - ; Edit the following as needed to interpolate to a new resolution. - ; - ; Input resolution and position - ; - name = getenv("PTNAME"); ; Get name of this point - - latS = stringtodouble( getenv("S_LAT") ); ; Get south latitude from env variable - latN = stringtodouble( getenv("N_LAT") ); ; Get north latitude from env variable - lonE = stringtodouble( getenv("E_LON") ); ; Get east longitude from env variable - lonW = stringtodouble( getenv("W_LON") ); ; Get west longitude from env variable - - nx = stringtointeger( getenv("NX" ) ); ; Get number of grids along longitude lines - ny = stringtointeger( getenv("NY" ) ); ; Get number of grids along latitude lines - - imask = stringtointeger( getenv("IMASK") ); ; Get imask to use from env variable - - print_str = getenv("PRINT"); ; Do Extra printing for debugging - - outfilename = getenv("GRIDFILE"); ; Get filename from env variable - - gitdescribe = getenv("GITDES"); ; Git describe from the source clone - - if ( ismissing(nx) )then - nx = 1; - end if - if ( ismissing(ny) )then - ny = 1; - end if - if ( ismissing(imask) )then - imask = 1; - end if - if ( ismissing(name) )then - name = nx+"x"+ny+"pt_US-UMB"; - end if - if ( ismissing(latS) )then - latS = 45.5098; - end if - if ( ismissing(latN) )then - latN = 45.6098; - end if - if ( ismissing(lonW) )then - lonW = 275.2362; - end if - if ( ismissing(lonE) )then - lonE = 275.3362; - end if - if ( ismissing(print_str) )then - printn = False; - else - if ( print_str .eq. "TRUE" )then - printn = True; - else - printn = False; - end if - end if - - if ( ismissing(outfilename) )then - if ( imask .eq. 1 )then - outfilename = "SCRIPgrid_"+name+"_nomask_c"+cdate+".nc"; - else - if ( imask .eq. 0 )then - outfilename = "SCRIPgrid_"+name+"_noocean_c"+cdate+".nc"; - else - outfilename = "SCRIPgrid_"+name+"_mask_c"+cdate+".nc"; - end if - end if - end if - - if ( ismissing(gitdescribe) )then - gitdescribe = systemfunc( "git describe" ) - end if - - system( "/bin/rm -f "+outfilename ); - if ( printn )then - print( "output file: "+outfilename ); - end if - -function fspan1up( fbegin [*]:double, fend [*]:double, number:integer ) -; -; An "fspan" that can handle size of 1 and up. -; Do fspan for arrays of two or more, or average of end points for array of one. -; -local farray; -begin - if ( number .eq. 1) then - farray = (/ (fbegin + fend) / 2.0d00 /); - else - farray = fspan( fbegin, fend, number ); - end if - return( farray ); -end - - ; - ; Compute derived quantities - ; - - delX = (lonE - lonW) / int2dble(nx); - delY = (latN - latS) / int2dble(ny); - - lonCenters = fspan1up( (lonW + delX/2.d0), (lonE - delX/2.d0), nx) - latCenters = fspan1up( (latS + delY/2.d0), (latN - delY/2.d0), ny) - lon = new( (/ny, nx/), "double" ); - lat = new( (/ny, nx/), "double" ); - if ( (nx .eq. 1) .or. (ny .eq. 1) )then - if ( printn )then - print( "Calculate corners" ) - end if - lonCorners = new( (/ny, nx, 4/), "double" ); - latCorners = new( (/ny, nx, 4/), "double" ); - else - if ( printn )then - print( "Have NCL calculate corners" ) - end if - end if - do i = 0, nx-1 - lat(:,i) = latCenters; - if ( (nx .eq. 1) .or. (ny .eq. 1) )then - latCorners(:,i,0) = latCenters - delY/2.d0; - latCorners(:,i,1) = latCenters - delY/2.d0; - latCorners(:,i,2) = latCenters + delY/2.d0; - latCorners(:,i,3) = latCenters + delY/2.d0; - end if - end do - do j = 0, ny-1 - lon(j,:) = lonCenters; - if ( (nx .eq. 1) .or. (ny .eq. 1) )then - lonCorners(j,:,0) = lonCenters - delX/2.d0; - lonCorners(j,:,1) = lonCenters + delX/2.d0; - lonCorners(j,:,2) = lonCenters + delX/2.d0; - lonCorners(j,:,3) = lonCenters - delX/2.d0; - end if - end do - - ; for some reason, "No_FillValue" isn't working in the case where imask=1 - Mask2D = new( (/ny,nx/), "integer", "No_FillValue" ) - Mask2D(:,:) = imask - gridSize = delX+"x"+delY - - ; - ; Create SCRIP grid file - ; - - Opt = True - Opt@Mask2D = Mask2D - if ( (nx .eq. 1) .or. (ny .eq. 1) )then - Opt@GridCornerLat = latCorners - Opt@GridCornerLon = lonCorners - end if - Opt@Title = "SCRIP grid file for "+name - if (printn) then - Opt@Debug = True - end if - curvilinear_to_SCRIP(outfilename, lat, lon, Opt) - - ; - ; Add global attributes to file - ; - - nc = addfile( outfilename, "w" ); - nc@history = ldate+": create using mkscripgrid.ncl"; - nc@comment = "Ocean is assumed to be non-existant in this region"; - nc@Version = gitdescribe; - if ( printn )then - print( "================================================================================================" ); - print( "Successfully created SCRIP grid file: "+outfilename); - end if - - ; =========================================================================================================== - -end diff --git a/tools/mkprocdata_map/README b/tools/mkprocdata_map/README deleted file mode 100644 index f5ac71b1ff..0000000000 --- a/tools/mkprocdata_map/README +++ /dev/null @@ -1,152 +0,0 @@ -$CTSMROOT/tools/mkprocdata_map/clm/README Oct 30, 2012 - -This directory contains scripts for regridding CLM output from an -unstructured grid (1-d output using the lndgrid dimension) to a 2-d -(lat/lon) grid. The regridding method is area-conservative. - -The following steps provide a method to create the necessary inputs to -this script, produce an executable, and regrid output: - -In the following instructions, the "original" resolution is the -resolution of the run on an unstructured grid, and the "target" -resolution is the regular lat/lon resolution to which you will regrid -the output. - -(0) Install prerequisites: - - (a) If you do not already have a mapping file from the original - resolution to the target resolution, you will need the - ESMF_RegridWeightGen tool installed on your system. - - (b) The wrapper scripts describe below require the netCDF operators - (NCO). These nco tools (ncks, ncap2, etc.) must be in your path. - -(1) Determine the target resolution. This resolution must be a regular - lat/lon resolution. Generally, this should be a resolution close - to the resolution of the CLM run. For example, when running CLM at - ne30_np4 resolution, a good target resolution is 0.9x1.25 (i.e., - finite volume 1 degree: f09); when running CLM at ne120_np4 - resolution, a good target resolution is 0.23x0.31 (i.e., finitev - volume 1/4 degree: f02). - -(2) Perform a short CLM run at the target resolution, producing at - least one history file. After this run completes, set the - environment variable $TEMPLATE_FILE to point to one of the history - files created by this run. - -(3) Create a conservative mapping file from the original resolution to - the target resolution using the ESMF regrid weight generator. The - basic method for doing this is: - - $ESMF_PATH/bin/ESMF_RegridWeightGen -s $INGRID -d $OUTGRID -m conserve -w $MAP_FILE -i - - where $INGRID gives the path to a SCRIP grid file at the original - resolution, $OUTGRID gives the path to a SCRIP grid file at the - template resolution, and $MAP_FILE gives the name of the mapping - file that will be generated. - - However, you may want to wrap this in a job script to run it on - multiple processors (using mpirun), and you may have to set other - machine-specific environment variables. You can follow the method - used in tools/mkmapdata/mkmapdata.sh. - -(4) Build the mkprocdata_map tool. From the current directory, do the - following: - - > cd src - > gmake - > cd .. - - By default code compiles optimized so it's reasonably fast. If you want - to use the debugger, with bounds-checking, and float trapping on do the - following: - gmake OPT=FALSE - See Also: See the components/clm/tools/README file for notes about setting - the path for NetCDF. - - This builds the mkprocdata_map executable. However, you generally - will not want to run this executable directly: instead, you should - use one of the wrapper scripts described below. - -(5) Do the regridding using one of the wrapper scripts in this - directory. To determine which script is most appropriate: Do you - need to regrid just one or a few output files, or most/all of the - output files in a directory? - - (a) If you are regridding just one or a few output files, you can - use mkprocdata_map_wrap. Its usage is: - - > mkprocdata_map_wrap -i input_file -o output_file -m $MAP_FILE -t $TEMPLATE_FILE - - where: - - input_file is the CLM history file you want to regrid - - output_file is the name of the regridded file that will be - created - - $MAP_FILE is the ESMF conservative mapping file created in - step (3) - - $TEMPLATE_FILE is a CLM history file at the target resolution, - created in step (2) - - You may also specify the '-l' option to this script. This option - determines whether to determine landfrac and related variables - by regridding the input file (when you don't give the '-l' - option), or by copying these variables from the template file - (when you give the '-l' option). These variables are important - for computing regional and global averages, e.g., as is done in - the land diagnostics package. Each method may be reasonable, - depending on the purposes of the regridding. For example, if you - want regional/global integrals to be as true as possible to the - original run, you should run withOUT the '-l' option; but if you - want to compare regional/global integrals between the original - run and a run at the target resolution, then you may want to run - WITH the '-l' option. - - Run 'mkprocdata_map_wrap -h' for full usage - - (b) If you need to regrid most or all of the output files in a - directory, you can use the convenience script - mkprocdata_map_all. This script runs mkprocdata_map_wrap on all - files matching a given pattern within a directory. Its basic - usage is the following, done from a directory containing many - CLM history files: - - > /path/to/mkprocdata_map_all -p $CASE -m $MAP_FILE -t $TEMPLATE_FILE - - where: - - $CASE is the case name of the original run (this -p argument - is actually more general: it provides the prefix of files on - which mkprocdata_map_wrap should be run; run - 'mkprocdata_map_all -h' for details) - - $MAP_FILE is the ESMF conservative mapping file created in - step (3) - - $TEMPLATE_FILE is a CLM history file at the target resolution, - created in step (2) - - There are a number of additional optional arguments to this - script, including the '-l' option described in (a), above. Run - 'mkprocdata_map_all -h' for full usage. - - ------------------------------------------------------------------------- -Some miscellaneous notes on the scripts contained here ------------------------------------------------------------------------- - -- area vs. area_regridded in the output of mkprocdata_map_wrap and - mkprocdata_map_all: The 'area' variable gives the actual grid cell - area on the destination grid. The 'area_regridded' variable is the - result of performing the regridding procedure on the 'area' variable - in the original source data. This seems to be the wrong way to - regrid areas (e.g., it leads to global totals that do not make - sense). However, area_regridded is left in the regridded files as a - diagnostic. BUT PLEASE USE CAUTION IF USING THIS AREA_REGRIDDED - VALUE, UNLESS YOU KNOW WHAT IT REALLY REPRESENTS! - -- At least as of this writing (Oct 29, 2012), there is insufficient - metadata on the CLM history files to regrid all variables - perfectly. In particular, note that many CLM history variables apply - only over a subset of the grid cell (e.g., over the non-lake portion - of the grid cell). Thus, to regrid these variables appropriately, we - would need to weight each grid cell's value by the portion of the - grid cell over which the field applies. However, doing this would - require metadata about each field that is not currently - available. diff --git a/tools/mkprocdata_map/README.filedescriptions b/tools/mkprocdata_map/README.filedescriptions deleted file mode 100644 index e657e7c7d9..0000000000 --- a/tools/mkprocdata_map/README.filedescriptions +++ /dev/null @@ -1,25 +0,0 @@ -$CTSMROOT/tools/mkprocdata_map/README.filedescriptions Erik Kluzek - 06/08/2018 - -mkprocdata_map_all ------------ Script to run over a list of files -mkprocdata_map_wrap ----------- Main script to actually use -mkprocdata_map_functions.bash - Bash shell functions to use in other scripts -README ------------------------ Description and how to run -src --------------------------- Directory with FORTRAN source code - -Also there are some sample files that can be used for testing under inputdata in - -$DIN_LOC_ROOT/lnd/clm2/test_mkprocdata_map - -See how this is done by looking at the file for testing mkprocdata_map: - -../../test/tools/nl_files/mkprocdata_ne30_to_f19_I2000 - -Which does something like the following: - -./mkprocdata_map_wrap \ --i $DIN_LOC_ROOT/lnd/clm2/test_mkprocdata_map/clm4054_ne30g16_I2000.clm2.h0.2000-01_c170430.nc \ --o ne30output_onf19grid.nc \ --m $DIN_LOC_ROOT/lnd/clm2/test_mkprocdata_map/map_ne30np4_nomask_to_fv1.9x2.5_nomask_aave_da_c121107.nc \ --t $DIN_LOC_ROOT/lnd/clm2/test_mkprocdata_map/clm4054_f19g16_I2000.clm2.h0.2000-01_c170430.nc - diff --git a/tools/mkprocdata_map/mkprocdata_map_all b/tools/mkprocdata_map/mkprocdata_map_all deleted file mode 100755 index 73e8abedf1..0000000000 --- a/tools/mkprocdata_map/mkprocdata_map_all +++ /dev/null @@ -1,202 +0,0 @@ -#!/bin/bash - -# This script runs mkprocdata_map_wrap on all files matching a given -# pattern within a directory. - -# Created by Bill Sacks, 5-26-11 - -# ---------------------------------------------------------------------- -# LOCAL FUNCTIONS DEFINED HERE -# ---------------------------------------------------------------------- - -function Usage { - script_name=`basename $0` - echo "Usage: $script_name -p prefix -m map_file -t template_file [-d] [-e executable-path] [-h] [-i] [-l] [-o output_suffix] [-r diRectory] [-s suffix]" - echo "" - echo "This script runs mkprocdata_map_wrap on all files matching a" - echo "given pattern within a directory." - echo "" - echo "'prefix' gives the prefix of the files on which" - echo "mkprocdata_map_wrap should be run; 'prefix' should NOT contain" - echo "wildcard characters. The prefix is also used to translate" - echo "from input to output file names (see examples below)" - echo "" - echo "'map_file' gives the name (and full path if not in the current" - echo "directory) of the mapping file" - echo "" - echo "'template_file' gives the name (and full path if not in the" - echo "current directory) of the template file, from which we read" - echo "lats, lons and some other variables" - echo "" - echo "The following are optional arguments:" - echo "" - echo "[-d]: Do a test (Dry run): do all error-checking on" - echo " arguments and print commands that would be run, but" - echo " don't actually run commands" - echo "" - echo "[-e executable-path]: Gives the path of the mkprocdata_map executable." - echo " If not specified, the path is determined by the" - echo " default value in mkprocdata_map_wrap." - echo "" - echo "[-h]: Print this help message and exit" - echo "" - echo "[-i]: Ignore (skip) existing output files; if this option is" - echo " not specified, then the script dies with an error if" - echo " any of the desired output files already exist" - echo "" - echo "[-l]: Option passed to mkprocdata_map_wrap: rather than computing" - echo " landfrac and related variables by regridding the input file," - echo " instead copy these variables directly from the template file." - echo "" - echo "[-o output_suffix]: suffix to append to the end of the prefix" - echo " on the output files" - echo " If not specified, '_2d' is used" - echo "" - echo "[-r diRectory]: Do the processing in the given directory." - echo " If not specified, processing is done in the" - echo " current working directory." - echo "" - echo "[-s suffix]: Run mkprocdata_map_wrap on all files matching the" - echo " pattern '\${prefix}\${suffix}'. The suffix can -" - echo " and often will - contain wildcards; but" - echo " remember to enclose 'suffix' in quotes to" - echo " prevent shell expansion." - echo " If not specified, run mkprocdata_map_wrap on all" - echo " files matching '\${prefix}*'" - echo "" - echo "" - echo "Example: $script_name -p Ib14_ne30np4_gx1v6 -m map_ne30np4_to_fv1.9x2.5_aave_da_091230.nc -t Ib19_1.9x2.5_gx1v6.clm2.h0.0001-01.nc" - echo "This will run mkprocdata_map_wrap on all files whose names begin" - echo "with 'Ib14_ne30np4_gx1v6' in the current directory, using the" - echo "mapping file named 'map_ne30np4_to_fv1.9x2.5_aave_da_091230.nc'" - echo "and the template file named 'Ib19_1.9x2.5_gx1v6.clm2.h0.0001-01.nc'" - echo "For an input file named:" - echo " Ib14_ne30np4_gx1v6.clm2.h0.0001-01-06-00000.nc" - echo "The output file will be named:" - echo " Ib14_ne30np4_gx1v6_2d.clm2.h0.0001-01-06-00000.nc" - echo "" - echo "Example: $script_name -o '_remap' -s '*.h0.0001*.nc' -p Ib14_ne30np4_gx1v6 -m map_ne30np4_to_fv1.9x2.5_aave_da_091230.nc -t Ib19_1.9x2.5_gx1v6.clm2.h0.0001-01.nc" - echo "This will run mkprocdata_map_wrap on all files whose names match" - echo "the pattern 'Ib14_ne30np4_gx1v6*.h0.0001*.nc', in the" - echo "current directory, using the mapping file named" - echo "'map_ne30np4_to_fv1.9x2.5_aave_da_091230.nc' and the" - echo "template file named Ib19_1.9x2.5_gx1v6.clm2.h0.0001-01.nc" - echo "For an input file named:" - echo " Ib14_ne30np4_gx1v6.clm2.h0.0001-01-06-00000.nc" - echo "The output file will be named:" - echo " Ib14_ne30np4_gx1v6_remap.clm2.h0.0001-01-06-00000.nc" - echo "" -} - -# ---------------------------------------------------------------------- -# BEGIN MAIN SCRIPT -# ---------------------------------------------------------------------- - -script_dir=`dirname $0` -source $script_dir/mkprocdata_map_functions.bash - -# ---------------------------------------------------------------------- -# Handle command-line arguments -# ---------------------------------------------------------------------- - -# define default values: -# required arguments: -prefix="" -map_file="" -template_file="" -# optional arguments: -directory="." -ignore_existing=0 -output_suffix="_2d" -suffix="*" -dryrun=0 -extra_args="" - -while getopts de:hilm:o:p:r:s:t: opt; do - case $opt in - d) dryrun=1;; - e) extra_args="$extra_args -e $OPTARG";; - h) Usage; exit;; - i) ignore_existing=1;; - l) extra_args="$extra_args -l";; - m) map_file=$OPTARG;; - o) output_suffix=$OPTARG;; - p) prefix=$OPTARG;; - r) directory=$OPTARG;; - s) suffix=$OPTARG;; - t) template_file=$OPTARG;; - \?) Usage; exit 1 - esac -done - -# ---------------------------------------------------------------------- -# Error checking on arguments -# ---------------------------------------------------------------------- - -if [ -z "$prefix" ]; then - echo "Must specify a prefix" - Usage - exit 1 -fi - -check_file_arg "$map_file" "map" -check_file_arg "$template_file" "template" - -# Make sure directory is really a directory -if [ ! -d $directory ]; then - echo "ERROR: $directory is not a directory" - echo "" - Usage - exit 1 -fi - - -# ---------------------------------------------------------------------- -# Change to desired directory -# ---------------------------------------------------------------------- - -olddir=`pwd` -cd $directory - -# ---------------------------------------------------------------------- -# Get list of files matching the given pattern; make sure there really -# are some matching files -# ---------------------------------------------------------------------- - -files=`ls ${prefix}${suffix}` -if [ $? -ne 0 ]; then - echo "ERROR trying to find files matching: ${prefix}${suffix}" - echo "" - Usage - exit 1 -fi - -# ---------------------------------------------------------------------- -# Loop through files matching the given pattern; run mkprocdata_map_wrap for each -# ---------------------------------------------------------------------- - -for infile in $files; do - outfile=${infile/$prefix/${prefix}${output_suffix}} - if [ -e $outfile ]; then - if [ $ignore_existing -eq 0 ]; then - echo "" - echo "ERROR: output file $outfile already exists" - exit 1 - else - echo "" - echo "WARNING: output file $outfile already exists: skipping" - echo "" - fi - - else # outfile does not exist - echo "" - do_cmd "${script_dir}/mkprocdata_map_wrap -i $infile -o $outfile -m $map_file -t $template_file $extra_args" $dryrun - fi -done - -# ---------------------------------------------------------------------- -# Clean up -# ---------------------------------------------------------------------- - -cd $olddir - diff --git a/tools/mkprocdata_map/mkprocdata_map_functions.bash b/tools/mkprocdata_map/mkprocdata_map_functions.bash deleted file mode 100644 index bbc359fb89..0000000000 --- a/tools/mkprocdata_map/mkprocdata_map_functions.bash +++ /dev/null @@ -1,57 +0,0 @@ -#!/bin/bash - -# This file contains functions used by other bash scripts in this directory. - -# This function echoes the command given by $1 (cmd), then executes it. -# However, if $2 (dryrun) is non-zero, then it only does the echo, not the execution. -# Usage: do_cmd cmd dryrun -# Returns 0 on success, non-zero on failure; if there is an error, the error string is echoed. -function do_cmd { - if [[ $# -ne 2 ]]; then - echo "ERROR in do_cmd: wrong number of arguments: expected 2, received $#" - exit 1 - fi - - local cmd=$1 - local dryrun=$2 - - echo $cmd - if [ $dryrun -eq 0 ]; then - # We use 'eval $cmd' rather than just '$cmd', because the - # latter doesn't work right if the command contains any quoted - # strings (e.g., svn ci -m "this is my message") - eval $cmd - if [ $? -ne 0 ]; then - echo "ERROR in do_cmd: error executing command" - exit 2 - fi - fi - - return 0 -} - -# make sure that the given file name argument was provided, and that -# the file exists; exit the script with a usage message if either of -# these is not true -# -# Usage: check_file_arg filename_arg description -# (description is echoed if there is an error) -# Example: check_file_arg "$input_file" "input" -# (note that $input_file must be in quotes) -function check_file_arg { - local filename=$1 - local description=$2 - - if [ -z "$filename" ]; then - echo "ERROR: Must specify $description file" - Usage - exit 1 - fi - - if [ ! -f $filename ]; then - echo "ERROR: Can't find $description file: $filename" - Usage - exit 1 - fi -} - diff --git a/tools/mkprocdata_map/mkprocdata_map_wrap b/tools/mkprocdata_map/mkprocdata_map_wrap deleted file mode 100755 index 4744b0eacc..0000000000 --- a/tools/mkprocdata_map/mkprocdata_map_wrap +++ /dev/null @@ -1,250 +0,0 @@ -#!/bin/bash - -# This script is a wrapper around mkprocdata_map that runs that -# program and then copies some additional variables from the template -# file to the output file. It also does some additional pre and -# post-processing in order to create some additional variables. - -# Created by Bill Sacks, 5-25-11 - -# ---------------------------------------------------------------------- -# SET PARAMETERS HERE -# ---------------------------------------------------------------------- - -# comma-delimited list of extra variables to copy directly from -# template file; note that these variables should not be written out -# by mkprocdata_map (i.e., everything in this list should be listed in -# the 'ignore_var' function in mkprocdata_map.F90); however, there may -# be some variables in the 'ignore_var' function that are not listed -# here - e.g., variables that we treat specially. -copy_vars="lon,lat" - -# comma-delimited list of extra variables to copy from the template -# file if the -l option is specified -- this option says to copy -# landfrac and related variables. Note that some of these variables -# may be written out by mkprocdata_map, in which case they will be -# overwritten afterwards (slighly less efficient, but that keeps -# things simpler). -landfrac_copy_vars="landfrac,landmask,pftmask" - -# name of the executable; -# expected to be in the same directory as this script unless -e option is given -executable="mkprocdata_map" - -# minimum value for regridded pftmask variable for the output variable to be 1 -pftmask_min="1.e-6" - -# fill value for landmask -landmask_fill=-9999 - -# ---------------------------------------------------------------------- -# LOCAL FUNCTIONS DEFINED HERE -# ---------------------------------------------------------------------- - -function Usage { - script_name=`basename $0` - echo "Usage: $script_name -i input_file -o output_file -m map_file -t template_file [-e executable-path] [-h] [-l]" - echo "" - echo "This script runs mkprocdata_map with the given arguments (-i, -o, -m and -t)," - echo "then copies some additional variables from the template file" - echo "to the output file. It also does some additional pre and" - echo "post-processing in order to create some additional variables." - echo "" - echo "Additional optional arguments:" - echo "" - echo "[-e executable-path]: Gives the path of the mkprocdata_map executable." - echo " If not specified, the executable is assumed to be" - echo " in the same directory as this script." - echo "" - echo "[-h]: Print this help message and exit" - echo "" - echo "[-l]: Rather than computing landfrac and related variables" - echo "by regridding the input file, instead copy these variables" - echo "directly from the template file. The variables this pertains" - echo "to are:" - echo $landfrac_copy_vars -} - -# This function operates on a single variable in a file, changing all -# places where that variable is missing to some new (non-missing) -# value. The _FillValue attribute remains unchanged. -# Usage: change_missing_to_value varname newval infile outfile -# - varname: the name of the variable to change -# - newval: all instances of the missing value will be replaced with -# this new value -# - infile: input file name -# - outfile: output file name (can be the same as infile) -function change_missing_to_value { - if [[ $# -ne 4 ]]; then - echo "ERROR in change_missing_to_value: wrong number of arguments: expected 2, received $#" - exit 1 - fi - - varname=$1 - newval=$2 - infile=$3 - outfile=$4 - - varname_tmp=${varname}_tmp_$$ - - cat > cmds.nco.tmp.$$ <= $pftmask_min)' $output_file $output_file" 0 - do_cmd "ncks -O -x -v pftmask_float $output_file $output_file" 0 - - # --- Calculate landmask from landfrac --- - echo "" - - cat > cmds.nco.tmp.$$ < 0); -landmask_float.change_miss($landmask_fill); -landmask=int(landmask_float); -EOF - - do_cmd "ncap2 -O -S cmds.nco.tmp.$$ $output_file $output_file" 0 - rm cmds.nco.tmp.$$ - - change_missing_to_value landmask 0 $output_file $output_file - - # in the following, note that we need to manually set missing_value, because it doesn't get changed through the .set_miss call in nco: - do_cmd "ncatted -a long_name,landmask,o,c,'land/ocean mask (0.=ocean and 1.=land)' -a missing_value,landmask,o,i,$landmask_fill $output_file" 0 -fi - -echo "Successfully regridded data" diff --git a/tools/mkprocdata_map/src/Filepath b/tools/mkprocdata_map/src/Filepath deleted file mode 100644 index 9c558e357c..0000000000 --- a/tools/mkprocdata_map/src/Filepath +++ /dev/null @@ -1 +0,0 @@ -. diff --git a/tools/mkprocdata_map/src/Makefile b/tools/mkprocdata_map/src/Makefile deleted file mode 100644 index 6f07deb741..0000000000 --- a/tools/mkprocdata_map/src/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -# Makefile for mksurfdata_map - -EXENAME = ../mkprocdata_map - -# Set optimization on by default -ifeq ($(OPT),$(null)) - OPT := TRUE -endif - -include Makefile.common \ No newline at end of file diff --git a/tools/mkprocdata_map/src/Makefile.common b/tools/mkprocdata_map/src/Makefile.common deleted file mode 100644 index ab79f94144..0000000000 --- a/tools/mkprocdata_map/src/Makefile.common +++ /dev/null @@ -1,360 +0,0 @@ -#----------------------------------------------------------------------- -# This Makefile is for building clm tools on AIX, Linux (with pgf90 or -# lf95 compiler), Darwin or IRIX platforms. -# -# These macros can be changed by setting environment variables: -# -# LIB_NETCDF --- Library directory location of netcdf. (defaults to /usr/local/lib) -# INC_NETCDF --- Include directory location of netcdf. (defaults to /usr/local/include) -# MOD_NETCDF --- Module directory location of netcdf. (defaults to $LIB_NETCDF) -# USER_FC ------ Allow user to override the default Fortran compiler specified in Makefile. -# USER_FCTYP --- Allow user to override the default type of Fortran compiler (linux and USER_FC=ftn only). -# USER_CC ------ Allow user to override the default C compiler specified in Makefile (linux only). -# USER_LINKER -- Allow user to override the default linker specified in Makefile. -# USER_CPPDEFS - Additional CPP defines. -# USER_CFLAGS -- Additional C compiler flags that the user wishes to set. -# USER_FFLAGS -- Additional Fortran compiler flags that the user wishes to set. -# USER_LDLAGS -- Additional load flags that the user wishes to set. -# SMP ---------- Shared memory Multi-processing (TRUE or FALSE) [default is FALSE] -# OPT ---------- Use optimized options. -# -#------------------------------------------------------------------------ - -# Set up special characters -null := - -# Newer makes set the CURDIR variable. -CURDIR := $(shell pwd) - -RM = rm - -# Check for the netcdf library and include directories -ifeq ($(LIB_NETCDF),$(null)) - LIB_NETCDF := /usr/local/lib -endif - -ifeq ($(INC_NETCDF),$(null)) - INC_NETCDF := /usr/local/include -endif - -ifeq ($(MOD_NETCDF),$(null)) - MOD_NETCDF := $(LIB_NETCDF) -endif - -# Set user specified Fortran compiler -ifneq ($(USER_FC),$(null)) - FC := $(USER_FC) -endif - -# Set user specified C compiler -ifneq ($(USER_CC),$(null)) - CC := $(USER_CC) -endif - -# Set if Shared memory multi-processing will be used -ifeq ($(SMP),$(null)) - SMP := FALSE -endif - -CPPDEF := $(USER_CPPDEFS) - -# Set optimization on by default -ifeq ($(OPT),$(null)) - OPT := TRUE -endif - -ifeq ($(OPT),TRUE) - CPPDEF := -DOPT -endif - -# Determine platform -UNAMES := $(shell uname -s) - -# Load dependency search path. -dirs := . $(shell cat Filepath) - -# Set cpp search path, include netcdf -cpp_dirs := $(dirs) $(INC_NETCDF) $(MOD_NETCDF) -cpp_path := $(foreach dir,$(cpp_dirs),-I$(dir)) # format for command line - -# Expand any tildes in directory names. Change spaces to colons. -# (the vpath itself is set elsewhere, based on this variable) -vpath_dirs := $(foreach dir,$(cpp_dirs),$(wildcard $(dir))) -vpath_dirs := $(subst $(space),:,$(vpath_dirs)) - -#Primary Target: build the tool -all: $(EXENAME) - -# Get list of files and build dependency file for all .o files -# using perl scripts mkSrcfiles and mkDepends - -SOURCES := $(shell cat Srcfiles) - -OBJS := $(addsuffix .o, $(basename $(SOURCES))) - -# Set path to Mkdepends script; assumes that any Makefile including -# this file is in a sibling of the src directory, in which Mkdepends -# resides -Mkdepends := ../src/Mkdepends - -$(CURDIR)/Depends: $(CURDIR)/Srcfiles $(CURDIR)/Filepath - $(Mkdepends) Filepath Srcfiles > $@ - - -# Architecture-specific flags and rules -#------------------------------------------------------------------------ -# AIX -#------------------------------------------------------------------------ - -ifeq ($(UNAMES),AIX) -CPPDEF += -DAIX -cpre = $(null)-WF,-D$(null) -FPPFLAGS := $(patsubst -D%,$(cpre)%,$(CPPDEF)) -FFLAGS = -c -I$(INC_NETCDF) -q64 -qsuffix=f=f90 -qsuffix=f=f90:cpp=F90 \ - $(FPPFLAGS) -g -qfullpath -qarch=auto -qtune=auto -qsigtrap=xl__trcedump -qsclk=micro - -LDFLAGS = -L$(LIB_NETCDF) -q64 -lnetcdff -lnetcdf -ifneq ($(OPT),TRUE) - FFLAGS += -qinitauto=7FF7FFFF -qflttrap=ov:zero:inv:en -qspillsize=4000 -C -else - FFLAGS += -O2 -qmaxmem=-1 -Q - LDFLAGS += -Q -endif -CFLAGS := -q64 -g $(CPPDEF) -O2 -FFLAGS += $(cpp_path) -CFLAGS += $(cpp_path) - -ifeq ($(SMP),TRUE) - FC = xlf90_r - FFLAGS += -qsmp=omp - LDFLAGS += -qsmp=omp -else - FC = xlf90 -endif - -endif - -#------------------------------------------------------------------------ -# Darwin -#------------------------------------------------------------------------ - -ifeq ($(UNAMES),Darwin) - -# Set the default Fortran compiler -ifeq ($(USER_FC),$(null)) - FC := g95 -endif -ifeq ($(USER_CC),$(null)) - CC := gcc -endif - -CFLAGS := -g -O2 -CPPDEF += -DSYSDARWIN -DDarwin -DLINUX -LDFLAGS := - -ifeq ($(FC),g95) - - CPPDEF += -DG95 - FFLAGS := -c -fno-second-underscore $(CPPDEF) $(cpp_path) -I$(MOD_NETCDF) - ifeq ($(OPT),TRUE) - FFLAGS += -O2 - else - FFLAGS += -g -fbounds-check - endif - -endif - -ifeq ($(FC),gfortran) - - CPPDEF += -DG95 - FFLAGS := -c -fno-second-underscore $(CPPDEF) $(cpp_path) -I$(MOD_NETCDF) \ - -fno-range-check - ifeq ($(OPT),TRUE) - FFLAGS += -O2 - else - FFLAGS += -g -fbounds-check - endif - -endif - -ifeq ($(FC),ifort) - - CPPDEF += -DFORTRANUNDERSCORE - FFLAGS += -c -ftz -g -fp-model precise $(CPPDEF) $(cpp_path) \ - -convert big_endian -assume byterecl -traceback -FR - LDFLAGS += -m64 - - ifneq ($(OPT),TRUE) - FFLAGS += -CB -O0 - else - FFLAGS += -O2 - endif - ifeq ($(SMP),TRUE) - FFLAGS += -qopenmp - LDFLAGS += -qopenmp - endif -endif - -ifeq ($(FC),pgf90) - - CPPDEF += -DFORTRANUNDERSCORE - FFLAGS += -c $(CPPDEF) $(cpp_path) - ifneq ($(OPT),TRUE) - FFLAGS += -g -Ktrap=fp -Mbounds -Kieee - else - FFLAGS += -fast -Kieee - endif - - ifeq ($(SMP),TRUE) - FFLAGS += -mp - LDFLAGS += -mp - endif - -endif - -ifeq ($(CC),icc) - CFLAGS += -m64 -g - ifeq ($(SMP),TRUE) - CFLAGS += -qopenmp - endif -endif -ifeq ($(CC),pgcc) - CFLAGS += -g -fast -endif - -CFLAGS += $(CPPDEF) $(cpp_path) -LDFLAGS += -L$(LIB_NETCDF) -lnetcdf -lnetcdff - -endif - -#------------------------------------------------------------------------ -# Linux -#------------------------------------------------------------------------ - -ifeq ($(UNAMES),Linux) - ifeq ($(USER_FC),$(null)) - FC := ifort - FCTYP := ifort - else - ifeq ($(USER_FC),ftn) - ifneq ($(USER_FCTYP),$(null)) - FCTYP := $(USER_FCTYP) - else - FCTYP := pgf90 - endif - else - FCTYP := $(USER_FC) - endif - endif - CPPDEF += -DLINUX -DFORTRANUNDERSCORE - CFLAGS := $(CPPDEF) - LDFLAGS := $(shell $(LIB_NETCDF)/../bin/nf-config --flibs) - FFLAGS = - - ifeq ($(FCTYP),pgf90) - CC := pgcc - ifneq ($(OPT),TRUE) - FFLAGS += -g -Ktrap=fp -Mbounds -Kieee - else - FFLAGS += -fast -Kieee - CFLAGS += -fast - endif - - ifeq ($(SMP),TRUE) - FFLAGS += -mp - LDFLAGS += -mp - endif - - endif - - ifeq ($(FCTYP),lf95) - ifneq ($(OPT),TRUE) - FFLAGS += -g --chk a,e,s,u -O0 - else - FFLAGS += -O - endif - # Threading only works by putting thread memory on the heap rather than the stack - # (--threadheap). - # As of lf95 version 6.2 the thread stacksize limits are (still) too small to run - # even small - # resolution problems (FV at 10x15 res fails). - ifeq ($(SMP),TRUE) - FFLAGS += --openmp --threadheap 4096 - LDFLAGS += --openmp --threadheap 4096 - endif - endif - ifeq ($(FCTYP),pathf90) - FFLAGS += -extend_source -ftpp -fno-second-underscore - ifneq ($(OPT),TRUE) - FFLAGS += -g -O0 - else - FFLAGS += -O - endif - ifeq ($(SMP),TRUE) - FFLAGS += -mp - LDFLAGS += -mp - endif - endif - ifeq ($(FCTYP),ifort) - - FFLAGS += -ftz -g -fp-model precise -convert big_endian -assume byterecl -traceback -FR - CFLAGS += -m64 -g - LDFLAGS += -m64 - - ifneq ($(OPT),TRUE) - FFLAGS += -CB -O0 - else - FFLAGS += -O2 - endif - ifeq ($(SMP),TRUE) - FFLAGS += -qopenmp - CFLAGS += -qopenmp - LDFLAGS += -qopenmp - endif - endif - FFLAGS += -c -I$(INC_NETCDF) $(CPPDEF) $(cpp_path) - CFLAGS += $(cpp_path) -endif - -#------------------------------------------------------------------------ -# Default rules and macros -#------------------------------------------------------------------------ - -.SUFFIXES: -.SUFFIXES: .F90 .c .o - -# Set the vpath for all file types EXCEPT .o -# We do this for individual file types rather than generally using -# VPATH, because for .o files, we don't want to use files from a -# different build (e.g., in building the unit tester, we don't want to -# use .o files from the main build) -vpath %.F90 $(vpath_dirs) -vpath %.c $(vpath_dirs) -vpath %.h $(vpath_dirs) - -# Append user defined compiler and load flags to Makefile defaults -CFLAGS += $(USER_CFLAGS) -FFLAGS += $(USER_FFLAGS) -LDFLAGS += $(USER_LDFLAGS) - -# Set user specified linker -ifneq ($(USER_LINKER),$(null)) - LINKER := $(USER_LINKER) -else - LINKER := $(FC) -endif - -.F90.o: - $(FC) $(FFLAGS) $< - -.c.o: - $(CC) -c $(CFLAGS) $< - - -$(EXENAME): $(OBJS) - $(LINKER) -o $@ $(OBJS) $(LDFLAGS) - -clean: - $(RM) -f $(OBJS) *.mod Depends - -include $(CURDIR)/Depends diff --git a/tools/mkprocdata_map/src/Mkdepends b/tools/mkprocdata_map/src/Mkdepends deleted file mode 100755 index a75e8fdde0..0000000000 --- a/tools/mkprocdata_map/src/Mkdepends +++ /dev/null @@ -1,327 +0,0 @@ -#!/usr/bin/env perl - -# Generate dependencies in a form suitable for inclusion into a Makefile. -# The source filenames are provided in a file, one per line. Directories -# to be searched for the source files and for their dependencies are provided -# in another file, one per line. Output is written to STDOUT. -# -# For CPP type dependencies (lines beginning with #include) the dependency -# search is recursive. Only dependencies that are found in the specified -# directories are included. So, for example, the standard include file -# stdio.h would not be included as a dependency unless /usr/include were -# one of the specified directories to be searched. -# -# For Fortran module USE dependencies (lines beginning with a case -# insensitive "USE", possibly preceded by whitespace) the Fortran compiler -# must be able to access the .mod file associated with the .o file that -# contains the module. In order to correctly generate these dependencies -# two restrictions must be observed. -# 1) All modules must be contained in files that have the same base name as -# the module, in a case insensitive sense. This restriction implies that -# there can only be one module per file. -# 2) All modules that are to be contained in the dependency list must be -# contained in one of the source files in the list provided on the command -# line. -# The reason for the second restriction is that since the makefile doesn't -# contain rules to build .mod files the dependency takes the form of the .o -# file that contains the module. If a module is being used for which the -# source code is not available (e.g., a module from a library), then adding -# a .o dependency for that module is a mistake because make will attempt to -# build that .o file, and will fail if the source code is not available. -# -# Author: B. Eaton -# Climate Modelling Section, NCAR -# Feb 2001 - -use Getopt::Std; -use File::Basename; - -# Check for usage request. -@ARGV >= 2 or usage(); - -# Process command line. -my %opt = (); -getopts( "t:w", \%opt ) or usage(); -my $filepath_arg = shift() or usage(); -my $srcfile_arg = shift() or usage(); -@ARGV == 0 or usage(); # Check that all args were processed. - -my $obj_dir; -if ( defined $opt{'t'} ) { $obj_dir = $opt{'t'}; } - -open(FILEPATH, $filepath_arg) or die "Can't open $filepath_arg: $!\n"; -open(SRCFILES, $srcfile_arg) or die "Can't open $srcfile_arg: $!\n"; - -# Make list of paths to use when looking for files. -# Prepend "." so search starts in current directory. This default is for -# consistency with the way GNU Make searches for dependencies. -my @file_paths = ; -close(FILEPATH); -chomp @file_paths; -unshift(@file_paths,'.'); -foreach $dir (@file_paths) { # (could check that directories exist here) - $dir =~ s!/?\s*$!!; # remove / and any whitespace at end of directory name - ($dir) = glob $dir; # Expand tildes in path names. -} - -# Make list of files containing source code. -my @src = ; -close(SRCFILES); -chomp @src; - -# For each file that may contain a Fortran module (*.[fF]90 *.[fF]) convert the -# file's basename to uppercase and use it as a hash key whose value is the file's -# basename. This allows fast identification of the files that contain modules. -# The only restriction is that the file's basename and the module name must match -# in a case insensitive way. -my %module_files = (); -my ($f, $name, $path, $suffix, $mod); -my @suffixes = ('\.[fF]90', '\.[fF]' ); -foreach $f (@src) { - ($name, $path, $suffix) = fileparse($f, @suffixes); - ($mod = $name) =~ tr/a-z/A-Z/; - $module_files{$mod} = $name; -} - -# Now make a list of .mod files in the file_paths. If a .o source dependency -# can't be found based on the module_files list above, then maybe a .mod -# module dependency can if the mod file is visible. -my %trumod_files = (); -my ($dir); -my ($f, $name, $path, $suffix, $mod); -my @suffixes = ('\.mod' ); -foreach $dir (@file_paths) { - @filenames = (glob("$dir/*.mod")); - foreach $f (@filenames) { - ($name, $path, $suffix) = fileparse($f, @suffixes); - ($mod = $name) =~ tr/a-z/A-Z/; - $trumod_files{$mod} = $name; - } -} - -#print STDERR "\%module_files\n"; -#while ( ($k,$v) = each %module_files ) { -# print STDERR "$k => $v\n"; -#} - -# Find module and include dependencies of the source files. -my ($file_path, $rmods, $rincs); -my %file_modules = (); -my %file_includes = (); -my @check_includes = (); -foreach $f ( @src ) { - - # Find the file in the seach path (@file_paths). - unless ($file_path = find_file($f)) { - if (defined $opt{'w'}) {print STDERR "$f not found\n";} - next; - } - - # Find the module and include dependencies. - ($rmods, $rincs) = find_dependencies( $file_path ); - - # Remove redundancies (a file can contain multiple procedures that have - # the same dependencies). - $file_modules{$f} = rm_duplicates($rmods); - $file_includes{$f} = rm_duplicates($rincs); - - # Make a list of all include files. - push @check_includes, @{$file_includes{$f}}; -} - -#print STDERR "\%file_modules\n"; -#while ( ($k,$v) = each %file_modules ) { -# print STDERR "$k => @$v\n"; -#} -#print STDERR "\%file_includes\n"; -#while ( ($k,$v) = each %file_includes ) { -# print STDERR "$k => @$v\n"; -#} -#print STDERR "\@check_includes\n"; -#print STDERR "@check_includes\n"; - -# Find include file dependencies. -my %include_depends = (); -while (@check_includes) { - $f = shift @check_includes; - if (defined($include_depends{$f})) { next; } - - # Mark files not in path so they can be removed from the dependency list. - unless ($file_path = find_file($f)) { - $include_depends{$f} = -1; - next; - } - - # Find include file dependencies. - ($rmods, $include_depends{$f}) = find_dependencies($file_path); - - # Add included include files to the back of the check_includes list so - # that their dependencies can be found. - push @check_includes, @{$include_depends{$f}}; - - # Add included modules to the include_depends list. - if ( @$rmods ) { push @{$include_depends{$f}}, @$rmods; } -} - -#print STDERR "\%include_depends\n"; -#while ( ($k,$v) = each %include_depends ) { -# print STDERR (ref $v ? "$k => @$v\n" : "$k => $v\n"); -#} - -# Remove include file dependencies that are not in the Filepath. -my $i, $ii; -foreach $f (keys %include_depends) { - - unless (ref $include_depends{$f}) { next; } - $rincs = $include_depends{$f}; - unless (@$rincs) { next; } - $ii = 0; - $num_incs = @$rincs; - for ($i = 0; $i < $num_incs; ++$i) { - if ($include_depends{$$rincs[$ii]} == -1) { - splice @$rincs, $ii, 1; - next; - } - ++$ii; - } -} - -# Substitute the include file dependencies into the %file_includes lists. -foreach $f (keys %file_includes) { - my @expand_incs = (); - - # Initialize the expanded %file_includes list. - my $i; - unless (@{$file_includes{$f}}) { next; } - foreach $i (@{$file_includes{$f}}) { - push @expand_incs, $i unless ($include_depends{$i} == -1); - } - unless (@expand_incs) { - $file_includes{$f} = []; - next; - } - - # Expand - for ($i = 0; $i <= $#expand_incs; ++$i) { - push @expand_incs, @{ $include_depends{$expand_incs[$i]} }; - } - - $file_includes{$f} = rm_duplicates(\@expand_incs); -} - -#print STDERR "expanded \%file_includes\n"; -#while ( ($k,$v) = each %file_includes ) { -# print STDERR "$k => @$v\n"; -#} - -# Print dependencies to STDOUT. -foreach $f (sort keys %file_modules) { - $f =~ /(.+)\./; - $target = "$1.o"; - if ( defined $opt{'t'} ) { $target = "$opt{'t'}/$1.o"; } - print "$target : $f @{$file_modules{$f}} @{$file_includes{$f}}\n"; -} - -#-------------------------------------------------------------------------------------- - -sub find_dependencies { - - # Find dependencies of input file. - # Use'd Fortran 90 modules are returned in \@mods. - # Files that are "#include"d by the cpp preprocessor are returned in \@incs. - - my( $file ) = @_; - my( @mods, @incs ); - - open(FH, $file) or die "Can't open $file: $!\n"; - - while ( ) { - # Search for "#include" and strip filename when found. - if ( /^#include\s+[<"](.*)[>"]/ ) { - push @incs, $1; - } - # Search for Fortran include dependencies. - elsif ( /^\s*include\s+['"](.*)['"]/ ) { #" for emacs fontlock - push @incs, $1; - } - # Search for module dependencies. - elsif ( /^\s*USE\s+(\w+)/i ) { - ($module = $1) =~ tr/a-z/A-Z/; - # Return dependency in the form of a .o version of the file that contains - # the module. this is from the source list. - if ( defined $module_files{$module} ) { - if ( defined $obj_dir ) { - push @mods, "$obj_dir/$module_files{$module}.o"; - } else { - push @mods, "$module_files{$module}.o"; - } - } - # Return dependency in the form of a .mod version of the file that contains - # the module. this is from the .mod list. only if .o version not found - elsif ( defined $trumod_files{$module} ) { - if ( defined $obj_dir ) { - push @mods, "$obj_dir/$trumod_files{$module}.mod"; - } else { - push @mods, "$trumod_files{$module}.mod"; - } - } - } - } - close( FH ); - return (\@mods, \@incs); -} - -#-------------------------------------------------------------------------------------- - -sub find_file { - -# Search for the specified file in the list of directories in the global -# array @file_paths. Return the first occurance found, or the null string if -# the file is not found. - - my($file) = @_; - my($dir, $fname); - - foreach $dir (@file_paths) { - $fname = "$dir/$file"; - if ( -f $fname ) { return $fname; } - } - return ''; # file not found -} - -#-------------------------------------------------------------------------------------- - -sub rm_duplicates { - -# Return a list with duplicates removed. - - my ($in) = @_; # input arrary reference - my @out = (); - my $i; - my %h = (); - foreach $i (@$in) { - $h{$i} = ''; - } - @out = keys %h; - return \@out; -} - -#-------------------------------------------------------------------------------------- - -sub usage { - ($ProgName = $0) =~ s!.*/!!; # name of program - die < shr_kind_r8 - implicit none - save - - real(R8),parameter :: SHR_CONST_REARTH = 6.37122e6_R8 ! radius of earth ~ m - real(r8),parameter :: re_km = SHR_CONST_REARTH*0.001 ! radius of earth (km) - -end module constMod diff --git a/tools/mkprocdata_map/src/fileutils.F90 b/tools/mkprocdata_map/src/fileutils.F90 deleted file mode 100644 index e1f8e633da..0000000000 --- a/tools/mkprocdata_map/src/fileutils.F90 +++ /dev/null @@ -1,282 +0,0 @@ -module fileutils - -!----------------------------------------------------------------------- -!BOP -! -! !MODULE: fileutils -! -! !DESCRIPTION: -! Module containing file I/O utilities -! -! !USES: -! -! !PUBLIC TYPES: - implicit none - save -! -! !PUBLIC MEMBER FUNCTIONS: - public :: get_filename !Returns filename given full pathname - public :: opnfil !Open local unformatted or formatted file - public :: getfil !Obtain local copy of file - public :: relavu !Close and release Fortran unit no longer in use - public :: getavu !Get next available Fortran unit number -! -! !REVISION HISTORY: -! Created by Mariana Vertenstein -! -! -! !PRIVATE MEMBER FUNCTIONS: None -!EOP -!----------------------------------------------------------------------- - -contains - -!----------------------------------------------------------------------- -!BOP -! -! !IROUTINE: get_filename -! -! !INTERFACE: - character(len=256) function get_filename (fulpath) -! -! !DESCRIPTION: -! Returns filename given full pathname -! -! !ARGUMENTS: - implicit none - character(len=*), intent(in) :: fulpath !full pathname -! -! !REVISION HISTORY: -! Created by Mariana Vertenstein -! -! -! !LOCAL VARIABLES: -!EOP - integer i !loop index - integer klen !length of fulpath character string -!------------------------------------------------------------------------ - - klen = len_trim(fulpath) - do i = klen, 1, -1 - if (fulpath(i:i) == '/') go to 10 - end do - i = 0 -10 get_filename = fulpath(i+1:klen) - - end function get_filename - -!------------------------------------------------------------------------ -!BOP -! -! !IROUTINE: set_filename -! -! !INTERFACE: - character(len=256) function set_filename (rem_dir, loc_fn) -! -! !DESCRIPTION: -! -! !ARGUMENTS: -! - implicit none - character(len=*), intent(in) :: rem_dir !remote directory - character(len=*), intent(in) :: loc_fn !local full path filename -! -! !REVISION HISTORY: -! Created by Mariana Vertenstein -! -! -! !LOCAL VARIABLES: -!EOP - integer :: i !integer -!------------------------------------------------------------------------ - - set_filename = ' ' - do i = len_trim(loc_fn), 1, -1 - if (loc_fn(i:i)=='/') go to 10 - end do - i = 0 -10 set_filename = trim(rem_dir) // loc_fn(i+1:len_trim(loc_fn)) - - end function set_filename - -!------------------------------------------------------------------------ -!BOP -! -! !IROUTINE: getfil -! -! !INTERFACE: - subroutine getfil (fulpath, locfn, iflag) -! -! !DESCRIPTION: -! Obtain local copy of file -! First check current working directory -! Next check full pathname[fulpath] on disk -! Finally check full pathname[fulpath] on archival system -! -! !USES: -! -! !ARGUMENTS: - implicit none - character(len=*), intent(in) :: fulpath !Archival or permanent disk full pathname - character(len=*), intent(out) :: locfn !output local file name - integer, optional, intent(in) :: iflag !0=>abort if file not found 1=>do not abort -! -! !REVISION HISTORY: -! Created by Mariana Vertenstein -! -! -! !LOCAL VARIABLES: -!EOP - integer i !loop index - integer klen !length of fulpath character string - integer ierr !error status - logical lexist !true if local file exists - character(len=len(fulpath)+5) :: fulpath2 !Archival full pathname -!------------------------------------------------------------------------ - - ! get local file name from full name: start at end. look for first "/" - - klen = len_trim(fulpath) - do i = klen, 1, -1 - if (fulpath(i:i).eq.'/') go to 100 - end do - i = 0 -100 locfn = fulpath(i+1:klen) - if (len_trim(locfn) == 0) then - write(6,*)'(GETFIL): local filename has zero length' - stop 1 - else - write(6,*)'(GETFIL): attempting to find local file ',trim(locfn) - endif - - ! first check if file is in current working directory. - - inquire (file=locfn,exist=lexist) - if (lexist) then - write(6,*) '(GETFIL): using ',trim(locfn),' in current working directory' - RETURN - endif - - ! second check for full pathname on disk - - inquire(file=fulpath, exist=lexist) - if (lexist) then - locfn = trim(fulpath) - write(6,*) '(GETFIL): using ',trim(fulpath) - RETURN - else - write(6,*) 'GETFIL: FAILED to get '//trim(fulpath) - stop 1 - end if - - end subroutine getfil - -!------------------------------------------------------------------------ -!BOP -! -! !IROUTINE: opnfil -! -! !INTERFACE: - subroutine opnfil (locfn, iun, form) -! -! !DESCRIPTION: -! Open file locfn in unformatted or formatted form on unit iun -! -! !ARGUMENTS: -! - implicit none - character(len=*), intent(in):: locfn !file name - integer, intent(in):: iun !fortran unit number - character(len=1), intent(in):: form !file format: u = unformatted, - !f = formatted -! -! !REVISION HISTORY: -! Created by Mariana Vertenstein -! -! -! !LOCAL VARIABLES: -!EOP - integer ioe !error return from fortran open - character(len=11) ft !format type: formatted. unformatted -!------------------------------------------------------------------------ - - if (len_trim(locfn) == 0) then - write(6,*)'OPNFIL: local filename has zero length' - stop 1 - endif - if (form=='u' .or. form=='U') then - ft = 'unformatted' - else - ft = 'formatted ' - end if - open (unit=iun,file=locfn,status='unknown',form=ft,iostat=ioe) - if (ioe /= 0) then - write(6,*)'(OPNFIL): failed to open file ',trim(locfn), & - & ' on unit ',iun,' ierr=',ioe - stop 1 - else - write(6,*)'(OPNFIL): Successfully opened file ',trim(locfn),' on unit= ',iun - end if - - end subroutine opnfil - -!------------------------------------------------------------------------ -!BOP -! -! !IROUTINE: getavu -! -! !INTERFACE: - integer function getavu() -! -! !DESCRIPTION: -! Get next available Fortran unit number. -! -! !USES: - use shr_file_mod, only : shr_file_getUnit -! -! !ARGUMENTS: - implicit none -! -! !REVISION HISTORY: -! Created by Gordon Bonan -! Modified for clm2 by Mariana Vertenstein -! -! -! !LOCAL VARIABLES: -!EOP -!------------------------------------------------------------------------ - - getavu = shr_file_getunit() - - end function getavu - -!------------------------------------------------------------------------ -!BOP -! -! !IROUTINE: relavu -! -! !INTERFACE: - subroutine relavu (iunit) -! -! !DESCRIPTION: -! Close and release Fortran unit no longer in use! -! -! !USES: - use shr_file_mod, only : shr_file_freeUnit -! -! !ARGUMENTS: - implicit none - integer, intent(in) :: iunit !Fortran unit number -! -! !REVISION HISTORY: -! Created by Gordon Bonan -! -!EOP -!------------------------------------------------------------------------ - - close(iunit) - call shr_file_freeUnit(iunit) - - end subroutine relavu - -end module fileutils diff --git a/tools/mkprocdata_map/src/fmain.F90 b/tools/mkprocdata_map/src/fmain.F90 deleted file mode 100644 index ba9e593c1d..0000000000 --- a/tools/mkprocdata_map/src/fmain.F90 +++ /dev/null @@ -1,78 +0,0 @@ -program fmain - - use mkprocdata_map, only : mkmap - implicit none - - character(len= 256) :: arg - integer :: n !index - integer :: nargs !number of arguments - integer, external :: iargc !number of arguments function - character(len=256) :: filei !input file - character(len=256) :: fileo !output mapped file - character(len=256) :: fmap !maping file - character(len=256) :: ftemplate !template file, containing lat & lon arrays desired in output file - character(len=256) :: cmdline !input command line - integer, parameter :: inival = -999 !initial value for command-line integers - !---------------------------------------------------- - - filei = ' ' - fileo = ' ' - fmap = ' ' - ftemplate = ' ' - - cmdline = 'mkprocdata_map' - nargs = iargc() - n = 1 - do while (n <= nargs) - arg = ' ' - call getarg (n, arg) - n = n + 1 - - select case (arg) - case ('-i') - call getarg (n, arg) - n = n + 1 - filei = trim(arg) - cmdline = trim(cmdline) // ' -i ' // trim(arg) - case ('-o') - call getarg (n, arg) - n = n + 1 - fileo = trim(arg) - cmdline = trim(cmdline) // ' -o ' // trim(arg) - case ('-m') - call getarg (n, arg) - n = n + 1 - fmap = trim(arg) - cmdline = trim(cmdline) // ' -m ' // trim(arg) - case ('-t') - call getarg (n, arg) - n = n + 1 - ftemplate = trim(arg) - cmdline = trim(cmdline) // ' -t ' // trim(arg) - case default - write (6,*) 'Argument ', arg,' is not known' - call usage_exit (' ') - cmdline = trim(cmdline) // ' ' // trim(arg) - end select - end do - - if (filei == ' ' .or. fileo == ' ' .or. fmap == ' ' & - .or. ftemplate == ' ') then - call usage_exit ('Must specify all the following arguments') - end if - - call mkmap (filei, fileo, fmap, ftemplate) - -end program fmain - - -subroutine usage_exit (arg) - implicit none - character(len=*) :: arg - if (arg /= ' ') write (6,*) arg - write (6,*) 'Usage: mkprocdata_map -i -o -m -t