/**
* \file
* \author Karsten Rink
* \date 2013-03-18
* \brief Implementation of the StationBorehole class.
*
* \copyright
* Copyright (c) 2012-2020, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#include "StationBorehole.h"
#include <algorithm>
#include <cmath>
#include <cstdlib>
#include <fstream>
#include "BaseLib/Logging.h"
#include "BaseLib/StringTools.h"
#include "BaseLib/DateTools.h"
namespace GeoLib
{
////////////////////////
// The Borehole class //
////////////////////////
StationBorehole::StationBorehole(double x,
double y,
double z,
const std::string& name)
: Station(x, y, z, name)
{
_type = Station::StationType::BOREHOLE;
// add first point of borehole
_profilePntVec.push_back(this);
_soilName.emplace_back("");
}
StationBorehole::~StationBorehole()
{
// deletes profile vector of borehole, starting at layer 1
// the first point is NOT deleted as it points to the station object itself
for (std::size_t k(1); k < _profilePntVec.size(); k++)
{
delete _profilePntVec[k];
}
}
StationBorehole* StationBorehole::createStation(const std::string &line)
{
StationBorehole* borehole = new StationBorehole();
std::list<std::string> fields = BaseLib::splitString(line, '\t');
if (fields.size() >= 5)
{
borehole->_name = fields.front();
fields.pop_front();
(*borehole)[0] = strtod(BaseLib::replaceString(",", ".", fields.front()).c_str(), nullptr);
fields.pop_front();
(*borehole)[1] = strtod(BaseLib::replaceString(",", ".", fields.front()).c_str(), nullptr);
fields.pop_front();
(*borehole)[2] = strtod(BaseLib::replaceString(",", ".", fields.front()).c_str(), nullptr);
fields.pop_front();
borehole->_depth = strtod(BaseLib::replaceString(",", ".", fields.front()).c_str(), nullptr);
fields.pop_front();
if (fields.empty())
{
borehole->_date = 0;
}
else
{
borehole->_date = BaseLib::strDate2int(fields.front());
fields.pop_front();
}
}
else
{
WARN("Station::createStation() - Unexpected file format.");
delete borehole;
return nullptr;
}
return borehole;
}
StationBorehole* StationBorehole::createStation(const std::string &name,
double x,
double y,
double z,
double depth,
const std::string &date)
{
StationBorehole* station = new StationBorehole();
station->_name = name;
(*station)[0] = x;
(*station)[1] = y;
(*station)[2] = z;
station->_depth = depth;
if (date != "0000-00-00")
{
station->_date = BaseLib::xmlDate2int(date);
}
return station;
}
void StationBorehole::addSoilLayer ( double thickness, const std::string &soil_name)
{
/*
// TF - Altmark
if (_profilePntVec.empty())
addSoilLayer ((*this)[0], (*this)[1], (*this)[2]-thickness, soil_name);
else {
std::size_t idx (_profilePntVec.size());
// read coordinates from last above
double x((*_profilePntVec[idx-1])[0]);
double y((*_profilePntVec[idx-1])[1]);
double z((*_profilePntVec[idx-1])[2]-thickness);
addSoilLayer (x, y, z, soil_name);
}
*/
// KR - Bode
if (_profilePntVec.empty())
{
addSoilLayer((*this)[0], (*this)[1], (*this)[2], "");
}
std::size_t idx (_profilePntVec.size());
double x((*_profilePntVec[idx - 1])[0]);
double y((*_profilePntVec[idx - 1])[1]);
double z((*_profilePntVec[0])[2] - thickness);
addSoilLayer (x, y, z, soil_name);
}
void StationBorehole::addSoilLayer ( double x, double y, double z, const std::string &soil_name)
{
_profilePntVec.push_back (new Point (x, y, z));
_soilName.push_back(soil_name);
}
bool isBorehole(GeoLib::Point const* pnt)
{
auto const* bh(dynamic_cast<GeoLib::StationBorehole const*>(pnt));
return bh != nullptr;
}
} // namespace GeoLib