ilqgames
A new real-time solver for large-scale differential games.
Main Page
Classes
Files
File List
include
ilqgames
cost
semiquadratic_norm_cost.h
1
/*
2
* Copyright (c) 2019, The Regents of the University of California (Regents).
3
* All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are
7
* met:
8
*
9
* 1. Redistributions of source code must retain the above copyright
10
* notice, this list of conditions and the following disclaimer.
11
*
12
* 2. Redistributions in binary form must reproduce the above
13
* copyright notice, this list of conditions and the following
14
* disclaimer in the documentation and/or other materials provided
15
* with the distribution.
16
*
17
* 3. Neither the name of the copyright holder nor the names of its
18
* contributors may be used to endorse or promote products derived
19
* from this software without specific prior written permission.
20
*
21
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS AS IS
22
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
25
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31
* POSSIBILITY OF SUCH DAMAGE.
32
*
33
* Please contact the author(s) of this library if you have any questions.
34
* Authors: David Fridovich-Keil ( dfk@eecs.berkeley.edu )
35
*/
36
37
///////////////////////////////////////////////////////////////////////////////
38
//
39
// Semiquadratic cost function of the norm of two states (difference from some
40
// nominal norm value), i.e. 0.5 * w * (||(x, y)|| - nominal)^2 if ||(x, y)|| >
41
// nominal (or optionally <).
42
//
43
///////////////////////////////////////////////////////////////////////////////
44
45
#ifndef ILQGAMES_COST_SEMIQUADRATIC_NORM_COST_H
46
#define ILQGAMES_COST_SEMIQUADRATIC_NORM_COST_H
47
48
#include <ilqgames/cost/time_invariant_cost.h>
49
#include <ilqgames/utils/types.h>
50
51
#include <glog/logging.h>
52
#include <string>
53
#include <utility>
54
55
namespace
ilqgames
{
56
57
class
SemiquadraticNormCost
:
public
TimeInvariantCost
{
58
public
:
59
// Construct from a multiplicative weight, the dimensions in which to apply
60
// the semiquadratic cost, a threshold, and a flag for which side to apply it.
61
SemiquadraticNormCost
(
float
weight,
62
const
std::pair<Dimension, Dimension>& dims,
63
float
threshold,
bool
oriented_right,
64
const
std::string& name =
""
)
65
:
TimeInvariantCost
(weight, name),
66
dim1_(dims.first),
67
dim2_(dims.second),
68
threshold_(threshold),
69
oriented_right_(oriented_right) {
70
CHECK_GE(dim1_, 0);
71
CHECK_GE(dim2_, 0);
72
}
73
74
// Evaluate this cost at the current input.
75
float
Evaluate(
const
VectorXf& input)
const
;
76
77
// Quadraticize this cost at the given input, and add to the running
78
// sum of gradients and Hessians.
79
void
Quadraticize(
const
VectorXf& input, MatrixXf* hess,
80
VectorXf* grad)
const
;
81
82
private
:
83
// Dimensions in which to apply the quadratic cost.
84
const
Dimension dim1_, dim2_;
85
86
// Threshold and which side to apply it to.
87
const
float
threshold_;
88
const
bool
oriented_right_;
89
};
//\class SemiquadraticNormCost
90
91
}
// namespace ilqgames
92
93
#endif
ilqgames::SemiquadraticNormCost
Definition:
semiquadratic_norm_cost.h:57
ilqgames
Definition:
air_3d.cpp:56
ilqgames::TimeInvariantCost
Definition:
time_invariant_cost.h:53
Generated by
1.8.11