Skip to content
This repository has been archived by the owner on Mar 16, 2022. It is now read-only.

DomainModels (Tier 2) consist of CommunicationObjects, ServiceDefinitions, Parameters and StateDefinitions

License

Notifications You must be signed in to change notification settings

skarvtech/DomainModelsRepositories

 
 

Repository files navigation

Set of Repositories for DomainModels

DomainModels consist of CommunicationObjects, ServiceDefinitions, Parameters and StateDefinitions.

DomainModels specify domain-specific structures for a particular sub-fomain in robotics like mobile manipulation, object recognition, SLAM, etc. (see also Composition Tier 2). DomainModels are shaped by the experts of these robotics sub-domains. This is typically a community effort which structures each robotics domain by creating domain-models. Domain-models, for example, are “Service Definitions” that cover data structure, communication semantics and additional properties for specific services such as “robot localization”. To find such a service definition, domain experts of each particular robotics sub-domain discuss how to represent the location/position of a robot and what additional attributes are required and how they are represented (e.g. how the accuracy is represented).

All the DomainModels in this repository have been modelled and developed with the SmartMDSD Toolchain v3.

DomainModels are used by Component projects as an external dependency.

This repository is maintained by Servicerobotik Ulm. For more information see:

Installation insttructions

DomainModels are generally independent of specific components or systems. However, some predefined C++ structures such as the digital-data representations (also called CommunicationObjects) for service-definitions, need to be compiled. The CommunicationObjects of one repository might depend on other CommunicationObject from another repository. These dependencies are automatically resolved by the CMake scripts using the environment variable called SMART_PACKAGE_PATH. Therefore this variable should point to one (or several) root folders containing domain-models repositories (multiple folders should be separated by a ":" within the varaible value).

Moreover, CommunicationObjects additionally depend on some of the UtilityRepositories. Therefore, the location of the cloned UtilityRepositories should be stored within the same environment variable called SMART_PACKAGE_PATH. You can specify one parent location such as e.g. ~/SOFTWARE/smartsoft/repos for all the repositories and point the SMART_PACKAGE_PATH to this top-level folder only. All the subfolders will be searched recursivelly for the matching dependencies. Alltogether, DomainModels can be compiled as follows:

> mkdir -p ~/SOFTWARE/smartsoft/repos
> cd ~/SOFTWARE/smartsoft/repos
> echo "export SMART_PACKAGE_PATH=$SMART_PACKAGE_PATH:$PWD" > ~/.profile
> source ~/.profile
> git clone https://github.com/Servicerobotics-Ulm/DomainModelsRepositories.git
> cd DomainModelsRepositories
> mkdir build; cd build
> cmake ..
> make

The resulting libraries and header files will be automatically installed into a location specified by the environment variable named SMART_ROOT_ACE. A typical value for this variable is for instance ~/SOFTWARE/smartsoft.

In order for the components to find the libraries at startup, the LD_LIBRARY_PATH can be specified as follows:

> echo "export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$SMART_ROOT_ACE/lib" > ~/.bashrc

Now you can continue with checking out and building the component projects.

About

DomainModels (Tier 2) consist of CommunicationObjects, ServiceDefinitions, Parameters and StateDefinitions

Topics

Resources

License

Stars

Watchers

Forks

Languages

  • C++ 96.6%
  • CMake 3.4%