File: GridSettings.cpp

package info (click to toggle)
ausaxs 1.1.8-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 72,592 kB
  • sloc: cpp: 49,853; ansic: 6,901; python: 730; makefile: 18
file content (46 lines) | stat: -rw-r--r-- 2,146 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// SPDX-License-Identifier: LGPL-3.0-or-later
// Author: Kristian Lytje

#include <settings/GridSettings.h>
#include <settings/SettingsIORegistry.h>
#include <utility/Exceptions.h>

using namespace ausaxs;

double settings::grid::water_scaling = 0.01;
double settings::grid::cell_width = 1;
double settings::grid::scaling = 0.25;
bool settings::grid::cubic = false;
double settings::grid::min_exv_radius = 2.15;
unsigned int settings::grid::min_bins = 0;

double settings::grid::exv::surface_thickness = 1;
double settings::grid::exv::width = 1;
bool settings::grid::exv::save = false;
settings::grid::exv::ExvType settings::grid::exv::expansion_strategy = settings::grid::exv::ExvType::AtomicOnly;

double settings::grid::detail::min_score = 0.25;

namespace ausaxs::settings::io {
    settings::io::SettingSection grid_section("Grid", {
        settings::io::create(grid::water_scaling, "water_scaling"),
        settings::io::create(grid::cell_width, "width"),
        settings::io::create(grid::scaling, "scaling"),
        settings::io::create(grid::cubic, "cubic"),
        settings::io::create(grid::min_exv_radius, "rvol"),
        settings::io::create(grid::exv::width, "exv_width"),
        settings::io::create(grid::exv::save, "save_exv"),
        settings::io::create(grid::exv::surface_thickness, "surface_thickness"),
        settings::io::create(grid::detail::min_score, "detail.min_score"),
    });
}

template<> std::string settings::io::detail::SettingRef<Limit3D>::get() const {
    return std::to_string(settingref.x.min) + " " + std::to_string(settingref.x.max) + " "
         + std::to_string(settingref.y.min) + " " + std::to_string(settingref.y.max) + " " 
         + std::to_string(settingref.z.min) + " " + std::to_string(settingref.z.max);
}
template<> void settings::io::detail::SettingRef<Limit3D>::set(const std::vector<std::string>& val) {
    if (val.size() != 6) throw except::io_error("settings::grid::axes: Expected 6 values, got " + std::to_string(val.size()) + ".");
    settingref = Limit3D(std::stod(val[0]), std::stod(val[1]), std::stod(val[2]), std::stod(val[3]), std::stod(val[4]), std::stod(val[5]));
}