iloscar-win


Nameiloscar-win JSON
Version 0.1.7 PyPI version JSON
download
home_pagehttps://github.com/Shihan150/iloscar
SummaryiLOSCAR_win
upload_time2023-05-18 17:33:06
maintainer
docs_urlNone
authorShihan Li
requires_python>3.7, <3.11
licenseMIT
keywords python carbon cycle model paleoclimate global warming loscar
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            
# iloscar
 A web-based interactive carbon cycle model, built upon the classic LOSCAR model. Forward and inverse mode incorporated.  
 Author: Shihan Li.    
 For any questions, please contact shihan@tamu.edu

## Install it from PyPI

```bash
pip install iloscar
```

## Usage

```py
from iloscar import iloscar_run

iloscar_run()

```
Open [http://127.0.0.1:7777/](http://127.0.0.1:7777/) to run the model. 

## Model description
The overall framework of iLOSCAR is built upon the LOSCAR (*Long-term Ocean-atmosphere Sediment CArbon cycle Reservoir*). LOSCAR is a carbon cycle box model that can operate on both short-term (centuries) and long-term (millions of years) time scales, efficiently computing the partitioning of carbon between various model components (ocean, atmosphere, and sediments). The thorough description of the equations and corresponding processes in the model is given in [***Zeebe (2012)***](https://gmd.copernicus.org/articles/5/149/2012/). Here I will briefly introduce the original forward model from the mathematic perspective, and the algorithm for the inverse model.

The ocean component in LOSCAR is composed of three (four in the palaeo version) ocean reservoirs (Atlantic, Indian, Pacific, and Tethys in the palaeo set-up). Each of the basins is further subdivided into three depth boxes (surface, intermediate, and deep) and there is one gereric box representing the high latitude ocean. The ocean part is coupled with a genuine sediment model, which contains 13 layers of diffenrent depths and calculates %CaCO3 in each layer.

LOSCAR keeps track the concentrations of various biogeochemical tracers (including total carbon-TC, total alkalinity-TA, stable carbon isotopes-13C, and others) in different boxes. These tracers compose the state variables ($\overrightarrow{y_i}$) of the model and their dynamic changes over time are governed by the following first-order ordinary equation system (Zeebe, 2012):

$$\frac{d\overrightarrow{y_i}}{dt} = F(t, \overrightarrow{y_i})  \text{       }  Eq. 1$$,  

where $t$ is time, and F is a konwn function to calculate the derivatives of $\overrightarrow{y_i}$. The dimension of $\overrightarrow{y_i}$ is 140 (modern setup) or 184 (palaeo setup). Note that model parameters required for derivative calculation except the state variables are implicitly included in the function F. For the convenience of introducing the inverse algorithm, we rewrite Eq. 1 as:
$$\frac{d\overrightarrow{y_i}}{dt} = f(\overrightarrow{y_i}, \lambda, \theta (t)  \text{       }  Eq. 2$$, 

where $\lambda$ represents the assembly of time-invariant parameters and $\theta$ for the time-dependent parameters. $\lambda$ can be subdivided into three categories: i. the model architecture settings (e.g., ocean volume and areas, oceanic Mg and Ca concentrations, the area percentage of each sediment layer, the thermohaline intensity et al.,); ii. initial fluxes and correponding isotopic values (e.g, the initial silicate and weathering fluxes, the initial primary productivity in the high box, et al.,); iii. to describe the dynamic evolution of each flux (e.g., the calcite dissolution constant, silicate and carbonate weathering exponent, air-sea CO2 exchange coefficient, biopump efficiency, rain ratio et al.,). In most LOSCAR applications, the flux from possilbe carbon input sources is the only item in $\theta$ (termed $fcinp$).

According to Eq.2, we can define two main glasses main classes of problems in the carbon cycle study: forward solution and parameter estimation inversely from  the data. The first type of models solve the temporal evolution of $\overrightarrow{y_i}$ with $f, \lambda, \theta$ are known and $y(t=0)$ is given, while the latter type starts from available records (e.g., proxy-derived pH, pCO2 records) and aims to find out parameters $lambda and theta$ that best describe the observed data. Usually only several parameters of key interest in $lambda and theta$ will be inversely constrained. 

In iLOSCAR, the forward model allows user to tune parameters of interest and runs experiments in the same way as in LOSCAR. The inverse model draws the emission trajectory constrained by the proxy records data in a single run. In both models, users can tune the model parameters and run experiments from a web-based interface interactively instead of diving into the complex code files. 

### Forward model
There are three innovations in the iLOSCAR compared with the original LOSCAR model. Firstly, it is written in the open source Python language, which is a higher-level programming language than C used in LOSCAR. Thus, the iLOSCAR will be availble to a wider audience and advanced computation packages can be easily applied. Secondly, to comprimise the reduction of running speed caused by switching the programming lanuage, [Numba](https://numba.pydata.org/) is used to accelerate the model. Also, the original function for the oceanic carbonate system is vectorized to perform calculation from multi-inputs. Lastly, [LSODA from scipy package](https://docs.scipy.org/doc/scipy/reference/generated/scipy.integrate.solve_ivp.html#scipy.integrate.solve_ivp) is chosen as the ODE solver due to its stability in stiff systems. 

### Inverse model
The aim of inverse model is to estimate the carbon emission trajectory (i.e., fcinp(t)) from the given target records (i.e., pCO2 and mean sea surface pH, termed as x(t)) and to constrain the carbon isotopic value (d13c(t)) according to the mean sea surface d13c record (i.e., fd13c(t)). 

x(t) can be derived from each given $\overrightarrow{y}(t)$ (pCO2 is a state variable and pH in each ocean box can be caculated from two state variables: TA and ALK.). We generalize the relationship as:  
$$x(t) = g(\overrightarrow{y}(t))  \text{       }  Eq. 3$$ 
where $\overrightarrow{y}(t)$ can be solved from Eq. 2 when $lambda$, $\overrightarrow{y}(t=0)$, $fcinp(t)$ are given. Note that fd13c(t) only controls the 13C/12C ratio of input carbon and has no effect on x(t). Here we take $lambda$ and $\overrightarrow{y}(t=0)$ are fixed and $fcinp(t)$ could be adjusted to produce x(t) that makes the best fit with proxy records (X(t)). Then   Eq. 3 can be further written as:
$$x(t) = G(fcinp(t))  \text{       }  Eq. 4$$.  

Theoretically carbon emission could be intermittent and spontaneous, thus it is adventurous to simplify $fcinp(t)$ to some known distributions. However, some assumption is inevitable to reduce the parameters required to describe $fcinp(t)$. Therefore, we seperate the input scenario to (n-1) intervals by n points from X(t) time series data, and in each interval, we assume a linear increase/decrease of emission rate, i.e.:

$$\eqalign{
fcinp(t) &= k_1 * (t - t_0) \text{  }  (\text{if }t_0 <= t <=t_1) \\
        &= fcinp(t_1) + k_2 * (t - t_1) \text{  }  (\text{if }t_1 < t <= t_2) \\
        & ... \\
        &= fcinp(t_{n-1}) + k_n * (t - t_{n-1})\text{  }  (\text{if }t_{n-1} < t <= t_n)
} Eq. 5$$ 

where t_i is the time points of time-series X(t) data. In this way, $fcinp(t)$ could be represented by $(n-1)$ parameters ($k_1 - k_{n-1}$). The problem can be rephrased as to find the $\overrightarrow{k})$ to minimize the following function:

$$\eqalign{
\sum_{i=1}^n G(\overrightarrow{k})[t = t_i] - X(t = t_i)
} \text{       }   Eq.6$$  

Since there are k equations for k parameters, the essence of inverse problem belongs to the category of root finder instead of optimization. To find the solution, a sequential iteration algorithm is applied. Concretely, we start from [t0, t1] interval and apply ['toms748' method](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.toms748.html) from Python scipy package to solve the equation $G(k_1)[t=t_1] = X(t=t_1)$. The toms74 method is chosen as the numerical solver mainly due to its fast convergence rate, thus accelerating the model speed. When $k_1$ is solved, the algorithm will run forwardly with the $k_1$-based fcinp(t) at $[t_0, t_1]$ inveterval and save the $\overrightarrow{y}(t=t_1)$, which will serve as the initial y0 for next iteration at $[t1, t2]$ interval. The same process will repeat until $k_n$ is solved. 

The modeling d13c results depend on both the isotopic signature and the mass of emitted carbon. When fcinp(t) is solved, the similar procedure will be applied to calculate fd13c(t), except that a constant d13c value in each interval.

### Smoothing function
A LOWESS smoothing function is provided. Users are allowed to upload data files and tune the hyperparamter that controls the windown fraction used in LOWESS manually. Note that the default temporal resolution for output data is 0.2 kyr. For a full description of smoothing algorithm, refer to [https://www.statsmodels.org/dev/generated/statsmodels.nonparametric.smoothers_lowess.lowess.html](https://www.statsmodels.org/dev/generated/statsmodels.nonparametric.smoothers_lowess.lowess.html). 

### Output files
| File.csv    | Unit        | Variable         |
| ----------- | ----------- | ---------------- |
| tcb    |  (deg C)  | OCN temperature|
| dic    |   (mmol/kg) | OCN total dissolved inorganic carbon|
|  alk    |  (mmol/kg)| OCN total alkalinity|
|  po4   |    (umol/kg)| OCN phosphate|
|  dox   |    (mol/m3) | OCN dissolved oxygen|
|   dicc  |    (mmol/kg) |OCN DIC-13|
|  d13c   |   (per mil)| OCN delta13C(DIC)|
|  d13ca   |  (per mil) |ATM delta13C(atmosphere)|
|   pco2a_d13c   |  (ppmv, per mil)   | ATM atmospheric pCO2 and d13c|
|    co3      | (umol/kg) |OCN carbonate ion concentration|
|   ph      |  (-)      | OCN pH (total scale)|
|    pco2ocn |  (uatm)   | OCN ocean pCO2|
|    omegaclc | (-)     |  OCN calcite saturation state|
|    omegaarg | (-)     |  OCN aragonite saturation state|
|     fca     |  (-)    |   SED calcite content Atlantic|
|    fci    |   (-)     |  SED calcite content Indian|
|    fcp     |  (-)     |  SED calcite content Pacific|
|    fct     |  (-)     |  SED calcite content Tethys (PALEO only)|
|    ccda   |   (m)     |  SED calcite compens. depth Atlantic|
|    ccdi   |   (m)     |  SED calcite compens. depth Indian|
|    ccdp   |   (m)     |  SED calcite compens. depth Pacific|
|     ccdt    |  (m)     |  SED calcite compens. depth Tethys (PALEO only)|
| Surface_dic_alk_d13c_ph | (-) |  Mean OCN surface DIC, ALK, d13c, and pH|
|        Carbon_inventory |   (mol)   |  Total carbon and alkalinty in the ocean|
        
        

## External file requirement
| Mode      | File usage| Format | Requirement
| ----------- | ----------- | ------- | -------
| Forward    | Initial y0   | .dat | 1 column, 140 (for modern) or 184  rows; <br /> y0 satisfies dy0/dt = F(t=t0, y0) = 0 
|            | Emission file | .dat | When LOADFLAG == 2, two columns (age (yr) + emission mass (Gt/yr)).<br /> When LOADFLAG == 3, three columns (age (yr) + emission mass (Gt/yr)+d13c of input (per mil)).
|            | Save yfinal  | .dat | When Save ystart == 1, y(t=tfinal) will be saved into the according |
| Inverse | pCO2 data for inversion | .csv | 2 column with headline, age (yr) + pCO2 (ppmv)
|          | mean surface pH data for inversion | .csv | 2 column with headline, age (yr) + pH |
|          | mean surface d13c data for inversion | .csv | 2 column with headline, age (yr) + d13c |

| Function | data to be smoothed | .csv | 2 column with headline, age (yr) + data |


## Example
(Required dataset could be downloaded [here](https://github.com/Shihan150/iloscar/tree/main/dat).)

### 1. Benchmark

1.1 Origninal PETM example from [Zeebe et al., 2009](https://www.nature.com/articles/ngeo578).

    1. Go to the Forward page   

![image](https://user-images.githubusercontent.com/57557675/232100195-e47c4d51-dbba-4b5b-a82a-b60cb3870703.png)

    2. Turn the PALEO to '1'. Then the model parameters in Table 2 will adjust automatically to the palaeo settings, so skip the Step 2.

![image](https://user-images.githubusercontent.com/57557675/232095753-3edcd6d7-9a06-49cd-85f8-ecf19c4fca94.png)

    3. Select the carbon emission scenario in Table 3. In this example, set 'emission pattern' == 1, emission amount == 3000, 'd13c emission' == -55, 'emission start' == 0, 'emission duration' == 6000.

![image](https://user-images.githubusercontent.com/57557675/232096837-51e2d08a-5f5c-48c5-b0dd-ac867f97327a.png)

    4. Give a name to your experiment and run it. I name it as Zeebe2009 here.

![image](https://user-images.githubusercontent.com/57557675/232097501-d03a8807-07e3-4e6f-bef9-ca7bb1eb8770.png)

    5. The running information will be given in the following chunck. A progress bar is displayed to track the experiment running. 

![image](https://user-images.githubusercontent.com/57557675/232097903-6d2d0c27-6d90-464b-9359-8d42d0d9bded.png)

    6. When integration finished, modeling results are saved to exp_name folder (Zeebe2009 here). The folder will be in the same dictionary where you run your python code. 44Modeling Mean surface DIC, ALK, pH and d13c, pCO2, and CCD for each ocean basin will be displayed when integration succeeds. 

![image](https://user-images.githubusercontent.com/57557675/232099371-c2bac20e-fd1c-4c16-8acb-88f4de7e7815.png)

1.2 Inverse twin experiment 

To test the performance of inverse algorithm, an identical twin test is performed. In identical twin testing, a preliminary run of the forward model is used to generate a synthetic 'truth' data set which can subsequently be used in inversion experiments. It is straightfoward to check whether the inverse algorithm works correctly. 

1. Preliminary run
    * In Forward page, follow all the default settings in Table 1 and 2, except turn tfinal to 2e4.
    * Set 'emission pattern' as 3 in Step 3 and input 'pulse_emi.dat' in second row of Table 4. Note that relative path is required for the file name. 
    * 'puluse_emi.dat'  two emission events: fast and short (3000 Gt in 3 kyr) vs slow and long (10000 Gt in 35 kyr), thus serving an excellent example to check the inversion algorithm.
    * Name the model and run the experiment. 
    
    ![image](https://user-images.githubusercontent.com/57557675/232114536-3d65cadb-fcea-45e9-9e52-c1cbb66c1bae.png)

2. Prepare data for inversion
    * At twin_exp folder, select the pCO2 results from pCO2_d13c.csv file and save as twin_pco2_for_inv.csv. Note that the modeling results are of high temporal resolution and we take a slice to keep the inversion time reasonable.
    * Repeat the process for mean surface pH and surface d13C result.

3. Inverse experiment (457.08s used)
    * Navigate to the Inverse page. Select 'pCO2 + mean surface d13c' from the dropdown menu and input the target file names manually.
    
   ![image](https://user-images.githubusercontent.com/57557675/232131733-cedd0fb3-1246-43af-9c88-cb344e4517e0.png)
    * Name the experiment and run the model.
    * (If you meet an error similar to the following figure, which means some degassing rate is larger than the default higher boundary in Table 3. Try to adjust the values of second and third row in Table 3.)
    
    ![image](https://user-images.githubusercontent.com/57557675/232137441-c1a4c47b-5420-46a0-a88f-2f6841de7991.png)
    
    * Succeed! Note that when fcinp(t) = 0, inversed d13c may experience some fluctuation.
![image](https://user-images.githubusercontent.com/57557675/232155210-c4b169b7-e0ba-49dd-a5e6-d061ef85e2b1.png)

 
  

### 2. Example

2.1 [Gutjahr et al., 2017](https://www.nature.com/articles/nature23646#Tab1)

1. Derive the steady state y0

    * Navigate to the Forward page.
    * In Table 1, set PALEO == 1, LOADFLAG == 0, Save ystart == 1
    * In Table 2, set tfinal == 1e7, pCO2_ref == 834, pCO2_initial == 834, silicate weathering0 = 7.5, carbonate weathering0 = 17.5, d13c volcanic == -1.5
    * In Table 4, input './gutjahr2017.dat' into the third row.
    * Name the experiment and run the model.
        
2. Inversion experiment (878s)
    * Navigate to the Inverse page.
    * Download the 'Gutjahr_pH.csv' and 'Gutjahr_d13c.csv' from the [link](https://github.com/Shihan150/iloscar/tree/main/dat).
    * In Table 1, set PALEO == 1, LOADFLAG == 1
    * In Table 2, set pCO2_ref == 834, pCO2_initial == 834, silicate weathering0 = 7.5, carbonate weathering0 = 17.5, d13c volcanic == -1.5
    * In Table 4, input './gutjahr2017.dat'
    * Name the experiment and run the model
    * Succeed! 
  
        
        
3. Data interpretation
    * Refer to [TBD]

2.2 [Wu et al., 2023](https://www.science.org/doi/full/10.1126/sciadv.abq4082)

1. Derive the steady state y0

    * Navigate to the Forward page.
    * In Table 1, set PALEO == 0, LOADFLAG == 0, Save ystart == 1
    * In Table 2, set tfinal == 1e7, pCO2_ref == 425, pCO2_initial == 449, , fsh == 5, silicate weathering0 = 12, carbonate weathering0 = 17, d13c volcanic == -1.3, ca concentration == 0.013, mg concentration == 0.042
    * In Table 4, input './wu2023.dat' into the third row.
    * Name the experiment and run the model.
        
2. Inversion experiment (s)
    * Navigate to the Inverse page.
    * Download the 'wu_pco2.csv' and 'wu_d13c.csv' from the [link](https://github.com/Shihan150/iloscar/tree/main/dat).
    * In Table 1, set PALEO == 0, LOADFLAG == 1
    * In Table 2, set  pCO2_ref == 425, pCO2_initial == 449, fsh == 5, silicate weathering0 = 12, carbonate weathering0 = 17, d13c volcanic == -1.3, ca concentration == 0.013, mg concentration == 0.042, nsi == 0.3, ncc == 0.5
    * In table 3, set lower and higher boundary as [-0.1, 1], which will accelerate the model
    * In Table 4, input './wu2023.dat'
    * Name the experiment and run the model
    * Succeed! 
  ![image](https://user-images.githubusercontent.com/57557675/232583038-0837c29a-9568-4e22-8159-f001b92a6341.png)


## Common bugs
1. The age of target records must be in year unit.

        
        

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/Shihan150/iloscar",
    "name": "iloscar-win",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">3.7, <3.11",
    "maintainer_email": "",
    "keywords": "python,carbon cycle,model,paleoclimate,global warming,LOSCAR",
    "author": "Shihan Li",
    "author_email": "<shihan@tamu.edu>",
    "download_url": "https://files.pythonhosted.org/packages/66/e1/d9bc64c2b525f68742d41c2fbda2624f792dbc6e235380cbe9aed9121a16/iloscar_win-0.1.7.tar.gz",
    "platform": null,
    "description": "\r\n# iloscar\r\n A web-based interactive carbon cycle model, built upon the classic LOSCAR model. Forward and inverse mode incorporated.  \r\n Author: Shihan Li.    \r\n For any questions, please contact shihan@tamu.edu\r\n\r\n## Install it from PyPI\r\n\r\n```bash\r\npip install iloscar\r\n```\r\n\r\n## Usage\r\n\r\n```py\r\nfrom iloscar import iloscar_run\r\n\r\niloscar_run()\r\n\r\n```\r\nOpen [http://127.0.0.1:7777/](http://127.0.0.1:7777/) to run the model. \r\n\r\n## Model description\r\nThe overall framework of iLOSCAR is built upon the LOSCAR (*Long-term Ocean-atmosphere Sediment CArbon cycle Reservoir*). LOSCAR is a carbon cycle box model that can operate on both short-term (centuries) and long-term (millions of years) time scales, efficiently computing the partitioning of carbon between various model components (ocean, atmosphere, and sediments). The thorough description of the equations and corresponding processes in the model is given in [***Zeebe (2012)***](https://gmd.copernicus.org/articles/5/149/2012/). Here I will briefly introduce the original forward model from the mathematic perspective, and the algorithm for the inverse model.\r\n\r\nThe ocean component in LOSCAR is composed of three (four in the palaeo version) ocean reservoirs (Atlantic, Indian, Pacific, and Tethys in the palaeo set-up). Each of the basins is further subdivided into three depth boxes (surface, intermediate, and deep) and there is one gereric box representing the high latitude ocean. The ocean part is coupled with a genuine sediment model, which contains 13 layers of diffenrent depths and calculates %CaCO3 in each layer.\r\n\r\nLOSCAR keeps track the concentrations of various biogeochemical tracers (including total carbon-TC, total alkalinity-TA, stable carbon isotopes-13C, and others) in different boxes. These tracers compose the state variables ($\\overrightarrow{y_i}$) of the model and their dynamic changes over time are governed by the following first-order ordinary equation system (Zeebe, 2012):\r\n\r\n$$\\frac{d\\overrightarrow{y_i}}{dt} = F(t, \\overrightarrow{y_i})  \\text{       }  Eq. 1$$,  \r\n\r\nwhere $t$ is time, and F is a konwn function to calculate the derivatives of $\\overrightarrow{y_i}$. The dimension of $\\overrightarrow{y_i}$ is 140 (modern setup) or 184 (palaeo setup). Note that model parameters required for derivative calculation except the state variables are implicitly included in the function F. For the convenience of introducing the inverse algorithm, we rewrite Eq. 1 as:\r\n$$\\frac{d\\overrightarrow{y_i}}{dt} = f(\\overrightarrow{y_i}, \\lambda, \\theta (t)  \\text{       }  Eq. 2$$, \r\n\r\nwhere $\\lambda$ represents the assembly of time-invariant parameters and $\\theta$ for the time-dependent parameters. $\\lambda$ can be subdivided into three categories: i. the model architecture settings (e.g., ocean volume and areas, oceanic Mg and Ca concentrations, the area percentage of each sediment layer, the thermohaline intensity et al.,); ii. initial fluxes and correponding isotopic values (e.g, the initial silicate and weathering fluxes, the initial primary productivity in the high box, et al.,); iii. to describe the dynamic evolution of each flux (e.g., the calcite dissolution constant, silicate and carbonate weathering exponent, air-sea CO2 exchange coefficient, biopump efficiency, rain ratio et al.,). In most LOSCAR applications, the flux from possilbe carbon input sources is the only item in $\\theta$ (termed $fcinp$).\r\n\r\nAccording to Eq.2, we can define two main glasses main classes of problems in the carbon cycle study: forward solution and parameter estimation inversely from  the data. The first type of models solve the temporal evolution of $\\overrightarrow{y_i}$ with $f, \\lambda, \\theta$ are known and $y(t=0)$ is given, while the latter type starts from available records (e.g., proxy-derived pH, pCO2 records) and aims to find out parameters $lambda and theta$ that best describe the observed data. Usually only several parameters of key interest in $lambda and theta$ will be inversely constrained. \r\n\r\nIn iLOSCAR, the forward model allows user to tune parameters of interest and runs experiments in the same way as in LOSCAR. The inverse model draws the emission trajectory constrained by the proxy records data in a single run. In both models, users can tune the model parameters and run experiments from a web-based interface interactively instead of diving into the complex code files. \r\n\r\n### Forward model\r\nThere are three innovations in the iLOSCAR compared with the original LOSCAR model. Firstly, it is written in the open source Python language, which is a higher-level programming language than C used in LOSCAR. Thus, the iLOSCAR will be availble to a wider audience and advanced computation packages can be easily applied. Secondly, to comprimise the reduction of running speed caused by switching the programming lanuage, [Numba](https://numba.pydata.org/) is used to accelerate the model. Also, the original function for the oceanic carbonate system is vectorized to perform calculation from multi-inputs. Lastly, [LSODA from scipy package](https://docs.scipy.org/doc/scipy/reference/generated/scipy.integrate.solve_ivp.html#scipy.integrate.solve_ivp) is chosen as the ODE solver due to its stability in stiff systems. \r\n\r\n### Inverse model\r\nThe aim of inverse model is to estimate the carbon emission trajectory (i.e., fcinp(t)) from the given target records (i.e., pCO2 and mean sea surface pH, termed as x(t)) and to constrain the carbon isotopic value (d13c(t)) according to the mean sea surface d13c record (i.e., fd13c(t)). \r\n\r\nx(t) can be derived from each given $\\overrightarrow{y}(t)$ (pCO2 is a state variable and pH in each ocean box can be caculated from two state variables: TA and ALK.). We generalize the relationship as:  \r\n$$x(t) = g(\\overrightarrow{y}(t))  \\text{       }  Eq. 3$$ \r\nwhere $\\overrightarrow{y}(t)$ can be solved from Eq. 2 when $lambda$, $\\overrightarrow{y}(t=0)$, $fcinp(t)$ are given. Note that fd13c(t) only controls the 13C/12C ratio of input carbon and has no effect on x(t). Here we take $lambda$ and $\\overrightarrow{y}(t=0)$ are fixed and $fcinp(t)$ could be adjusted to produce x(t) that makes the best fit with proxy records (X(t)). Then   Eq. 3 can be further written as:\r\n$$x(t) = G(fcinp(t))  \\text{       }  Eq. 4$$.  \r\n\r\nTheoretically carbon emission could be intermittent and spontaneous, thus it is adventurous to simplify $fcinp(t)$ to some known distributions. However, some assumption is inevitable to reduce the parameters required to describe $fcinp(t)$. Therefore, we seperate the input scenario to (n-1) intervals by n points from X(t) time series data, and in each interval, we assume a linear increase/decrease of emission rate, i.e.:\r\n\r\n$$\\eqalign{\r\nfcinp(t) &= k_1 * (t - t_0) \\text{  }  (\\text{if }t_0 <= t <=t_1) \\\\\r\n        &= fcinp(t_1) + k_2 * (t - t_1) \\text{  }  (\\text{if }t_1 < t <= t_2) \\\\\r\n        & ... \\\\\r\n        &= fcinp(t_{n-1}) + k_n * (t - t_{n-1})\\text{  }  (\\text{if }t_{n-1} < t <= t_n)\r\n} Eq. 5$$ \r\n\r\nwhere t_i is the time points of time-series X(t) data. In this way, $fcinp(t)$ could be represented by $(n-1)$ parameters ($k_1 - k_{n-1}$). The problem can be rephrased as to find the $\\overrightarrow{k})$ to minimize the following function:\r\n\r\n$$\\eqalign{\r\n\\sum_{i=1}^n G(\\overrightarrow{k})[t = t_i] - X(t = t_i)\r\n} \\text{       }   Eq.6$$  \r\n\r\nSince there are k equations for k parameters, the essence of inverse problem belongs to the category of root finder instead of optimization. To find the solution, a sequential iteration algorithm is applied. Concretely, we start from [t0, t1] interval and apply ['toms748' method](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.toms748.html) from Python scipy package to solve the equation $G(k_1)[t=t_1] = X(t=t_1)$. The toms74 method is chosen as the numerical solver mainly due to its fast convergence rate, thus accelerating the model speed. When $k_1$ is solved, the algorithm will run forwardly with the $k_1$-based fcinp(t) at $[t_0, t_1]$ inveterval and save the $\\overrightarrow{y}(t=t_1)$, which will serve as the initial y0 for next iteration at $[t1, t2]$ interval. The same process will repeat until $k_n$ is solved. \r\n\r\nThe modeling d13c results depend on both the isotopic signature and the mass of emitted carbon. When fcinp(t) is solved, the similar procedure will be applied to calculate fd13c(t), except that a constant d13c value in each interval.\r\n\r\n### Smoothing function\r\nA LOWESS smoothing function is provided. Users are allowed to upload data files and tune the hyperparamter that controls the windown fraction used in LOWESS manually. Note that the default temporal resolution for output data is 0.2 kyr. For a full description of smoothing algorithm, refer to [https://www.statsmodels.org/dev/generated/statsmodels.nonparametric.smoothers_lowess.lowess.html](https://www.statsmodels.org/dev/generated/statsmodels.nonparametric.smoothers_lowess.lowess.html). \r\n\r\n### Output files\r\n| File.csv    | Unit        | Variable         |\r\n| ----------- | ----------- | ---------------- |\r\n| tcb    |  (deg C)  | OCN temperature|\r\n| dic    |   (mmol/kg) | OCN total dissolved inorganic carbon|\r\n|  alk    |  (mmol/kg)| OCN total alkalinity|\r\n|  po4   |    (umol/kg)| OCN phosphate|\r\n|  dox   |    (mol/m3) | OCN dissolved oxygen|\r\n|   dicc  |    (mmol/kg) |OCN DIC-13|\r\n|  d13c   |   (per mil)| OCN delta13C(DIC)|\r\n|  d13ca   |  (per mil) |ATM delta13C(atmosphere)|\r\n|   pco2a_d13c   |  (ppmv, per mil)   | ATM atmospheric pCO2 and d13c|\r\n|    co3      | (umol/kg) |OCN carbonate ion concentration|\r\n|   ph      |  (-)      | OCN pH (total scale)|\r\n|    pco2ocn |  (uatm)   | OCN ocean pCO2|\r\n|    omegaclc | (-)     |  OCN calcite saturation state|\r\n|    omegaarg | (-)     |  OCN aragonite saturation state|\r\n|     fca     |  (-)    |   SED calcite content Atlantic|\r\n|    fci    |   (-)     |  SED calcite content Indian|\r\n|    fcp     |  (-)     |  SED calcite content Pacific|\r\n|    fct     |  (-)     |  SED calcite content Tethys (PALEO only)|\r\n|    ccda   |   (m)     |  SED calcite compens. depth Atlantic|\r\n|    ccdi   |   (m)     |  SED calcite compens. depth Indian|\r\n|    ccdp   |   (m)     |  SED calcite compens. depth Pacific|\r\n|     ccdt    |  (m)     |  SED calcite compens. depth Tethys (PALEO only)|\r\n| Surface_dic_alk_d13c_ph | (-) |  Mean OCN surface DIC, ALK, d13c, and pH|\r\n|        Carbon_inventory |   (mol)   |  Total carbon and alkalinty in the ocean|\r\n        \r\n        \r\n\r\n## External file requirement\r\n| Mode      | File usage| Format | Requirement\r\n| ----------- | ----------- | ------- | -------\r\n| Forward    | Initial y0   | .dat | 1 column, 140 (for modern) or 184  rows; <br /> y0 satisfies dy0/dt = F(t=t0, y0) = 0 \r\n|            | Emission file | .dat | When LOADFLAG == 2, two columns (age (yr) + emission mass (Gt/yr)).<br /> When LOADFLAG == 3, three columns (age (yr) + emission mass (Gt/yr)+d13c of input (per mil)).\r\n|            | Save yfinal  | .dat | When Save ystart == 1, y(t=tfinal) will be saved into the according |\r\n| Inverse | pCO2 data for inversion | .csv | 2 column with headline, age (yr) + pCO2 (ppmv)\r\n|          | mean surface pH data for inversion | .csv | 2 column with headline, age (yr) + pH |\r\n|          | mean surface d13c data for inversion | .csv | 2 column with headline, age (yr) + d13c |\r\n\r\n| Function | data to be smoothed | .csv | 2 column with headline, age (yr) + data |\r\n\r\n\r\n## Example\r\n(Required dataset could be downloaded [here](https://github.com/Shihan150/iloscar/tree/main/dat).)\r\n\r\n### 1. Benchmark\r\n\r\n1.1 Origninal PETM example from [Zeebe et al., 2009](https://www.nature.com/articles/ngeo578).\r\n\r\n    1. Go to the Forward page   \r\n\r\n![image](https://user-images.githubusercontent.com/57557675/232100195-e47c4d51-dbba-4b5b-a82a-b60cb3870703.png)\r\n\r\n    2. Turn the PALEO to '1'. Then the model parameters in Table 2 will adjust automatically to the palaeo settings, so skip the Step 2.\r\n\r\n![image](https://user-images.githubusercontent.com/57557675/232095753-3edcd6d7-9a06-49cd-85f8-ecf19c4fca94.png)\r\n\r\n    3. Select the carbon emission scenario in Table 3. In this example, set 'emission pattern' == 1, emission amount == 3000, 'd13c emission' == -55, 'emission start' == 0, 'emission duration' == 6000.\r\n\r\n![image](https://user-images.githubusercontent.com/57557675/232096837-51e2d08a-5f5c-48c5-b0dd-ac867f97327a.png)\r\n\r\n    4. Give a name to your experiment and run it. I name it as Zeebe2009 here.\r\n\r\n![image](https://user-images.githubusercontent.com/57557675/232097501-d03a8807-07e3-4e6f-bef9-ca7bb1eb8770.png)\r\n\r\n    5. The running information will be given in the following chunck. A progress bar is displayed to track the experiment running. \r\n\r\n![image](https://user-images.githubusercontent.com/57557675/232097903-6d2d0c27-6d90-464b-9359-8d42d0d9bded.png)\r\n\r\n    6. When integration finished, modeling results are saved to exp_name folder (Zeebe2009 here). The folder will be in the same dictionary where you run your python code. 44Modeling Mean surface DIC, ALK, pH and d13c, pCO2, and CCD for each ocean basin will be displayed when integration succeeds. \r\n\r\n![image](https://user-images.githubusercontent.com/57557675/232099371-c2bac20e-fd1c-4c16-8acb-88f4de7e7815.png)\r\n\r\n1.2 Inverse twin experiment \r\n\r\nTo test the performance of inverse algorithm, an identical twin test is performed. In identical twin testing, a preliminary run of the forward model is used to generate a synthetic 'truth' data set which can subsequently be used in inversion experiments. It is straightfoward to check whether the inverse algorithm works correctly. \r\n\r\n1. Preliminary run\r\n    * In Forward page, follow all the default settings in Table 1 and 2, except turn tfinal to 2e4.\r\n    * Set 'emission pattern' as 3 in Step 3 and input 'pulse_emi.dat' in second row of Table 4. Note that relative path is required for the file name. \r\n    * 'puluse_emi.dat'  two emission events: fast and short (3000 Gt in 3 kyr) vs slow and long (10000 Gt in 35 kyr), thus serving an excellent example to check the inversion algorithm.\r\n    * Name the model and run the experiment. \r\n    \r\n    ![image](https://user-images.githubusercontent.com/57557675/232114536-3d65cadb-fcea-45e9-9e52-c1cbb66c1bae.png)\r\n\r\n2. Prepare data for inversion\r\n    * At twin_exp folder, select the pCO2 results from pCO2_d13c.csv file and save as twin_pco2_for_inv.csv. Note that the modeling results are of high temporal resolution and we take a slice to keep the inversion time reasonable.\r\n    * Repeat the process for mean surface pH and surface d13C result.\r\n\r\n3. Inverse experiment (457.08s used)\r\n    * Navigate to the Inverse page. Select 'pCO2 + mean surface d13c' from the dropdown menu and input the target file names manually.\r\n    \r\n   ![image](https://user-images.githubusercontent.com/57557675/232131733-cedd0fb3-1246-43af-9c88-cb344e4517e0.png)\r\n    * Name the experiment and run the model.\r\n    * (If you meet an error similar to the following figure, which means some degassing rate is larger than the default higher boundary in Table 3. Try to adjust the values of second and third row in Table 3.)\r\n    \r\n    ![image](https://user-images.githubusercontent.com/57557675/232137441-c1a4c47b-5420-46a0-a88f-2f6841de7991.png)\r\n    \r\n    * Succeed! Note that when fcinp(t) = 0, inversed d13c may experience some fluctuation.\r\n![image](https://user-images.githubusercontent.com/57557675/232155210-c4b169b7-e0ba-49dd-a5e6-d061ef85e2b1.png)\r\n\r\n \r\n  \r\n\r\n### 2. Example\r\n\r\n2.1 [Gutjahr et al., 2017](https://www.nature.com/articles/nature23646#Tab1)\r\n\r\n1. Derive the steady state y0\r\n\r\n    * Navigate to the Forward page.\r\n    * In Table 1, set PALEO == 1, LOADFLAG == 0, Save ystart == 1\r\n    * In Table 2, set tfinal == 1e7, pCO2_ref == 834, pCO2_initial == 834, silicate weathering0 = 7.5, carbonate weathering0 = 17.5, d13c volcanic == -1.5\r\n    * In Table 4, input './gutjahr2017.dat' into the third row.\r\n    * Name the experiment and run the model.\r\n        \r\n2. Inversion experiment (878s)\r\n    * Navigate to the Inverse page.\r\n    * Download the 'Gutjahr_pH.csv' and 'Gutjahr_d13c.csv' from the [link](https://github.com/Shihan150/iloscar/tree/main/dat).\r\n    * In Table 1, set PALEO == 1, LOADFLAG == 1\r\n    * In Table 2, set pCO2_ref == 834, pCO2_initial == 834, silicate weathering0 = 7.5, carbonate weathering0 = 17.5, d13c volcanic == -1.5\r\n    * In Table 4, input './gutjahr2017.dat'\r\n    * Name the experiment and run the model\r\n    * Succeed! \r\n  \r\n        \r\n        \r\n3. Data interpretation\r\n    * Refer to [TBD]\r\n\r\n2.2 [Wu et al., 2023](https://www.science.org/doi/full/10.1126/sciadv.abq4082)\r\n\r\n1. Derive the steady state y0\r\n\r\n    * Navigate to the Forward page.\r\n    * In Table 1, set PALEO == 0, LOADFLAG == 0, Save ystart == 1\r\n    * In Table 2, set tfinal == 1e7, pCO2_ref == 425, pCO2_initial == 449, , fsh == 5, silicate weathering0 = 12, carbonate weathering0 = 17, d13c volcanic == -1.3, ca concentration == 0.013, mg concentration == 0.042\r\n    * In Table 4, input './wu2023.dat' into the third row.\r\n    * Name the experiment and run the model.\r\n        \r\n2. Inversion experiment (s)\r\n    * Navigate to the Inverse page.\r\n    * Download the 'wu_pco2.csv' and 'wu_d13c.csv' from the [link](https://github.com/Shihan150/iloscar/tree/main/dat).\r\n    * In Table 1, set PALEO == 0, LOADFLAG == 1\r\n    * In Table 2, set  pCO2_ref == 425, pCO2_initial == 449, fsh == 5, silicate weathering0 = 12, carbonate weathering0 = 17, d13c volcanic == -1.3, ca concentration == 0.013, mg concentration == 0.042, nsi == 0.3, ncc == 0.5\r\n    * In table 3, set lower and higher boundary as [-0.1, 1], which will accelerate the model\r\n    * In Table 4, input './wu2023.dat'\r\n    * Name the experiment and run the model\r\n    * Succeed! \r\n  ![image](https://user-images.githubusercontent.com/57557675/232583038-0837c29a-9568-4e22-8159-f001b92a6341.png)\r\n\r\n\r\n## Common bugs\r\n1. The age of target records must be in year unit.\r\n\r\n        \r\n        \r\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "iLOSCAR_win",
    "version": "0.1.7",
    "project_urls": {
        "Homepage": "https://github.com/Shihan150/iloscar"
    },
    "split_keywords": [
        "python",
        "carbon cycle",
        "model",
        "paleoclimate",
        "global warming",
        "loscar"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ac2d56f5d87c18961ea78abfbee4d17d72d6185174d8133d76f9ca018af703f5",
                "md5": "448d467e1c7a06ed7c5c24db51a9369b",
                "sha256": "ea518fc6c9c4b58bf01aaa517355c9051e57aa381357cab39c43ee2588a47e27"
            },
            "downloads": -1,
            "filename": "iloscar_win-0.1.7-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "448d467e1c7a06ed7c5c24db51a9369b",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">3.7, <3.11",
            "size": 49178,
            "upload_time": "2023-05-18T17:33:01",
            "upload_time_iso_8601": "2023-05-18T17:33:01.362601Z",
            "url": "https://files.pythonhosted.org/packages/ac/2d/56f5d87c18961ea78abfbee4d17d72d6185174d8133d76f9ca018af703f5/iloscar_win-0.1.7-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "66e1d9bc64c2b525f68742d41c2fbda2624f792dbc6e235380cbe9aed9121a16",
                "md5": "a53254506bc250bae6ccd658be148306",
                "sha256": "7c7796772c0d191f8422bcea7c72344a3b4237b7f29013fd63abf7d2aed32d63"
            },
            "downloads": -1,
            "filename": "iloscar_win-0.1.7.tar.gz",
            "has_sig": false,
            "md5_digest": "a53254506bc250bae6ccd658be148306",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">3.7, <3.11",
            "size": 52385,
            "upload_time": "2023-05-18T17:33:06",
            "upload_time_iso_8601": "2023-05-18T17:33:06.131410Z",
            "url": "https://files.pythonhosted.org/packages/66/e1/d9bc64c2b525f68742d41c2fbda2624f792dbc6e235380cbe9aed9121a16/iloscar_win-0.1.7.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-05-18 17:33:06",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "Shihan150",
    "github_project": "iloscar",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "iloscar-win"
}
        
Elapsed time: 1.84226s