-
Notifications
You must be signed in to change notification settings - Fork 1
/
ReconFun.h
65 lines (56 loc) · 2.45 KB
/
ReconFun.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/*
* Synthesis-based resolution of features/enforcers interactions in CPS
* Copyright 2020 Carnegie Mellon University.
* NO WARRANTY. THIS CARNEGIE MELLON UNIVERSITY AND SOFTWARE ENGINEERING
* INSTITUTE MATERIAL IS FURNISHED ON AN "AS-IS" BASIS. CARNEGIE MELLON
* UNIVERSITY MAKES NO WARRANTIES OF ANY KIND, EITHER EXPRESSED OR IMPLIED,
* AS TO ANY MATTER INCLUDING, BUT NOT LIMITED TO, WARRANTY OF FITNESS FOR
* PURPOSE OR MERCHANTABILITY, EXCLUSIVITY, OR RESULTS OBTAINED FROM USE OF
* THE MATERIAL. CARNEGIE MELLON UNIVERSITY DOES NOT MAKE ANY WARRANTY OF ANY
* KIND WITH RESPECT TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT
* INFRINGEMENT.
* Released under a BSD (SEI)-style license, please see license.txt or contact
* [email protected] for full terms.
* [DISTRIBUTION STATEMENT A] This material has been approved for public
* release and unlimited distribution. Please see Copyright notice for
* non-US Government use and distribution.
* This Software includes and/or makes use of the following Third-Party Software
* subject to its own license:
* 1. JsonCpp
* (https://github.com/open-source-parsers/jsoncpp/blob/master/LICENSE)
* Copyright 2010 Baptiste Lepilleur and The JsonCpp Authors.
* DM20-0762
*/
#ifndef MISSIONAPP_RECONFUN_H
#define MISSIONAPP_RECONFUN_H
#include "Signal.h"
#include "SigFun.h"
namespace cdra {
/**
* Distance to Elevation (DTE) function
* A function that takes a signal as an input and computes
* distance between the drone under control and the ideal elevation
*/
class ReconFun : public SigFun {
const float goal_z;
const float acceptable_range;
const float lowerx, lowery, upperx, uppery;
float computeDTE(float ego_z);
bool isInReconZone(float ego_x, float ego_y);
public:
ReconFun(float goal_z, float acceptable_range, float lowerx,
float lowery, float upperx, float uppery);
virtual ~ReconFun();
// returns the DTE at tick "t"
float value(Signal *sig, int t);
// returns the current DTE
float value(Signal *sig);
// returns true iff current DTE is within acceptable_range
bool prop(Signal *sig, int t);
// returns true iff DTE at tick "t" is within acceptable_range
bool prop(Signal *sig);
std::string enforcer_name() { return "Missile";};
std::string propStr() { return "dist-to-elevation - " + std::to_string(acceptable_range) + " >= 0"; };
};
}
#endif //MISSIONAPP_RECONFUN_H