diff options
Diffstat (limited to 'vignettes')
19 files changed, 972 insertions, 0 deletions
diff --git a/vignettes/.build.timestamp b/vignettes/.build.timestamp new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/vignettes/.build.timestamp diff --git a/vignettes/gmkin_manual.Rmd b/vignettes/gmkin_manual.Rmd new file mode 100644 index 0000000..ef40e75 --- /dev/null +++ b/vignettes/gmkin_manual.Rmd @@ -0,0 +1,387 @@ +<!-- +%\VignetteEngine{knitr::knitr} +%\VignetteIndexEntry{Manual for gmkin} +--> + +```{r, include = FALSE} +library(knitr) +opts_chunk$set(tidy = FALSE, cache = TRUE) +``` +# Manual for gmkin + +## Introduction + +The R add-on package gmkin provides a browser based graphical interface for +performing kinetic evaluations of degradation data using the mkin package. +While the use of gmkin should be largely self-explanatory, this manual may serve +as a functionality overview and reference. + +For system requirements and installation instructions, please refer to the +[gmkin homepage](http://kinfit.r-forge.r-project.org/gmkin_static) + +## Starting gmkin + +As gmkin is an R package, you need to start R and load the gmkin package before you can run gmkin. +This can be achieved by entering the command + +```{r, eval = FALSE} +library(gmkin) +``` + +into the R console. This will also load the packages that gmkin depends on, +most notably gWidgetsWWW2 and mkin. Loading the package only has to be done +once after you have started R. + +Before you start gmkin, you should make sure that R is using the working +directory that you would like to keep your gmkin project file(s) in. If you use +the standard R application on windows, you can change the working directory +from the File menu. + +Once you are sure that the working directory is what you want it to be, gmkin +can be started by entering the R command + +```{r, eval = FALSE} +gmkin() +``` + +This will cause the default browser to start up or, if it is already running, to +pop up and open a new tab for displaying the gmkin user interface. + +In the R console, you should see some messages, telling you if the local R help +server, which also serves the gmkin application, has been started, which port it is +using and that it is starting an app called gmkin. + +Finally, it should give a message like + +```{r, eval = FALSE} +Model cost at call 1: 2388.077 +``` + +which means that the first kinetic evaluation has been configured for fitting. + +In the browser, you should see something like the screenshot below. + +![gmkin start](img/gmkin_start.png) + +The statusbar at the bottom of the gmkin window shows, among others, the +working directory that gmkin uses. + +Note that the project file management area described below can be minimized by clicking on +the arrows on the right hand side of its title bar. This may be helpful if the vertical +size of your browser window is restricted. + +## Project file management + +At startup, gmkin loads a project called "FOCUS\_2006\_gmkin" which is distributed +with the gmkin package. A gmkin project contains datasets, kinetic models for +fitting, and so-called fits, i.e. the results of fitting models to data. These +gmkin projects can be saved and restored using the project file management area in the +top left. + +![projects](img/projects.png) + +If you would like to save these items for reference or for the purpose of continuing +your work at a later time, you can modify the project name and press the button below it. +The full name of the project file created and the working directory will be displayed +in the gmkin status bar. + +For restoring a previously saved project file, use the Browse button to locate +it, and the "Upload" button to load its contents into gmkin. + +## Studies + +The "Studies" area directly below the "Project file management" area can be expanded by clicking +on the arrows on the right hand side of its title bar. Studies in gmkin are +simply a numbered list of sources for the datasets in a project. You can edit the titles +directly by clicking on them. If you would like to add a new data source, use the "Add" +button above the table containing the list. If there are more than one studies in the list, +you can also remove them using the "Remove" button. + +![studies](img/studies.png) + +Note that the user is responsible to keep the study list consistent with the numbers that are +used in the list of datasets described below. + +## Datasets and Models +The project loaded at the start of gmkin contains two datasets and four kinetic models. These +are listed to the left under the heading "Datasets and Models", together with a button for +setting up fits as shown below. + +![datasets and models](img/datasetsnmodels.png) + +For editing, adding or removing datasets or models, you need to click on an +entry in the respective list. + +For setting up a fit of a specific model to a specific dataset, the model and +the dataset should be selected by clicking on them. If they are compatible, clicking +the button "Configure fit for selected dataset and model" will set up the fit and +open the "Plotting and Fitting" tab to the right. + +## Dataset editor + +The dataset editor allows for editing datasets, entering new datasets, uploading +data from text files and deleting datasets. + +![dataset editor](img/dataseteditor.png) + +If you want to create (enter or load) a new dataset, it is wise to first edit +the list of data sources in the "Studies" area as described above. + +### Entering data directly + +For entering new data manually, click on "New dataset", enter a title and select +the study from which the dataset is taken. At this stage, you may already want +to press "Keep changes", so the dataset appears in the list of datasets. + +In order to generate a table suitable for entering the data, enter a comma separated +list of sampling times, optionally the time unit, and the number of replicate measurements +at each sampling time. Also, add a comma separated list of short names of the +relevant compounds in your dataset. A unit can be specified for the observed +values. An example of filling out the respective fields is shown below. + +![generate data grid](img/generatedatagrid.png) + +Once everyting is filled out to your satisfaction, press the button "Generate empty grid +for kinetic data". In our example, this would result in the data grid shown below. You +can enter the observed data into the value column, as shown in the screenshot below. + +![data grid](img/datagrid.png) + +The column with title override serves to override data points from the original +datasets, without loosing the information which value was originally reported. + +If everything is OK, press "Keep changes" to save the dataset in the current +workspace. Note that you need to save the project file (see above) in order to +be able to use the dataset that you created in a future gmkin session. + +### Entering data directly + +In case you want to work with a larger dataset that is already available as a computer +file e.g. in a spreadsheet application, you can export these data as a tab separated +or comma separated text file and import it using the "Browse" and "Upload" buttons in the +dataset editor. + +As an example, we can create a text file from one of the datasets shipped with +the mkin package using the following R command: + +```{r, eval = FALSE} +write.table(schaefer07_complex_case, sep = ",", dec = ".", + row.names = FALSE, quote = FALSE, + file = "schaefer07.csv") +``` + +This produces a text file with comma separated values in the current working directory of R. + +Loading this text file into gmkin using the "Browse" and "Upload" buttons results in +an import configuration area like this, with the uploaded text file displayed to the left, +and the import options to the right. + +![upload area](img/uploadarea.png) + +In the import configuration area, the following options can be specified. In the field +"Comment lines", the number of lines in the beginning of the file that should be ignored +can be specified. + +The checkbox on the next line should be checked if the first line of the file contains +the column names, i.e. the names of the observed variables when the data are in wide format. + +As "Separator", whitespace, semicolon or comma can be chosen. If whitespace is selected, +files in which the values are separated by a fixed or varying number of whitespace characters +should be read in correctly. As the tabulator counts as a whitespace character, this is +also the option to choose for tabulator separated values. + +As the "Decimal" separator, comma "," or period "." can be selected. + +In the next line, it can be specified if the data are in wide or in long format. +If in wide format, the only option left to specify is the title of the column containing +the sampling times. If the data is in long format, the column headings specifying the +columns containing the observed variables (default is "name"), the sampling times +(default is "time"), the observed values (default is "value") and, if present in the data, +the relative errors (default is "err") can be adapted. The default settings appearing if +the long format is selected are shown below. + +![long](img/long.png) + +In our example we have data in the wide format, and after adapting the +"Separator" to a comma, we can press the button "Import using options specified +below", and the data should be imported. If successful, the data editor should +show the sampling times and the names of the observed variables, as well as the +imported data in a grid for further editing or specifying overrides. + +After editing the title of the dataset and selecting the correct study as +the source of the data, the dataset editor should look like shown below. + +![successful upload](img/successfulupload.png) + +If everything is OK, press "Keep changes" to save the dataset in the current +workspace. Again, you need to save the project file in order to be able to use +the dataset that you created in a future gmkin session. + +## Model editor + +The following screenshot shows the model editor for the model number 4 in +the list of models that are in the initial workspace. + +![model editor](img/modeleditor.png) + +In the first line the name of the model can be edited. You can also specify "min" or +"max" for minimum or maximum use of formation fractions. Maximum use of formation +fractions means that the differential equations in the degradation model are formulated +using formation fractions. When you specify "min", then formation fractions are only used +for the parent compound when you use the FOMC, DFOP or the HS model for it. + +Pressing "Copy model" keeps the model name, so you should change it for the newly generated copy. +Pressing "Add observed variable" adds a line in the array of state variable specifications below. +The observed variables to be added are usually transformation products (usually termed metabolites), +but can also be the parent compound in a different compartment (e.g. "parent\_sediment"). + +Only observed variable names that occur in previously defined datasets can be selected. For any observed +variable other than the first one, only the SFO or the SFORB model can be selected. For each +observed variables, a comma separated list of target variables can be specified. In addition, a pathway +to the sink compartment can be selected. If too many observed variables have been added, complete lines +can be removed from the model definition by pressing the button "Remove observed variable". + +If the model definition is supposedly correct, press "Keep changes" to make it possible to select +it for fitting in the listing of models to the left. + +## Plotting and fitting + +If the dataset(s) to be used in a project are created, and suitable kinetic models have been defined, +kinetic evaluations can be configured by selecting one dataset and one model in the lists to the left, +and the pressing the button "Configure fit for selected dataset and model" below these lists. + +This opens the "Plotting and fitting" tab area to the right, consisting of a graphical window +showing the data points in the selected dataset and the model, evaluated with the initial parameters +defined by calling `mkinfit` without defining starting parameters. The value of the objective function +to be minimized for these default parameters can be seen in the R console, e.g. as + +```{r, eval = FALSE} +Model cost at call 1: 15156.12 +``` + +for the example shown below, where the FOCUS example dataset D and the model SFO\_SFO were selected. + +![plotting and fitting](img/plottingnfitting.png) + +### Parameters + +In the right hand area, initially the tab with the parameter list is displayed. While +name and type of the parameters should not be edited, their initial values can be edited +by clicking on a row. Also, it can be specified if the parameters should be fixed +in the optimisation process. + +If the initial values for the parameters were changed, the resulting model solution +can be visually checked by pressing the button "Show initial". This will update the +plot of the model and the data using the specified initial parameter values. + +If a similar model with a partially overlapping model definition has already be fitted, +initial values for parameters with the same name in both models can also be retrieved +from previous fits. This facilitates stepwise fitting of more complex degradation pathways. + +After the model has been successfully fitted by pressing the "Run" button, the optimised +parameter values are added to the parameter table. + +### Fit options + +The most important fit options of the `mkinfit` function can be set via the +"Fit option" tab shown below. If the "plot" checkbox is checked, an R graphics device +started via the R console shows the fitting progress, i.e. the change of the model +solution together with the data during the optimisation. + +![fit options](img/fitoptions.png) + +The "solution\_type" can either be "auto", which means that the most effective solution +method is chosen for the model, in the order of "analytical" (for parent only degradation +data), "eigen" (for differential equation models with only linear terms, i.e. without +FOMC, DFOP or HS submodels) or "deSolve", which can handle all model definitions generated +by the `mkin` package. + +The parameters "atol" and "rtol" are only effective if the solution type is "deSolve". They +control the precision of the iterative numerical solution of the differential equation model. + +The checkboxes "transform\_rates" and "transform\_fractions" control if the parameters are fitted +as defined in the model, or if they are internally transformed during the fitting process in +order to improve the estimation of standard errors and confidence intervals which are based +on a linear approximation at the optimum found by the fitting algorithm. + +The dropdown box "weight" specifies if and how the observed values should be weighted +in the fitting process. If "manual" is chosen, the values in the "err" column of the +dataset are used, which are set to unity by default. Setting these to higher values +gives lower weight and vice versa. If "none" is chosen, observed +values are not weighted. Please refer to the documentation of the `modFit` function from +the `FME` package for the meaning of options "std" and "mean". + +The options "reweight.method", "reweight.tol" and "reweight.max.iter" enable the use of +iteratively reweighted least squares fitting, if the reweighting method is set to "obs". Please +refer to the `mkinfit` [documentation](http://kinfit.r-forge.r-project.org/mkin_static/mkinfit.html) +for more details. + +The drop down box "method.modFit" makes it possible to choose between the optimisation +algorithms "Marq" (the default Levenberg-Marquardt implementation from the R package +`minpack.lm`), "Port" (an alternative, also local optimisation algorithm) and +"SANN" (the simulated annealing method - robust but inefficient and without a +convergence criterion). + +Finally, the maximum number of iterations for the optimisation can be adapted using the +"maxit.modFit" field. + +### Fitting the model + +In many cases the starting parameters and the fit options do not need to be modified +and the model fitting process can simply be started by pressing the "Run" button. +In the R console, the progressive reduction in the model cost can be monitored and will +be displayed like this: + +```{r, eval = FALSE} +Model cost at call 1 : 15156.12 +Model cost at call 3 : 15156.12 +Model cost at call 7 : 14220.79 +Model cost at call 8 : 14220.79 +Model cost at call 11 : 14220.79 +Model cost at call 12 : 3349.268 +Model cost at call 15 : 3349.268 +Model cost at call 17 : 788.6367 +Model cost at call 18 : 788.6366 +Model cost at call 22 : 374.0575 +Model cost at call 23 : 374.0575 +Model cost at call 27 : 371.2135 +Model cost at call 28 : 371.2135 +Model cost at call 32 : 371.2134 +Model cost at call 36 : 371.2134 +Model cost at call 37 : 371.2134 +``` + +If plotting of the fitting progress was selecte in the "Fit options" tab, a +new separate graphics window should either pop up, or a graphics window previously +started for this purpose will be reused. + +### Summary + +Once a fit has successfully been performed by pressing the "Run" button, the summary +as displayed below can be accessed via the "Summary" tab. + +![summary](img/summary.png) + +The complete summary can be saved into a text file by specifying a suitable file name +and pressing the button "Save summary". + +### Plot options + +In the tab "Plot options", the observed variables for which the data and the model fit should be +plotted can be selected as shown below. + +![plot options](img/plotoptions.png) + +### Confidence interval plots + +Whenever a new fit has been configured or a run of a fit has been completed, the plotting +area is update with the abovementioned plot of the data and the current model solution. + +In addition, a confidence interval plot is shown below this conventional plot. In case +a fit has been run and confidence intervals were successfully calculated for the fit (i.e. +if the model was not overparameterised and no other problems occurred), the +confidence intervals are graphically displayed as bars as shown below. + +![conficence](img/confidence.png) + +<!-- vim: set foldmethod=syntax ts=2 sw=2 expandtab: --> diff --git a/vignettes/gmkin_manual.html b/vignettes/gmkin_manual.html new file mode 100644 index 0000000..e80ee3e --- /dev/null +++ b/vignettes/gmkin_manual.html @@ -0,0 +1,585 @@ +<!DOCTYPE html> +<html> +<head> +<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> + +<title>Manual for gmkin</title> + +<script type="text/javascript"> +window.onload = function() { + var imgs = document.getElementsByTagName('img'), i, img; + for (i = 0; i < imgs.length; i++) { + img = imgs[i]; + // center an image if it is the only element of its parent + if (img.parentElement.childElementCount === 1) + img.parentElement.style.textAlign = 'center'; + } +}; +</script> + +<!-- Styles for R syntax highlighter --> +<style type="text/css"> + pre .operator, + pre .paren { + color: rgb(104, 118, 135) + } + + pre .literal { + color: #990073 + } + + pre .number { + color: #099; + } + + pre .comment { + color: #998; + font-style: italic + } + + pre .keyword { + color: #900; + font-weight: bold + } + + pre .identifier { + color: rgb(0, 0, 0); + } + + pre .string { + color: #d14; + } +</style> + +<!-- R syntax highlighter --> +<script type="text/javascript"> +var hljs=new function(){function m(p){return p.replace(/&/gm,"&").replace(/</gm,"<")}function f(r,q,p){return RegExp(q,"m"+(r.cI?"i":"")+(p?"g":""))}function b(r){for(var p=0;p<r.childNodes.length;p++){var q=r.childNodes[p];if(q.nodeName=="CODE"){return q}if(!(q.nodeType==3&&q.nodeValue.match(/\s+/))){break}}}function h(t,s){var p="";for(var r=0;r<t.childNodes.length;r++){if(t.childNodes[r].nodeType==3){var q=t.childNodes[r].nodeValue;if(s){q=q.replace(/\n/g,"")}p+=q}else{if(t.childNodes[r].nodeName=="BR"){p+="\n"}else{p+=h(t.childNodes[r])}}}if(/MSIE [678]/.test(navigator.userAgent)){p=p.replace(/\r/g,"\n")}return p}function a(s){var r=s.className.split(/\s+/);r=r.concat(s.parentNode.className.split(/\s+/));for(var q=0;q<r.length;q++){var p=r[q].replace(/^language-/,"");if(e[p]){return p}}}function c(q){var p=[];(function(s,t){for(var r=0;r<s.childNodes.length;r++){if(s.childNodes[r].nodeType==3){t+=s.childNodes[r].nodeValue.length}else{if(s.childNodes[r].nodeName=="BR"){t+=1}else{if(s.childNodes[r].nodeType==1){p.push({event:"start",offset:t,node:s.childNodes[r]});t=arguments.callee(s.childNodes[r],t);p.push({event:"stop",offset:t,node:s.childNodes[r]})}}}}return t})(q,0);return p}function k(y,w,x){var q=0;var z="";var s=[];function u(){if(y.length&&w.length){if(y[0].offset!=w[0].offset){return(y[0].offset<w[0].offset)?y:w}else{return w[0].event=="start"?y:w}}else{return y.length?y:w}}function t(D){var A="<"+D.nodeName.toLowerCase();for(var B=0;B<D.attributes.length;B++){var C=D.attributes[B];A+=" "+C.nodeName.toLowerCase();if(C.value!==undefined&&C.value!==false&&C.value!==null){A+='="'+m(C.value)+'"'}}return A+">"}while(y.length||w.length){var v=u().splice(0,1)[0];z+=m(x.substr(q,v.offset-q));q=v.offset;if(v.event=="start"){z+=t(v.node);s.push(v.node)}else{if(v.event=="stop"){var p,r=s.length;do{r--;p=s[r];z+=("</"+p.nodeName.toLowerCase()+">")}while(p!=v.node);s.splice(r,1);while(r<s.length){z+=t(s[r]);r++}}}}return z+m(x.substr(q))}function j(){function q(x,y,v){if(x.compiled){return}var u;var s=[];if(x.k){x.lR=f(y,x.l||hljs.IR,true);for(var w in x.k){if(!x.k.hasOwnProperty(w)){continue}if(x.k[w] instanceof Object){u=x.k[w]}else{u=x.k;w="keyword"}for(var r in u){if(!u.hasOwnProperty(r)){continue}x.k[r]=[w,u[r]];s.push(r)}}}if(!v){if(x.bWK){x.b="\\b("+s.join("|")+")\\s"}x.bR=f(y,x.b?x.b:"\\B|\\b");if(!x.e&&!x.eW){x.e="\\B|\\b"}if(x.e){x.eR=f(y,x.e)}}if(x.i){x.iR=f(y,x.i)}if(x.r===undefined){x.r=1}if(!x.c){x.c=[]}x.compiled=true;for(var t=0;t<x.c.length;t++){if(x.c[t]=="self"){x.c[t]=x}q(x.c[t],y,false)}if(x.starts){q(x.starts,y,false)}}for(var p in e){if(!e.hasOwnProperty(p)){continue}q(e[p].dM,e[p],true)}}function d(B,C){if(!j.called){j();j.called=true}function q(r,M){for(var L=0;L<M.c.length;L++){if((M.c[L].bR.exec(r)||[null])[0]==r){return M.c[L]}}}function v(L,r){if(D[L].e&&D[L].eR.test(r)){return 1}if(D[L].eW){var M=v(L-1,r);return M?M+1:0}return 0}function w(r,L){return L.i&&L.iR.test(r)}function K(N,O){var M=[];for(var L=0;L<N.c.length;L++){M.push(N.c[L].b)}var r=D.length-1;do{if(D[r].e){M.push(D[r].e)}r--}while(D[r+1].eW);if(N.i){M.push(N.i)}return f(O,M.join("|"),true)}function p(M,L){var N=D[D.length-1];if(!N.t){N.t=K(N,E)}N.t.lastIndex=L;var r=N.t.exec(M);return r?[M.substr(L,r.index-L),r[0],false]:[M.substr(L),"",true]}function z(N,r){var L=E.cI?r[0].toLowerCase():r[0];var M=N.k[L];if(M&&M instanceof Array){return M}return false}function F(L,P){L=m(L);if(!P.k){return L}var r="";var O=0;P.lR.lastIndex=0;var M=P.lR.exec(L);while(M){r+=L.substr(O,M.index-O);var N=z(P,M);if(N){x+=N[1];r+='<span class="'+N[0]+'">'+M[0]+"</span>"}else{r+=M[0]}O=P.lR.lastIndex;M=P.lR.exec(L)}return r+L.substr(O,L.length-O)}function J(L,M){if(M.sL&&e[M.sL]){var r=d(M.sL,L);x+=r.keyword_count;return r.value}else{return F(L,M)}}function I(M,r){var L=M.cN?'<span class="'+M.cN+'">':"";if(M.rB){y+=L;M.buffer=""}else{if(M.eB){y+=m(r)+L;M.buffer=""}else{y+=L;M.buffer=r}}D.push(M);A+=M.r}function G(N,M,Q){var R=D[D.length-1];if(Q){y+=J(R.buffer+N,R);return false}var P=q(M,R);if(P){y+=J(R.buffer+N,R);I(P,M);return P.rB}var L=v(D.length-1,M);if(L){var O=R.cN?"</span>":"";if(R.rE){y+=J(R.buffer+N,R)+O}else{if(R.eE){y+=J(R.buffer+N,R)+O+m(M)}else{y+=J(R.buffer+N+M,R)+O}}while(L>1){O=D[D.length-2].cN?"</span>":"";y+=O;L--;D.length--}var r=D[D.length-1];D.length--;D[D.length-1].buffer="";if(r.starts){I(r.starts,"")}return R.rE}if(w(M,R)){throw"Illegal"}}var E=e[B];var D=[E.dM];var A=0;var x=0;var y="";try{var s,u=0;E.dM.buffer="";do{s=p(C,u);var t=G(s[0],s[1],s[2]);u+=s[0].length;if(!t){u+=s[1].length}}while(!s[2]);if(D.length>1){throw"Illegal"}return{r:A,keyword_count:x,value:y}}catch(H){if(H=="Illegal"){return{r:0,keyword_count:0,value:m(C)}}else{throw H}}}function g(t){var p={keyword_count:0,r:0,value:m(t)};var r=p;for(var q in e){if(!e.hasOwnProperty(q)){continue}var s=d(q,t);s.language=q;if(s.keyword_count+s.r>r.keyword_count+r.r){r=s}if(s.keyword_count+s.r>p.keyword_count+p.r){r=p;p=s}}if(r.language){p.second_best=r}return p}function i(r,q,p){if(q){r=r.replace(/^((<[^>]+>|\t)+)/gm,function(t,w,v,u){return w.replace(/\t/g,q)})}if(p){r=r.replace(/\n/g,"<br>")}return r}function n(t,w,r){var x=h(t,r);var v=a(t);var y,s;if(v){y=d(v,x)}else{return}var q=c(t);if(q.length){s=document.createElement("pre");s.innerHTML=y.value;y.value=k(q,c(s),x)}y.value=i(y.value,w,r);var u=t.className;if(!u.match("(\\s|^)(language-)?"+v+"(\\s|$)")){u=u?(u+" "+v):v}if(/MSIE [678]/.test(navigator.userAgent)&&t.tagName=="CODE"&&t.parentNode.tagName=="PRE"){s=t.parentNode;var p=document.createElement("div");p.innerHTML="<pre><code>"+y.value+"</code></pre>";t=p.firstChild.firstChild;p.firstChild.cN=s.cN;s.parentNode.replaceChild(p.firstChild,s)}else{t.innerHTML=y.value}t.className=u;t.result={language:v,kw:y.keyword_count,re:y.r};if(y.second_best){t.second_best={language:y.second_best.language,kw:y.second_best.keyword_count,re:y.second_best.r}}}function o(){if(o.called){return}o.called=true;var r=document.getElementsByTagName("pre");for(var p=0;p<r.length;p++){var q=b(r[p]);if(q){n(q,hljs.tabReplace)}}}function l(){if(window.addEventListener){window.addEventListener("DOMContentLoaded",o,false);window.addEventListener("load",o,false)}else{if(window.attachEvent){window.attachEvent("onload",o)}else{window.onload=o}}}var e={};this.LANGUAGES=e;this.highlight=d;this.highlightAuto=g;this.fixMarkup=i;this.highlightBlock=n;this.initHighlighting=o;this.initHighlightingOnLoad=l;this.IR="[a-zA-Z][a-zA-Z0-9_]*";this.UIR="[a-zA-Z_][a-zA-Z0-9_]*";this.NR="\\b\\d+(\\.\\d+)?";this.CNR="\\b(0[xX][a-fA-F0-9]+|(\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)";this.BNR="\\b(0b[01]+)";this.RSR="!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|\\.|-|-=|/|/=|:|;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~";this.ER="(?![\\s\\S])";this.BE={b:"\\\\.",r:0};this.ASM={cN:"string",b:"'",e:"'",i:"\\n",c:[this.BE],r:0};this.QSM={cN:"string",b:'"',e:'"',i:"\\n",c:[this.BE],r:0};this.CLCM={cN:"comment",b:"//",e:"$"};this.CBLCLM={cN:"comment",b:"/\\*",e:"\\*/"};this.HCM={cN:"comment",b:"#",e:"$"};this.NM={cN:"number",b:this.NR,r:0};this.CNM={cN:"number",b:this.CNR,r:0};this.BNM={cN:"number",b:this.BNR,r:0};this.inherit=function(r,s){var p={};for(var q in r){p[q]=r[q]}if(s){for(var q in s){p[q]=s[q]}}return p}}();hljs.LANGUAGES.cpp=function(){var a={keyword:{"false":1,"int":1,"float":1,"while":1,"private":1,"char":1,"catch":1,"export":1,virtual:1,operator:2,sizeof:2,dynamic_cast:2,typedef:2,const_cast:2,"const":1,struct:1,"for":1,static_cast:2,union:1,namespace:1,unsigned:1,"long":1,"throw":1,"volatile":2,"static":1,"protected":1,bool:1,template:1,mutable:1,"if":1,"public":1,friend:2,"do":1,"return":1,"goto":1,auto:1,"void":2,"enum":1,"else":1,"break":1,"new":1,extern:1,using:1,"true":1,"class":1,asm:1,"case":1,typeid:1,"short":1,reinterpret_cast:2,"default":1,"double":1,register:1,explicit:1,signed:1,typename:1,"try":1,"this":1,"switch":1,"continue":1,wchar_t:1,inline:1,"delete":1,alignof:1,char16_t:1,char32_t:1,constexpr:1,decltype:1,noexcept:1,nullptr:1,static_assert:1,thread_local:1,restrict:1,_Bool:1,complex:1},built_in:{std:1,string:1,cin:1,cout:1,cerr:1,clog:1,stringstream:1,istringstream:1,ostringstream:1,auto_ptr:1,deque:1,list:1,queue:1,stack:1,vector:1,map:1,set:1,bitset:1,multiset:1,multimap:1,unordered_set:1,unordered_map:1,unordered_multiset:1,unordered_multimap:1,array:1,shared_ptr:1}};return{dM:{k:a,i:"</",c:[hljs.CLCM,hljs.CBLCLM,hljs.QSM,{cN:"string",b:"'\\\\?.",e:"'",i:"."},{cN:"number",b:"\\b(\\d+(\\.\\d*)?|\\.\\d+)(u|U|l|L|ul|UL|f|F)"},hljs.CNM,{cN:"preprocessor",b:"#",e:"$"},{cN:"stl_container",b:"\\b(deque|list|queue|stack|vector|map|set|bitset|multiset|multimap|unordered_map|unordered_set|unordered_multiset|unordered_multimap|array)\\s*<",e:">",k:a,r:10,c:["self"]}]}}}();hljs.LANGUAGES.r={dM:{c:[hljs.HCM,{cN:"number",b:"\\b0[xX][0-9a-fA-F]+[Li]?\\b",e:hljs.IMMEDIATE_RE,r:0},{cN:"number",b:"\\b\\d+(?:[eE][+\\-]?\\d*)?L\\b",e:hljs.IMMEDIATE_RE,r:0},{cN:"number",b:"\\b\\d+\\.(?!\\d)(?:i\\b)?",e:hljs.IMMEDIATE_RE,r:1},{cN:"number",b:"\\b\\d+(?:\\.\\d*)?(?:[eE][+\\-]?\\d*)?i?\\b",e:hljs.IMMEDIATE_RE,r:0},{cN:"number",b:"\\.\\d+(?:[eE][+\\-]?\\d*)?i?\\b",e:hljs.IMMEDIATE_RE,r:1},{cN:"keyword",b:"(?:tryCatch|library|setGeneric|setGroupGeneric)\\b",e:hljs.IMMEDIATE_RE,r:10},{cN:"keyword",b:"\\.\\.\\.",e:hljs.IMMEDIATE_RE,r:10},{cN:"keyword",b:"\\.\\.\\d+(?![\\w.])",e:hljs.IMMEDIATE_RE,r:10},{cN:"keyword",b:"\\b(?:function)",e:hljs.IMMEDIATE_RE,r:2},{cN:"keyword",b:"(?:if|in|break|next|repeat|else|for|return|switch|while|try|stop|warning|require|attach|detach|source|setMethod|setClass)\\b",e:hljs.IMMEDIATE_RE,r:1},{cN:"literal",b:"(?:NA|NA_integer_|NA_real_|NA_character_|NA_complex_)\\b",e:hljs.IMMEDIATE_RE,r:10},{cN:"literal",b:"(?:NULL|TRUE|FALSE|T|F|Inf|NaN)\\b",e:hljs.IMMEDIATE_RE,r:1},{cN:"identifier",b:"[a-zA-Z.][a-zA-Z0-9._]*\\b",e:hljs.IMMEDIATE_RE,r:0},{cN:"operator",b:"<\\-(?!\\s*\\d)",e:hljs.IMMEDIATE_RE,r:2},{cN:"operator",b:"\\->|<\\-",e:hljs.IMMEDIATE_RE,r:1},{cN:"operator",b:"%%|~",e:hljs.IMMEDIATE_RE},{cN:"operator",b:">=|<=|==|!=|\\|\\||&&|=|\\+|\\-|\\*|/|\\^|>|<|!|&|\\||\\$|:",e:hljs.IMMEDIATE_RE,r:0},{cN:"operator",b:"%",e:"%",i:"\\n",r:1},{cN:"identifier",b:"`",e:"`",r:0},{cN:"string",b:'"',e:'"',c:[hljs.BE],r:0},{cN:"string",b:"'",e:"'",c:[hljs.BE],r:0},{cN:"paren",b:"[[({\\])}]",e:hljs.IMMEDIATE_RE,r:0}]}}; +hljs.initHighlightingOnLoad(); +</script> + + + +<style type="text/css"> +body, td { + font-family: sans-serif; + background-color: white; + font-size: 13px; +} + +body { + max-width: 800px; + margin: auto; + padding: 1em; + line-height: 20px; +} + +tt, code, pre { + font-family: 'DejaVu Sans Mono', 'Droid Sans Mono', 'Lucida Console', Consolas, Monaco, monospace; +} + +h1 { + font-size:2.2em; +} + +h2 { + font-size:1.8em; +} + +h3 { + font-size:1.4em; +} + +h4 { + font-size:1.0em; +} + +h5 { + font-size:0.9em; +} + +h6 { + font-size:0.8em; +} + +a:visited { + color: rgb(50%, 0%, 50%); +} + +pre, img { + max-width: 100%; +} +pre { + overflow-x: auto; +} +pre code { + display: block; padding: 0.5em; +} + +code { + font-size: 92%; + border: 1px solid #ccc; +} + +code[class] { + background-color: #F8F8F8; +} + +table, td, th { + border: none; +} + +blockquote { + color:#666666; + margin:0; + padding-left: 1em; + border-left: 0.5em #EEE solid; +} + +hr { + height: 0px; + border-bottom: none; + border-top-width: thin; + border-top-style: dotted; + border-top-color: #999999; +} + +@media print { + * { + background: transparent !important; + color: black !important; + filter:none !important; + -ms-filter: none !important; + } + + body { + font-size:12pt; + max-width:100%; + } + + a, a:visited { + text-decoration: underline; + } + + hr { + visibility: hidden; + page-break-before: always; + } + + pre, blockquote { + padding-right: 1em; + page-break-inside: avoid; + } + + tr, img { + page-break-inside: avoid; + } + + img { + max-width: 100% !important; + } + + @page :left { + margin: 15mm 20mm 15mm 10mm; + } + + @page :right { + margin: 15mm 10mm 15mm 20mm; + } + + p, h2, h3 { + orphans: 3; widows: 3; + } + + h2, h3 { + page-break-after: avoid; + } +} +</style> + + + +</head> + +<body> +<!-- +%\VignetteEngine{knitr::knitr} +%\VignetteIndexEntry{Manual for gmkin} +--> + +<h1>Manual for gmkin</h1> + +<h2>Introduction</h2> + +<p>The R add-on package gmkin provides a browser based graphical interface for +performing kinetic evaluations of degradation data using the mkin package. +While the use of gmkin should be largely self-explanatory, this manual may serve +as a functionality overview and reference.</p> + +<p>For system requirements and installation instructions, please refer to the +<a href="http://kinfit.r-forge.r-project.org/gmkin_static">gmkin homepage</a></p> + +<h2>Starting gmkin</h2> + +<p>As gmkin is an R package, you need to start R and load the gmkin package before you can run gmkin. +This can be achieved by entering the command</p> + +<pre><code class="r">library(gmkin) +</code></pre> + +<p>into the R console. This will also load the packages that gmkin depends on, +most notably gWidgetsWWW2 and mkin. Loading the package only has to be done +once after you have started R. </p> + +<p>Before you start gmkin, you should make sure that R is using the working +directory that you would like to keep your gmkin project file(s) in. If you use +the standard R application on windows, you can change the working directory +from the File menu.</p> + +<p>Once you are sure that the working directory is what you want it to be, gmkin +can be started by entering the R command</p> + +<pre><code class="r">gmkin() +</code></pre> + +<p>This will cause the default browser to start up or, if it is already running, to +pop up and open a new tab for displaying the gmkin user interface.</p> + +<p>In the R console, you should see some messages, telling you if the local R help +server, which also serves the gmkin application, has been started, which port it is +using and that it is starting an app called gmkin.</p> + +<p>Finally, it should give a message like</p> + +<pre><code class="r">Model cost at call 1: 2388.077 +</code></pre> + +<p>which means that the first kinetic evaluation has been configured for fitting.</p> + +<p>In the browser, you should see something like the screenshot below.</p> + +<p><img src="" alt="gmkin start"/></p> + +<p>The statusbar at the bottom of the gmkin window shows, among others, the +working directory that gmkin uses.</p> + +<p>Note that the project file management area described below can be minimized by clicking on +the arrows on the right hand side of its title bar. This may be helpful if the vertical +size of your browser window is restricted.</p> + +<h2>Project file management</h2> + +<p>At startup, gmkin loads a project called “FOCUS_2006_gmkin” which is distributed +with the gmkin package. A gmkin project contains datasets, kinetic models for +fitting, and so-called fits, i.e. the results of fitting models to data. These +gmkin projects can be saved and restored using the project file management area in the +top left.</p> + +<p><img src="" alt="projects"/></p> + +<p>If you would like to save these items for reference or for the purpose of continuing +your work at a later time, you can modify the project name and press the button below it. +The full name of the project file created and the working directory will be displayed +in the gmkin status bar.</p> + +<p>For restoring a previously saved project file, use the Browse button to locate +it, and the “Upload” button to load its contents into gmkin.</p> + +<h2>Studies</h2> + +<p>The “Studies” area directly below the “Project file management” area can be expanded by clicking +on the arrows on the right hand side of its title bar. Studies in gmkin are +simply a numbered list of sources for the datasets in a project. You can edit the titles +directly by clicking on them. If you would like to add a new data source, use the “Add” +button above the table containing the list. If there are more than one studies in the list, +you can also remove them using the “Remove” button.</p> + +<p><img src="" alt="studies"/></p> + +<p>Note that the user is responsible to keep the study list consistent with the numbers that are +used in the list of datasets described below.</p> + +<h2>Datasets and Models</h2> + +<p>The project loaded at the start of gmkin contains two datasets and four kinetic models. These +are listed to the left under the heading “Datasets and Models”, together with a button for +setting up fits as shown below.</p> + +<p><img src="" alt="datasets and models"/></p> + +<p>For editing, adding or removing datasets or models, you need to click on an +entry in the respective list. </p> + +<p>For setting up a fit of a specific model to a specific dataset, the model and +the dataset should be selected by clicking on them. If they are compatible, clicking +the button “Configure fit for selected dataset and model” will set up the fit and +open the “Plotting and Fitting” tab to the right.</p> + +<h2>Dataset editor</h2> + +<p>The dataset editor allows for editing datasets, entering new datasets, uploading +data from text files and deleting datasets.</p> + +<p><img src="" alt="dataset editor"/></p> + +<p>If you want to create (enter or load) a new dataset, it is wise to first edit +the list of data sources in the “Studies” area as described above.</p> + +<h3>Entering data directly</h3> + +<p>For entering new data manually, click on “New dataset”, enter a title and select +the study from which the dataset is taken. At this stage, you may already want +to press “Keep changes”, so the dataset appears in the list of datasets.</p> + +<p>In order to generate a table suitable for entering the data, enter a comma separated +list of sampling times, optionally the time unit, and the number of replicate measurements +at each sampling time. Also, add a comma separated list of short names of the +relevant compounds in your dataset. A unit can be specified for the observed +values. An example of filling out the respective fields is shown below.</p> + +<p><img src="" alt="generate data grid"/></p> + +<p>Once everyting is filled out to your satisfaction, press the button “Generate empty grid +for kinetic data”. In our example, this would result in the data grid shown below. You +can enter the observed data into the value column, as shown in the screenshot below.</p> + +<p><img src="" alt="data grid"/></p> + +<p>The column with title override serves to override data points from the original +datasets, without loosing the information which value was originally reported.</p> + +<p>If everything is OK, press “Keep changes” to save the dataset in the current +workspace. Note that you need to save the project file (see above) in order to +be able to use the dataset that you created in a future gmkin session.</p> + +<h3>Entering data directly</h3> + +<p>In case you want to work with a larger dataset that is already available as a computer +file e.g. in a spreadsheet application, you can export these data as a tab separated +or comma separated text file and import it using the “Browse” and “Upload” buttons in the +dataset editor.</p> + +<p>As an example, we can create a text file from one of the datasets shipped with +the mkin package using the following R command:</p> + +<pre><code class="r">write.table(schaefer07_complex_case, sep = ",", dec = ".", + row.names = FALSE, quote = FALSE, + file = "schaefer07.csv") +</code></pre> + +<p>This produces a text file with comma separated values in the current working directory of R. </p> + +<p>Loading this text file into gmkin using the “Browse” and “Upload” buttons results in +an import configuration area like this, with the uploaded text file displayed to the left, +and the import options to the right.</p> + +<p><img src="" alt="upload area"/></p> + +<p>In the import configuration area, the following options can be specified. In the field +“Comment lines”, the number of lines in the beginning of the file that should be ignored +can be specified.</p> + +<p>The checkbox on the next line should be checked if the first line of the file contains +the column names, i.e. the names of the observed variables when the data are in wide format.</p> + +<p>As “Separator”, whitespace, semicolon or comma can be chosen. If whitespace is selected, +files in which the values are separated by a fixed or varying number of whitespace characters +should be read in correctly. As the tabulator counts as a whitespace character, this is +also the option to choose for tabulator separated values.</p> + +<p>As the “Decimal” separator, comma “,” or period “.” can be selected.</p> + +<p>In the next line, it can be specified if the data are in wide or in long format. +If in wide format, the only option left to specify is the title of the column containing +the sampling times. If the data is in long format, the column headings specifying the +columns containing the observed variables (default is “name”), the sampling times +(default is “time”), the observed values (default is “value”) and, if present in the data, +the relative errors (default is “err”) can be adapted. The default settings appearing if +the long format is selected are shown below.</p> + +<p><img src="" alt="long"/></p> + +<p>In our example we have data in the wide format, and after adapting the +“Separator” to a comma, we can press the button “Import using options specified +below”, and the data should be imported. If successful, the data editor should +show the sampling times and the names of the observed variables, as well as the +imported data in a grid for further editing or specifying overrides.</p> + +<p>After editing the title of the dataset and selecting the correct study as +the source of the data, the dataset editor should look like shown below.</p> + +<p><img src="" alt="successful upload"/></p> + +<p>If everything is OK, press “Keep changes” to save the dataset in the current +workspace. Again, you need to save the project file in order to be able to use +the dataset that you created in a future gmkin session.</p> + +<h2>Model editor</h2> + +<p>The following screenshot shows the model editor for the model number 4 in +the list of models that are in the initial workspace.</p> + +<p><img src="" alt="model editor"/></p> + +<p>In the first line the name of the model can be edited. You can also specify “min” or +“max” for minimum or maximum use of formation fractions. Maximum use of formation +fractions means that the differential equations in the degradation model are formulated +using formation fractions. When you specify “min”, then formation fractions are only used +for the parent compound when you use the FOMC, DFOP or the HS model for it.</p> + +<p>Pressing “Copy model” keeps the model name, so you should change it for the newly generated copy. +Pressing “Add observed variable” adds a line in the array of state variable specifications below. +The observed variables to be added are usually transformation products (usually termed metabolites), +but can also be the parent compound in a different compartment (e.g. “parent_sediment”).</p> + +<p>Only observed variable names that occur in previously defined datasets can be selected. For any observed +variable other than the first one, only the SFO or the SFORB model can be selected. For each +observed variables, a comma separated list of target variables can be specified. In addition, a pathway +to the sink compartment can be selected. If too many observed variables have been added, complete lines +can be removed from the model definition by pressing the button “Remove observed variable”.</p> + +<p>If the model definition is supposedly correct, press “Keep changes” to make it possible to select +it for fitting in the listing of models to the left.</p> + +<h2>Plotting and fitting</h2> + +<p>If the dataset(s) to be used in a project are created, and suitable kinetic models have been defined, +kinetic evaluations can be configured by selecting one dataset and one model in the lists to the left, +and the pressing the button “Configure fit for selected dataset and model” below these lists.</p> + +<p>This opens the “Plotting and fitting” tab area to the right, consisting of a graphical window +showing the data points in the selected dataset and the model, evaluated with the initial parameters +defined by calling <code>mkinfit</code> without defining starting parameters. The value of the objective function +to be minimized for these default parameters can be seen in the R console, e.g. as</p> + +<pre><code class="r">Model cost at call 1: 15156.12 +</code></pre> + +<p>for the example shown below, where the FOCUS example dataset D and the model SFO_SFO were selected.</p> + +<p><img src="" alt="plotting and fitting"/></p> + +<h3>Parameters</h3> + +<p>In the right hand area, initially the tab with the parameter list is displayed. While +name and type of the parameters should not be edited, their initial values can be edited +by clicking on a row. Also, it can be specified if the parameters should be fixed +in the optimisation process. </p> + +<p>If the initial values for the parameters were changed, the resulting model solution +can be visually checked by pressing the button “Show initial”. This will update the +plot of the model and the data using the specified initial parameter values.</p> + +<p>If a similar model with a partially overlapping model definition has already be fitted, +initial values for parameters with the same name in both models can also be retrieved +from previous fits. This facilitates stepwise fitting of more complex degradation pathways.</p> + +<p>After the model has been successfully fitted by pressing the “Run” button, the optimised +parameter values are added to the parameter table.</p> + +<h3>Fit options</h3> + +<p>The most important fit options of the <code>mkinfit</code> function can be set via the +“Fit option” tab shown below. If the “plot” checkbox is checked, an R graphics device +started via the R console shows the fitting progress, i.e. the change of the model +solution together with the data during the optimisation.</p> + +<p><img src="" alt="fit options"/></p> + +<p>The “solution_type” can either be “auto”, which means that the most effective solution +method is chosen for the model, in the order of “analytical” (for parent only degradation +data), “eigen” (for differential equation models with only linear terms, i.e. without +FOMC, DFOP or HS submodels) or “deSolve”, which can handle all model definitions generated +by the <code>mkin</code> package.</p> + +<p>The parameters “atol” and “rtol” are only effective if the solution type is “deSolve”. They +control the precision of the iterative numerical solution of the differential equation model.</p> + +<p>The checkboxes “transform_rates” and “transform_fractions” control if the parameters are fitted +as defined in the model, or if they are internally transformed during the fitting process in +order to improve the estimation of standard errors and confidence intervals which are based +on a linear approximation at the optimum found by the fitting algorithm.</p> + +<p>The dropdown box “weight” specifies if and how the observed values should be weighted +in the fitting process. If “manual” is chosen, the values in the “err” column of the +dataset are used, which are set to unity by default. Setting these to higher values +gives lower weight and vice versa. If “none” is chosen, observed +values are not weighted. Please refer to the documentation of the <code>modFit</code> function from +the <code>FME</code> package for the meaning of options “std” and “mean”.</p> + +<p>The options “reweight.method”, “reweight.tol” and “reweight.max.iter” enable the use of +iteratively reweighted least squares fitting, if the reweighting method is set to “obs”. Please +refer to the <code>mkinfit</code> <a href="http://kinfit.r-forge.r-project.org/mkin_static/mkinfit.html">documentation</a> +for more details.</p> + +<p>The drop down box “method.modFit” makes it possible to choose between the optimisation +algorithms “Marq” (the default Levenberg-Marquardt implementation from the R package +<code>minpack.lm</code>), “Port” (an alternative, also local optimisation algorithm) and +“SANN” (the simulated annealing method - robust but inefficient and without a +convergence criterion).</p> + +<p>Finally, the maximum number of iterations for the optimisation can be adapted using the +“maxit.modFit” field.</p> + +<h3>Fitting the model</h3> + +<p>In many cases the starting parameters and the fit options do not need to be modified +and the model fitting process can simply be started by pressing the “Run” button. +In the R console, the progressive reduction in the model cost can be monitored and will +be displayed like this:</p> + +<pre><code class="r">Model cost at call 1 : 15156.12 +Model cost at call 3 : 15156.12 +Model cost at call 7 : 14220.79 +Model cost at call 8 : 14220.79 +Model cost at call 11 : 14220.79 +Model cost at call 12 : 3349.268 +Model cost at call 15 : 3349.268 +Model cost at call 17 : 788.6367 +Model cost at call 18 : 788.6366 +Model cost at call 22 : 374.0575 +Model cost at call 23 : 374.0575 +Model cost at call 27 : 371.2135 +Model cost at call 28 : 371.2135 +Model cost at call 32 : 371.2134 +Model cost at call 36 : 371.2134 +Model cost at call 37 : 371.2134 +</code></pre> + +<p>If plotting of the fitting progress was selecte in the “Fit options” tab, a +new separate graphics window should either pop up, or a graphics window previously +started for this purpose will be reused.</p> + +<h3>Summary</h3> + +<p>Once a fit has successfully been performed by pressing the “Run” button, the summary +as displayed below can be accessed via the “Summary” tab.</p> + +<p><img src="" alt="summary"/></p> + +<p>The complete summary can be saved into a text file by specifying a suitable file name +and pressing the button “Save summary”.</p> + +<h3>Plot options</h3> + +<p>In the tab “Plot options”, the observed variables for which the data and the model fit should be +plotted can be selected as shown below.</p> + +<p><img src="" alt="plot options"/></p> + +<h3>Confidence interval plots</h3> + +<p>Whenever a new fit has been configured or a run of a fit has been completed, the plotting +area is update with the abovementioned plot of the data and the current model solution.</p> + +<p>In addition, a confidence interval plot is shown below this conventional plot. In case +a fit has been run and confidence intervals were successfully calculated for the fit (i.e. +if the model was not overparameterised and no other problems occurred), the +confidence intervals are graphically displayed as bars as shown below.</p> + +<p><img src="" alt="conficence"/></p> + +<!-- vim: set foldmethod=syntax ts=2 sw=2 expandtab: --> + +</body> + +</html> diff --git a/vignettes/img/confidence.png b/vignettes/img/confidence.png Binary files differnew file mode 100644 index 0000000..4cf929b --- /dev/null +++ b/vignettes/img/confidence.png diff --git a/vignettes/img/datagrid.png b/vignettes/img/datagrid.png Binary files differnew file mode 100644 index 0000000..b44ce27 --- /dev/null +++ b/vignettes/img/datagrid.png diff --git a/vignettes/img/dataseteditor.png b/vignettes/img/dataseteditor.png Binary files differnew file mode 100644 index 0000000..1c51374 --- /dev/null +++ b/vignettes/img/dataseteditor.png diff --git a/vignettes/img/datasetsnmodels.png b/vignettes/img/datasetsnmodels.png Binary files differnew file mode 100644 index 0000000..411424a --- /dev/null +++ b/vignettes/img/datasetsnmodels.png diff --git a/vignettes/img/fitoptions.png b/vignettes/img/fitoptions.png Binary files differnew file mode 100644 index 0000000..0a76040 --- /dev/null +++ b/vignettes/img/fitoptions.png diff --git a/vignettes/img/generatedatagrid.png b/vignettes/img/generatedatagrid.png Binary files differnew file mode 100644 index 0000000..04d29c4 --- /dev/null +++ b/vignettes/img/generatedatagrid.png diff --git a/vignettes/img/gmkin_start.png b/vignettes/img/gmkin_start.png Binary files differnew file mode 100644 index 0000000..13c3613 --- /dev/null +++ b/vignettes/img/gmkin_start.png diff --git a/vignettes/img/long.png b/vignettes/img/long.png Binary files differnew file mode 100644 index 0000000..0a13a9a --- /dev/null +++ b/vignettes/img/long.png diff --git a/vignettes/img/modeleditor.png b/vignettes/img/modeleditor.png Binary files differnew file mode 100644 index 0000000..d5d9941 --- /dev/null +++ b/vignettes/img/modeleditor.png diff --git a/vignettes/img/plotoptions.png b/vignettes/img/plotoptions.png Binary files differnew file mode 100644 index 0000000..4dcf025 --- /dev/null +++ b/vignettes/img/plotoptions.png diff --git a/vignettes/img/plottingnfitting.png b/vignettes/img/plottingnfitting.png Binary files differnew file mode 100644 index 0000000..de7b5c1 --- /dev/null +++ b/vignettes/img/plottingnfitting.png diff --git a/vignettes/img/projects.png b/vignettes/img/projects.png Binary files differnew file mode 100644 index 0000000..eb7af8b --- /dev/null +++ b/vignettes/img/projects.png diff --git a/vignettes/img/studies.png b/vignettes/img/studies.png Binary files differnew file mode 100644 index 0000000..e73ac3e --- /dev/null +++ b/vignettes/img/studies.png diff --git a/vignettes/img/successfulupload.png b/vignettes/img/successfulupload.png Binary files differnew file mode 100644 index 0000000..62464f3 --- /dev/null +++ b/vignettes/img/successfulupload.png diff --git a/vignettes/img/summary.png b/vignettes/img/summary.png Binary files differnew file mode 100644 index 0000000..7d0cb15 --- /dev/null +++ b/vignettes/img/summary.png diff --git a/vignettes/img/uploadarea.png b/vignettes/img/uploadarea.png Binary files differnew file mode 100644 index 0000000..87b793a --- /dev/null +++ b/vignettes/img/uploadarea.png |