aboutsummaryrefslogtreecommitdiff
path: root/inst
diff options
context:
space:
mode:
authorJohannes Ranke <jranke@uni-bremen.de>2015-10-22 17:30:09 +0200
committerJohannes Ranke <jranke@uni-bremen.de>2015-10-22 17:30:09 +0200
commitc737c606058cb4c2a0805e2bec8ce356d01a627a (patch)
tree39da39d3868144fd8103386ed31fcccb09c73164 /inst
parentd1fe83f2f1a9c0d775b0dc8f18301a8bbb454077 (diff)
A lot of working components of the new layout
Diffstat (limited to 'inst')
-rw-r--r--inst/GUI/gmkin.R1370
-rw-r--r--inst/GUI/gmkin_manual.html233
-rw-r--r--inst/GUI/gmkin_workflow_434x569.pngbin0 -> 43317 bytes
-rw-r--r--inst/GUI/gmkin_workflow_inkscape.svg556
4 files changed, 1132 insertions, 1027 deletions
diff --git a/inst/GUI/gmkin.R b/inst/GUI/gmkin.R
index 7fef7a1..0b615c4 100644
--- a/inst/GUI/gmkin.R
+++ b/inst/GUI/gmkin.R
@@ -1,12 +1,12 @@
# gWidgetsWWW2 GUI for mkin {{{1
-# Copyright (C) 2013,2014 Johannes Ranke
+# Copyright (C) 2013,2014,2015 Johannes Ranke
# Portions of this file are copyright (C) 2013 Eurofins Regulatory AG, Switzerland
# Contact: jranke@uni-bremen.de
-# This file is part of the R package mkin
+# This file is part of the R package gmkin
-# mkin is free software: you can redistribute it and/or modify it under the
+# gmkin is free software: you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later
# version.
@@ -20,1061 +20,377 @@
# this program. If not, see <http://www.gnu.org/licenses/>
# Set the GUI title and create the basic widget layout {{{1
-w <- gwindow("gmkin - Browser based GUI for kinetic evaluations using mkin")
-sb <- gstatusbar(paste("Powered by gWidgetsWWW2 (ExtJS, Rook)",
- "and mkin (FME, deSolve and minpack.lm)",
- "--- Working directory is", getwd()), cont = w)
-pg <- gpanedgroup(cont = w, default.size = 260)
-center <- gnotebook(cont = pg)
-left <- gvbox(cont = pg, use.scrollwindow = TRUE)
-# Set initial values {{{1
-# Initial project workspace contents {{{2
-project_name <- "FOCUS_2006_gmkin"
-project_file <- paste0(project_name, ".RData")
-workspace <- get(project_name) # From dataset distributed with mkin
-studies.df <- workspace$studies.df # dataframe containing study titles
-ds <- workspace$ds # list of datasets
-ds.cur <- workspace$ds.cur # current dataset index
-m <- workspace$m # list with mkinmod models, amended with mkinmod$name
-m.cur <- workspace$m.cur # m.cur current model index
-f <- workspace$f # f list of fitted mkinfit objects
-f.cur <- workspace$f.cur # current fit index
-s <- workspace$s # list of summaries of the fitted mkinfit objects
-# Initialise meta data objects so assignments within functions using <<- will {{{2
-# update them in the right environment
-observed.all <- vector() # vector of names of observed variables in datasets
-ds.df <- data.frame()
-m.df <- data.frame()
-f.df <- data.frame()
-# Empty versions of meta data {{{2
-f.df.empty <- data.frame(Fit = as.integer(0),
- Dataset = "",
- Model = "",
- stringsAsFactors = FALSE)
+# Configuration {{{2
+left_width = 250
+right_width = 500
+save_keybinding = "Ctrl-X"
+# Widgets {{{2
+window_title <- paste0("gmkin ", packageVersion("gmkin"),
+ "- Browser based GUI for kinetic evaluations using mkin")
+w <- gwindow(window_title)
+sb <- gstatusbar(paste("Powered by gWidgetsWWW2 (ExtJS, Rook)",
+ "and mkin (FME, deSolve and minpack.lm)",
+ "--- Working directory is", getwd()), cont = w)
+
+bl <- gborderlayout(cont = w,
+ #title = list(center = "Work", east = "Results"),
+ panels = c("center", "west", "east"),
+ collapsible = list(west = FALSE))
+
+bl$set_panel_size("west", left_width)
+bl$set_panel_size("east", right_width)
+
+center <- gnotebook(cont = bl, where = "center")
+left <- gvbox(cont = bl, use.scrollwindow = TRUE, where = "west")
+right <- gnotebook(cont = bl, use.scrollwindow = TRUE, where = "east")
+
# Helper functions {{{1
# Override function for making it possible to override original data points using the GUI {{{2
override <- function(d) {
- data.frame(name = d$name, time = d$time,
- value = ifelse(is.na(d$override), d$value, d$override),
- err = d$err)
+ if (!is.null(d$override)) {
+ d_new <- data.frame(name = d$name, time = d$time,
+ value = ifelse(is.na(d$override), d$value, d$override),
+ err = d$err)
+ return(d_new)
+ } else {
+ return(d)
+ }
+}
+# Update dataframe with projects {{{2
+update_p.df <- function() {
+ wd_projects <- gsub(".gmkinws", "", dir(pattern = ".gmkinws$"))
+ if (length(wd_projects) > 0) {
+ p.df.wd <- data.frame(Name = wd_projects,
+ Source = rep("working directory",
+ length(wd_projects)),
+ stringsAsFactors = FALSE)
+ p.df <<- rbind(p.df.package, p.df.wd)
+ } else {
+ p.df <<- p.df.package
+ }
}
# Update dataframe with datasets {{{2
update_ds.df <- function() {
- ds.n <- length(ds)
- ds.df <<- data.frame(Index = 1:ds.n,
- Title = character(ds.n),
- Study = character(ds.n),
- stringsAsFactors = FALSE)
- for (i in 1:ds.n)
- {
- ds.index <- names(ds)[[i]]
- ds.df[i, "Title"] <<- ds[[ds.index]]$title
- ds.df[i, "Study"] <<- ds[[ds.index]]$study_nr
- observed = as.character(unique(ds[[ds.index]]$data$name))
- observed.all <<- union(observed, observed.all)
- }
+ ds.df <<- data.frame(Title = sapply(ws$ds, function(x) x$title))
}
# Update dataframe with models {{{2
update_m.df <- function() {
- m.n <- length(m)
- m.df <<- data.frame(Index = 1:m.n,
- Name = character(m.n),
- stringsAsFactors = FALSE)
- for (i in 1:m.n) {
- m.index <- names(m)[[i]]
- m.df[i, "Name"] <<- m[[m.index]]$name
- }
+ m.df <<- data.frame(Name = names(ws$m))
}
# Update dataframe with fits {{{2
update_f.df <- function() {
- f.df <<- f.df.empty
- f.count <- 0
- for (fit.index in names(f)) {
- f.count <- f.count + 1
- ftmp <- f[[fit.index]]
- f.df[f.count, "Fit"] <<- as.integer(f.count)
- f.df[f.count, c("Dataset", "Model")] <<- c(ftmp$ds.index, ftmp$mkinmod$name)
- }
-}
-# Initialise meta data objects {{{1
-update_ds.df()
-update_m.df()
-update_f.df()
-# Widgets and handlers for project data {{{1
-prg <- gexpandgroup("Project file management", cont = left, horizontal = FALSE)
-# Project data management handler functions {{{2
-upload_file_handler <- function(h, ...)
-{
- # General
- tmpfile <- normalizePath(svalue(h$obj), winslash = "/")
- project_file <<- pr.gf$filename
- project_name <<- try(load(tmpfile))
- if (inherits(project_name, "try-error")) {
- galert(paste("Failed to load", project_file), parent = w)
- }
-
- workspace <- get(project_name)
-
- # Check for old workspaces created using mkin < 0.9-32 that aren't loaded properly
- workspace_old <- FALSE
- if (length(workspace$f) > 0) {
- if (is.null(workspace$f[[1]]$method.modFit)) {
- stopmessage <- paste("Could not load workspace ",
- project_file,
- ". It seems it was created using mkin with version < 0.9-32",
- sep = "")
- galert(stopmessage, parent = w)
- svalue(sb) <- stopmessage
- workspace_old <- TRUE
- }
+ f.df <- f.df.empty
+ if (!is.na(ftmp[1])) {
+ f.df[1, "Name"] <- c("Temporary (not fitted)")
}
-
- if (!workspace_old) {
- # Update project file name and status bar
- svalue(pr.ge) <- project_name
- svalue(sb) <- paste("Loaded project file", project_file)
-
- # Studies
- studies.gdf[,] <- studies.df <- workspace$studies.df
-
- # Datasets
- ds.cur <<- workspace$ds.cur
- ds <<- workspace$ds
- update_ds.df()
- ds.gtable[,] <- ds.df
- update_ds_editor()
-
- # Models
- m.cur <<- workspace$m.cur
- m <<- workspace$m
- update_m.df()
- m.gtable[,] <- m.df
- update_m_editor()
-
- # Fits
- f.cur <<- workspace$f.cur
- f <<- workspace$f
- s <<- workspace$s
- if (length(f) > 0) {
- update_f.df()
- ftmp <<- f[[f.cur]]
- stmp <<- s[[f.cur]]
- ds.i <<- ds.cur
- delete(f.gg.plotopts, f.gg.po.obssel)
- f.gg.po.obssel <<- gcheckboxgroup(names(ftmp$mkinmod$spec), cont = f.gg.plotopts,
- checked = TRUE)
- update_plotting_and_fitting()
- } else {
- f.df <<- f.df.empty
- update_ds_editor()
- svalue(center) <- 1
- }
- f.gtable[,] <- f.df
+ if (!is.na(ws$f)) {
+ f.df.ws <- data.frame(Name = names(ws$f), stringsAsFactors = FALSE)
+ f.df <- rbind(f.df, f.df.ws)
}
+ f.df <<- f.df
}
-save_to_file_handler <- function(h, ...)
-{
- studies.df <- data.frame(studies.gdf[,], stringsAsFactors = FALSE)
- workspace <- list(
- studies.df = studies.df,
-
- ds = ds,
- ds.cur = ds.cur,
-
- m = m,
- m.cur = m.cur,
-
- f = f,
- f.cur = f.cur,
-
- s = s)
- assign(project_name, workspace)
- save(list = project_name, file = project_file)
- svalue(sb) <- paste("Saved project contents to", project_file, "in working directory", getwd())
-}
-change_project_name_handler = function(h, ...) {
- project_name <<- as.character(svalue(h$obj))
- project_file <<- paste0(project_name, ".RData")
-}
-# Project data management GUI elements {{{2
-pr.gf <- gfile(text = "Select project file", cont = prg,
- handler = upload_file_handler)
-pr.ge <- gedit(project_name, cont = prg, label = "Project",
- handler = change_project_name_handler)
-# The save button is always visible {{{2
-gbutton("Save current project contents", cont = left,
- handler = save_to_file_handler)
-
-# Widget and handler for Studies {{{1
-stg <- gexpandgroup("Studies", cont = left)
-visible(stg) <- FALSE
-update_study_selector <- function(h, ...) {
- delete(ds.e.1, ds.study.gc)
- ds.study.gc <<- gcombobox(paste("Study", studies.gdf[,1]), cont = ds.e.1)
- svalue(ds.study.gc, index = TRUE) <- ds[[ds.cur]]$study_nr
-}
-studies.gdf <- gdf(studies.df, name = "Edit studies in the project",
- width = 235,
- height = 180, cont = stg)
-studies.gdf$set_column_width(1, 40)
-addHandlerChanged(studies.gdf, update_study_selector)
-# Widgets and handlers for datasets and models {{{1
-dsm <- gframe("Datasets and models", cont = left, horizontal = FALSE)
-# Widget for dataset table with handler {{{2
-ds.switcher <- function(h, ...) {
- ds.cur <<- as.character(svalue(h$obj))
- update_ds_editor()
+# Generate the initial workspace {{{1
+ws <- gmkinws$new()
+ws.import <- NA
+# Initialise meta data objects so assignments within functions using <<- will {{{2
+# update them in the right environment.
+# Also create initial versions of meta data in order to be able to clear the workspace
+p.df <- p.df.package <- data.frame(Name = c("FOCUS_2006", "FOCUS_2006_Z"),
+ Source = rep("gmkin package", 2), stringsAsFactors = FALSE)
+
+update_p.df()
+ds.df <- ds.df.empty <- data.frame(Title = "", stringsAsFactors = FALSE)
+m.df <- m.df.empty <- data.frame(Name = "", stringsAsFactors = FALSE)
+f.df <- f.df.empty <- data.frame(Name = "", stringsAsFactors = FALSE)
+ftmp <- NA
+# left: Explorer tables {{{1
+# Frames {{{2
+p.gf <- gframe("Projects", cont = left, horizontal = FALSE)
+ds.gf <- gframe("Datasets", cont = left)
+m.gf <- gframe("Models", cont = left)
+c.gf <- gframe("Configuration", cont = left, horizontal = FALSE)
+f.gf <- gframe("Results", cont = left)
+
+# Project explorer {{{2
+# Initialize project list from the gmkin package and the current working directory
+# The former must be manually amended if additional workspaces should be available
+p.gtable <- gtable(p.df, cont = p.gf, width = left_width - 10, height = 120)
+size(p.gtable) <- list(columnWidths = c(130, 100))
+p.switcher <- function(h, ...) {
+ p.cur <- h$row_index
+ Name <- p.df[p.cur, "Name"]
+ if (p.df[p.cur, "Source"] == "working directory") {
+ load(paste0(Name, ".gmkinws"))
+ ws <<- ws
+ } else {
+ ws <<- get(Name)
+ }
svalue(center) <- 1
+ svalue(c.ds) <- empty_conf_labels[1]
+ svalue(c.m) <- empty_conf_labels[2]
+ update_p_editor(p.cur)
+ update_ds.df()
+ ds.gtable[,] <<- ds.df
+ update_m.df()
+ m.gtable[,] <<- m.df
+ update_f.df()
+ f.gtable[,] <<- f.df
}
-ds.gtable <- gtable(ds.df, cont = dsm)
-addHandlerDoubleClick(ds.gtable, ds.switcher)
-size(ds.gtable) <- list(columnWidths = c(40, 150, 30))
-ds.gtable$value <- 1
-
-# Model table with handler {{{2
-m.switcher <- function(h, ...) {
- m.cur <<- as.character(svalue(h$obj))
- update_m_editor()
+addHandlerClicked(p.gtable, p.switcher)
+# Dataset explorer {{{2
+ds.switcher <- function(h, ...) {
+ ws$ds.cur <<- h$row_index
+ svalue(c.ds) <- ds.df[ws$ds.cur, "Title"]
+ #update_ds_editor()
svalue(center) <- 2
}
-m.gtable <- gtable(m.df, cont = dsm)
-addHandlerDoubleClick(m.gtable, m.switcher)
-m.gtable$set_column_width(1, 40)
-m.gtable$value <- 1
-
-# Button for setting up a fit for the selected dataset and model {{{2
-configure_fit_handler = function(h, ...) {
- ds.i <<- as.character(svalue(ds.gtable))
- m.i <<- as.character(svalue(m.gtable))
- ftmp <<- suppressWarnings(mkinfit(m[[m.i]],
- override(ds[[ds.i]]$data),
- method.modFit = "Marq",
- err = "err",
- control.modFit = list(maxiter = 0)))
- ftmp$ds.index <<- ds.i
- ftmp$ds <<- ds[[ds.i]]
- stmp <<- summary(ftmp)
- svalue(pf) <- paste0("Dataset ", ds.i, ", Model ", m[[m.i]]$name)
- svalue(f.gg.opts.plot) <<- FALSE
- svalue(f.gg.opts.st) <<- ftmp$solution_type
- svalue(f.gg.opts.weight) <<- ftmp$weight
- svalue(f.gg.opts.atol) <<- ftmp$atol
- svalue(f.gg.opts.rtol) <<- ftmp$rtol
- svalue(f.gg.opts.transform_rates) <<- ftmp$transform_rates
- svalue(f.gg.opts.transform_fractions) <<- ftmp$transform_fractions
- svalue(f.gg.opts.reweight.method) <<- ifelse(
- is.null(ftmp$reweight.method),
- "none", ftmp$reweight.method)
- svalue(f.gg.opts.reweight.tol) <<- ftmp$reweight.tol
- svalue(f.gg.opts.reweight.max.iter) <<- ftmp$reweight.max.iter
- svalue(f.gg.opts.method.modFit) <<- "Port"
- svalue(f.gg.opts.maxit.modFit) <<- ftmp$maxit.modFit
- f.gg.parms[,] <- get_Parameters(stmp, FALSE)
- delete(f.gg.plotopts, f.gg.po.obssel)
- f.gg.po.obssel <<- gcheckboxgroup(names(ftmp$mkinmod$spec), cont = f.gg.plotopts,
- checked = TRUE)
- show_plot("Initial", default = TRUE)
- svalue(plot.ftmp.savefile) <<- paste(ftmp$ds$title, "_", ftmp$mkinmod$name,
- ".", plot_format, sep = "")
- oldwidth <<- options()$width
- options(width = 90)
- svalue(f.gg.summary.filename) <<- ""
- svalue(f.gg.summary.listing) <<- c("<pre>", capture.output(stmp), "</pre>")
- options(width = oldwidth)
- svalue(center) <- 3
+ds.gtable <- gtable(ds.df, cont = ds.gf, width = left_width - 10, height = 160)
+addHandlerClicked(ds.gtable, ds.switcher)
+# Model explorer {{{2
+m.switcher <- function(h, ...) {
+ ws$m.cur <<- h$row_index
+ svalue(c.m) <- m.df[ws$m.cur, "Name"]
+ #update_m_editor()
+ svalue(center) <- 3
}
-gbutton("Configure fit for selected model and dataset", cont = dsm,
- handler = configure_fit_handler)
-
-# Widget and handler for fits {{{1
-f.gf <- gframe("Fits", cont = left, horizontal = FALSE)
+m.gtable <- gtable(m.df, cont = m.gf, width = left_width - 10, height = 160)
+addHandlerClicked(m.gtable, m.switcher)
+# Fit explorer {{{2
f.switcher <- function(h, ...) {
- if (svalue(h$obj) != 0) {
- f.cur <<- svalue(h$obj)
- ftmp <<- f[[f.cur]]
- stmp <<- s[[f.cur]]
- ds.i <<- ftmp$ds.index
- update_plotting_and_fitting()
+ ws$f.cur <<- h$row_index - 1
+ if (ws$f.cur > 0) {
+ ftmp <<- ws$f[[ws$f.cur]]
+ stmp <<- ws$s[[ws$f.cur]]
+ c.ds$call_Ext("setText",
+ paste0("<font color='gray'>", ftmp$ds$title, "</font>"), FALSE)
+ c.m$call_Ext("setText",
+ paste0("<font color='gray'>", ftmp$m$name, "</font>"), FALSE)
}
- svalue(center) <- 3
-}
-f.gtable <- gtable(f.df, cont = f.gf)
-addHandlerDoubleClick(f.gtable, f.switcher)
-f.gtable$set_column_width(1, 40)
-f.gtable$set_column_width(2, 60)
-
-# Dataset editor {{{1
-ds.editor <- gframe("Dataset 1", horizontal = FALSE, cont = center,
- label = "Dataset editor")
-# Handler functions {{{2
-ds.empty <- list(
- study_nr = 1,
- title = "",
- sampling_times = c(0, 1),
- time_unit = "",
- observed = "parent",
- unit = "",
- replicates = 1,
- data = data.frame(
- name = "parent",
- time = c(0, 1),
- value = c(100, NA),
- override = "NA",
- err = 1,
- stringsAsFactors = FALSE))
-
-copy_dataset_handler <- function(h, ...) {
- ds.old <- ds.cur
- ds.cur <<- as.character(1 + length(ds))
- svalue(ds.editor) <- paste("Dataset", ds.cur)
- ds[[ds.cur]] <<- ds[[ds.old]]
- update_ds.df()
- ds.gtable[,] <- ds.df
-}
-
-delete_dataset_handler <- function(h, ...) {
- if (length(ds) > 1) {
- ds[[ds.cur]] <<- NULL
- names(ds) <<- as.character(1:length(ds))
- ds.cur <<- names(ds)[[1]]
- update_ds.df()
- ds.gtable[,] <- ds.df
- update_ds_editor()
+ #update_f_conf()
+ #update_f_results()
+ svalue(center) <- 5
+}
+f.gtable <- gtable(f.df, cont = f.gf, width = left_width - 10, height = 160)
+addHandlerClicked(f.gtable, f.switcher)
+# Configuration {{{2
+empty_conf_labels <- paste0("<font color='gray'>Current ", c("dataset", "model"), "</font>")
+c.ds <- glabel(empty_conf_labels[1], cont = c.gf)
+c.m <- glabel(empty_conf_labels[2], cont = c.gf)
+c.conf <- gbutton("Configure fit", cont = c.gf, handler = function(h, ...) svalue(center) <- 4)
+# center: Project editor {{{1
+p.editor <- gframe("", horizontal = FALSE, cont = center,
+ label = "Project")
+# Working directory {{{2
+p.line.wd <- ggroup(cont = p.editor, horizontal = TRUE)
+wd_handler <- function(h, ...) {
+ target_wd <- svalue(p.wde)
+ wd <- try(setwd(target_wd))
+ if (inherits(wd, "try-error")) {
+ gmessage(paste("Could not set working directory to", target_wd), parent = w)
+ } else {
+ svalue(sb) <- paste("Changed working directory to", wd)
+ update_p.df()
+ p.gtable[,] <- p.df
+ p.line.import.p[,] <- c("", p.df$Name)
+ }
+}
+p.wde <- gedit(getwd(), cont = p.line.wd, label = "Working directory", width = 50)
+p.wde$add_handler_enter(wd_handler)
+p.wdb <- gbutton("Change", cont = p.line.wd, handler = wd_handler)
+tooltip(p.wdb) <- "Edit the box on the left and press enter to change"
+# Project name {{{2
+p.line.name <- ggroup(cont = p.editor, horizontal = TRUE)
+p.name <- gedit("New project", label = "Project name",
+ width = 50, cont = p.line.name)
+p.save <- gaction("Save", parent = w,
+ handler = function(h, ...) {
+ filename <- paste0(svalue(p.name), ".gmkinws")
+ try_to_save <- function (filename) {
+ if (!inherits(try(save(ws, file = filename)),
+ "try-error")) {
+ svalue(sb) <- paste("Saved project to file", filename,
+ "in working directory", getwd())
+ update_p.df()
+ p.gtable[,] <- p.df
+ } else {
+ gmessage("Saving failed for an unknown reason", parent = w)
+ }
+ }
+ if (file.exists(filename)) {
+ gconfirm(paste("File", filename, "exists. Overwrite?"),
+ parent = w,
+ handler = function(h, ...) {
+ try_to_save(filename)
+ })
+ } else {
+ try_to_save(filename)
+ }
+ })
+p.save.button <- gbutton(action = p.save, cont = p.line.name)
+p.save$add_keybinding(save_keybinding)
+tooltip(p.save.button) <- paste("Press", save_keybinding, "to save")
+
+update_p_editor <- function(p.cur) {
+ project_name <- as.character(p.df[p.cur, "Name"])
+ svalue(p.name) <- project_name
+ if (p.df[p.cur, "Source"] == "gmkin package") {
+ svalue(p.filename) <- ""
+ p.delete$call_Ext("disable")
} else {
- galert("Deleting the last dataset is not supported", parent = w)
+ svalue(p.filename) <- file.path(getwd(), paste0(project_name, ".gmkinws"))
+ p.delete$call_Ext("enable")
}
}
-
-new_dataset_handler <- function(h, ...) {
- ds.cur <<- as.character(1 + length(ds))
- ds[[ds.cur]] <<- ds.empty
- update_ds.df()
- ds.gtable[,] <- ds.df
- update_ds_editor()
-}
-
-tmptextheader <- character(0)
-load_text_file_with_data <- function(h, ...) {
- tmptextfile <<- normalizePath(svalue(h$obj), winslash = "/")
- tmptext <- readLines(tmptextfile, warn = FALSE)
- tmptextskip <<- 0
- for (tmptextline in tmptext) {
- if (grepl(":|#|/", tmptextline)) tmptextskip <<- tmptextskip + 1
- else break()
- }
- svalue(ds.e.up.skip) <- tmptextskip
- if (svalue(ds.e.up.header)) {
- tmptextheader <<- strsplit(tmptext[tmptextskip + 1],
- " |\t|;|,")[[1]]
- }
- svalue(ds.e.up.wide.time) <- tmptextheader[[1]]
- svalue(ds.e.up.long.time) <- tmptextheader[[2]]
- svalue(ds.e.up.text) <- c("<pre>", tmptext, "</pre>")
- svalue(ds.e.stack) <- 2
-}
-
-new_ds_from_csv_handler <- function(h, ...) {
- tmpd <- try(read.table(tmptextfile,
- skip = as.numeric(svalue(ds.e.up.skip)),
- dec = svalue(ds.e.up.dec),
- sep = switch(svalue(ds.e.up.sep),
- whitespace = "",
- ";" = ";",
- "," = ","),
- header = svalue(ds.e.up.header),
- stringsAsFactors = FALSE))
- if(svalue(ds.e.up.widelong) == "wide") {
- tmpdl <- mkin_wide_to_long(tmpd, time = as.character(svalue(ds.e.up.wide.time)))
- } else {
- tmpdl <- data.frame(
- name = tmpd[[svalue(ds.e.up.long.name)]],
- time = tmpd[[svalue(ds.e.up.long.time)]],
- value = tmpd[[svalue(ds.e.up.long.value)]])
- tmpderr <- tmpd[[svalue(ds.e.up.long.err)]]
- if (!is.null(tmpderr)) tmpdl$err <- tmpderr
- }
- if (class(tmpd) != "try-error") {
- ds.cur <<- as.character(1 + length(ds))
- ds[[ds.cur]] <<- list(
- study_nr = NA,
- title = "New import",
- sampling_times = sort(unique(tmpdl$time)),
- time_unit = "",
- observed = unique(tmpdl$name),
- unit = "",
- replicates = max(aggregate(tmpdl$time,
- list(tmpdl$time,
- tmpdl$name),
- length)$x),
- data = tmpdl)
- ds[[ds.cur]]$data$override <<- as.numeric(NA)
- if (is.null(ds[[ds.cur]]$data$err)) ds[[ds.cur]]$data$err <<- 1
+# File name {{{2
+p.line.file <- ggroup(cont = p.editor, horizontal = TRUE)
+p.filename.gg <- ggroup(width = 400, cont = p.line.file)
+p.filename <- glabel("", cont = p.filename.gg)
+p.delete.handler = function(h, ...) {
+ filename <- file.path(getwd(), paste0(svalue(p.name), ".gmkinws"))
+ gconfirm(paste0("Are you sure you want to delete ", filename, "?"),
+ parent = w,
+ handler = function(h, ...) {
+ if (inherits(try(unlink(filename)), "try-error")) {
+ gmessage("Deleting failed for an unknown reason", cont = w)
+ } else {
+ svalue(sb) <- paste("Deleted", filename)
+ svalue(p.filename) <- ""
+ p.delete$call_Ext("disable")
+ update_p.df()
+ p.gtable[,] <- p.df
+ }
+ })
+}
+p.delete <- gbutton("Delete", cont = p.line.file,
+ handler = p.delete.handler)
+p.delete$call_Ext("disable")
+# Import {{{2
+p.line.import <- ggroup(cont = p.editor, horizontal = TRUE)
+p.line.import.p <- gcombobox(c("", p.df$Name), label = "Import from", cont = p.line.import,
+ handler = function(h, ...) {
+ p.import <- svalue(h$obj, index = TRUE) - 1
+ Name <- p.df[p.import, "Name"]
+ if (p.df[p.import, "Source"] == "working directory") {
+ load(paste0(Name, ".gmkinws"))
+ ws.import <<- ws
+ } else {
+ ws.import <<- get(Name)
+ }
+ p.line.import.dst[,] <- data.frame(Title = sapply(ws.import$ds, function(x) x$title),
+ stringsAsFactors = FALSE)
+ p.line.import.mt[,] <- data.frame(Name = names(ws.import$m),
+ stringsAsFactors = FALSE)
+ })
+p.line.import.frames <- ggroup(cont = p.editor, horizontal = TRUE)
+
+p.line.import.dsf <- gframe("Datasets for import", cont = p.line.import.frames, horizontal = FALSE)
+p.line.import.dst <- gtable(ds.df.empty, cont = p.line.import.dsf, multiple = TRUE,
+ width = left_width - 10, height = 160)
+p.line.import.dsb <- gbutton("Import selected", cont = p.line.import.dsf,
+ handler = function(h, ...) {
+ i <- svalue(p.line.import.dst, index = TRUE)
+ ws$ds <<- append(ws$ds, ws.import$ds[i])
update_ds.df()
ds.gtable[,] <- ds.df
- update_ds_editor()
- } else {
- galert("Uploading failed", parent = "w")
}
-}
-
-empty_grid_handler <- function(h, ...) {
- obs <- strsplit(svalue(ds.e.obs), ", ")[[1]]
- sampling_times <- strsplit(svalue(ds.e.st), ", ")[[1]]
- replicates <- as.numeric(svalue(ds.e.rep))
- new.data = data.frame(
- name = rep(obs, each = replicates * length(sampling_times)),
- time = as.numeric(rep(sampling_times, each = replicates, times = length(obs))),
- value = as.numeric(NA),
- override = as.numeric(NA),
- err = 1,
- stringsAsFactors = FALSE
- )
- ds.e.gdf[,] <- new.data
-}
-
-keep_ds_changes_handler <- function(h, ...) {
- ds[[ds.cur]]$title <<- svalue(ds.title.ge)
- ds[[ds.cur]]$study_nr <<- as.numeric(gsub("Study ", "", svalue(ds.study.gc)))
- update_ds.df()
- ds.gtable[,] <- ds.df
- tmpd <- ds.e.gdf[,]
- ds[[ds.cur]]$data <<- tmpd
- ds[[ds.cur]]$sampling_times <<- sort(unique(tmpd$time))
- ds[[ds.cur]]$time_unit <<- svalue(ds.e.stu)
- ds[[ds.cur]]$observed <<- unique(tmpd$name)
- ds[[ds.cur]]$unit <<- svalue(ds.e.obu)
- ds[[ds.cur]]$replicates <<- max(aggregate(tmpd$time,
- list(tmpd$time, tmpd$name), length)$x)
- update_ds_editor()
- observed.all <<- union(observed.all, ds[[ds.cur]]$observed)
- update_m_editor()
-}
-
-# Widget setup {{{2
-# Line 1 {{{3
-ds.e.1 <- ggroup(cont = ds.editor, horizontal = TRUE)
-glabel("Title: ", cont = ds.e.1)
-ds.title.ge <- gedit(ds[[ds.cur]]$title, cont = ds.e.1)
-glabel(" from ", cont = ds.e.1)
-ds.study.gc <- gcombobox(paste("Study", studies.gdf[,1]), cont = ds.e.1)
-
-# Line 2 {{{3
-ds.e.2 <- ggroup(cont = ds.editor, horizontal = TRUE)
-ds.e.2a <- ggroup(cont = ds.e.2, horizontal = FALSE)
-gbutton("Copy dataset", cont = ds.e.2a, handler = copy_dataset_handler)
-gbutton("Delete dataset", cont = ds.e.2a, handler = delete_dataset_handler)
-gbutton("New dataset", cont = ds.e.2a, handler = new_dataset_handler)
-
-ds.e.2b <- ggroup(cont = ds.e.2)
-tmptextfile <- "" # Initialize file name for imported data
-tmptextskip <- 0 # Initialize number of lines to be skipped
-tmptexttime <- "V1" # Initialize name of time variable if no header row
-upload_dataset.gf <- gfile(text = "Upload text file", cont = ds.e.2b,
- handler = load_text_file_with_data)
-
-gbutton("Keep changes", cont = ds.e.2, handler = keep_ds_changes_handler)
-
-# Line 3 with forms or upload area {{{3
-ds.e.stack <- gstackwidget(cont = ds.editor)
-# Forms for meta data {{{4
-ds.e.forms <- ggroup(cont = ds.e.stack, horizontal = TRUE)
-
-ds.e.3a <- gvbox(cont = ds.e.forms)
-ds.e.3a.gfl <- gformlayout(cont = ds.e.3a)
-ds.e.st <- gedit(paste(ds[[ds.cur]]$sampling_times, collapse = ", "),
- width = 40,
- label = "Sampling times",
- cont = ds.e.3a.gfl)
-ds.e.stu <- gedit(ds[[ds.cur]]$time_unit,
- width = 20,
- label = "Unit", cont = ds.e.3a.gfl)
-ds.e.rep <- gedit(ds[[ds.cur]]$replicates,
- width = 20,
- label = "Replicates", cont = ds.e.3a.gfl)
-
-ds.e.3b <- gvbox(cont = ds.e.forms)
-ds.e.3b.gfl <- gformlayout(cont = ds.e.3b)
-ds.e.obs <- gedit(paste(ds[[ds.cur]]$observed, collapse = ", "),
- width = 50,
- label = "Observed", cont = ds.e.3b.gfl)
-ds.e.obu <- gedit(ds[[ds.cur]]$unit,
- width = 20, label = "Unit",
- cont = ds.e.3b.gfl)
-generate_grid.gb <- gbutton("Generate empty grid for kinetic data", cont = ds.e.3b,
- handler = empty_grid_handler)
-tooltip(generate_grid.gb) <- "Overwrites the kinetic data shown below"
-# Data upload area {{{4
-ds.e.upload <- ggroup(cont = ds.e.stack, horizontal = TRUE)
-ds.e.up.text <- ghtml("<pre></pre>", cont = ds.e.upload, width = 400, height = 400)
-ds.e.up.options <- ggroup(cont = ds.e.upload, horizontal = FALSE)
-ds.e.up.import <- gbutton("Import using options specified below", cont = ds.e.up.options,
- handler = new_ds_from_csv_handler)
-ds.e.up.skip <- gedit(tmptextskip, label = "Comment lines", cont = ds.e.up.options)
-ds.e.up.header <- gcheckbox(cont = ds.e.up.options, label = "Column names",
- checked = TRUE)
-ds.e.up.sep <- gcombobox(c("whitespace", ";", ","), cont = ds.e.up.options,
- selected = 1, label = "Separator")
-ds.e.up.dec <- gcombobox(c(".", ","), cont = ds.e.up.options,
- selected = 1, label = "Decimal")
-ds.e.up.widelong <- gradio(c("wide", "long"), horizontal = TRUE,
- label = "Format", cont = ds.e.up.options,
- handler = function(h, ...) {
- widelong = svalue(h$obj, index = TRUE)
- svalue(ds.e.up.wlstack) <- widelong
- })
-ds.e.up.wlstack <- gstackwidget(cont = ds.e.up.options)
-ds.e.up.wide <- ggroup(cont = ds.e.up.wlstack, horizontal = FALSE, width = 300)
-ds.e.up.wide.time <- gedit(tmptexttime, cont = ds.e.up.wide, label = "Time column")
-ds.e.up.long <- ggroup(cont = ds.e.up.wlstack, horizontal = FALSE, width = 300)
-ds.e.up.long.name <- gedit("name", cont = ds.e.up.long, label = "Observed variables")
-ds.e.up.long.time <- gedit(tmptexttime, cont = ds.e.up.long, label = "Time column")
-ds.e.up.long.value <- gedit("value", cont = ds.e.up.long, label = "Value column")
-ds.e.up.long.err <- gedit("err", cont = ds.e.up.long, label = "Relative errors")
-svalue(ds.e.up.wlstack) <- 1
-
-svalue(ds.e.stack) <- 1
-
-# Kinetic Data {{{3
-ds.e.gdf <- gdf(ds[[ds.cur]]$data, name = "Kinetic data",
- width = 500, height = 700, cont = ds.editor)
-ds.e.gdf$set_column_width(2, 70)
-
-# Update the dataset editor {{{3
-update_ds_editor <- function() {
- svalue(ds.editor) <- paste("Dataset", ds.cur)
- svalue(ds.title.ge) <- ds[[ds.cur]]$title
- svalue(ds.study.gc, index = TRUE) <- ds[[ds.cur]]$study_nr
-
- svalue(ds.e.st) <- paste(ds[[ds.cur]]$sampling_times, collapse = ", ")
- svalue(ds.e.stu) <- ds[[ds.cur]]$time_unit
- svalue(ds.e.obs) <- paste(ds[[ds.cur]]$observed, collapse = ", ")
- svalue(ds.e.obu) <- ds[[ds.cur]]$unit
- svalue(ds.e.rep) <- ds[[ds.cur]]$replicates
- svalue(ds.e.stack) <- 1
- ds.e.gdf[,] <- ds[[ds.cur]]$data
-}
-# Model editor {{{1
-m.editor <- gframe("Model 1", horizontal = FALSE, cont = center, label = "Model editor")
-# Handler functions {{{3
-copy_model_handler <- function(h, ...) {
- m.old <- m.cur
- m.cur <<- as.character(1 + length(m))
- svalue(m.editor) <- paste("Model", m.cur)
- m[[m.cur]] <<- m[[m.old]]
- update_m.df()
- m.gtable[,] <- m.df
-}
-
-delete_model_handler <- function(h, ...) {
- if (length(m) > 1) {
- m[[m.cur]] <<- NULL
- names(m) <<- as.character(1:length(m))
- m.cur <<- "1"
+)
+
+p.line.import.mf <- gframe("Models for import", cont = p.line.import.frames, horizontal = FALSE)
+p.line.import.mt <- gtable(m.df.empty, cont = p.line.import.mf, multiple = TRUE,
+ width = left_width - 10, height = 160)
+p.line.import.mb <- gbutton("Import selected", cont = p.line.import.mf,
+ handler = function(h, ...) {
+ i <- svalue(p.line.import.mt, index = TRUE)
+ ws$m <<- append(ws$m, ws.import$m[i])
update_m.df()
m.gtable[,] <- m.df
- update_m_editor()
- } else {
- galert("Deleting the last model is not supported", parent = w)
- }
-}
-
-add_observed_handler <- function(h, ...) {
- obs.i <- length(m.e.rows) + 1
- m.e.rows[[obs.i]] <<- ggroup(cont = m.editor, horizontal = TRUE)
- m.e.obs[[obs.i]] <<- gcombobox(observed.all, selected = obs.i,
- cont = m.e.rows[[obs.i]])
- m.e.type[[obs.i]] <<- gcombobox(c("SFO", "SFORB"),
- cont = m.e.rows[[obs.i]])
- svalue(m.e.type[[obs.i]]) <- "SFO"
- glabel("to", cont = m.e.rows[[obs.i]])
- m.e.to[[obs.i]] <<- gedit("",
- initial.msg = "Optional list of target variables, e.g. 'm1, m2'",
- width = 40, cont = m.e.rows[[obs.i]])
- m.e.sink[[obs.i]] <<- gcheckbox("Path to sink",
- checked = TRUE, cont = m.e.rows[[obs.i]])
- gbutton("Remove compound", handler = remove_observed_handler,
- action = obs.i, cont = m.e.rows[[obs.i]])
-}
-
-remove_observed_handler <- function(h, ...) {
- m[[m.cur]]$spec[[h$action]] <<- NULL
- update_m_editor()
-}
-
-keep_m_changes_handler <- function(h, ...) {
- spec <- list()
- for (obs.i in 1:length(m.e.rows)) {
- to_vector = strsplit(svalue(m.e.to[[obs.i]]), ", ")[[1]]
- if (length(to_vector) == 0) to_vector = ""
- spec[[obs.i]] <- list(type = svalue(m.e.type[[obs.i]]),
- to = to_vector,
- sink = svalue(m.e.sink[[obs.i]]))
- if(spec[[obs.i]]$to[[1]] == "") spec[[obs.i]]$to = NULL
- names(spec)[[obs.i]] <- svalue(m.e.obs[[obs.i]])
- }
- m[[m.cur]] <<- mkinmod(use_of_ff = svalue(m.ff.gc),
- speclist = spec)
- m[[m.cur]]$name <<- svalue(m.name.ge)
- update_m.df()
- m.gtable[,] <- m.df
-}
-
-# Widget setup {{{3
-m.e.0 <- ggroup(cont = m.editor, horizontal = TRUE)
-glabel("Model name: ", cont = m.e.0)
-m.name.ge <- gedit(m[[m.cur]]$name, cont = m.e.0)
-glabel("Use of formation fractions: ", cont = m.e.0)
-m.ff.gc <- gcombobox(c("min", "max"), cont = m.e.0)
-svalue(m.ff.gc) <- m[[m.cur]]$use_of_ff
-
-# Model handling buttons {{{4
-m.e.b <- ggroup(cont = m.editor, horizontal = TRUE)
-gbutton("Copy model", cont = m.e.b, handler = copy_model_handler)
-gbutton("Delete model", cont = m.e.b, handler = delete_model_handler)
-gbutton("Add observed variable", cont = m.e.b,
- handler = add_observed_handler)
-gbutton("Keep changes", cont = m.e.b, handler = keep_m_changes_handler)
-
-
-m.observed <- names(m[[m.cur]]$spec)
-m.e.rows <- m.e.obs <- m.e.type <- m.e.to <- m.e.sink <- list()
-obs.to <- ""
-
-# Show the model specification {{{4
-show_m_spec <- function() {
- for (obs.i in 1:length(m[[m.cur]]$spec)) {
- obs.name <- names(m[[m.cur]]$spec)[[obs.i]]
- m.e.rows[[obs.i]] <<- ggroup(cont = m.editor, horizontal = TRUE)
- m.e.obs[[obs.i]] <<- gcombobox(observed.all, selected = 0,
- cont = m.e.rows[[obs.i]])
- svalue(m.e.obs[[obs.i]]) <<- obs.name
- if (obs.i == 1) {
- m.e.type[[obs.i]] <<- gcombobox(c("SFO", "FOMC", "DFOP", "HS", "SFORB"),
- cont = m.e.rows[[obs.i]])
- } else {
- m.e.type[[obs.i]] <<- gcombobox(c("SFO", "SFORB"),
- cont = m.e.rows[[obs.i]])
- }
- svalue(m.e.type[[obs.i]]) <<- m[[m.cur]]$spec[[obs.i]]$type
- glabel("to", cont = m.e.rows[[obs.i]])
- obs.to <<- ifelse(is.null(m[[m.cur]]$spec[[obs.i]]$to), "",
- paste(m[[m.cur]]$spec[[obs.i]]$to, collapse = ", "))
- m.e.to[[obs.i]] <<- gedit(obs.to,
- initial.msg = "Optional list of target variables, e.g. 'm1, m2'",
- width = 40, cont = m.e.rows[[obs.i]])
- m.e.sink[[obs.i]] <<- gcheckbox("Path to sink", checked = m[[m.cur]]$spec[[obs.i]]$sink,
- cont = m.e.rows[[obs.i]])
- if (obs.i > 1) {
- gbutton("Remove observed variable", handler = remove_observed_handler,
- action = obs.i, cont = m.e.rows[[obs.i]])
- }
- }
-}
-show_m_spec()
-
-# Update the model editor {{{3
-update_m_editor <- function() {
- svalue(m.editor) <- paste("Model", m.cur)
- svalue(m.name.ge) <- m[[m.cur]]$name
- svalue(m.ff.gc) <- m[[m.cur]]$use_of_ff
- for (oldrow.i in 1:length(m.e.rows)) {
- delete(m.editor, m.e.rows[[oldrow.i]])
- }
- m.observed <<- names(m[[m.cur]]$spec)
- m.e.rows <<- m.e.obs <<- m.e.type <<- m.e.to <<- m.e.sink <<- list()
- show_m_spec()
-}
-
-# 3}}}
-# 2}}}
-# Plotting and fitting {{{1
-show_plot <- function(type, default = FALSE) {
- Parameters <- f.gg.parms[,]
- Parameters.de <- subset(Parameters, Type == "deparm", type)
- stateparms <- subset(Parameters, Type == "state")[[type]]
- deparms <- as.numeric(Parameters.de[[type]])
- names(deparms) <- rownames(Parameters.de)
- if (type == "Initial" & default == FALSE) {
- ftmp <<- suppressWarnings(mkinfit(ftmp$mkinmod,
- override(ds[[ds.i]]$data),
- parms.ini = deparms,
- state.ini = stateparms,
- fixed_parms = names(deparms),
- fixed_initials = names(stateparms),
- err = "err",
- method.modFit = "Marq",
- control.modFit = list(maxiter = 0)))
- ftmp$ds.index <<- ds.i
- ftmp$ds <<- ds[[ds.i]]
- }
- svalue(plot.ftmp.gi) <<- plot_ftmp_png()
- svalue(plot.confint.gi) <<- plot_confint_png()
-}
-get_Parameters <- function(stmp, optimised)
-{
- pars <- rbind(stmp$start[1:2], stmp$fixed)
-
- pars$fixed <- c(rep(FALSE, length(stmp$start$value)),
- rep(TRUE, length(stmp$fixed$value)))
- pars$name <- rownames(pars)
- Parameters <- data.frame(Name = pars$name,
- Type = pars$type,
- Initial = pars$value,
- Fixed = pars$fixed,
- Optimised = as.numeric(NA))
- Parameters <- rbind(subset(Parameters, Type == "state"),
- subset(Parameters, Type == "deparm"))
- rownames(Parameters) <- Parameters$Name
- if (optimised) {
- Parameters[rownames(stmp$bpar), "Optimised"] <- stmp$bpar[, "Estimate"]
- }
- return(Parameters)
-}
-run_fit <- function() {
- Parameters <- f.gg.parms[,]
- Parameters.de <- subset(Parameters, Type == "deparm")
- deparms <- Parameters.de$Initial
- names(deparms) <- Parameters.de$Name
- defixed <- names(deparms[Parameters.de$Fixed])
- Parameters.ini <- subset(Parameters, Type == "state")
- iniparms <- Parameters.ini$Initial
- names(iniparms) <- sub("_0", "", Parameters.ini$Name)
- inifixed <- names(iniparms[Parameters.ini$Fixed])
- weight <- svalue(f.gg.opts.weight)
- if (weight == "manual") {
- err = "err"
- } else {
- err = NULL
}
- reweight.method <- svalue(f.gg.opts.reweight.method)
- if (reweight.method == "none") reweight.method = NULL
- ftmp <<- mkinfit(ftmp$mkinmod, override(ds[[ds.i]]$data),
- state.ini = iniparms,
- fixed_initials = inifixed,
- parms.ini = deparms,
- fixed_parms = defixed,
- plot = svalue(f.gg.opts.plot),
- solution_type = svalue(f.gg.opts.st),
- atol = as.numeric(svalue(f.gg.opts.atol)),
- rtol = as.numeric(svalue(f.gg.opts.rtol)),
- transform_rates = svalue(f.gg.opts.transform_rates),
- transform_fractions = svalue(f.gg.opts.transform_fractions),
- weight = weight,
- err = err,
- reweight.method = reweight.method,
- reweight.tol = as.numeric(svalue(f.gg.opts.reweight.tol)),
- reweight.max.iter = as.numeric(svalue(f.gg.opts.reweight.max.iter)),
- method.modFit = svalue(f.gg.opts.method.modFit),
- maxit.modFit = svalue(f.gg.opts.maxit.modFit)
- )
- ftmp$ds.index <<- ds.i
- ftmp$ds <<- ds[[ds.i]]
- stmp <<- summary(ftmp)
- show_plot("Optimised")
- svalue(f.gg.opts.st) <- ftmp$solution_type
- svalue(f.gg.opts.weight) <- ftmp$weight.ini
- f.gg.parms[,] <- get_Parameters(stmp, TRUE)
- svalue(f.gg.summary.filename) <<- paste(ftmp$ds$title, "_", ftmp$mkinmod$name, ".txt", sep = "")
- svalue(f.gg.summary.listing) <<- c("<pre>", capture.output(stmp), "</pre>")
-}
-ds.i <- m.i <- "1"
-f.cur <- "0"
+)
+
+
+# center: Dataset editor {{{1
+ds.editor <- gframe("", horizontal = FALSE, cont = center,
+ label = "Dataset editor")
+m.editor <- gframe("", horizontal = FALSE, cont = center,
+ label = "Model editor")
+f.config <- gframe("", horizontal = FALSE, cont = center,
+ label = "Fit configuration")
+r.viewer <- gframe("", horizontal = FALSE, cont = center,
+ label = "Result viewer")
+svalue(center) <- 1
+# right: Viewing area {{{1
+# Workflow {{{2
+workflow.gg <- ggroup(cont = right, label = "Workflow", width = 480, height = 600,
+ ext.args = list(layout = list(type="vbox", align = "center")))
+
+workflow.png <- get_tempfile(ext = ".png")
+file.copy(system.file("GUI/gmkin_workflow_434x569.png", package = "gmkin"), workflow.png)
+workflow.gi <- gimage(workflow.png, size = c(434, 569), label = "Workflow", cont = workflow.gg)
+
+# Manual {{{2
+gmkin_manual <- readLines(system.file("GUI/gmkin_manual.html", package = "gmkin"))
+gmb_start <- grep("<body>", gmkin_manual)
+gmb_end <- grep("</body>", gmkin_manual)
+gmkin_manual_body <- gmkin_manual[gmb_start:gmb_end]
+
+manual.gh <- ghtml(label = "Manual", paste0("<div class = 'manual' style = 'margin: 20px'>
+<style>
+.manual h1{
+ font-size: 14px;
+ line-height: 20px;
+}
+.manual h2{
+ font-size: 14px;
+ line-height: 20px;
+}
+.manual h3{
+ font-size: 12px;
+ line-height: 18px;
+}
+.manual ul{
+ font-size: 12px;
+ line-height: 12px;
+}
+.manual li{
+ font-size: 12px;
+ line-height: 12px;
+}
+</style>
+", paste(gmkin_manual_body, collapse = '\n'), "
+</div>"), width = 460, cont = right)
+
+# Changes {{{2
+gmkin_news <- markdownToHTML(system.file("NEWS.md", package = "gmkin"),
+ fragment.only = TRUE,
+ )
+
+changes.gh <- ghtml(label = "Changes", paste0("<div class = 'news' style = 'margin: 20px'>
+<style>
+.news h1{
+ font-size: 14px;
+ line-height: 20px;
+}
+.news h2{
+ font-size: 14px;
+ line-height: 20px;
+}
+.news h3{
+ font-size: 12px;
+ line-height: 18px;
+}
+.news ul{
+ font-size: 12px;
+ line-height: 12px;
+}
+.news li{
+ font-size: 12px;
+ line-height: 12px;
+}
+</style>
+", gmkin_news, "
+</div>"), width = 460, cont = right)
+
+svalue(right) <- 1
-# GUI widgets {{{2
-pf <- gframe("Dataset 1, Model SFO", horizontal = TRUE,
- cont = center, label = "Plotting and fitting")
-# Plot area to the left {{{3
-pf.p <- ggroup(cont = pf, horizontal = FALSE)
-ftmp <- suppressWarnings(mkinfit(m[[m.cur]], override(ds[[ds.i]]$data),
- err = "err",
- method.modFit = "Marq",
- control.modFit = list(maxiter = 0)))
-ftmp$ds.index = ds.i
-ftmp$ds = ds[[ds.i]]
-stmp <- summary(ftmp)
-Parameters <- get_Parameters(stmp, FALSE)
-
-plot_ftmp <- function() {
- if(exists("f.gg.po.obssel")) {
- obs_vars_plot = svalue(f.gg.po.obssel)
- } else {
- obs_vars_plot = names(ftmp$mkinmod$spec)
- }
- if(exists("f.gg.po.legend")) {
- plot_legend = svalue(f.gg.po.legend)
- } else {
- plot_legend = TRUE
- }
- plot(ftmp, main = ftmp$ds$title, obs_vars = obs_vars_plot,
- xlab = ifelse(ftmp$ds$time_unit == "", "Time",
- paste("Time in", ftmp$ds$time_unit)),
- ylab = ifelse(ds[[ds.i]]$unit == "", "Observed",
- paste("Observed in", ftmp$ds$unit)),
- legend = plot_legend,
- show_residuals = TRUE)
-}
-
-plot_ftmp_png <- function() {
- tf <- get_tempfile(ext=".png")
- png(tf, width = 400, height = 400)
- plot_ftmp()
- dev.off()
- return(tf)
-}
-
-plot_ftmp_save <- function(filename) {
- switch(plot_format,
- png = png(filename, width = 400, height = 400),
- pdf = pdf(filename),
- wmf = win.metafile(filename))
- plot_ftmp()
- dev.off()
- svalue(sb) <- paste("Saved plot to", filename, "in working directory", getwd())
-}
-
-plot_confint_png <- function() {
- tf <- get_tempfile(ext=".png")
- png(tf, width = 400, height = 400)
- mkinparplot(ftmp)
- dev.off()
- return(tf)
-}
-
-plot_formats <- c("png", "pdf")
-if (exists("win.metafile", "package:grDevices", inherits = FALSE)) {
- plot_formats = c("wmf", plot_formats)
-}
-plot_format <- plot_formats[[1]]
-
-plot.ftmp.gi <- gimage(plot_ftmp_png(), container = pf.p, width = 400, height = 400)
-plot.ftmp.saveline <- ggroup(cont = pf.p, horizontal = TRUE)
-plot.ftmp.savefile <- gedit(paste(ds[[ds.cur]]$title, "_", m[[m.cur]]$name, ".",
- plot_format, sep = ""),
- width = 40, cont = plot.ftmp.saveline)
-plot.ftmp.savebutton <- gbutton("Save plot", cont = plot.ftmp.saveline,
- handler = function(h, ...) {
- filename <- svalue(plot.ftmp.savefile)
- if (file.exists(filename))
- {
- gconfirm(paste("File", filename,
- "exists. Overwrite?"),
- parent = w,
- handler = function(h, ...) {
- plot_ftmp_save(filename)
- }
- )
- } else {
- plot_ftmp_save(filename)
- }
- })
-plot.space <- ggroup(cont = pf.p, horizontal = TRUE, height = 18)
-plot.confint.gi <- gimage(plot_confint_png(), container = pf.p, width = 400, height = 400)
-
-# Buttons and notebook area to the right {{{3
-p.gg <- ggroup(cont = pf, horizontal = FALSE)
-# Row with buttons {{{4
-f.gg.buttons <- ggroup(cont = p.gg)
-run.fit.gb <- gbutton("Run", width = 100,
- handler = function(h, ...) run_fit(), cont =
- f.gg.buttons)
-tooltip(run.fit.gb) <- "Fit with current settings on the current dataset, with the original model"
-
-keep.fit.gb <- gbutton("Keep fit",
- handler = function(h, ...) {
- f.cur <<- as.character(length(f) + 1)
- f[[f.cur]] <<- ftmp
- s[[f.cur]] <<- stmp
- update_f.df()
- f.gtable[,] <<- f.df
- delete(f.gg.plotopts, f.gg.po.obssel)
- f.gg.po.obssel <<- gcheckboxgroup(names(ftmp$mkinmod$spec),
- cont = f.gg.plotopts,
- checked = TRUE)
- delete(f.gg.buttons, get.initials.gc)
- get.initials.gc <<- gcombobox(paste("Fit", f.df$Fit),
- cont = f.gg.buttons)
- }, cont = f.gg.buttons)
-tooltip(keep.fit.gb) <- "Store the optimised model with all settings and the current dataset in the fit list"
-
-delete_fit_handler <- function(h, ...) {
- if (length(f) > 0) {
- f[[f.cur]] <<- NULL
- s[[f.cur]] <<- NULL
- }
- if (length(f) > 0) {
- names(f) <<- as.character(1:length(f))
- names(s) <<- as.character(1:length(f))
- update_f.df()
- f.cur <<- "1"
- ftmp <<- f[[f.cur]]
- stmp <<- s[[f.cur]]
- ds.i <<- ftmp$ds.index
- update_plotting_and_fitting()
- } else {
- f.df <<- f.df.empty
- f.cur <<- "0"
- }
- f.gtable[,] <<- f.df
-}
-
-delete.fit.gb <- gbutton("Delete fit", handler = delete_fit_handler,
- cont = f.gg.buttons)
-tooltip(delete.fit.gb) <- "Delete the currently loaded fit from the fit list"
-
-show.initial.gb <- gbutton("Show initial",
- handler = function(h, ...) show_plot("Initial"),
- cont = f.gg.buttons)
-tooltip(show.initial.gb) <- "Show model with current inital settings for current dataset"
-
-get_initials_handler <- function(h, ...)
-{
- f.i <- svalue(get.initials.gc, index = TRUE)
- if (length(f) > 0) {
- got_initials <- c(f[[f.i]]$bparms.fixed, f[[f.i]]$bparms.optim)
- parnames <- f.gg.parms[,"Name"]
- newparnames <- names(got_initials)
- commonparnames <- intersect(parnames, newparnames)
- f.gg.parms[commonparnames, "Initial"] <<- got_initials[commonparnames]
- }
-}
-get.initials.gb <- gbutton("Get initials from", cont = f.gg.buttons,
- handler = get_initials_handler)
-get.initials.gc <- gcombobox(paste("Fit", f.df$Fit), cont = f.gg.buttons)
-
-# Notebook to the right {{{3
-f.gn <- gnotebook(cont = p.gg, width = 680, height = 790)
-# Dataframe with initial and optimised parameters {{{4
-f.gg.parms <- gdf(Parameters, cont = f.gn,
- width = 670, height = 750,
- do_add_remove_buttons = FALSE, label = "Parameters")
-f.gg.parms$set_column_width(1, 200)
-f.gg.parms$set_column_width(2, 50)
-f.gg.parms$set_column_width(3, 60)
-f.gg.parms$set_column_width(4, 50)
-f.gg.parms$set_column_width(5, 60)
-
-# Fit options form {{{4
-f.gg.opts <- gformlayout(cont = f.gn, label = "Fit options")
-solution_types <- c("auto", "analytical", "eigen", "deSolve")
-f.gg.opts.plot <- gcheckbox("plot",
- cont = f.gg.opts, checked = FALSE)
-f.gg.opts.st <- gcombobox(solution_types, selected = 1,
- label = "solution_type", width = 200,
- cont = f.gg.opts)
-f.gg.opts.atol <- gedit(ftmp$atol, label = "atol", width = 20,
- cont = f.gg.opts)
-f.gg.opts.rtol <- gedit(ftmp$rtol, label = "rtol", width = 20,
- cont = f.gg.opts)
-f.gg.opts.transform_rates <- gcheckbox("transform_rates",
- cont = f.gg.opts, checked = TRUE)
-f.gg.opts.transform_fractions <- gcheckbox("transform_fractions",
- cont = f.gg.opts, checked = TRUE)
-weights <- c("manual", "none", "std", "mean")
-f.gg.opts.weight <- gcombobox(weights, selected = 1, label = "weight",
- width = 200, cont = f.gg.opts)
-f.gg.opts.reweight.method <- gcombobox(c("none", "obs"), selected = 1,
- label = "reweight.method",
- width = 200,
- cont = f.gg.opts)
-f.gg.opts.reweight.tol <- gedit(1e-8, label = "reweight.tol",
- width = 20, cont = f.gg.opts)
-f.gg.opts.reweight.max.iter <- gedit(10, label = "reweight.max.iter",
- width = 20, cont = f.gg.opts)
-optimisation_methods <- c("Port", "Marq", "SANN")
-f.gg.opts.method.modFit <- gcombobox(optimisation_methods, selected = 1,
- label = "method.modFit",
- width = 200,
- cont = f.gg.opts)
-f.gg.opts.maxit.modFit <- gedit("auto", label = "maxit.modFit",
- width = 20, cont = f.gg.opts)
-
-# Summary {{{3
-oldwidth <- options()$width
-options(width = 90)
-f.gg.summary <- ggroup(label = "Summary", cont = f.gn, horizontal = FALSE)
-f.gg.summary.topline <- ggroup(cont = f.gg.summary, horizontal = TRUE)
-f.gg.summary.filename <- gedit(paste(ds[[ds.cur]]$title, "_", m[[m.cur]]$name,
- ".txt", sep = ""),
- width = 50, cont = f.gg.summary.topline)
-f.gg.summary.savebutton <- gbutton("Save summary", cont = f.gg.summary.topline,
- handler = function(h, ...) {
- filename <- svalue(f.gg.summary.filename)
- if (file.exists(filename))
- {
- gconfirm(paste("File", filename, "exists. Overwrite?"),
- parent = w,
- handler = function(h, ...) {
- capture.output(stmp, file = filename)
- })
- } else {
- capture.output(stmp, file = filename)
- }
- })
-f.gg.summary.listing <- ghtml(c("<pre>", capture.output(stmp), "</pre>"),
- cont = f.gg.summary, label = "Summary")
-options(width = oldwidth)
-
-# Plot options {{{4
-f.gg.plotopts <- ggroup(cont = f.gn, label = "Plot options", horizontal = FALSE,
- width = 200)
-
-f.gg.po.format <- gcombobox(plot_formats, selected = 1, label = "File format",
- cont = f.gg.plotopts,
- handler = function(h, ...) {
- plot_format <<- svalue(h$obj)
- svalue(plot.ftmp.savefile) <<- gsub("...$", plot_format,
- svalue(plot.ftmp.savefile))
- })
-plot_format <- svalue(f.gg.po.format)
-f.gg.po.legend <- gcheckbox("legend", cont = f.gg.plotopts, checked = TRUE)
-f.gg.po.update <- gbutton("Update plot",
- handler = function(h, ...) show_plot("Optimised"),
- cont = f.gg.plotopts)
-f.gg.po.obssel <- gcheckboxgroup(names(m[[m.cur]]$spec), cont = f.gg.plotopts,
- checked = TRUE)
-svalue(f.gn) <- 1
-
-# Update the plotting and fitting area {{{3
-update_plotting_and_fitting <- function() {
- svalue(pf) <- paste0("Fit ", f.cur, ": Dataset ", ftmp$ds.index,
- ", Model ", ftmp$mkinmod$name)
- # Parameters
- f.gg.parms[,] <- get_Parameters(stmp, TRUE)
-
- # Fit options
- delete(f.gg.buttons, get.initials.gc)
- get.initials.gc <<- gcombobox(paste("Fit", f.df$Fit), cont = f.gg.buttons)
-
- svalue(f.gg.opts.st) <- ftmp$solution_type
- svalue(f.gg.opts.atol) <- ftmp$atol
- svalue(f.gg.opts.rtol) <- ftmp$rtol
- svalue(f.gg.opts.transform_rates) <- ftmp$transform_rates
- svalue(f.gg.opts.transform_fractions) <- ftmp$transform_fractions
- svalue(f.gg.opts.weight) <- ftmp$weight.ini
- svalue(f.gg.opts.reweight.method) <- ifelse(is.null(ftmp$reweight.method),
- "none",
- ftmp$reweight.method)
- svalue(f.gg.opts.reweight.tol) <- ftmp$reweight.tol
- svalue(f.gg.opts.reweight.max.iter) <- ftmp$reweight.max.iter
- svalue(f.gg.opts.method.modFit) <- ftmp$method.modFit
- svalue(f.gg.opts.maxit.modFit) <- ftmp$maxit.modFit
-
- # Summary
- oldwidth <<- options()$width
- options(width = 90)
- svalue(f.gg.summary.filename) <<- paste(ftmp$ds$title, "_", ftmp$mkinmod$name, ".txt", sep = "")
- svalue(f.gg.summary.listing) <<- c("<pre>", capture.output(stmp), "</pre>")
- options(width = oldwidth)
-
- # Plot options
- delete(f.gg.plotopts, f.gg.po.obssel)
- f.gg.po.obssel <<- gcheckboxgroup(names(ftmp$mkinmod$spec), cont = f.gg.plotopts,
- checked = TRUE)
- # Plot
- svalue(plot.ftmp.savefile) <<- paste(ftmp$ds$title, "_", ftmp$mkinmod$name,
- ".", plot_format, sep = "")
- show_plot("Optimised")
-
-}
# vim: set foldmethod=marker ts=2 sw=2 expandtab: {{{1
diff --git a/inst/GUI/gmkin_manual.html b/inst/GUI/gmkin_manual.html
new file mode 100644
index 0000000..588f580
--- /dev/null
+++ b/inst/GUI/gmkin_manual.html
@@ -0,0 +1,233 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+ <meta http-equiv="Content-Style-Type" content="text/css" />
+ <meta name="generator" content="pandoc" />
+ <title>Manual for gmkin</title>
+ <style type="text/css">code{white-space: pre;}</style>
+ <style type="text/css">
+table.sourceCode, tr.sourceCode, td.lineNumbers, td.sourceCode {
+ margin: 0; padding: 0; vertical-align: baseline; border: none; }
+table.sourceCode { width: 100%; line-height: 100%; }
+td.lineNumbers { text-align: right; padding-right: 4px; padding-left: 4px; color: #aaaaaa; border-right: 1px solid #aaaaaa; }
+td.sourceCode { padding-left: 5px; }
+code > span.kw { color: #007020; font-weight: bold; }
+code > span.dt { color: #902000; }
+code > span.dv { color: #40a070; }
+code > span.bn { color: #40a070; }
+code > span.fl { color: #40a070; }
+code > span.ch { color: #4070a0; }
+code > span.st { color: #4070a0; }
+code > span.co { color: #60a0b0; font-style: italic; }
+code > span.ot { color: #007020; }
+code > span.al { color: #ff0000; font-weight: bold; }
+code > span.fu { color: #06287e; }
+code > span.er { color: #ff0000; font-weight: bold; }
+ </style>
+</head>
+<body>
+<div id="header">
+<h1 class="title">Manual for gmkin</h1>
+</div>
+<div id="TOC">
+<ul>
+<li><a href="#introduction">Introduction</a></li>
+<li><a href="#starting-gmkin">Starting gmkin</a></li>
+<li><a href="#project-file-management">Project file management</a></li>
+<li><a href="#studies">Studies</a></li>
+<li><a href="#datasets-and-models">Datasets and Models</a></li>
+<li><a href="#dataset-editor">Dataset editor</a><ul>
+<li><a href="#entering-data-directly">Entering data directly</a></li>
+<li><a href="#importing-data-from-text-files">Importing data from text files</a></li>
+</ul></li>
+<li><a href="#model-editor">Model editor</a></li>
+<li><a href="#plotting-and-fitting">Plotting and fitting</a><ul>
+<li><a href="#parameters">Parameters</a></li>
+<li><a href="#fit-options">Fit options</a></li>
+<li><a href="#fitting-the-model">Fitting the model</a></li>
+<li><a href="#summary">Summary</a></li>
+<li><a href="#plot-options">Plot options</a></li>
+<li><a href="#confidence-interval-plots">Confidence interval plots</a></li>
+</ul></li>
+</ul>
+</div>
+<!--
+%\VignetteEngine{knitr::rmarkdown}
+%\VignetteIndexEntry{Manual for gmkin}
+-->
+<h2 id="introduction">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 id="starting-gmkin">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 class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(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 class="sourceCode r"><code class="sourceCode r"><span class="kw">gmkin</span>()</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 class="sourceCode r"><code class="sourceCode r">Model cost at call <span class="dv">1</span>:<span class="st"> </span><span class="fl">2388.077</span></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>
+<div class="figure">
+<img src="" alt="gmkin start" />
+<p class="caption">gmkin start</p>
+</div>
+<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 id="project-file-management">Project file management</h2>
+<p>At startup, gmkin loads a project called &quot;FOCUS_2006_gmkin&quot; 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>
+<div class="figure">
+<img src="" alt="projects" />
+<p class="caption">projects</p>
+</div>
+<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 &quot;Upload&quot; button to load its contents into gmkin.</p>
+<h2 id="studies">Studies</h2>
+<p>The &quot;Studies&quot; area directly below the &quot;Project file management&quot; 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 &quot;Add&quot; button above the table containing the list. If there are more than one studies in the list, you can also remove them using the &quot;Remove&quot; button.</p>
+<div class="figure">
+<img src="" alt="studies" />
+<p class="caption">studies</p>
+</div>
+<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 id="datasets-and-models">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 &quot;Datasets and Models&quot;, together with a button for setting up fits as shown below.</p>
+<div class="figure">
+<img src="" alt="datasets and models" />
+<p class="caption">datasets and models</p>
+</div>
+<p>For editing, adding or removing datasets or models, you need to double-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 &quot;Configure fit for selected dataset and model&quot; will set up the fit and open the &quot;Plotting and Fitting&quot; tab to the right.</p>
+<h2 id="dataset-editor">Dataset editor</h2>
+<p>The dataset editor allows for editing datasets, entering new datasets, uploading data from text files and deleting datasets.</p>
+<div class="figure">
+<img src="" alt="dataset editor" />
+<p class="caption">dataset editor</p>
+</div>
+<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 &quot;Studies&quot; area as described above.</p>
+<h3 id="entering-data-directly">Entering data directly</h3>
+<p>For entering new data manually, click on &quot;New dataset&quot;, enter a title and select the study from which the dataset is taken. At this stage, you may already want to press &quot;Keep changes&quot;, 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>
+<div class="figure">
+<img src="" alt="generate data grid" />
+<p class="caption">generate data grid</p>
+</div>
+<p>Once everyting is filled out to your satisfaction, press the button &quot;Generate empty grid for kinetic data&quot;. 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>
+<div class="figure">
+<img src="" alt="data grid" />
+<p class="caption">data grid</p>
+</div>
+<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 &quot;Keep changes&quot; 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 id="importing-data-from-text-files">Importing data from text files</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 &quot;Browse&quot; and &quot;Upload&quot; 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 class="sourceCode r"><code class="sourceCode r"><span class="kw">write.table</span>(schaefer07_complex_case, <span class="dt">sep =</span> <span class="st">&quot;,&quot;</span>, <span class="dt">dec =</span> <span class="st">&quot;.&quot;</span>,
+ <span class="dt">row.names =</span> <span class="ot">FALSE</span>, <span class="dt">quote =</span> <span class="ot">FALSE</span>,
+ <span class="dt">file =</span> <span class="st">&quot;schaefer07.csv&quot;</span>)</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 &quot;Browse&quot; and &quot;Upload&quot; 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>
+<div class="figure">
+<img src="" alt="upload area" />
+<p class="caption">upload area</p>
+</div>
+<p>In the import configuration area, the following options can be specified. In the field &quot;Comment lines&quot;, 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 &quot;Separator&quot;, 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 &quot;Decimal&quot; separator, comma &quot;,&quot; or period &quot;.&quot; 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 &quot;name&quot;), the sampling times (default is &quot;time&quot;), the observed values (default is &quot;value&quot;) and, if present in the data, the relative errors (default is &quot;err&quot;) can be adapted. The default settings appearing if the long format is selected are shown below.</p>
+<div class="figure">
+<img src="" alt="long" />
+<p class="caption">long</p>
+</div>
+<p>In our example we have data in the wide format, and after adapting the &quot;Separator&quot; to a comma, we can press the button &quot;Import using options specified below&quot;, 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>
+<div class="figure">
+<img src="" alt="successful upload" />
+<p class="caption">successful upload</p>
+</div>
+<p>If everything is OK, press &quot;Keep changes&quot; 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 id="model-editor">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>
+<div class="figure">
+<img src="" alt="model editor" />
+<p class="caption">model editor</p>
+</div>
+<p>In the first line the name of the model can be edited. You can also specify &quot;min&quot; or &quot;max&quot; 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 &quot;min&quot;, 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 &quot;Copy model&quot; keeps the model name, so you should change it for the newly generated copy. Pressing &quot;Add observed variable&quot; 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. &quot;parent_sediment&quot;).</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 &quot;Remove observed variable&quot;.</p>
+<p>If the model definition is supposedly correct, press &quot;Keep changes&quot; to make it possible to select it for fitting in the listing of models to the left.</p>
+<h2 id="plotting-and-fitting">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 &quot;Configure fit for selected dataset and model&quot; below these lists.</p>
+<p>This opens the &quot;Plotting and fitting&quot; 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 class="sourceCode r"><code class="sourceCode r">Model cost at call <span class="dv">1</span>:<span class="st"> </span><span class="fl">15156.12</span></code></pre>
+<p>for the example shown below, where the FOCUS example dataset D and the model SFO_SFO were selected.</p>
+<div class="figure">
+<img src="" alt="plotting and fitting" />
+<p class="caption">plotting and fitting</p>
+</div>
+<h3 id="parameters">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 &quot;Show initial&quot;. 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 by selecting the fit and pressing the button &quot;Get initials from&quot;. This facilitates stepwise fitting of more complex degradation pathways.</p>
+<p>After the model has been successfully fitted by pressing the &quot;Run&quot; button, the optimised parameter values are added to the parameter table.</p>
+<h3 id="fit-options">Fit options</h3>
+<p>The most important fit options of the <code>mkinfit</code> function can be set via the &quot;Fit option&quot; tab shown below. If the &quot;plot&quot; 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>
+<div class="figure">
+<img src="" alt="fit options" />
+<p class="caption">fit options</p>
+</div>
+<p>The &quot;solution_type&quot; can either be &quot;auto&quot;, which means that the most effective solution method is chosen for the model, in the order of &quot;analytical&quot; (for parent only degradation data), &quot;eigen&quot; (for differential equation models with only linear terms, i.e. without FOMC, DFOP or HS submodels) or &quot;deSolve&quot;, which can handle all model definitions generated by the <code>mkin</code> package.</p>
+<p>The parameters &quot;atol&quot; and &quot;rtol&quot; are only effective if the solution type is &quot;deSolve&quot;. They control the precision of the iterative numerical solution of the differential equation model.</p>
+<p>The checkboxes &quot;transform_rates&quot; and &quot;transform_fractions&quot; 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>If fitting with transformed fractions leads to a suboptimal fit, doing a first run without transforming fractions may help. A final run using the optimised parameters from the previous run as starting values (see comment on &quot;Get initials from&quot; above) can then be performed with transformed fractions.</p>
+<p>The dropdown box &quot;weight&quot; specifies if and how the observed values should be weighted in the fitting process. If &quot;manual&quot; is chosen, the values in the &quot;err&quot; 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 &quot;none&quot; 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 &quot;std&quot; and &quot;mean&quot;.</p>
+<p>The options &quot;reweight.method&quot;, &quot;reweight.tol&quot; and &quot;reweight.max.iter&quot; enable the use of iteratively reweighted least squares fitting, if the reweighting method is set to &quot;obs&quot;. 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 &quot;method.modFit&quot; makes it possible to choose between the optimisation algorithms &quot;Port&quot; (the default in mkin versions &gt; 0.9-33, a local optimisation algorithm using a model/trust region approach), &quot;Marq&quot; (the former default in mkin, a Levenberg-Marquardt variant from the R package <code>minpack.lm</code>), and &quot;SANN&quot; (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 &quot;maxit.modFit&quot; field.</p>
+<h3 id="fitting-the-model">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 &quot;Run&quot; button. In the R console, the progressive reduction in the model cost can be monitored and will be displayed like this:</p>
+<pre class="sourceCode r"><code class="sourceCode r">Model cost at call <span class="dv">1</span> :<span class="st"> </span><span class="fl">15156.12</span>
+Model cost at call <span class="dv">3</span> :<span class="st"> </span><span class="fl">15156.12</span>
+Model cost at call <span class="dv">7</span> :<span class="st"> </span><span class="fl">14220.79</span>
+Model cost at call <span class="dv">8</span> :<span class="st"> </span><span class="fl">14220.79</span>
+Model cost at call <span class="dv">11</span> :<span class="st"> </span><span class="fl">14220.79</span>
+Model cost at call <span class="dv">12</span> :<span class="st"> </span><span class="fl">3349.268</span>
+Model cost at call <span class="dv">15</span> :<span class="st"> </span><span class="fl">3349.268</span>
+Model cost at call <span class="dv">17</span> :<span class="st"> </span><span class="fl">788.6367</span>
+Model cost at call <span class="dv">18</span> :<span class="st"> </span><span class="fl">788.6366</span>
+Model cost at call <span class="dv">22</span> :<span class="st"> </span><span class="fl">374.0575</span>
+Model cost at call <span class="dv">23</span> :<span class="st"> </span><span class="fl">374.0575</span>
+Model cost at call <span class="dv">27</span> :<span class="st"> </span><span class="fl">371.2135</span>
+Model cost at call <span class="dv">28</span> :<span class="st"> </span><span class="fl">371.2135</span>
+Model cost at call <span class="dv">32</span> :<span class="st"> </span><span class="fl">371.2134</span>
+Model cost at call <span class="dv">36</span> :<span class="st"> </span><span class="fl">371.2134</span>
+Model cost at call <span class="dv">37</span> :<span class="st"> </span><span class="fl">371.2134</span> </code></pre>
+<p>If plotting of the fitting progress was selecte in the &quot;Fit options&quot; tab, a new separate graphics window should either pop up, or a graphics window previously started for this purpose will be reused.</p>
+<h3 id="summary">Summary</h3>
+<p>Once a fit has successfully been performed by pressing the &quot;Run&quot; button, the summary as displayed below can be accessed via the &quot;Summary&quot; tab.</p>
+<div class="figure">
+<img src="" alt="summary" />
+<p class="caption">summary</p>
+</div>
+<p>The complete summary can be saved into a text file by specifying a suitable file name and pressing the button &quot;Save summary&quot;.</p>
+<h3 id="plot-options">Plot options</h3>
+<p>In the tab &quot;Plot options&quot;, the file format can be chosen, the legend can be turned off, and the observed variables for which the data and the model fit should be plotted can be selected as shown below.</p>
+<div class="figure">
+<img src="" alt="plot options" />
+<p class="caption">plot options</p>
+</div>
+<p>On systems running the Windows operating system, the windows metafile (wmf) format can be additionally chosen. Chaning the file format for plotting will also change the extension of the proposed filename for saving the plot.</p>
+<h3 id="confidence-interval-plots">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 updated 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>
+<div class="figure">
+<img src="" alt="confidence" />
+<p class="caption">confidence</p>
+</div>
+<!-- vim: set foldmethod=syntax ts=2 sw=2 expandtab: -->
+</body>
+</html>
diff --git a/inst/GUI/gmkin_workflow_434x569.png b/inst/GUI/gmkin_workflow_434x569.png
new file mode 100644
index 0000000..a18f48f
--- /dev/null
+++ b/inst/GUI/gmkin_workflow_434x569.png
Binary files differ
diff --git a/inst/GUI/gmkin_workflow_inkscape.svg b/inst/GUI/gmkin_workflow_inkscape.svg
new file mode 100644
index 0000000..0d7275b
--- /dev/null
+++ b/inst/GUI/gmkin_workflow_inkscape.svg
@@ -0,0 +1,556 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:ooo="http://xml.openoffice.org/svg/export"
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ version="1.2"
+ width="210mm"
+ height="297mm"
+ viewBox="0 0 21000 29700"
+ preserveAspectRatio="xMidYMid"
+ fill-rule="evenodd"
+ clip-path="url(#presentation_clip_path)"
+ stroke-width="28.222"
+ stroke-linejoin="round"
+ xml:space="preserve"
+ id="svg2"
+ inkscape:version="0.48.5 r10040"
+ sodipodi:docname="gmkin_workflow.svg"><metadata
+ id="metadata297"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1341"
+ inkscape:window-height="1034"
+ id="namedview295"
+ showgrid="false"
+ inkscape:zoom="0.63234634"
+ inkscape:cx="372.04724"
+ inkscape:cy="422.47404"
+ inkscape:window-x="0"
+ inkscape:window-y="0"
+ inkscape:window-maximized="0"
+ inkscape:current-layer="svg2" /><defs
+ class="ClipPathGroup"
+ id="defs4"><clipPath
+ id="presentation_clip_path"
+ clipPathUnits="userSpaceOnUse"><rect
+ x="0"
+ y="0"
+ width="21000"
+ height="29700"
+ id="rect7" /></clipPath></defs><defs
+ id="defs9"><font
+ id="EmbeddedFont_1"
+ horiz-adv-x="2048"><font-face
+ font-family="Liberation Sans embedded"
+ units-per-em="2048"
+ font-weight="normal"
+ font-style="normal"
+ ascent="1852"
+ descent="423"
+ id="font-face12" /><missing-glyph
+ horiz-adv-x="2048"
+ d="M 0,0 L 2047,0 2047,2047 0,2047 0,0 Z"
+ id="missing-glyph14" /><glyph
+ unicode="w"
+ horiz-adv-x="1535"
+ d="M 1174,0 L 965,0 792,698 C 787,716 781,738 776,765 770,792 764,818 759,843 752,872 746,903 740,934 734,904 728,874 721,845 716,820 710,793 704,766 697,739 691,715 686,694 L 508,0 300,0 -3,1082 175,1082 358,347 C 363,332 367,313 372,291 377,268 381,246 386,225 391,200 396,175 401,149 406,174 412,199 418,223 423,244 429,265 434,286 439,307 444,325 448,339 L 644,1082 837,1082 1026,339 C 1031,322 1036,302 1041,280 1046,258 1051,237 1056,218 1061,195 1067,172 1072,149 1077,174 1083,199 1088,223 1093,244 1098,265 1103,288 1108,310 1112,330 1117,347 L 1308,1082 1484,1082 1174,0 Z"
+ id="glyph16" /><glyph
+ unicode="v"
+ horiz-adv-x="1059"
+ d="M 613,0 L 400,0 7,1082 199,1082 437,378 C 442,363 447,346 454,325 460,304 466,282 473,259 480,236 486,215 492,194 497,173 502,155 506,141 510,155 515,173 522,194 528,215 534,236 541,258 548,280 555,302 562,323 569,344 575,361 580,376 L 826,1082 1017,1082 613,0 Z"
+ id="glyph18" /><glyph
+ unicode="t"
+ horiz-adv-x="531"
+ d="M 554,8 C 527,1 499,-5 471,-10 442,-14 409,-16 372,-16 228,-16 156,66 156,229 L 156,951 31,951 31,1082 163,1082 216,1324 336,1324 336,1082 536,1082 536,951 336,951 336,268 C 336,216 345,180 362,159 379,138 408,127 450,127 467,127 484,128 501,131 517,134 535,137 554,141 L 554,8 Z"
+ id="glyph20" /><glyph
+ unicode="s"
+ horiz-adv-x="927"
+ d="M 950,299 C 950,248 940,203 921,164 901,124 872,91 835,64 798,37 752,16 698,2 643,-13 581,-20 511,-20 448,-20 392,-15 342,-6 291,4 247,20 209,41 171,62 139,91 114,126 88,161 69,203 57,254 L 216,285 C 231,227 263,185 311,158 359,131 426,117 511,117 550,117 585,120 618,125 650,130 678,140 701,153 724,166 743,183 756,205 769,226 775,253 775,285 775,318 767,345 752,366 737,387 715,404 688,418 661,432 628,444 589,455 550,465 507,476 460,489 417,500 374,513 331,527 288,541 250,560 216,583 181,606 153,634 132,668 111,702 100,745 100,796 100,895 135,970 206,1022 276,1073 378,1099 513,1099 632,1099 727,1078 798,1036 868,994 912,927 931,834 L 769,814 C 763,842 752,866 736,885 720,904 701,919 678,931 655,942 630,951 602,956 573,961 544,963 513,963 432,963 372,951 333,926 294,901 275,864 275,814 275,785 282,761 297,742 311,723 331,707 357,694 382,681 413,669 449,660 485,650 525,640 568,629 597,622 626,614 656,606 686,597 715,587 744,576 772,564 799,550 824,535 849,519 870,500 889,478 908,456 923,430 934,401 945,372 950,338 950,299 Z"
+ id="glyph22" /><glyph
+ unicode="r"
+ horiz-adv-x="556"
+ d="M 142,0 L 142,830 C 142,853 142,876 142,900 141,923 141,946 140,968 139,990 139,1011 138,1030 137,1049 137,1067 136,1082 L 306,1082 C 307,1067 308,1049 309,1030 310,1010 311,990 312,969 313,948 313,929 314,910 314,891 314,874 314,861 L 318,861 C 331,902 344,938 359,969 373,999 390,1024 409,1044 428,1063 451,1078 478,1088 505,1097 537,1102 575,1102 590,1102 604,1101 617,1099 630,1096 641,1094 648,1092 L 648,927 C 636,930 622,933 606,935 590,936 572,937 552,937 511,937 476,928 447,909 418,890 394,865 376,832 357,799 344,759 335,714 326,668 322,618 322,564 L 322,0 142,0 Z"
+ id="glyph24" /><glyph
+ unicode="p"
+ horiz-adv-x="953"
+ d="M 1053,546 C 1053,464 1046,388 1033,319 1020,250 998,190 967,140 936,90 895,51 844,23 793,-6 730,-20 655,-20 578,-20 510,-5 452,24 394,53 350,101 319,168 L 314,168 C 315,167 315,161 316,150 316,139 316,126 317,110 317,94 317,76 318,57 318,37 318,17 318,-2 L 318,-425 138,-425 138,861 C 138,887 138,912 138,936 137,960 137,982 136,1002 135,1021 135,1038 134,1052 133,1066 133,1076 132,1082 L 306,1082 C 307,1080 308,1073 309,1061 310,1049 311,1035 312,1018 313,1001 314,982 315,963 316,944 316,925 316,908 L 320,908 C 337,943 356,972 377,997 398,1021 423,1041 450,1057 477,1072 508,1084 542,1091 575,1098 613,1101 655,1101 730,1101 793,1088 844,1061 895,1034 936,997 967,949 998,900 1020,842 1033,774 1046,705 1053,629 1053,546 Z M 864,542 C 864,609 860,668 852,720 844,772 830,816 811,852 791,888 765,915 732,934 699,953 658,962 609,962 569,962 531,956 496,945 461,934 430,912 404,880 377,848 356,804 341,748 326,691 318,618 318,528 318,451 324,387 337,334 350,281 368,238 393,205 417,172 447,149 483,135 519,120 560,113 607,113 657,113 699,123 732,142 765,161 791,189 811,226 830,263 844,308 852,361 860,414 864,474 864,542 Z"
+ id="glyph26" /><glyph
+ unicode="o"
+ horiz-adv-x="980"
+ d="M 1053,542 C 1053,353 1011,212 928,119 845,26 724,-20 565,-20 490,-20 422,-9 363,14 304,37 254,71 213,118 172,165 140,223 119,294 97,364 86,447 86,542 86,915 248,1102 571,1102 655,1102 728,1090 789,1067 850,1044 900,1009 939,962 978,915 1006,857 1025,787 1044,717 1053,635 1053,542 Z M 864,542 C 864,626 858,695 845,750 832,805 813,848 788,881 763,914 732,937 696,950 660,963 619,969 574,969 528,969 487,962 450,949 413,935 381,912 355,879 329,846 309,802 296,747 282,692 275,624 275,542 275,458 282,389 297,334 312,279 332,235 358,202 383,169 414,146 449,133 484,120 522,113 563,113 609,113 651,120 688,133 725,146 757,168 783,201 809,234 829,278 843,333 857,388 864,458 864,542 Z"
+ id="glyph28" /><glyph
+ unicode="n"
+ horiz-adv-x="900"
+ d="M 825,0 L 825,686 C 825,739 821,783 814,818 806,853 793,882 776,904 759,925 736,941 708,950 679,959 644,963 602,963 559,963 521,956 487,941 452,926 423,904 399,876 374,847 355,812 342,771 329,729 322,681 322,627 L 322,0 142,0 142,851 C 142,874 142,898 142,923 141,948 141,971 140,994 139,1016 139,1035 138,1051 137,1067 137,1077 136,1082 L 306,1082 C 307,1079 307,1070 308,1055 309,1040 310,1024 311,1005 312,986 312,966 313,947 314,927 314,910 314,897 L 317,897 C 334,928 353,957 374,982 395,1007 419,1029 446,1047 473,1064 505,1078 540,1088 575,1097 616,1102 663,1102 723,1102 775,1095 818,1080 861,1065 897,1043 925,1012 953,981 974,942 987,894 1000,845 1006,788 1006,721 L 1006,0 825,0 Z"
+ id="glyph30" /><glyph
+ unicode="m"
+ horiz-adv-x="1456"
+ d="M 768,0 L 768,686 C 768,739 765,783 758,818 751,853 740,882 725,904 709,925 688,941 663,950 638,959 607,963 570,963 532,963 498,956 467,941 436,926 410,904 389,876 367,847 350,812 339,771 327,729 321,681 321,627 L 321,0 142,0 142,851 C 142,874 142,898 142,923 141,948 141,971 140,994 139,1016 139,1035 138,1051 137,1067 137,1077 136,1082 L 306,1082 C 307,1079 307,1070 308,1055 309,1040 310,1024 311,1005 312,986 312,966 313,947 314,927 314,910 314,897 L 317,897 C 333,928 350,957 369,982 388,1007 410,1029 435,1047 460,1064 488,1078 521,1088 553,1097 590,1102 633,1102 715,1102 780,1086 828,1053 875,1020 908,968 927,897 L 930,897 C 946,928 964,957 984,982 1004,1007 1027,1029 1054,1047 1081,1064 1111,1078 1144,1088 1177,1097 1215,1102 1258,1102 1313,1102 1360,1095 1400,1080 1439,1065 1472,1043 1497,1012 1522,981 1541,942 1553,894 1565,845 1571,788 1571,721 L 1571,0 1393,0 1393,686 C 1393,739 1390,783 1383,818 1376,853 1365,882 1350,904 1334,925 1313,941 1288,950 1263,959 1232,963 1195,963 1157,963 1123,956 1092,942 1061,927 1035,906 1014,878 992,850 975,815 964,773 952,731 946,682 946,627 L 946,0 768,0 Z"
+ id="glyph32" /><glyph
+ unicode="l"
+ horiz-adv-x="187"
+ d="M 138,0 L 138,1484 318,1484 318,0 138,0 Z"
+ id="glyph34" /><glyph
+ unicode="k"
+ horiz-adv-x="927"
+ d="M 816,0 L 450,494 318,385 318,0 138,0 138,1484 318,1484 318,557 793,1082 1004,1082 565,617 1027,0 816,0 Z"
+ id="glyph36" /><glyph
+ unicode="j"
+ horiz-adv-x="372"
+ d="M 137,1312 L 137,1484 317,1484 317,1312 137,1312 Z M 317,-132 C 317,-174 314,-212 307,-247 300,-283 287,-313 269,-339 251,-365 227,-386 196,-401 165,-416 125,-423 77,-423 54,-423 32,-423 11,-423 -11,-423 -31,-421 -50,-416 L -50,-277 C -41,-278 -31,-280 -19,-281 -7,-282 3,-283 12,-283 37,-283 58,-280 75,-273 91,-266 104,-256 113,-242 122,-227 129,-209 132,-187 135,-164 137,-138 137,-107 L 137,1082 317,1082 317,-132 Z"
+ id="glyph38" /><glyph
+ unicode="i"
+ horiz-adv-x="187"
+ d="M 137,1312 L 137,1484 317,1484 317,1312 137,1312 Z M 137,0 L 137,1082 317,1082 317,0 137,0 Z"
+ id="glyph40" /><glyph
+ unicode="h"
+ horiz-adv-x="874"
+ d="M 317,897 C 337,934 359,965 382,991 405,1016 431,1037 459,1054 487,1071 518,1083 551,1091 584,1098 622,1102 663,1102 732,1102 789,1093 834,1074 878,1055 913,1029 939,996 964,962 982,922 992,875 1001,828 1006,777 1006,721 L 1006,0 825,0 825,686 C 825,732 822,772 817,807 811,842 800,871 784,894 768,917 745,934 716,946 687,957 649,963 602,963 559,963 521,955 487,940 452,925 423,903 399,875 374,847 355,813 342,773 329,733 322,688 322,638 L 322,0 142,0 142,1484 322,1484 322,1098 C 322,1076 322,1054 321,1032 320,1010 320,990 319,971 318,952 317,937 316,924 315,911 315,902 314,897 L 317,897 Z"
+ id="glyph42" /><glyph
+ unicode="g"
+ horiz-adv-x="954"
+ d="M 548,-425 C 486,-425 431,-419 383,-406 335,-393 294,-375 260,-352 226,-328 198,-300 177,-267 156,-234 140,-198 131,-158 L 312,-132 C 324,-182 351,-220 392,-248 433,-274 486,-288 553,-288 594,-288 631,-282 664,-271 697,-260 726,-241 749,-217 772,-191 790,-159 803,-119 816,-79 822,-30 822,27 L 822,201 820,201 C 807,174 790,148 771,123 751,98 727,75 699,56 670,37 637,21 600,10 563,-2 520,-8 472,-8 403,-8 345,4 296,27 247,50 207,84 176,130 145,176 122,233 108,302 93,370 86,449 86,539 86,626 93,704 108,773 122,842 145,901 178,950 210,998 252,1035 304,1061 355,1086 418,1099 492,1099 569,1099 635,1082 692,1047 748,1012 791,962 822,897 L 824,897 C 824,914 825,932 826,953 827,974 828,993 829,1012 830,1030 831,1046 832,1059 833,1072 835,1080 836,1082 L 1007,1082 C 1006,1076 1006,1066 1005,1052 1004,1037 1004,1020 1003,1000 1002,980 1002,958 1002,934 1001,909 1001,884 1001,858 L 1001,31 C 1001,-120 964,-234 890,-311 815,-387 701,-425 548,-425 Z M 822,541 C 822,616 814,681 798,735 781,788 760,832 733,866 706,900 676,925 642,941 607,957 572,965 536,965 490,965 451,957 418,941 385,925 357,900 336,866 314,831 298,787 288,734 277,680 272,616 272,541 272,463 277,398 288,345 298,292 314,249 335,216 356,183 383,160 416,146 449,132 488,125 533,125 569,125 604,133 639,148 673,163 704,188 731,221 758,254 780,297 797,350 814,403 822,466 822,541 Z"
+ id="glyph44" /><glyph
+ unicode="f"
+ horiz-adv-x="557"
+ d="M 361,951 L 361,0 181,0 181,951 29,951 29,1082 181,1082 181,1204 C 181,1243 185,1280 192,1314 199,1347 213,1377 233,1402 252,1427 279,1446 313,1461 347,1475 391,1482 445,1482 466,1482 489,1481 512,1479 535,1477 555,1474 572,1470 L 572,1333 C 561,1335 548,1337 533,1339 518,1340 504,1341 492,1341 465,1341 444,1337 427,1330 410,1323 396,1312 387,1299 377,1285 370,1268 367,1248 363,1228 361,1205 361,1179 L 361,1082 572,1082 572,951 361,951 Z"
+ id="glyph46" /><glyph
+ unicode="e"
+ horiz-adv-x="980"
+ d="M 276,503 C 276,446 282,394 294,347 305,299 323,258 348,224 372,189 403,163 441,144 479,125 525,115 578,115 656,115 719,131 766,162 813,193 844,233 861,281 L 1019,236 C 1008,206 992,176 972,146 951,115 924,88 890,64 856,39 814,19 763,4 712,-12 650,-20 578,-20 418,-20 296,28 213,123 129,218 87,360 87,548 87,649 100,735 125,806 150,876 185,933 229,977 273,1021 324,1053 383,1073 442,1092 504,1102 571,1102 662,1102 738,1087 799,1058 860,1029 909,988 946,937 983,885 1009,824 1025,754 1040,684 1048,608 1048,527 L 1048,503 276,503 Z M 862,641 C 852,755 823,838 775,891 727,943 658,969 568,969 538,969 507,964 474,955 441,945 410,928 382,903 354,878 330,845 311,803 292,760 281,706 278,641 L 862,641 Z"
+ id="glyph48" /><glyph
+ unicode="d"
+ horiz-adv-x="954"
+ d="M 821,174 C 788,105 744,55 689,25 634,-5 565,-20 484,-20 347,-20 247,26 183,118 118,210 86,349 86,536 86,913 219,1102 484,1102 566,1102 634,1087 689,1057 744,1027 788,979 821,914 L 823,914 C 823,921 823,931 823,946 822,960 822,975 822,991 821,1006 821,1021 821,1035 821,1049 821,1059 821,1065 L 821,1484 1001,1484 1001,223 C 1001,197 1001,172 1002,148 1002,124 1002,102 1003,82 1004,62 1004,45 1005,31 1006,16 1006,6 1007,0 L 835,0 C 834,7 833,16 832,29 831,41 830,55 829,71 828,87 827,104 826,122 825,139 825,157 825,174 L 821,174 Z M 275,542 C 275,467 280,403 289,350 298,297 313,253 334,219 355,184 381,159 413,143 445,127 484,119 530,119 577,119 619,127 656,142 692,157 722,182 747,217 771,251 789,296 802,351 815,406 821,474 821,554 821,631 815,696 802,749 789,802 771,844 746,877 721,910 691,933 656,948 620,962 579,969 532,969 488,969 450,961 418,946 386,931 359,906 338,872 317,838 301,794 291,740 280,685 275,619 275,542 Z"
+ id="glyph50" /><glyph
+ unicode="c"
+ horiz-adv-x="875"
+ d="M 275,546 C 275,484 280,427 289,375 298,323 313,278 334,241 355,203 384,174 419,153 454,132 497,122 548,122 612,122 666,139 709,173 752,206 778,258 788,328 L 970,328 C 964,283 951,239 931,197 911,155 884,118 850,86 815,54 773,28 724,9 675,-10 618,-20 553,-20 468,-20 396,-6 337,23 278,52 230,91 193,142 156,192 129,251 112,320 95,388 87,462 87,542 87,615 93,679 105,735 117,790 134,839 156,881 177,922 203,957 232,986 261,1014 293,1037 328,1054 362,1071 398,1083 436,1091 474,1098 512,1102 551,1102 612,1102 666,1094 713,1077 760,1060 801,1038 836,1009 870,980 898,945 919,906 940,867 955,824 964,779 L 779,765 C 770,825 746,873 708,908 670,943 616,961 546,961 495,961 452,953 418,936 383,919 355,893 334,859 313,824 298,781 289,729 280,677 275,616 275,546 Z"
+ id="glyph52" /><glyph
+ unicode="b"
+ horiz-adv-x="953"
+ d="M 1053,546 C 1053,169 920,-20 655,-20 573,-20 505,-5 451,25 396,54 352,102 318,168 L 316,168 C 316,151 316,133 315,114 314,95 313,78 312,62 311,46 310,32 309,21 308,10 307,3 306,0 L 132,0 C 133,6 133,16 134,31 135,45 135,62 136,82 137,102 137,124 138,148 138,172 138,197 138,223 L 138,1484 318,1484 318,1061 C 318,1041 318,1022 318,1004 317,985 317,969 316,955 315,938 315,923 314,908 L 318,908 C 351,977 396,1027 451,1057 506,1087 574,1102 655,1102 792,1102 892,1056 957,964 1021,872 1053,733 1053,546 Z M 864,540 C 864,615 859,679 850,732 841,785 826,829 805,864 784,898 758,923 726,939 694,955 655,963 609,963 562,963 520,955 484,940 447,925 417,900 393,866 368,832 350,787 337,732 324,677 318,609 318,529 318,452 324,387 337,334 350,281 368,239 393,206 417,173 447,149 483,135 519,120 560,113 607,113 651,113 689,121 721,136 753,151 780,176 801,210 822,244 838,288 849,343 859,397 864,463 864,540 Z"
+ id="glyph54" /><glyph
+ unicode="a"
+ horiz-adv-x="1060"
+ d="M 414,-20 C 305,-20 224,9 169,66 114,124 87,203 87,303 87,375 101,434 128,480 155,526 190,562 234,588 277,614 327,632 383,642 439,652 496,657 554,657 L 797,657 797,717 C 797,762 792,800 783,832 774,863 759,889 740,908 721,928 697,942 668,951 639,960 604,965 565,965 530,965 499,963 471,958 443,953 419,944 398,931 377,918 361,900 348,878 335,855 327,827 323,793 L 135,810 C 142,853 154,892 173,928 192,963 218,994 253,1020 287,1046 330,1066 382,1081 433,1095 496,1102 569,1102 705,1102 807,1071 876,1009 945,946 979,856 979,738 L 979,272 C 979,219 986,179 1000,152 1014,125 1041,111 1080,111 1090,111 1100,112 1110,113 1120,114 1130,116 1139,118 L 1139,6 C 1116,1 1094,-3 1072,-6 1049,-9 1025,-10 1000,-10 966,-10 937,-5 913,4 888,13 868,26 853,45 838,63 826,86 818,113 810,140 805,171 803,207 L 797,207 C 778,172 757,141 734,113 711,85 684,61 653,42 622,22 588,7 549,-4 510,-15 465,-20 414,-20 Z M 455,115 C 512,115 563,125 606,146 649,167 684,194 713,226 741,259 762,294 776,332 790,371 797,408 797,443 L 797,531 600,531 C 556,531 514,528 475,522 435,517 400,506 370,489 340,472 316,449 299,418 281,388 272,349 272,300 272,241 288,195 320,163 351,131 396,115 455,115 Z"
+ id="glyph56" /><glyph
+ unicode="S"
+ horiz-adv-x="1139"
+ d="M 1272,389 C 1272,330 1261,275 1238,225 1215,175 1179,132 1131,96 1083,59 1023,31 950,11 877,-10 790,-20 690,-20 515,-20 378,11 280,72 182,133 120,222 93,338 L 278,375 C 287,338 302,305 321,275 340,245 367,219 400,198 433,176 473,159 522,147 571,135 629,129 697,129 754,129 806,134 853,144 900,153 941,168 975,188 1009,208 1036,234 1055,266 1074,297 1083,335 1083,379 1083,425 1073,462 1052,491 1031,520 1001,543 963,562 925,581 880,596 827,609 774,622 716,635 652,650 613,659 573,668 534,679 494,689 456,701 420,716 383,730 349,747 317,766 285,785 257,809 234,836 211,863 192,894 179,930 166,965 159,1006 159,1053 159,1120 173,1177 200,1225 227,1272 264,1311 312,1342 360,1373 417,1395 482,1409 547,1423 618,1430 694,1430 781,1430 856,1423 918,1410 980,1396 1032,1375 1075,1348 1118,1321 1152,1287 1178,1247 1203,1206 1224,1159 1239,1106 L 1051,1073 C 1042,1107 1028,1137 1011,1164 993,1191 970,1213 941,1231 912,1249 878,1263 837,1272 796,1281 747,1286 692,1286 627,1286 572,1280 528,1269 483,1257 448,1241 421,1221 394,1201 374,1178 363,1151 351,1124 345,1094 345,1063 345,1021 356,987 377,960 398,933 426,910 462,892 498,874 540,859 587,847 634,835 685,823 738,811 781,801 825,791 868,781 911,770 952,758 991,744 1030,729 1067,712 1102,693 1136,674 1166,650 1191,622 1216,594 1236,561 1251,523 1265,485 1272,440 1272,389 Z"
+ id="glyph58" /><glyph
+ unicode="L"
+ horiz-adv-x="900"
+ d="M 168,0 L 168,1409 359,1409 359,156 1071,156 1071,0 168,0 Z"
+ id="glyph60" /><glyph
+ unicode="C"
+ horiz-adv-x="1297"
+ d="M 792,1274 C 712,1274 641,1261 580,1234 518,1207 466,1169 425,1120 383,1071 351,1011 330,942 309,873 298,796 298,711 298,626 310,549 333,479 356,408 389,348 432,297 475,246 527,207 590,179 652,151 722,137 800,137 855,137 905,144 950,159 995,173 1035,193 1072,219 1108,245 1140,276 1169,312 1198,347 1223,387 1245,430 L 1401,352 C 1376,299 1344,250 1307,205 1270,160 1226,120 1176,87 1125,54 1068,28 1005,9 941,-10 870,-20 791,-20 677,-20 577,-2 492,35 406,71 334,122 277,187 219,252 176,329 147,418 118,507 104,605 104,711 104,821 119,920 150,1009 180,1098 224,1173 283,1236 341,1298 413,1346 498,1380 583,1413 681,1430 790,1430 940,1430 1065,1401 1166,1342 1267,1283 1341,1196 1388,1081 L 1207,1021 C 1194,1054 1176,1086 1153,1117 1130,1147 1102,1174 1068,1197 1034,1220 994,1239 949,1253 903,1267 851,1274 792,1274 Z"
+ id="glyph62" /><glyph
+ unicode=","
+ horiz-adv-x="212"
+ d="M 385,219 L 385,51 C 385,16 384,-16 381,-46 378,-74 373,-101 366,-127 359,-151 351,-175 342,-197 332,-219 320,-241 307,-262 L 184,-262 C 214,-219 237,-175 254,-131 270,-87 278,-43 278,0 L 190,0 190,219 385,219 Z"
+ id="glyph64" /><glyph
+ unicode=" "
+ horiz-adv-x="556"
+ id="glyph66" /></font></defs><defs
+ id="defs68"><font
+ id="EmbeddedFont_2"
+ horiz-adv-x="2048"><font-face
+ font-family="Liberation Sans embedded"
+ units-per-em="2048"
+ font-weight="bold"
+ font-style="normal"
+ ascent="1852"
+ descent="423"
+ id="font-face71" /><missing-glyph
+ horiz-adv-x="2048"
+ d="M 0,0 L 2047,0 2047,2047 0,2047 0,0 Z"
+ id="missing-glyph73" /><glyph
+ unicode="w"
+ horiz-adv-x="1615"
+ d="M 436,255 L 645,1082 946,1082 1153,255 1337,1082 1597,1082 1313,0 1016,0 797,882 571,0 274,0 -6,1082 258,1082 436,255 Z"
+ id="glyph75" /><glyph
+ unicode="v"
+ horiz-adv-x="1139"
+ d="M 565,227 L 836,1082 1130,1082 731,0 395,0 8,1082 305,1082 565,227 Z"
+ id="glyph77" /><glyph
+ unicode="u"
+ horiz-adv-x="1007"
+ d="M 408,1082 L 408,475 C 408,433 411,395 418,360 425,325 436,295 451,270 466,245 486,225 511,211 535,197 565,190 600,190 634,190 665,198 693,213 720,228 744,249 764,277 784,304 800,337 811,376 822,414 827,456 827,502 L 827,1082 1108,1082 1108,242 C 1108,219 1108,196 1109,171 1109,146 1110,122 1111,100 1112,77 1113,57 1114,40 1115,22 1115,9 1116,0 L 848,0 C 847,8 846,21 845,39 843,56 842,76 841,97 840,118 839,140 838,161 837,182 836,200 836,215 L 831,215 C 794,133 746,73 689,36 631,-1 562,-20 483,-20 418,-20 363,-9 318,12 273,33 236,63 208,100 179,137 159,180 146,231 133,282 127,336 127,395 L 127,1082 408,1082 Z"
+ id="glyph79" /><glyph
+ unicode="t"
+ horiz-adv-x="636"
+ d="M 420,-18 C 337,-18 274,5 229,50 184,95 162,163 162,254 L 162,892 25,892 25,1082 176,1082 264,1336 440,1336 440,1082 645,1082 645,892 440,892 440,330 C 440,277 450,239 470,214 490,189 521,176 563,176 580,176 596,177 610,180 624,183 640,186 657,190 L 657,16 C 622,5 586,-4 547,-10 508,-15 466,-18 420,-18 Z"
+ id="glyph81" /><glyph
+ unicode="s"
+ horiz-adv-x="980"
+ d="M 1055,316 C 1055,264 1044,217 1023,176 1001,135 969,100 928,71 887,42 836,19 776,4 716,-12 648,-20 571,-20 502,-20 440,-15 385,-5 330,5 281,22 240,45 198,68 163,97 135,134 107,171 86,216 72,270 L 319,307 C 327,277 338,253 352,234 366,215 383,201 404,191 425,181 449,174 477,171 504,168 536,166 571,166 603,166 633,168 661,172 688,175 712,182 733,191 753,200 769,212 780,229 791,245 797,265 797,290 797,318 789,340 773,357 756,373 734,386 706,397 677,407 644,416 606,424 567,431 526,440 483,450 438,460 393,472 349,486 305,500 266,519 231,543 196,567 168,598 147,635 126,672 115,718 115,775 115,826 125,872 145,913 165,953 194,987 233,1016 272,1044 320,1066 377,1081 434,1096 499,1103 573,1103 632,1103 686,1098 737,1087 788,1076 833,1058 873,1035 913,1011 947,981 974,944 1001,907 1019,863 1030,811 L 781,785 C 776,811 768,833 756,850 744,867 729,880 712,890 694,900 673,907 650,911 627,914 601,916 573,916 506,916 456,908 423,891 390,874 373,845 373,805 373,780 380,761 394,746 407,731 427,719 452,710 477,700 506,692 541,685 575,678 612,669 653,659 703,648 752,636 801,622 849,607 892,588 930,563 967,538 998,505 1021,466 1044,427 1055,377 1055,316 Z"
+ id="glyph83" /><glyph
+ unicode="r"
+ horiz-adv-x="662"
+ d="M 143,0 L 143,828 C 143,851 143,876 143,902 142,928 142,953 141,977 140,1000 139,1022 138,1041 137,1060 136,1073 135,1082 L 403,1082 C 404,1074 406,1060 407,1041 408,1021 410,999 411,976 412,953 414,930 415,907 416,884 416,865 416,851 L 420,851 C 434,890 448,926 462,957 476,988 493,1014 512,1036 531,1057 553,1074 580,1086 607,1097 640,1103 679,1103 696,1103 712,1102 729,1099 745,1096 757,1092 766,1088 L 766,853 C 748,857 730,861 712,864 693,867 671,868 646,868 576,868 522,840 483,783 444,726 424,642 424,531 L 424,0 143,0 Z"
+ id="glyph85" /><glyph
+ unicode="o"
+ horiz-adv-x="1086"
+ d="M 1171,542 C 1171,459 1160,384 1137,315 1114,246 1079,187 1033,138 987,88 930,49 861,22 792,-6 712,-20 621,-20 533,-20 455,-6 388,21 321,48 264,87 219,136 173,185 138,245 115,314 92,383 80,459 80,542 80,623 91,697 114,766 136,834 170,893 215,943 260,993 317,1032 386,1060 455,1088 535,1102 627,1102 724,1102 807,1088 876,1060 945,1032 1001,993 1045,944 1088,894 1120,835 1141,767 1161,698 1171,623 1171,542 Z M 877,542 C 877,671 856,764 814,822 772,880 711,909 631,909 548,909 485,880 441,821 397,762 375,669 375,542 375,477 381,422 393,375 404,328 421,290 442,260 463,230 489,208 519,194 549,179 582,172 618,172 659,172 696,179 729,194 761,208 788,230 810,260 832,290 849,328 860,375 871,422 877,477 877,542 Z"
+ id="glyph87" /><glyph
+ unicode="n"
+ horiz-adv-x="1006"
+ d="M 844,0 L 844,607 C 844,649 841,688 834,723 827,758 816,788 801,813 786,838 766,857 741,871 716,885 686,892 651,892 617,892 586,885 559,870 531,855 507,833 487,806 467,778 452,745 441,707 430,668 424,626 424,580 L 424,0 143,0 143,840 C 143,863 143,887 143,912 142,937 142,960 141,983 140,1005 139,1025 138,1043 137,1060 136,1073 135,1082 L 403,1082 C 404,1074 406,1061 407,1044 408,1026 410,1006 411,985 412,964 414,942 415,921 416,900 416,882 416,867 L 420,867 C 458,950 506,1010 563,1047 620,1084 689,1103 768,1103 833,1103 889,1092 934,1071 979,1050 1015,1020 1044,983 1072,946 1092,902 1105,851 1118,800 1124,746 1124,687 L 1124,0 844,0 Z"
+ id="glyph89" /><glyph
+ unicode="m"
+ horiz-adv-x="1562"
+ d="M 780,0 L 780,607 C 780,649 777,688 772,723 766,758 757,788 744,813 731,838 714,857 693,871 672,885 646,892 616,892 587,892 561,885 538,870 515,855 495,833 478,806 461,778 447,745 438,707 429,668 424,626 424,580 L 424,0 143,0 143,840 C 143,863 143,887 143,912 142,937 142,960 141,983 140,1005 139,1025 138,1043 137,1060 136,1073 135,1082 L 403,1082 C 404,1074 406,1061 407,1044 408,1026 410,1006 411,985 412,964 414,942 415,921 416,900 416,882 416,867 L 420,867 C 455,950 498,1010 550,1047 601,1084 663,1103 735,1103 818,1103 884,1083 935,1043 985,1002 1019,944 1036,867 L 1042,867 C 1061,912 1082,949 1105,979 1127,1009 1152,1033 1179,1052 1206,1070 1235,1083 1267,1091 1298,1099 1333,1103 1370,1103 1429,1103 1480,1092 1521,1071 1562,1050 1595,1020 1621,983 1646,946 1665,902 1677,851 1688,800 1694,746 1694,687 L 1694,0 1415,0 1415,607 C 1415,649 1412,688 1407,723 1401,758 1392,788 1379,813 1366,838 1349,857 1328,871 1307,885 1281,892 1251,892 1223,892 1198,885 1175,871 1152,856 1132,836 1115,810 1098,783 1084,752 1075,715 1066,678 1060,638 1059,593 L 1059,0 780,0 Z"
+ id="glyph91" /><glyph
+ unicode="l"
+ horiz-adv-x="292"
+ d="M 143,0 L 143,1484 424,1484 424,0 143,0 Z"
+ id="glyph93" /><glyph
+ unicode="j"
+ horiz-adv-x="477"
+ d="M 144,1277 L 144,1484 425,1484 425,1277 144,1277 Z M 138,-423 C 101,-423 68,-423 41,-423 13,-423 -11,-421 -32,-416 L -32,-218 C -23,-219 -15,-220 -6,-221 3,-222 11,-222 19,-222 45,-222 66,-219 82,-214 98,-209 111,-200 120,-187 129,-174 136,-158 139,-137 142,-116 144,-91 144,-60 L 144,1082 425,1082 425,-126 C 425,-170 420,-209 409,-245 398,-281 382,-312 359,-339 336,-366 306,-386 270,-401 233,-416 189,-423 138,-423 Z"
+ id="glyph95" /><glyph
+ unicode="i"
+ horiz-adv-x="292"
+ d="M 143,1277 L 143,1484 424,1484 424,1277 143,1277 Z M 143,0 L 143,1082 424,1082 424,0 143,0 Z"
+ id="glyph97" /><glyph
+ unicode="g"
+ horiz-adv-x="1060"
+ d="M 596,-434 C 525,-434 462,-427 408,-413 353,-398 307,-378 269,-353 230,-327 200,-296 177,-261 154,-225 138,-186 129,-143 L 410,-110 C 420,-153 442,-187 475,-212 508,-237 551,-249 604,-249 637,-249 668,-244 696,-235 723,-226 747,-210 767,-188 786,-165 802,-136 813,-99 824,-62 829,-17 829,37 829,56 829,75 829,94 829,113 829,131 830,147 831,166 831,184 831,201 L 829,201 C 796,131 751,80 692,49 633,18 562,2 481,2 412,2 353,16 304,43 254,70 213,107 180,156 147,204 123,262 108,329 92,396 84,469 84,550 84,633 92,709 109,777 126,844 151,902 186,951 220,1000 263,1037 316,1064 368,1090 430,1103 502,1103 574,1103 639,1088 696,1057 753,1026 797,977 829,908 L 834,908 C 834,922 835,938 836,957 837,975 838,993 839,1010 840,1027 842,1042 844,1055 845,1068 847,1077 848,1082 L 1114,1082 C 1113,1058 1111,1024 1110,981 1109,938 1108,888 1108,832 L 1108,33 C 1108,-46 1097,-114 1074,-173 1051,-231 1018,-279 975,-318 931,-357 877,-386 814,-405 750,-424 677,-434 596,-434 Z M 831,556 C 831,624 824,681 811,726 798,771 780,808 759,835 738,862 713,882 686,893 658,904 630,910 602,910 566,910 534,903 507,889 479,875 455,853 436,824 417,795 402,757 392,712 382,667 377,613 377,550 377,433 396,345 433,286 470,227 526,197 600,197 628,197 656,203 684,214 711,225 736,244 758,272 780,299 798,336 811,382 824,428 831,486 831,556 Z"
+ id="glyph99" /><glyph
+ unicode="f"
+ horiz-adv-x="663"
+ d="M 473,892 L 473,0 193,0 193,892 35,892 35,1082 193,1082 193,1195 C 193,1236 198,1275 208,1310 218,1345 235,1375 259,1401 283,1427 315,1447 356,1462 397,1477 447,1484 508,1484 540,1484 572,1482 603,1479 634,1476 661,1472 686,1468 L 686,1287 C 674,1290 661,1292 646,1294 631,1295 617,1296 604,1296 578,1296 557,1293 540,1288 523,1283 509,1275 500,1264 490,1253 483,1240 479,1224 475,1207 473,1188 473,1167 L 473,1082 686,1082 686,892 473,892 Z"
+ id="glyph101" /><glyph
+ unicode="e"
+ horiz-adv-x="980"
+ d="M 586,-20 C 508,-20 438,-8 376,15 313,38 260,73 216,120 172,167 138,226 115,297 92,368 80,451 80,546 80,649 94,736 122,807 149,878 187,935 234,979 281,1022 335,1054 396,1073 457,1092 522,1102 590,1102 675,1102 748,1087 809,1058 869,1028 918,986 957,933 996,880 1024,816 1042,742 1060,667 1069,585 1069,495 L 1069,487 375,487 C 375,442 379,400 387,361 395,322 408,288 426,260 444,231 467,209 496,193 525,176 559,168 600,168 649,168 690,179 721,200 752,221 775,253 788,297 L 1053,274 C 1041,243 1024,211 1003,176 981,141 952,110 916,81 880,52 835,28 782,9 728,-10 663,-20 586,-20 Z M 586,925 C 557,925 531,920 506,911 481,901 459,886 441,865 422,844 407,816 396,783 385,750 378,710 377,663 L 797,663 C 792,750 771,816 734,860 697,903 648,925 586,925 Z"
+ id="glyph103" /><glyph
+ unicode="d"
+ horiz-adv-x="1060"
+ d="M 844,0 C 843,5 841,15 840,29 838,42 836,58 835,75 833,92 832,110 831,128 830,146 829,162 829,176 L 825,176 C 792,106 747,56 689,26 630,-5 560,-20 479,-20 411,-20 352,-6 303,22 253,50 212,89 180,139 147,189 123,248 108,317 92,385 84,459 84,540 84,622 92,697 109,766 125,835 150,894 184,944 218,993 261,1032 314,1060 366,1088 428,1102 500,1102 535,1102 569,1098 602,1091 635,1084 665,1072 693,1057 721,1042 746,1022 769,998 792,974 811,945 827,911 L 829,911 C 829,918 829,928 829,941 828,954 828,968 828,985 828,1002 828,1019 828,1037 827,1055 827,1072 827,1089 L 827,1484 1108,1484 1108,236 C 1108,183 1109,137 1111,96 1113,55 1115,23 1116,0 L 844,0 Z M 831,547 C 831,618 824,678 811,725 798,772 780,809 759,837 737,864 712,884 685,895 657,906 629,911 600,911 564,911 532,904 505,890 477,876 454,854 435,824 416,794 401,756 392,709 382,662 377,606 377,540 377,295 451,172 598,172 626,172 654,178 682,190 710,202 735,222 757,251 779,280 797,318 811,367 824,415 831,475 831,547 Z"
+ id="glyph105" /><glyph
+ unicode="c"
+ horiz-adv-x="1007"
+ d="M 594,-20 C 508,-20 433,-7 369,20 304,47 251,84 208,133 165,182 133,240 112,309 91,377 80,452 80,535 80,625 92,705 115,776 138,846 172,905 216,954 260,1002 314,1039 379,1064 443,1089 516,1102 598,1102 668,1102 730,1092 785,1073 839,1054 886,1028 925,995 964,963 996,924 1021,879 1045,834 1062,786 1071,734 L 788,734 C 780,787 760,830 728,861 696,893 651,909 592,909 517,909 462,878 427,816 392,754 375,664 375,546 375,297 449,172 596,172 649,172 694,188 730,221 766,253 788,302 797,366 L 1079,366 C 1072,315 1057,267 1034,220 1010,174 978,133 938,97 897,62 848,33 791,12 734,-9 668,-20 594,-20 Z"
+ id="glyph107" /><glyph
+ unicode="a"
+ horiz-adv-x="1112"
+ d="M 393,-20 C 341,-20 295,-13 254,2 213,16 178,37 149,65 120,93 98,127 83,168 68,208 60,255 60,307 60,371 71,425 94,469 116,513 146,548 185,575 224,602 269,622 321,634 373,647 428,653 487,653 L 720,653 720,709 C 720,748 717,782 710,808 703,835 692,857 679,873 666,890 649,902 630,909 610,916 587,920 562,920 539,920 518,918 500,913 481,909 465,901 452,890 439,879 428,864 420,845 411,826 405,803 402,774 L 109,774 C 117,822 132,866 153,906 174,946 204,981 242,1010 279,1039 326,1062 381,1078 436,1094 500,1102 574,1102 641,1102 701,1094 754,1077 807,1060 851,1036 888,1003 925,970 953,929 972,881 991,833 1001,777 1001,714 L 1001,320 C 1001,295 1002,272 1005,252 1007,232 1011,215 1018,202 1024,188 1033,178 1045,171 1056,164 1071,160 1090,160 1111,160 1132,162 1152,166 L 1152,14 C 1135,10 1120,6 1107,3 1094,0 1080,-3 1067,-5 1054,-7 1040,-9 1025,-10 1010,-11 992,-12 972,-12 901,-12 849,5 816,40 782,75 762,126 755,193 L 749,193 C 712,126 664,73 606,36 547,-1 476,-20 393,-20 Z M 720,499 L 576,499 C 546,499 518,497 491,493 464,490 440,482 420,470 399,459 383,442 371,420 359,397 353,367 353,329 353,277 365,239 389,214 412,189 444,176 483,176 519,176 552,184 581,199 610,214 635,234 656,259 676,284 692,312 703,345 714,377 720,411 720,444 L 720,499 Z"
+ id="glyph109" /><glyph
+ unicode="R"
+ horiz-adv-x="1351"
+ d="M 1105,0 L 778,535 432,535 432,0 137,0 137,1409 841,1409 C 929,1409 1006,1399 1072,1380 1137,1360 1192,1332 1236,1296 1280,1259 1313,1215 1335,1164 1356,1112 1367,1054 1367,989 1367,936 1359,888 1344,845 1328,801 1306,762 1279,728 1251,694 1218,666 1180,643 1142,620 1101,603 1056,592 L 1437,0 1105,0 Z M 1070,977 C 1070,1046 1048,1097 1003,1130 958,1163 893,1180 810,1180 L 432,1180 432,764 818,764 C 862,764 900,769 932,780 963,790 989,805 1010,824 1030,843 1045,865 1055,891 1065,917 1070,946 1070,977 Z"
+ id="glyph111" /><glyph
+ unicode="P"
+ horiz-adv-x="1139"
+ d="M 1296,963 C 1296,902 1286,844 1266,788 1245,731 1214,681 1172,638 1130,595 1077,560 1012,535 947,509 871,496 782,496 L 432,496 432,0 137,0 137,1409 770,1409 C 860,1409 938,1398 1004,1377 1070,1355 1125,1324 1168,1285 1211,1246 1244,1199 1265,1144 1286,1089 1296,1029 1296,963 Z M 999,958 C 999,1031 977,1086 934,1124 890,1161 824,1180 737,1180 L 432,1180 432,723 745,723 C 789,723 827,729 859,740 890,751 917,767 938,788 959,809 974,834 984,863 994,892 999,923 999,958 Z"
+ id="glyph113" /><glyph
+ unicode="M"
+ horiz-adv-x="1457"
+ d="M 1307,0 L 1307,854 C 1307,888 1308,923 1309,959 1310,995 1311,1028 1312,1058 1314,1093 1316,1128 1317,1161 1303,1108 1290,1058 1277,1011 1272,991 1266,970 1260,949 1254,928 1248,907 1243,887 1237,867 1231,848 1226,831 1221,814 1216,799 1212,786 L 958,0 748,0 494,786 C 490,799 486,814 481,831 476,848 470,867 465,887 459,907 453,928 447,949 441,970 435,991 429,1011 416,1058 402,1108 387,1161 389,1122 391,1084 393,1047 394,1015 396,981 397,946 398,911 399,880 399,854 L 399,0 137,0 137,1409 532,1409 784,621 C 791,600 798,575 806,545 813,515 821,486 828,458 836,425 845,391 854,356 863,391 872,424 881,456 885,470 889,484 893,499 897,514 901,528 905,542 909,556 913,569 917,582 921,595 925,606 928,616 L 1176,1409 1569,1409 1569,0 1307,0 Z"
+ id="glyph115" /><glyph
+ unicode="F"
+ horiz-adv-x="1033"
+ d="M 432,1181 L 432,745 1153,745 1153,517 432,517 432,0 137,0 137,1409 1176,1409 1176,1181 432,1181 Z"
+ id="glyph117" /><glyph
+ unicode="D"
+ horiz-adv-x="1271"
+ d="M 1393,715 C 1393,598 1375,495 1340,406 1305,317 1256,242 1195,182 1134,122 1061,77 978,46 894,15 804,0 707,0 L 137,0 137,1409 647,1409 C 756,1409 857,1395 948,1368 1039,1341 1118,1299 1184,1242 1250,1185 1301,1113 1338,1026 1375,939 1393,835 1393,715 Z M 1096,715 C 1096,797 1085,867 1063,926 1040,985 1009,1033 969,1071 929,1108 881,1136 826,1154 770,1172 708,1181 641,1181 L 432,1181 432,228 682,228 C 741,228 796,238 847,259 897,280 941,311 978,352 1015,393 1044,443 1065,504 1086,565 1096,635 1096,715 Z"
+ id="glyph119" /><glyph
+ unicode=":"
+ horiz-adv-x="292"
+ d="M 197,752 L 197,1034 485,1034 485,752 197,752 Z M 197,0 L 197,281 485,281 485,0 197,0 Z"
+ id="glyph121" /><glyph
+ unicode=" "
+ horiz-adv-x="556"
+ id="glyph123" /></font></defs><defs
+ class="TextShapeIndex"
+ id="defs125"><g
+ ooo:slide="id1"
+ ooo:id-list="id3 id4 id5 id6 id7 id8 id9 id10 id11"
+ id="g127" /></defs><defs
+ class="EmbeddedBulletChars"
+ id="defs129"><g
+ id="bullet-char-template(57356)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 580,1141 L 1163,571 580,0 -4,571 580,1141 Z"
+ id="path132" /></g><g
+ id="bullet-char-template(57354)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 8,1128 L 1137,1128 1137,0 8,0 8,1128 Z"
+ id="path135" /></g><g
+ id="bullet-char-template(10146)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 174,0 L 602,739 174,1481 1456,739 174,0 Z M 1358,739 L 309,1346 659,739 1358,739 Z"
+ id="path138" /></g><g
+ id="bullet-char-template(10132)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 2015,739 L 1276,0 717,0 1260,543 174,543 174,936 1260,936 717,1481 1274,1481 2015,739 Z"
+ id="path141" /></g><g
+ id="bullet-char-template(10007)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 0,-2 C -7,14 -16,27 -25,37 L 356,567 C 262,823 215,952 215,954 215,979 228,992 255,992 264,992 276,990 289,987 310,991 331,999 354,1012 L 381,999 492,748 772,1049 836,1024 860,1049 C 881,1039 901,1025 922,1006 886,937 835,863 770,784 769,783 710,716 594,584 L 774,223 C 774,196 753,168 711,139 L 727,119 C 717,90 699,76 672,76 641,76 570,178 457,381 L 164,-76 C 142,-110 111,-127 72,-127 30,-127 9,-110 8,-76 1,-67 -2,-52 -2,-32 -2,-23 -1,-13 0,-2 Z"
+ id="path144" /></g><g
+ id="bullet-char-template(10004)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 285,-33 C 182,-33 111,30 74,156 52,228 41,333 41,471 41,549 55,616 82,672 116,743 169,778 240,778 293,778 328,747 346,684 L 369,508 C 377,444 397,411 428,410 L 1163,1116 C 1174,1127 1196,1133 1229,1133 1271,1133 1292,1118 1292,1087 L 1292,965 C 1292,929 1282,901 1262,881 L 442,47 C 390,-6 338,-33 285,-33 Z"
+ id="path147" /></g><g
+ id="bullet-char-template(9679)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 813,0 C 632,0 489,54 383,161 276,268 223,411 223,592 223,773 276,916 383,1023 489,1130 632,1184 813,1184 992,1184 1136,1130 1245,1023 1353,916 1407,772 1407,592 1407,412 1353,268 1245,161 1136,54 992,0 813,0 Z"
+ id="path150" /></g><g
+ id="bullet-char-template(8226)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M 346,457 C 273,457 209,483 155,535 101,586 74,649 74,723 74,796 101,859 155,911 209,963 273,989 346,989 419,989 480,963 531,910 582,859 608,796 608,723 608,648 583,586 532,535 482,483 420,457 346,457 Z"
+ id="path153" /></g><g
+ id="bullet-char-template(8211)"
+ transform="scale(0.00048828125,-0.00048828125)"><path
+ d="M -4,459 L 1135,459 1135,606 -4,606 -4,459 Z"
+ id="path156" /></g></defs><defs
+ class="TextEmbeddedBitmaps"
+ id="defs158" /><g
+ id="g160"><g
+ id="id2"
+ class="Master_Slide"><g
+ id="bg-id2"
+ class="Background" /><g
+ id="bo-id2"
+ class="BackgroundObjects" /></g></g><g
+ class="SlideGroup"
+ id="g165"><g
+ id="g167"><g
+ id="id1"
+ class="Slide"
+ clip-path="url(#presentation_clip_path)"><g
+ class="Page"
+ id="g170"><g
+ class="com.sun.star.drawing.CustomShape"
+ id="g172"><g
+ id="id3"><path
+ fill="rgb(114,159,207)"
+ stroke="none"
+ d="M 10500,6200 L 6250,6200 6250,2900 14750,2900 14750,6200 10500,6200 Z"
+ id="path175" /><path
+ fill="none"
+ stroke="rgb(52,101,164)"
+ d="M 10500,6200 L 6250,6200 6250,2900 14750,2900 14750,6200 10500,6200 Z"
+ id="path177" /><text
+ class="TextShape"
+ id="text179"><tspan
+ class="TextParagraph"
+ font-family="Liberation Sans, sans-serif"
+ font-size="635px"
+ font-weight="700"
+ id="tspan181"><tspan
+ class="TextPosition"
+ x="7272"
+ y="4415"
+ id="tspan183"><tspan
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan185">Project management:</tspan></tspan><tspan
+ class="TextPosition"
+ x="6978"
+ y="5126"
+ id="tspan187"><tspan
+ font-weight="400"
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan189">Load or save project files</tspan></tspan></tspan></text>
+</g></g><g
+ class="com.sun.star.drawing.CustomShape"
+ id="g191"><g
+ id="id4"><path
+ fill="rgb(114,159,207)"
+ stroke="none"
+ d="M 10500,11300 L 3550,11300 3550,8000 17450,8000 17450,11300 10500,11300 Z"
+ id="path194" /><path
+ fill="none"
+ stroke="rgb(52,101,164)"
+ d="M 10500,11300 L 3550,11300 3550,8000 17450,8000 17450,11300 10500,11300 Z"
+ id="path196" /><text
+ class="TextShape"
+ id="text198"><tspan
+ class="TextParagraph"
+ font-family="Liberation Sans, sans-serif"
+ font-size="635px"
+ font-weight="700"
+ id="tspan200"><tspan
+ class="TextPosition"
+ x="7205"
+ y="9515"
+ id="tspan202"><tspan
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan204">Dataset management:</tspan></tspan><tspan
+ class="TextPosition"
+ x="4491"
+ y="10226"
+ id="tspan206"><tspan
+ font-weight="400"
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan208">Load, create, edit, move or delete datasets</tspan></tspan></tspan></text>
+</g></g><g
+ class="com.sun.star.drawing.CustomShape"
+ id="g210"><g
+ id="id5"><path
+ fill="rgb(114,159,207)"
+ stroke="none"
+ d="M 10500,16400 L 3550,16400 3550,13100 17450,13100 17450,16400 10500,16400 Z"
+ id="path213" /><path
+ fill="none"
+ stroke="rgb(52,101,164)"
+ d="M 10500,16400 L 3550,16400 3550,13100 17450,13100 17450,16400 10500,16400 Z"
+ id="path215" /><text
+ class="TextShape"
+ id="text217"><tspan
+ class="TextParagraph"
+ font-family="Liberation Sans, sans-serif"
+ font-size="635px"
+ font-weight="700"
+ id="tspan219"><tspan
+ class="TextPosition"
+ x="7429"
+ y="14615"
+ id="tspan221"><tspan
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan223">Model management:</tspan></tspan><tspan
+ class="TextPosition"
+ x="4491"
+ y="15326"
+ id="tspan225"><tspan
+ font-weight="400"
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan227">Select, create, edit, move or delete models</tspan></tspan></tspan></text>
+</g></g><g
+ class="com.sun.star.drawing.CustomShape"
+ id="g229"><g
+ id="id6"><path
+ fill="rgb(114,159,207)"
+ stroke="none"
+ d="M 10500,21500 L 2000,21500 2000,18200 19000,18200 19000,21500 10500,21500 Z"
+ id="path232" /><path
+ fill="none"
+ stroke="rgb(52,101,164)"
+ d="M 10500,21500 L 2000,21500 2000,18200 19000,18200 19000,21500 10500,21500 Z"
+ id="path234" /><text
+ class="TextShape"
+ id="text236"><tspan
+ class="TextParagraph"
+ font-family="Liberation Sans, sans-serif"
+ font-size="635px"
+ font-weight="700"
+ id="tspan238"><tspan
+ class="TextPosition"
+ x="7882"
+ y="19715"
+ id="tspan240"><tspan
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan242">Fit configuration:</tspan></tspan><tspan
+ class="TextPosition"
+ x="2698"
+ y="20426"
+ id="tspan244"><tspan
+ font-weight="400"
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan246">Combine model with data, set fit options and start the fit</tspan></tspan></tspan></text>
+</g></g><g
+ class="com.sun.star.drawing.CustomShape"
+ id="g248"><g
+ id="id7"><path
+ fill="rgb(114,159,207)"
+ stroke="none"
+ d="M 10463,26663 L 1313,26663 1313,23363 19613,23363 19613,26663 10463,26663 Z"
+ id="path251" /><path
+ fill="none"
+ stroke="rgb(52,101,164)"
+ d="M 10463,26663 L 1313,26663 1313,23363 19613,23363 19613,26663 10463,26663 Z"
+ id="path253" /><text
+ class="TextShape"
+ id="text255"><tspan
+ class="TextParagraph"
+ font-family="Liberation Sans, sans-serif"
+ font-size="635px"
+ font-weight="700"
+ id="tspan257"><tspan
+ class="TextPosition"
+ x="8311"
+ y="24878"
+ id="tspan259"><tspan
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan261">Result viewer:</tspan></tspan><tspan
+ class="TextPosition"
+ x="1660"
+ y="25589"
+ id="tspan263"><tspan
+ font-weight="400"
+ fill="rgb(0,0,0)"
+ stroke="none"
+ id="tspan265">Check graphs and statistics, view endpoints, save or delete fits</tspan></tspan></tspan></text>
+</g></g><g
+ class="com.sun.star.drawing.LineShape"
+ id="g267"><g
+ id="id8"><path
+ fill="none"
+ stroke="rgb(0,0,0)"
+ d="M 10500,6200 L 10500,7570"
+ id="path270" /><path
+ fill="rgb(0,0,0)"
+ stroke="none"
+ d="M 10500,8000 L 10650,7550 10350,7550 10500,8000 Z"
+ id="path272" /></g></g><g
+ class="com.sun.star.drawing.LineShape"
+ id="g274"><g
+ id="id9"><path
+ fill="none"
+ stroke="rgb(0,0,0)"
+ d="M 10500,11300 L 10500,12670"
+ id="path277" /><path
+ fill="rgb(0,0,0)"
+ stroke="none"
+ d="M 10500,13100 L 10650,12650 10350,12650 10500,13100 Z"
+ id="path279" /></g></g><g
+ class="com.sun.star.drawing.LineShape"
+ id="g281"><g
+ id="id10"><path
+ fill="none"
+ stroke="rgb(0,0,0)"
+ d="M 10500,16400 L 10500,17770"
+ id="path284" /><path
+ fill="rgb(0,0,0)"
+ stroke="none"
+ d="M 10500,18200 L 10650,17750 10350,17750 10500,18200 Z"
+ id="path286" /></g></g><g
+ class="com.sun.star.drawing.LineShape"
+ id="g288"><g
+ id="id11"><path
+ fill="none"
+ stroke="rgb(0,0,0)"
+ d="M 10500,21500 L 10500,22970"
+ id="path291" /><path
+ fill="rgb(0,0,0)"
+ stroke="none"
+ d="M 10500,23400 L 10650,22950 10350,22950 10500,23400 Z"
+ id="path293" /></g></g></g></g></g></g></svg> \ No newline at end of file

Contact - Imprint