IAP GITLAB

Skip to content
Snippets Groups Projects
CoordinateSystem.cc 1.26 KiB
Newer Older

/**
 * (c) Copyright 2018 CORSIKA Project, corsika-project@lists.kit.edu
 *
 * See file AUTHORS for a list of contributors.
 *
 * This software is distributed under the terms of the GNU General Public
 * Licence version 3 (GPL Version 3). See file LICENSE for a full version of
 * the license.
 */

#include <corsika/geometry/CoordinateSystem.h>
using namespace corsika::geometry;

EigenTransform CoordinateSystem::GetTransformation(CoordinateSystem const& c1,
                                                   CoordinateSystem const& c2) {
  CoordinateSystem const* a{&c1};
  CoordinateSystem const* b{&c2};
  CoordinateSystem const* commonBase{nullptr};

  while (a != b && b != nullptr) {
    a = &c1;

    while (a != b && a != nullptr) { a = a->GetReference(); }

    if (a == b) break;

    b = b->GetReference();
  }

  if (a == b && a != nullptr) {
    commonBase = a;

  } else {
    throw std::string("no connection between coordinate systems found!");
  }

  EigenTransform t = EigenTransform::Identity();

  auto* p = &c1;

  while (p != commonBase) {
    t = p->GetTransform() * t;
    p = p->GetReference();
  }

  p = &c2;

  while (p != commonBase) {
    t = p->GetTransform().inverse(Eigen::TransformTraits::Isometry) * t;
    p = p->GetReference();
  }

  return t;