SHOGUN
4.1.0
首页
相关页面
模块
类
文件
文件列表
文件成员
全部
类
命名空间
文件
函数
变量
类型定义
枚举
枚举值
友元
宏定义
组
页
src
shogun
optimization
L1Penalty.h
浏览该文件的文档.
1
/*
2
* Copyright (c) The Shogun Machine Learning Toolbox
3
* Written (w) 2015 Wu Lin
4
* All rights reserved.
5
*
6
* Redistribution and use in source and binary forms, with or without
7
* modification, are permitted provided that the following conditions are met:
8
*
9
* 1. Redistributions of source code must retain the above copyright notice, this
10
* list of conditions and the following disclaimer.
11
* 2. Redistributions in binary form must reproduce the above copyright notice,
12
* this list of conditions and the following disclaimer in the documentation
13
* and/or other materials provided with the distribution.
14
*
15
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
19
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25
*
26
* The views and conclusions contained in the software and documentation are those
27
* of the authors and should not be interpreted as representing official policies,
28
* either expressed or implied, of the Shogun Development Team.
29
*
30
*/
31
32
#ifndef L1PENALTY_H
33
#define L1PENALTY_H
34
#include <
shogun/optimization/SparsePenalty.h
>
35
#include <
shogun/lib/config.h
>
36
#include <
shogun/mathematics/Math.h
>
37
namespace
shogun
38
{
52
class
L1Penalty
:
public
SparsePenalty
53
{
54
public
:
55
L1Penalty
()
56
:
SparsePenalty
() {init();}
57
58
virtual
~L1Penalty
() {}
59
66
virtual
float64_t
get_penalty
(
float64_t
variable) {
return
CMath::abs
(variable);}
67
68
79
virtual
float64_t
get_penalty_gradient
(
float64_t
variable,
80
float64_t
gradient_of_variable) {
return
0.0;}
81
87
virtual
void
set_rounding_epsilon
(
float64_t
epsilon
)
88
{
89
REQUIRE
(epsilon>=0,
"Rounding epsilon (%f) should be non-negative\n"
, epsilon);
90
m_rounding_epsilon
=
epsilon
;
91
}
92
97
virtual
void
update_variable_for_proximity
(
SGVector<float64_t>
variable,
98
float64_t
proximal_weight)
99
{
100
for
(
index_t
idx=0; idx<variable.
vlen
; idx++)
101
variable[idx]=
get_sparse_variable
(variable[idx], proximal_weight);
102
}
103
109
virtual
void
update_context
(
CMinimizerContext
* context)
110
{
111
REQUIRE
(context,
"Context must set\n"
);
112
}
113
118
virtual
void
load_from_context
(
CMinimizerContext
* context)
119
{
120
REQUIRE
(context,
"Context must set\n"
);
121
}
122
128
virtual
float64_t
get_sparse_variable
(
float64_t
variable,
float64_t
penalty_weight)
129
{
130
if
(variable>0.0)
131
{
132
variable-=penalty_weight;
133
if
(variable<0.0)
134
variable=0.0;
135
}
136
else
137
{
138
variable+=penalty_weight;
139
if
(variable>0.0)
140
variable=0.0;
141
}
142
if
(
CMath::abs
(variable)<
m_rounding_epsilon
)
143
variable=0.0;
144
return
variable;
145
}
146
protected
:
148
float64_t
m_rounding_epsilon
;
149
150
private
:
152
void
init()
153
{
154
m_rounding_epsilon=1e-8;
155
}
156
};
157
158
}
159
160
#endif
shogun::L1Penalty::load_from_context
virtual void load_from_context(CMinimizerContext *context)
Definition:
L1Penalty.h:118
shogun::L1Penalty
The is the base class for L1 penalty/regularization within the FirstOrderMinimizer framework...
Definition:
L1Penalty.h:52
Math.h
index_t
int32_t index_t
Definition:
common.h:62
shogun::CMinimizerContext
The class is used to serialize and deserialize variables for the optimization framework.
Definition:
MinimizerContext.h:45
config.h
REQUIRE
#define REQUIRE(x,...)
Definition:
SGIO.h:206
shogun::SparsePenalty
The base class for sparse penalty/regularization used in minimization.
Definition:
SparsePenalty.h:46
shogun::L1Penalty::get_penalty_gradient
virtual float64_t get_penalty_gradient(float64_t variable, float64_t gradient_of_variable)
Definition:
L1Penalty.h:79
shogun::L1Penalty::update_context
virtual void update_context(CMinimizerContext *context)
Definition:
L1Penalty.h:109
shogun::epsilon
static const float64_t epsilon
Definition:
libbmrm.cpp:25
shogun::SGVector::vlen
index_t vlen
Definition:
SGVector.h:494
shogun::L1Penalty::set_rounding_epsilon
virtual void set_rounding_epsilon(float64_t epsilon)
Definition:
L1Penalty.h:87
shogun::L1Penalty::~L1Penalty
virtual ~L1Penalty()
Definition:
L1Penalty.h:58
SparsePenalty.h
shogun::SGVector< float64_t >
float64_t
double float64_t
Definition:
common.h:50
shogun::L1Penalty::m_rounding_epsilon
float64_t m_rounding_epsilon
Definition:
L1Penalty.h:148
shogun::L1Penalty::update_variable_for_proximity
virtual void update_variable_for_proximity(SGVector< float64_t > variable, float64_t proximal_weight)
Definition:
L1Penalty.h:97
shogun::L1Penalty::L1Penalty
L1Penalty()
Definition:
L1Penalty.h:55
shogun
all of classes and functions are contained in the shogun namespace
Definition:
class_list.h:18
shogun::L1Penalty::get_sparse_variable
virtual float64_t get_sparse_variable(float64_t variable, float64_t penalty_weight)
Definition:
L1Penalty.h:128
shogun::L1Penalty::get_penalty
virtual float64_t get_penalty(float64_t variable)
Definition:
L1Penalty.h:66
shogun::CMath::abs
static T abs(T a)
Definition:
Math.h:179
SHOGUN
机器学习工具包 - 项目文档