diff --git a/data/VariantInfo-RobotAPI.xml b/data/RobotAPI/VariantInfo-RobotAPI.xml
similarity index 91%
rename from data/VariantInfo-RobotAPI.xml
rename to data/RobotAPI/VariantInfo-RobotAPI.xml
index a9c6ecada350cb38d7d4d78d146229dc56168bd6..e74f767f7b603be9ed4e7b87267c1bcfd79ee2f6 100644
--- a/data/VariantInfo-RobotAPI.xml
+++ b/data/RobotAPI/VariantInfo-RobotAPI.xml
@@ -1,7 +1,7 @@
 <?xml version="1.0" encoding="utf-8"?>
 <VariantInfo>
 	<Lib name="RobotAPIRemoteRobot">
-		<VariantFactory include="RobotAPI/robotstate/remote/RobotStateObjectFactories.h" />
+		<VariantFactory include="RobotAPI/libraries/robotstate/remote/RobotStateObjectFactories.h" />
 		<Variant baseType="::armarx::Vector3Base" dataType="::armarx::Vector3" humanName="Vector3" />
 		<Variant baseType="::armarx::QuaternionBase" dataType="::armarx::Quaternion" humanName="Quaternion" />
 		<Variant baseType="::armarx::PoseBase" dataType="::armarx::Pose" humanName="Pose" />
diff --git a/scenarios/MotionControlTest/config/KinematicUnitObserver.cfg b/scenarios/MotionControlTest/config/KinematicUnitObserver.cfg
index ff20d3f9f5d3510f0ed52a198f1bde249e6b423d..c65656adb4480da37c3c1a7e90ca3656c1fd2e93 100644
--- a/scenarios/MotionControlTest/config/KinematicUnitObserver.cfg
+++ b/scenarios/MotionControlTest/config/KinematicUnitObserver.cfg
@@ -60,7 +60,7 @@
 #  Attributes:
 #  - Case sensitivity:   no
 #  - Required:           yes
-ArmarX.KinematicUnitObserver.RobotFileName = /Armar4/data/robotmodel/ArmarIV.xml
+ArmarX.KinematicUnitObserver.RobotFileName = Armar4/robotmodel/ArmarIV.xml
 
 
 # ArmarX.KinematicUnitObserver.RobotNodeSetName:  Robot node name
diff --git a/scenarios/MotionControlTest/config/KinematicUnitSimulation.cfg b/scenarios/MotionControlTest/config/KinematicUnitSimulation.cfg
index 6ade9a04de8653467979ae6146852bb04f888c4d..f60ff6fe4b6f116913e7d295350ceb58c9eaf3ea 100644
--- a/scenarios/MotionControlTest/config/KinematicUnitSimulation.cfg
+++ b/scenarios/MotionControlTest/config/KinematicUnitSimulation.cfg
@@ -68,7 +68,7 @@
 #  Attributes:
 #  - Case sensitivity:   no
 #  - Required:           yes
-ArmarX.KinematicUnitSimulation.RobotFileName = /Armar4/data/robotmodel/ArmarIV.xml
+ArmarX.KinematicUnitSimulation.RobotFileName = Armar4/robotmodel/ArmarIV.xml
 
 
 # ArmarX.KinematicUnitSimulation.RobotNodeSetName:  Robot node name
diff --git a/scenarios/MotionControlTest/config/RobotStateComponent.cfg b/scenarios/MotionControlTest/config/RobotStateComponent.cfg
index ab75dab24fe5f81bf8fc3698de37537c7c75009c..2ef0e94eb03f9228ee75236df3245518d6424822 100644
--- a/scenarios/MotionControlTest/config/RobotStateComponent.cfg
+++ b/scenarios/MotionControlTest/config/RobotStateComponent.cfg
@@ -1,4 +1,4 @@
-ArmarX.RobotStateComponent.RobotFileName=/Armar4/data/robotmodel/ArmarIV.xml       	# model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
+ArmarX.RobotStateComponent.RobotFileName=Armar4/robotmodel/ArmarIV.xml       	# model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
 ArmarX.RobotStateComponent.RobotNodeSetName=Robot					# node set name
 ArmarX.RobotStateComponent.ObjectName=RobotStateComponent      			# name of the ICE adapter
 
diff --git a/scenarios/RemoteRobotTest/configs/HeadUnit.cfg b/scenarios/RemoteRobotTest/configs/HeadUnit.cfg
index 4d5461f65d9b3b5c262485c291c219e0684c0987..bb8a9072dac5632642fb8a4c5d2ec124873ecbc9 100644
--- a/scenarios/RemoteRobotTest/configs/HeadUnit.cfg
+++ b/scenarios/RemoteRobotTest/configs/HeadUnit.cfg
@@ -1,5 +1,5 @@
 # test config file for KinematicUnit configured to be a Head
 
-ArmarX.KinematicUnitSimulation.RobotFileName=${ArmarXHome_DIR}/Armar3/data/robotmodel/ArmarIII-Head.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
+ArmarX.KinematicUnitSimulation.RobotFileName=Armar3/data/robotmodel/ArmarIII-Head.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
 ArmarX.KinematicUnitSimulation.RobotNodeSetName=Head          # node set name
 ArmarX.KinematicUnitSimulation.AdapterName=HeadKinematicUnit  # name of the Ice adapter
diff --git a/scenarios/RemoteRobotTest/configs/HeadUnitObserver.cfg b/scenarios/RemoteRobotTest/configs/HeadUnitObserver.cfg
index 39353728c0e190eb24f1e6733daef3c35002c45e..4e6024cdfde8e85b37b66a1c2ecc48719b7b1004 100644
--- a/scenarios/RemoteRobotTest/configs/HeadUnitObserver.cfg
+++ b/scenarios/RemoteRobotTest/configs/HeadUnitObserver.cfg
@@ -1,5 +1,5 @@
 # test config file for KinematicUnit configured to be a Head
 
-ArmarX.KinematicUnitObserver.RobotFileName=${ArmarXHome_DIR}/Armar3/data/robotmodel/ArmarIII-Head.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
+ArmarX.KinematicUnitObserver.RobotFileName=Armar3/data/robotmodel/ArmarIII-Head.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
 ArmarX.KinematicUnitObserver.RobotNodeSetName=Head                  # node set name
 ArmarX.KinematicUnitObserver.AdapterName=HeadKinematicUnitObserver  # name of the Ice adapter
diff --git a/scenarios/RemoteRobotTest/configs/RobotStateComponent.cfg b/scenarios/RemoteRobotTest/configs/RobotStateComponent.cfg
index 46260981c2de37a0dc21938875fdcf57797d5778..d1c56fea054978b252a0ea27a92e63fa4f20ba9d 100644
--- a/scenarios/RemoteRobotTest/configs/RobotStateComponent.cfg
+++ b/scenarios/RemoteRobotTest/configs/RobotStateComponent.cfg
@@ -1,5 +1,5 @@
 # test config file for KinematicUnit configured to be a Head
 
-ArmarX.RobotStateComponent.RobotFileName=${ArmarXHome_DIR}/Armar3/data/robotmodel/ArmarIII-LeftArm.xml   # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
+ArmarX.RobotStateComponent.RobotFileName=Armar3/data/robotmodel/ArmarIII-LeftArm.xml   # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
 ArmarX.RobotStateComponent.RobotNodeSetName=LeftArm         # node set name
 ArmarX.RobotStateComponent.AdapterName=RobotStateComponent  # name of the Ice adapter
diff --git a/scenarios/TCPMoverScenario/configs/ArmarXGui.cfg b/scenarios/TCPMoverScenario/configs/ArmarXGui.cfg
index 510feb9a8f61aa560bfa61d31a2e34f9f8e72303..5b3fa85c73ebf0fa00552b6579cdc64e0702838b 100644
--- a/scenarios/TCPMoverScenario/configs/ArmarXGui.cfg
+++ b/scenarios/TCPMoverScenario/configs/ArmarXGui.cfg
@@ -5,7 +5,7 @@ ArmarX.DisableLogging=False
 
 
 ArmarX.KinematicUnitGuiPlugin.MinimumLoggingLevel=Info
-ArmarX.KinematicUnitGuiPlugin.RobotFileName=${ArmarXHome_DIR}/Armar4/data/robotmodel/ArmarIV.xml
+ArmarX.KinematicUnitGuiPlugin.RobotFileName=Armar4/robotmodel/ArmarIV.xml
 ArmarX.KinematicUnitGuiPlugin.RobotNodeSetName=Robot
 ArmarX.KinematicUnitGuiPlugin.KinematicUnitName=RobotKinematicUnit
 #ArmarX.MdiPlugin.Profile=TCPMover
diff --git a/scenarios/TCPMoverScenario/configs/HeadUnit.cfg b/scenarios/TCPMoverScenario/configs/HeadUnit.cfg
index fdc0834859cb4c1bab784ecd3d10eef2cf80d89e..950a3fc0ddbcccc3569676bcf020a4be0ee8e01f 100644
--- a/scenarios/TCPMoverScenario/configs/HeadUnit.cfg
+++ b/scenarios/TCPMoverScenario/configs/HeadUnit.cfg
@@ -1,6 +1,6 @@
 # test config file for KinematicUnit configured to be a Head
 
-ArmarX.KinematicUnitSimulation.RobotFileName=${ArmarXHome_DIR}/Armar4/data/robotmodel/ArmarIV.xml
+ArmarX.KinematicUnitSimulation.RobotFileName=Armar4/robotmodel/ArmarIV.xml
 
 ArmarX.KinematicUnitSimulation.RobotNodeSetName=Robot          # node set name vorher Head
 ArmarX.KinematicUnitSimulation.AdapterName=RobotKinematicUnit  # name of the Ice adapter vorher HeadKinematicUnit
diff --git a/scenarios/TCPMoverScenario/configs/RobotUnit.cfg b/scenarios/TCPMoverScenario/configs/RobotUnit.cfg
index 570dc025f13903ade94afc6aa47addc3742e65e6..d77b04851b1909223d8cf41d24ba024285a994ba 100644
--- a/scenarios/TCPMoverScenario/configs/RobotUnit.cfg
+++ b/scenarios/TCPMoverScenario/configs/RobotUnit.cfg
@@ -1,6 +1,6 @@
 # A test config file for KinematicUnit configured to be a Head
 
-ArmarX.KinematicUnitSimulation.RobotFileName=${ArmarXHome_DIR}/Armar4/data/robotmodel/ArmarIV.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
+ArmarX.KinematicUnitSimulation.RobotFileName=Armar4/robotmodel/ArmarIV.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
 
 ArmarX.KinematicUnitSimulation.RobotNodeSetName=Robot          # node set name vorher Head
 ArmarX.KinematicUnitSimulation.AdapterName=RobotKinematicUnit  # name of the Ice adapter vorher HeadKinematicUnit
diff --git a/scenarios/TCPMoverScenario/configs/RobotUnitObserver.cfg b/scenarios/TCPMoverScenario/configs/RobotUnitObserver.cfg
index 9b84969c59bb31c3c3026f641a655e42e7a52896..88747008734c236aa778d61456da4c5ca9402e8c 100644
--- a/scenarios/TCPMoverScenario/configs/RobotUnitObserver.cfg
+++ b/scenarios/TCPMoverScenario/configs/RobotUnitObserver.cfg
@@ -1,5 +1,5 @@
 # test config file for KinematicUnit configured to be a Head
 
-ArmarX.KinematicUnitObserver.RobotFileName=${ArmarXHome_DIR}/Armar4/data/robotmodel/ArmarIV.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
+ArmarX.KinematicUnitObserver.RobotFileName=Armar4/robotmodel/ArmarIV.xml  # (absolut path required) model XML file path containing a VirtualRobot RobotNodeSet that defines the joints
 ArmarX.KinematicUnitObserver.RobotNodeSetName=Robot                  # node set name
 ArmarX.KinematicUnitObserver.AdapterName=RobotKinematicUnitObserver  # name of the Ice adapter
diff --git a/source/RobotAPI/components/WeissHapticSensorListener/WeissHapticSensorListener.h b/source/RobotAPI/components/WeissHapticSensorListener/WeissHapticSensorListener.h
index fa115ec5f3d86b799d95a11e85f8870135a37783..924d8f541988a799950633f29566974f2458d9aa 100644
--- a/source/RobotAPI/components/WeissHapticSensorListener/WeissHapticSensorListener.h
+++ b/source/RobotAPI/components/WeissHapticSensorListener/WeissHapticSensorListener.h
@@ -28,7 +28,7 @@
 #include <Core/core/Component.h>
 #include <RobotAPI/interface/units/HapticUnit.h>
 #include <Core/util/variants/eigen3/MatrixVariant.h>
-#include <Core/util/variants/eigen3/VariantObjectFactories.h>
+#include <Core/util/variants/eigen3/Eigen3VariantObjectFactories.h>
 
 
 namespace armarx
diff --git a/source/RobotAPI/components/units/ForceTorqueObserver.cpp b/source/RobotAPI/components/units/ForceTorqueObserver.cpp
index 6a2cc20da6eb92415840758b046186264790abe5..fb9f58a4d831296bf6cce3ee2b0b7da8ca05a651 100644
--- a/source/RobotAPI/components/units/ForceTorqueObserver.cpp
+++ b/source/RobotAPI/components/units/ForceTorqueObserver.cpp
@@ -90,21 +90,16 @@ void ForceTorqueObserver::offerValue(std::string channelName, const std::string
 
 
     channelName += "_pod";
-    if(!existsChannel(channelName))
-    {
-        offerChannel(channelName, type + " on " + channelName);
-        offerDataFieldWithDefault(channelName, type + "_x", Variant(vec->x), type + " on X axis");
-        offerDataFieldWithDefault(channelName, type + "_y", Variant(vec->y), type + " on Y axis");
-        offerDataFieldWithDefault(channelName, type + "_z", Variant(vec->z), type + " on Z axis");
-        offerDataFieldWithDefault(channelName, type + "_frame", Variant(vec->frame), "Frame of " + value);
-    }
-    else
+    if(!existsChannel(channelName) )
     {
-        setDataField(channelName, type + "_x", Variant(vec->x));
-        setDataField(channelName, type + "_y", Variant(vec->y));
-        setDataField(channelName, type + "_z", Variant(vec->z));
-        setDataField(channelName, type + "_frame", Variant(vec->frame));
+        offerChannel(channelName, identifier + " on " + channelName);
     }
+    offerOrUpdateDataField(channelName, identifier + "_x", Variant(vec->x), type + " on X axis");
+    offerOrUpdateDataField(channelName, identifier + "_y", Variant(vec->y), type + " on Y axis");
+    offerOrUpdateDataField(channelName, identifier + "_z", Variant(vec->z), type + " on Z axis");
+    offerOrUpdateDataField(channelName, identifier + "_frame", Variant(vec->frame), "Frame of " + value->frame);
+
+
 
     updateChannel(channelName);
 
diff --git a/source/RobotAPI/components/units/HapticObserver.h b/source/RobotAPI/components/units/HapticObserver.h
index 0ef0de0142ec4a8f2cfa35231d83ebde9e75a99d..71c19b9e9b1172c87601ad2d64c0fc985d0ec0fc 100644
--- a/source/RobotAPI/components/units/HapticObserver.h
+++ b/source/RobotAPI/components/units/HapticObserver.h
@@ -27,7 +27,8 @@
 #include <RobotAPI/interface/units/HapticUnit.h>
 #include <Core/observers/Observer.h>
 #include <Core/util/variants/eigen3/MatrixVariant.h>
-#include <Core/util/variants/eigen3/VariantObjectFactories.h>
+//#include <Core/util/variants/eigen3/Eigen3LibRegistry.h>
+#include <Core/util/variants/eigen3/Eigen3VariantObjectFactories.h>
 #include <Core/core/services/tasks/PeriodicTask.h>
 
 namespace armarx
diff --git a/source/RobotAPI/components/units/HeadIKUnit.cpp b/source/RobotAPI/components/units/HeadIKUnit.cpp
index 8be25d158f340b27dcc197705950d3a7690d1792..e3bdc087d7d95141b9579efabd86fb953842865e 100644
--- a/source/RobotAPI/components/units/HeadIKUnit.cpp
+++ b/source/RobotAPI/components/units/HeadIKUnit.cpp
@@ -44,7 +44,7 @@ namespace armarx
 
 
         //std::string robotModelFile;
-        //ArmarXDataPath::getAbsolutePath("Armar3/data/robotmodel/ArmarIII.xml", robotModelFile);
+        //ArmarXDataPath::getAbsolutePath("Armar3/robotmodel/ArmarIII.xml", robotModelFile);
         //localRobot = VirtualRobot::RobotIO::loadRobot(robotModelFile.c_str(), VirtualRobot::RobotIO::eStructure);
         //VirtualRobot::RobotPtr robotSnapshot(new RemoteRobot(remoteRobotPrx));
         //localRobot->setConfig(robotSnapshot->getConfig());
diff --git a/source/RobotAPI/interface/CMakeLists.txt b/source/RobotAPI/interface/CMakeLists.txt
index c15a6d81059298ac07c2c70a3c068486ac02c2bd..b50dd28c75939123a777a87c491e503ab6133ad9 100644
--- a/source/RobotAPI/interface/CMakeLists.txt
+++ b/source/RobotAPI/interface/CMakeLists.txt
@@ -26,6 +26,9 @@ set(SLICE_FILES
     units/TCPControlUnit.ice
     units/TCPMoverUnitInterface.ice
     units/UnitInterface.ice
+
+    visualization/DebugDrawerInterface.ice
+
 )
 
 # generate the interface library
diff --git a/source/RobotAPI/interface/robotstate/RobotState.ice b/source/RobotAPI/interface/robotstate/RobotState.ice
index e254732b9d7d01d50683b8184e34421c0f99c137..d58c6fdd691857a4d48867845001a1ddd11218a5 100644
--- a/source/RobotAPI/interface/robotstate/RobotState.ice
+++ b/source/RobotAPI/interface/robotstate/RobotState.ice
@@ -120,10 +120,16 @@ module armarx
          * @return proxy to the shared robot which constantly updates all joint values
          */
         SharedRobotInterface* getSynchronizedRobot();
+
         /**
          * @return proxy to a copy of the shared robot with non updating joint values
          */
         SharedRobotInterface* getRobotSnapshot(string time);
+        
+        /**
+         * @return the robot xml filename as specified in the configuration
+         */
+        string getRobotFilename();
     };
 };
 
diff --git a/source/RobotAPI/interface/visualization/DebugDrawerInterface.ice b/source/RobotAPI/interface/visualization/DebugDrawerInterface.ice
new file mode 100644
index 0000000000000000000000000000000000000000..71917f98f3429a4fdbeaa05598235379f4db6bb7
--- /dev/null
+++ b/source/RobotAPI/interface/visualization/DebugDrawerInterface.ice
@@ -0,0 +1,74 @@
+/*
+ * This file is part of ArmarX.
+ *
+ * ArmarX is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * ArmarX is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * @package    ArmarX::RobotAPI
+ * @author     Nikolaus Vahrenkamp
+ * @copyright  2014
+ * @license    http://www.gnu.org/licenses/gpl.txt
+ *             GNU General Public License
+ */
+
+#ifndef _ARMARX_API_DEBUGDRAWERLAYER_SLICE_
+#define _ARMARX_API_DEBUGDRAWERLAYER_SLICE_
+
+#include <Core/interface/core/UserException.ice>
+#include <Core/interface/core/BasicTypes.ice>
+#include <RobotAPI/interface/robotstate/PoseBase.ice>
+
+module armarx
+{
+
+    /*!
+      * \brief A layered drawing interface.
+      * All drawing operations are identified with a layer name in order to distinguish different drawing entitties.
+      * The layered approach allows a visualizer GUI to enable/disable different layers according to the requested visualization.
+    */
+    interface DebugDrawerInterface
+    {
+
+        /*!
+         * \brief Draw or update a coordinate system.
+         * \param drawLayer A custom name to distinguish different drawing layers.
+         * \param poseName The internal name of the pose (can be used to update/disable the drawing).
+         * \param globalPose The pose in global coordinate syetem.
+         */
+        void setPoseLayerVisu(string layerName, string poseName, PoseBase globalPose);
+
+        /*!
+         * \brief setPoseVisu draws on the "debug" layer
+         * \param poseName
+         * \param globalPose
+         */
+        void setPoseDebugLayerVisu(string poseName, PoseBase globalPose);
+
+        /*!
+         * \brief Remove visualization of coordinate system.
+         * \param layerName The name of the drawing layer.
+         * \param poseName The name of the pose.
+         */
+        void removePoseLayerVisu(string layerName, string poseName);
+
+        /*!
+         * \brief Removes pose from the "debug" layer.
+         */
+        void removePoseDebugLayerVisu(string poseName);
+
+    };
+
+
+};
+
+#endif
diff --git a/source/RobotAPI/libraries/drivers/WeissHapticSensor/WeissHapticSensor.h b/source/RobotAPI/libraries/drivers/WeissHapticSensor/WeissHapticSensor.h
index acfaad733b767ab7242f0135761854145ae017c4..65c9076d60537260d7c2cc40fe04be02e987afef 100644
--- a/source/RobotAPI/libraries/drivers/WeissHapticSensor/WeissHapticSensor.h
+++ b/source/RobotAPI/libraries/drivers/WeissHapticSensor/WeissHapticSensor.h
@@ -6,7 +6,8 @@
 #include "SerialInterface.h"
 #include "TactileSensor.h"
 #include <RobotAPI/interface/units/HapticUnit.h>
-#include <Core/util/variants/eigen3/VariantObjectFactories.h>
+#include <Core/util/variants/eigen3/Eigen3VariantObjectFactories.h>
+//#include <Core/util/variants/eigen3/Eigen3LibRegistry.h>
 #include "TextWriter.h"
 #include <Core/observers/variant/TimestampVariant.h>
 #include <Core/util/variants/eigen3/MatrixVariant.h>
diff --git a/source/RobotAPI/libraries/robotstate/RobotStateComponent.cpp b/source/RobotAPI/libraries/robotstate/RobotStateComponent.cpp
index cc50f66c194cd211365af7e739068e61c972ad3e..d5c81c859aab268f61e8f2de3d47f6858a472b3c 100644
--- a/source/RobotAPI/libraries/robotstate/RobotStateComponent.cpp
+++ b/source/RobotAPI/libraries/robotstate/RobotStateComponent.cpp
@@ -151,7 +151,12 @@ namespace armarx
 //        ARMARX_VERBOSE_S << "duration: " << (IceUtil::Time::now() - start).toMilliSeconds() << " ms";
     }
 
-
+    std::string RobotStateComponent::getRobotFilename(const Ice::Current&)
+    {
+		std::string robotFile = getProperty<std::string>("RobotFileName").getValue();
+		return robotFile;
+	}
+	
     void RobotStateComponent::reportControlModeChanged(const NameControlModeMap& jointModes,  bool aValueChanged,const Current& c){}
     void RobotStateComponent::reportJointVelocities(const NameValueMap& jointVelocities,  bool aValueChanged,const Current& c){}
     void RobotStateComponent::reportJointTorques(const NameValueMap& jointTorques,  bool aValueChanged,const Current& c){}
diff --git a/source/RobotAPI/libraries/robotstate/RobotStateComponent.h b/source/RobotAPI/libraries/robotstate/RobotStateComponent.h
index d4dafacca64b65902fa00f4007275fcca091598e..8b1bc656aa501878b48d87da7b4363521f510eed 100644
--- a/source/RobotAPI/libraries/robotstate/RobotStateComponent.h
+++ b/source/RobotAPI/libraries/robotstate/RobotStateComponent.h
@@ -91,7 +91,11 @@ namespace armarx
          * \return clone of the internal synchronized robot
          */
         virtual SharedRobotInterfacePrx getRobotSnapshot(const std::string & time, const Ice::Current&);
-
+        
+        /**
+         * \return the robot xml filename as specified in the configuration
+         */
+        virtual std::string getRobotFilename(const Ice::Current&);
 
         /**
          * Create an instance of RobotStatePropertyDefinitions.
diff --git a/source/RobotAPI/libraries/robotstate/remote/ArmarPose.h b/source/RobotAPI/libraries/robotstate/remote/ArmarPose.h
index 2bec17a53d0521fcc8a97908b94838f6af22852b..32c7155cd7e3ad127d30c339f07a157bd87fb645 100644
--- a/source/RobotAPI/libraries/robotstate/remote/ArmarPose.h
+++ b/source/RobotAPI/libraries/robotstate/remote/ArmarPose.h
@@ -49,8 +49,8 @@ namespace armarx
         const VariantTypeId Vector3 = Variant::addTypeName("::armarx::Vector3Base");
         const VariantTypeId Quaternion = Variant::addTypeName("::armarx::QuaternionBase");
         const VariantTypeId Pose = Variant::addTypeName("::armarx::PoseBase");
-        const VariantTypeId FramedVector3 = Variant::addTypeName("::armarx::FramedVector3Base");
         const VariantTypeId FramedPose = Variant::addTypeName("::armarx::FramedPoseBase");
+        const VariantTypeId FramedVector3 = Variant::addTypeName("::armarx::FramedVector3Base");
         const VariantTypeId FramedPosition = Variant::addTypeName("::armarx::FramedPositionBase");
         const VariantTypeId FramedOrientation = Variant::addTypeName("::armarx::FramedOrientationBase");
     }
diff --git a/source/RobotAPI/statecharts/motioncontrol/MotionControl.cpp b/source/RobotAPI/statecharts/motioncontrol/MotionControl.cpp
index 2a7e0d7715bdfb4fce8f3ec2c9a381f252ea2d18..dcbdd72b4404d9bccf3c68c5b8223a761d44628c 100644
--- a/source/RobotAPI/statecharts/motioncontrol/MotionControl.cpp
+++ b/source/RobotAPI/statecharts/motioncontrol/MotionControl.cpp
@@ -500,8 +500,8 @@ void CalculateJointAngleConfiguration::run()
     // TODO: with the following line, the IK doesn't find a solution, so this terrible hack must be used. Fix it!!!
     //VirtualRobot::RobotPtr robot = robotPtr->clone("CalculateTCPPoseClone");
     //std::string robotModelFile;
-    //ArmarXDataPath::getAbsolutePath("Armar4/data/Armar4/ArmarIV.xml", robotModelFile);
-    //ArmarXDataPath::getAbsolutePath("Armar3/data/robotmodel/ArmarIII.xml", robotModelFile);
+    //ArmarXDataPath::getAbsolutePath("Armar4/robotmodel/ArmarIV.xml", robotModelFile);
+    //ArmarXDataPath::getAbsolutePath("Armar3/robotmodel/ArmarIII.xml", robotModelFile);
     //VirtualRobot::RobotPtr robot = VirtualRobot::RobotIO::loadRobot(robotModelFile.c_str());
 
     std::string kinChainName = getInput<std::string>("kinematicChainName");
@@ -1043,7 +1043,7 @@ void CalculateHeadIK::run()
     //VirtualRobot::RobotPtr robot = robotPtr->clone("CalculateTCPPoseClone");
     VirtualRobot::RobotConfigPtr robotSnapshotConfig = robotSnapshot->getConfig();
     std::string robotModelFile;
-    ArmarXDataPath::getAbsolutePath("Armar3/data/robotmodel/ArmarIII.xml", robotModelFile);
+    ArmarXDataPath::getAbsolutePath("Armar3/robotmodel/ArmarIII.xml", robotModelFile);
     VirtualRobot::RobotPtr robot = VirtualRobot::RobotIO::loadRobot(robotModelFile.c_str(), VirtualRobot::RobotIO::eStructure);
     robot->setConfig(robotSnapshotConfig);