PluginPrediction.h
Go to the documentation of this file.
00001 /*********************************************************************
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2014, Institute for Artificial Intelligence,
00005  *  Universität Bremen.
00006  *  All rights reserved.
00007  *
00008  *  Redistribution and use in source and binary forms, with or without
00009  *  modification, are permitted provided that the following conditions
00010  *  are met:
00011  *
00012  *   * Redistributions of source code must retain the above copyright
00013  *     notice, this list of conditions and the following disclaimer.
00014  *   * Redistributions in binary form must reproduce the above
00015  *     copyright notice, this list of conditions and the following
00016  *     disclaimer in the documentation and/or other materials provided
00017  *     with the distribution.
00018  *   * Neither the name of the Institute for Artificial Intelligence,
00019  *     Universität Bremen, nor the names of its contributors may be
00020  *     used to endorse or promote products derived from this software
00021  *     without specific prior written permission.
00022  *
00023  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00024  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00025  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00026  *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00027  *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00028  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00029  *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00030  *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00031  *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00032  *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00033  *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00034  *  POSSIBILITY OF SUCH DAMAGE.
00035  *********************************************************************/
00036 
00040 #ifndef __PLUGIN_PREDICTION_H__
00041 #define __PLUGIN_PREDICTION_H__
00042 
00043 
00044 #define PLUGIN_CLASS PluginPrediction
00045 
00046 
00047 // System
00048 #include <cstdlib>
00049 #include <iostream>
00050 #include <fstream>
00051 #include <mutex>
00052 #include <map>
00053 #include <sstream>
00054 
00055 // Designators
00056 #include <designators/CDesignator.h>
00057 #include <designator_integration_msgs/DesignatorCommunication.h>
00058 
00059 // OWL Exporter for ontology
00060 #include <plugins/owlexporter/CExporterOwl.h>
00061 
00062 // Private
00063 #include <Types.h>
00064 #include <ForwardDeclarations.h>
00065 #include <Plugin.h>
00066 #include <Property.h>
00067 #include <JSON.h>
00068 #include <Node.h>
00069 #include <plugins/prediction/DecisionTree.h>
00070 
00071 
00072 namespace beliefstate {
00073   namespace plugins {
00074     class PLUGIN_CLASS : public Plugin {
00075     private:
00076       typedef struct {
00077         Property* prLevel;
00078         std::string strClass;
00079       } PredictionTrack;
00080       
00081       typedef struct {
00082         std::map<std::string, double> mapFailureProbabilities;
00083         std::map<std::string, Property*> mapRequestedFeatureValues;
00084         double dSuccessRate;
00085       } PredictionResult;
00086       
00087       JSON* m_jsnModel;
00088       DecisionTree* m_dtDecisionTree;
00089       std::list<PredictionTrack> m_lstPredictionStack;
00090       CExporterOwl* m_expOwl;
00091       bool m_bInsidePredictionModel;
00092       std::mutex m_mtxStackProtect;
00093       Node* m_ndActive;
00094       std::map< Property*, std::list<Property*> > m_mapNodeFailures;
00095       std::map< Property*, std::list<Property*> > m_mapNodeParameters;
00096       std::map< std::string, std::pair<int, int> > m_mapTimeStamps;
00097       bool m_bModelLoaded;
00098       int m_nClassFlexibility;
00099       
00100     public:
00101       PLUGIN_CLASS();
00102       ~PLUGIN_CLASS();
00103       
00104       virtual Result init(int argc, char** argv);
00105       virtual Result deinit();
00106       
00107       virtual Result cycle();
00108       
00109       virtual Event consumeServiceEvent(ServiceEvent seEvent);
00110       virtual void consumeEvent(Event evEvent);
00111       
00112       bool serviceCallbackLoad(designator_integration_msgs::DesignatorCommunication::Request &req, designator_integration_msgs::DesignatorCommunication::Response &res);
00113       
00114       bool load(std::string strFile);
00115       
00116       bool descend(std::string strClass, bool bForceClass = false);
00117       bool descend(Node* ndDescend);
00118       bool ascend(Node* ndAscend);
00119       
00120       bool predict(CDesignator* desigRequest, CDesignator* desigResponse);
00121       PredictionResult evaluatePredictionRequest(Property* prActive, CKeyValuePair* ckvpFeatures, CKeyValuePair* ckvpRequested);
00122       
00123       std::list< pair<Property*, int> > linearizeTree(Property* prTop, int nLevel);
00124       PredictionResult probability(std::list< pair<Property*, int> > lstSequence, CKeyValuePair* ckvpFeatures, CKeyValuePair* ckvpRequested);
00125       std::map<std::string, double> relativeFailureOccurrences(std::list<Property*> lstFailures, int nTracks);
00126       std::list<Property*> failuresForTreeNode(Property* prNode);
00127       std::map<std::string, double> relativeFailuresForNode(Property* prNode, int nLevel, CKeyValuePair* ckvpFeatures);
00128       std::list<Property*> parametersForTreeNode(Property* prNode);
00129       
00130       bool loadDecisionTree(std::string strPath);
00131       Property* evaluateDecisionTree(CKeyValuePair* ckvpFeatures);
00132     };
00133   }
00134   
00135   extern "C" plugins::PLUGIN_CLASS* createInstance();
00136   extern "C" void destroyInstance(plugins::PLUGIN_CLASS* icDestroy);
00137 }
00138 
00139 
00140 #endif /* __PLUGIN_PREDICTION_H__ */


beliefstate
Author(s): Jan Winkler
autogenerated on Sun Oct 5 2014 22:30:15