diff --git a/CMakeLists.txt b/CMakeLists.txt
index 227a7684c5830f670460237016d1471f95bced30..8b09a48d6193f2246235324f544978584db86be3 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -1,28 +1,48 @@
-cmake_minimum_required(VERSION 2.8.12)
+cmake_minimum_required(VERSION 3.16)
 project(VisOgsTools)
 
-set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH}
-  ${CMAKE_SOURCE_DIR}/ogs/scripts/cmake/cmake
-  ${CMAKE_SOURCE_DIR}/ogs/scripts/cmake)
-include(CompilerSetup)
-include(ProjectSetup)
+include(${PROJECT_SOURCE_DIR}/cmake/CPM.cmake)
 
-find_package( Qt4 )
-add_subdirectory(${CMAKE_SOURCE_DIR}/ogs)
-
-include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
-include_directories(
-	${CMAKE_SOURCE_DIR}/ogs
-	${CMAKE_SOURCE_DIR}/ogs/ThirdParty
-	${CMAKE_SOURCE_DIR}/ogs/ThirdParty/tclap/include
-	${Boost_INCLUDE_DIRS}
-	${CONAN_INCLUDE_DIRS}
+CPMFindPackage(
+    NAME Boost
+    VERSION 1.69.0
+    URL https://boostorg.jfrog.io/artifactory/main/release/1.69.0/source/boost_1_69_0.tar.gz
+)
+if(Boost_ADDED)
+    add_library(Boost::boost INTERFACE IMPORTED)
+    target_include_directories(Boost::boost INTERFACE "${Boost_SOURCE_DIR}")
+endif()
+CPMAddPackage(
+    NAME tclap
+    GITHUB_REPOSITORY ufz/tclap
+    VERSION 1.2.4
+    GIT_TAG 098dd0fe07a31618f3c2a9f8727bb01c8c5d61e2
+    DOWNLOAD_ONLY YES
+)
+if(tclap_ADDED)
+    add_library(tclap INTERFACE IMPORTED)
+    target_include_directories(
+        tclap SYSTEM INTERFACE ${tclap_SOURCE_DIR}/include
+    )
+endif()
+CPMAddPackage(
+  "https://gitlab.opengeosys.org/ogs/ogs.git#98aeeb379ac87cc88fb71d111bcb946e2db4c16f@6.4.0-dev"
 )
+if(ogs_ADDED)
+	add_library(ogs_include INTERFACE IMPORTED)
+    target_include_directories(
+        ogs_include SYSTEM INTERFACE ${ogs_SOURCE_DIR}/
+    )
+endif()
+
+# find_package(Qt4)
+
+# include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake) include_directories(
+# ${CMAKE_SOURCE_DIR}/ogs ${CMAKE_SOURCE_DIR}/ogs/ThirdParty
+# ${CMAKE_SOURCE_DIR}/ogs/ThirdParty/tclap/include ${Boost_INCLUDE_DIRS}
+# ${CONAN_INCLUDE_DIRS} )
 
 add_subdirectory(addEmiDataToMesh)
-add_subdirectory(addScalarArrayTimeSeries)
-#add_subdirectory(EmiData2PolyData)
-add_subdirectory(ErtData2Mesh)
-if (QT4_FOUND)
-	add_subdirectory(makeBuildings)
-endif()
+# add_subdirectory(addScalarArrayTimeSeries) add_subdirectory(EmiData2PolyData)
+# add_subdirectory(ErtData2Mesh) if (QT4_FOUND) add_subdirectory(makeBuildings)
+# endif()
diff --git a/addEmiDataToMesh/CMakeLists.txt b/addEmiDataToMesh/CMakeLists.txt
index 8a98df3d7c6a1acaad936deaf0a63e92335b71bf..8cd264b8a30b1d8a40128f92035e98f34f0d6bc0 100644
--- a/addEmiDataToMesh/CMakeLists.txt
+++ b/addEmiDataToMesh/CMakeLists.txt
@@ -1,10 +1,10 @@
 add_executable(addEmiDataToMesh addEmiDataToMesh.cpp)
-target_link_libraries(addEmiDataToMesh
-	logog
-	BaseLib
-	FileIO
-	InSituLib
-	${VTK_LIBRARIES}
-)
-ADD_VTK_DEPENDENCY(addEmiDataToMesh)
+target_link_libraries(
+  addEmiDataToMesh
+  ApplicationsFileIO
+  BaseLib
+  MeshLib
+  tclap
+  ogs_include
+  Boost::boost)
 set_target_properties(addEmiDataToMesh PROPERTIES FOLDER Utilities)
diff --git a/addEmiDataToMesh/addEmiDataToMesh.cpp b/addEmiDataToMesh/addEmiDataToMesh.cpp
index b4891f36d36958b7ef54031c7ff005edcd7db1b0..d6043eba92bdea9a99bf82167dec8fdde7d9c97e 100644
--- a/addEmiDataToMesh/addEmiDataToMesh.cpp
+++ b/addEmiDataToMesh/addEmiDataToMesh.cpp
@@ -12,56 +12,46 @@
  */
 
 #include <algorithm>
+#include <tclap/CmdLine.h>
 
-// TCLAP
-#include "tclap/CmdLine.h"
-
-// ThirdParty/logog
-#include "logog/include/logog.hpp"
-
-// BaseLib
-#include "BaseLib/LogogSimpleFormatter.h"
-
-// FileIO
-#include "MeshLib/IO/VtkIO/VtuInterface.h"
-#include "FileIO/CsvInterface.h"
-
-// GeoLib
-#include "GeoLib/Grid.h"
+#include "Applications/FileIO/CsvInterface.h"
+#include "BaseLib/Logging.h"
 #include "GeoLib/AnalyticalGeometry.h"
-
-// MeshLib
+#include "GeoLib/Grid.h"
+#include "MathLib/GeometricBasics.h"
+#include "MeshLib/Elements/Element.h"
+#include "MeshLib/IO/VtkIO/VtuInterface.h"
 #include "MeshLib/Mesh.h"
 #include "MeshLib/Node.h"
 #include "MeshLib/Properties.h"
 #include "MeshLib/PropertyVector.h"
-#include "MeshLib/Elements/Element.h"
-#include "MeshLib/MeshEditing/projectMeshOntoPlane.h"
 
-std::vector<double> getDataFromCSV(MeshLib::Mesh const& mesh, std::vector<GeoLib::Point*> data_points)
+std::vector<double> getDataFromCSV(MeshLib::Mesh const &mesh, std::vector<GeoLib::Point *> data_points)
 {
-	GeoLib::Point const origin(0, 0, 0);
-	MathLib::Vector3 const normal(0,0,-1);
-	MeshLib::Mesh* flat_mesh (MeshLib::projectMeshOntoPlane(mesh, origin, normal));
-	std::size_t n_elems (flat_mesh->getNElements());
+	auto nodes = mesh.getNodes();
+	std::vector<MeshLib::Node *> flat_nodes;
+	for (auto n : nodes)
+	{
+		flat_nodes.emplace_back(new MeshLib::Node((*n)[0], (*n)[1], 0));
+	}
+	std::size_t n_elems(mesh.getNumberOfElements());
 	std::vector<double> data(n_elems, 0.0);
 	std::vector<std::size_t> counter(n_elems, 0);
 
-	std::vector<MeshLib::Node*> const& nodes (flat_mesh->getNodes());
-	GeoLib::Grid<MeshLib::Node> grid(nodes.cbegin(), nodes.cend());
+	GeoLib::Grid<MeshLib::Node> grid(flat_nodes.cbegin(), flat_nodes.cend());
 
-	std::size_t const n_points (data_points.size());
-	for (std::size_t i=0; i<n_points; ++i)
+	std::size_t const n_points(data_points.size());
+	for (std::size_t i = 0; i < n_points; ++i)
 	{
 		MeshLib::Node const pnt((*data_points[i])[0], (*data_points[i])[1], 0.0);
-		MeshLib::Node const*const node = grid.getNearestPoint(pnt);
-		std::vector<MeshLib::Element*> const& conn_elems (node->getElements());
-		std::size_t const n_conn_elems (conn_elems.size());
-		for (std::size_t j=0; j<n_conn_elems; ++j)
+		MeshLib::Node const *const node = grid.getNearestPoint(pnt);
+		std::vector<MeshLib::Element *> const &conn_elems(node->getElements());
+		std::size_t const n_conn_elems(conn_elems.size());
+		for (std::size_t j = 0; j < n_conn_elems; ++j)
 		{
-			if (GeoLib::gaussPointInTriangle(pnt, *conn_elems[j]->getNode(0), *conn_elems[j]->getNode(1), *conn_elems[j]->getNode(2)))
+			if (MathLib::gaussPointInTriangle(pnt, *conn_elems[j]->getNode(0), *conn_elems[j]->getNode(1), *conn_elems[j]->getNode(2)))
 			{
-				std::size_t const idx (conn_elems[j]->getID());
+				std::size_t const idx(conn_elems[j]->getID());
 				data[idx] += ((*data_points[i])[2]);
 				counter[idx]++;
 				break;
@@ -69,28 +59,32 @@ std::vector<double> getDataFromCSV(MeshLib::Mesh const& mesh, std::vector<GeoLib
 		}
 	}
 
-	for (std::size_t i=0; i<n_elems; ++i)
+	for (std::size_t i = 0; i < n_elems; ++i)
 		if (counter[i] > 0)
 			data[i] /= static_cast<double>(counter[i]);
 
-	delete flat_mesh;
+	for (auto n : flat_nodes)
+	{
+		delete n;
+	}
+
 	return data;
 }
 
-std::vector<double> addFilesAsArrays(std::string csv_base_name, MeshLib::Mesh *mesh, std::string const& name_specifier)
+std::vector<double> addFilesAsArrays(std::string csv_base_name, MeshLib::Mesh *mesh, std::string const &name_specifier)
 {
-	std::vector<GeoLib::Point*> points;
-	std::vector<GeoLib::Point*> points2;
-	std::vector<GeoLib::Point*> points3;
+	std::vector<GeoLib::Point *> points;
+	std::vector<GeoLib::Point *> points2;
+	std::vector<GeoLib::Point *> points3;
 
 	std::string file_name = csv_base_name + "_A_" + name_specifier + ".txt";
-	INFO ("Reading file %s.", file_name.c_str());
-	int e1 = FileIO::CsvInterface::readPoints(file_name, '\t', points,  1, 2, 3);
+	INFO("Reading file {:s}.", file_name.c_str());
+	int e1 = FileIO::CsvInterface::readPoints(file_name, '\t', points, 1, 2, 3);
 	file_name = csv_base_name + "_B_" + name_specifier + ".txt";
-	INFO ("Reading file %s.", file_name.c_str());
+	INFO("Reading file {:s}.", file_name.c_str());
 	int e2 = FileIO::CsvInterface::readPoints(file_name, '\t', points2, 1, 2, 3);
 	file_name = csv_base_name + "_C_" + name_specifier + ".txt";
-	INFO ("Reading file %s.", file_name.c_str());
+	INFO("Reading file {:s}.", file_name.c_str());
 	int e3 = FileIO::CsvInterface::readPoints(file_name, '\t', points3, 1, 2, 3);
 
 	points.insert(points.end(), points2.begin(), points2.end());
@@ -98,7 +92,7 @@ std::vector<double> addFilesAsArrays(std::string csv_base_name, MeshLib::Mesh *m
 
 	if (e1 < 0 || e2 < 0 || e3 < 0 || points.empty())
 	{
-		ERR ("Error reading CSV-file.");
+		ERR("Error reading CSV-file.");
 		delete mesh;
 		std::vector<double> no_data;
 		return no_data;
@@ -110,47 +104,41 @@ std::vector<double> addFilesAsArrays(std::string csv_base_name, MeshLib::Mesh *m
 	return data;
 }
 
-
-int main (int argc, char* argv[])
+int main(int argc, char *argv[])
 {
-	LOGOG_INITIALIZE();
-	logog::Cout* logog_cout (new logog::Cout);
-	BaseLib::LogogSimpleFormatter *custom_format (new BaseLib::LogogSimpleFormatter);
-	logog_cout->SetFormatter(*custom_format);
-
 	TCLAP::CmdLine cmd("Add EMI data as a scalar cell array to a 2d mesh.", ' ', "0.1");
 
 	// I/O params
 	TCLAP::ValueArg<std::string> mesh_out("o", "mesh-output-file",
-	                                      "the name of the file the mesh will be written to", true,
-	                                      "", "file name of output mesh");
+										  "the name of the file the mesh will be written to", true,
+										  "", "file name of output mesh");
 	cmd.add(mesh_out);
 	TCLAP::ValueArg<std::string> mesh_in("i", "mesh-input-file",
-	                                     "the name of the file containing the input mesh", true,
-	                                     "", "file name of input mesh");
+										 "the name of the file containing the input mesh", true,
+										 "", "file name of input mesh");
 	cmd.add(mesh_in);
 
 	TCLAP::ValueArg<std::string> csv_in("", "csv",
-	                                    "csv-file containing EMI data to be added as a scalar array.",
-	                                    true, "", "name of the csv input file");
+										"csv-file containing EMI data to be added as a scalar array.",
+										true, "", "name of the csv input file");
 	cmd.add(csv_in);
 	cmd.parse(argc, argv);
 
-	INFO ("Reading mesh %s.", mesh_in.getValue().c_str());
-	MeshLib::Mesh* mesh (MeshLib::IO::VtuInterface::readVTUFile(mesh_in.getValue()));
+	INFO("Reading mesh {:s}.", mesh_in.getValue().c_str());
+	MeshLib::Mesh *mesh(MeshLib::IO::VtuInterface::readVTUFile(mesh_in.getValue()));
 	if (mesh == nullptr)
 	{
-		ERR ("Error reading mesh file.");
+		ERR("Error reading mesh file.");
 		return -2;
 	}
 
 	if (mesh->getDimension() != 2)
 	{
-		ERR ("This utility can handle only 2d meshes at this point.");
+		ERR("This utility can handle only 2d meshes at this point.");
 		delete mesh;
 		return -3;
 	}
-	INFO("Mesh read: %d nodes, %d elements.", mesh->getNNodes(), mesh->getNElements());
+	INFO("Mesh read: {:d} nodes, {:d} elements.", mesh->getNumberOfNodes(), mesh->getNumberOfElements());
 
 	/*
 	std::vector<GeoLib::Point*> points;
@@ -169,26 +157,21 @@ int main (int argc, char* argv[])
 	if (data.empty())
 		return -1;
 	std::string const h_prop_name("TM_DD_H");
-	boost::optional< MeshLib::PropertyVector<double>&> h_vector = mesh->getProperties().createNewPropertyVector<double>(h_prop_name, MeshLib::MeshItemType::Cell);
+	auto h_vector = mesh->getProperties().createNewPropertyVector<double>(h_prop_name, MeshLib::MeshItemType::Cell);
 	std::copy(data.cbegin(), data.cend(), std::back_inserter(*h_vector));
 
 	data = addFilesAsArrays(csv_in.getValue(), mesh, "V");
 	if (data.empty())
 		return -1;
 	std::string const v_prop_name("TM_DD_V");
-	boost::optional< MeshLib::PropertyVector<double>&> v_vector = mesh->getProperties().createNewPropertyVector<double>(v_prop_name, MeshLib::MeshItemType::Cell);
+	auto v_vector = mesh->getProperties().createNewPropertyVector<double>(v_prop_name, MeshLib::MeshItemType::Cell);
 	std::copy(data.cbegin(), data.cend(), std::back_inserter(*v_vector));
 
-	INFO ("Writing result...");
+	INFO("Writing result...");
 	MeshLib::IO::VtuInterface vtu(mesh);
 	vtu.writeToFile(mesh_out.getValue());
 
 	delete mesh;
-	delete custom_format;
-	delete logog_cout;
-	LOGOG_SHUTDOWN();
 
 	return 0;
 }
-
-
diff --git a/cmake/CPM.cmake b/cmake/CPM.cmake
new file mode 100644
index 0000000000000000000000000000000000000000..e0bda70b8aaf68ac5d52f27aa79ac3fa4097329b
--- /dev/null
+++ b/cmake/CPM.cmake
@@ -0,0 +1,21 @@
+set(CPM_DOWNLOAD_VERSION 0.32.2)
+
+if(CPM_SOURCE_CACHE)
+  # Expand relative path. This is important if the provided path contains a tilde (~)
+  get_filename_component(CPM_SOURCE_CACHE ${CPM_SOURCE_CACHE} ABSOLUTE)
+  set(CPM_DOWNLOAD_LOCATION "${CPM_SOURCE_CACHE}/cpm/CPM_${CPM_DOWNLOAD_VERSION}.cmake")
+elseif(DEFINED ENV{CPM_SOURCE_CACHE})
+  set(CPM_DOWNLOAD_LOCATION "$ENV{CPM_SOURCE_CACHE}/cpm/CPM_${CPM_DOWNLOAD_VERSION}.cmake")
+else()
+  set(CPM_DOWNLOAD_LOCATION "${CMAKE_BINARY_DIR}/cmake/CPM_${CPM_DOWNLOAD_VERSION}.cmake")
+endif()
+
+if(NOT (EXISTS ${CPM_DOWNLOAD_LOCATION}))
+  message(STATUS "Downloading CPM.cmake to ${CPM_DOWNLOAD_LOCATION}")
+  file(DOWNLOAD
+       https://github.com/cpm-cmake/CPM.cmake/releases/download/v${CPM_DOWNLOAD_VERSION}/CPM.cmake
+       ${CPM_DOWNLOAD_LOCATION}
+  )
+endif()
+
+include(${CPM_DOWNLOAD_LOCATION})