-
Notifications
You must be signed in to change notification settings - Fork 1
/
DTGFun.h
62 lines (53 loc) · 2.29 KB
/
DTGFun.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
/*
* 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_DISTTOGROUNDFUN_H
#define MISSIONAPP_DISTTOGROUNDFUN_H
#include "Signal.h"
#include "SigFun.h"
namespace cdra {
/**
* Distance to Ground (DTG) function
* A function that takes a signal as an input and computes
* distance between the drone under control and the ground
*/
class DTGFun : public SigFun {
const float safeDist;
const float ground_z = 0; // Note: Assumes flat ground
float computeDTG(float ego_z);
public:
DTGFun(float safeDist);
virtual ~DTGFun();
// returns the DTG at tick "t"
float value(Signal *sig, int t);
// returns the current DTG
float value(Signal *sig);
// returns true iff current DTG within safe threshold
bool prop(Signal *sig, int t);
// returns true iff DTG at tick "t" within safe threshold
bool prop(Signal *sig);
std::string propStr() { return "dist-to-ground - " + std::to_string(safeDist) + " >= 0"; };
std::string enforcer_name() { return "Flight";};
};
}
#endif //MISSIONAPP_DISTTOGROUNDFUN_H