SHOGUN  4.1.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
FirstOrderStochasticMinimizer.h
Go to the documentation of this file.
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 #ifndef FIRSTORDERSTOCHASTICMINIMIZER_H
32 #define FIRSTORDERSTOCHASTICMINIMIZER_H
39 namespace shogun
40 {
41 
72 {
73 public:
77  {
78  init();
79  }
80 
86  {
87  init();
88  }
89 
93 
98  virtual bool supports_batch_update() const {return false;}
99 
104  virtual void set_gradient_updater(DescendUpdater* gradient_updater)
105  {
106  REQUIRE(gradient_updater, "Gradient updater must set\n");
107  m_gradient_updater=gradient_updater;
108  }
109 
114  virtual float64_t minimize()=0;
115 
125  virtual void set_number_passes(int32_t num_passes)
126  {
127  REQUIRE(num_passes>0, "The number (%d) to go through data must be positive\n", num_passes);
128  m_num_passes=num_passes;
129  }
130 
136  virtual void load_from_context(CMinimizerContext* context)
137  {
138  REQUIRE(context,"Context must set\n");
139  REQUIRE(m_gradient_updater,"Descend updater must set\n");
142  if(m_learning_rate)
144  std::string key="FirstOrderStochasticMinimizer::m_iter_counter";
145  m_iter_counter=context->get_data_int32(key);
146  }
147 
151  virtual void set_learning_rate(LearningRate *learning_rate)
152  {
153  m_learning_rate=learning_rate;
154  }
155 
160  virtual int32_t get_iteration_counter() {return m_iter_counter;}
161 protected:
167  virtual void do_proximal_operation(SGVector<float64_t>variable_reference)
168  {
169  ProximalPenalty* proximal_penalty=dynamic_cast<ProximalPenalty*>(m_penalty_type);
170  if(proximal_penalty)
171  {
172  float64_t proximal_weight=m_penalty_weight;
173  SparsePenalty* sparse_penalty=dynamic_cast<SparsePenalty*>(m_penalty_type);
174  if(sparse_penalty)
175  {
176  REQUIRE(m_learning_rate, "Learning rate must set when Sparse Penalty (eg, L1) is used\n");
178  }
179  proximal_penalty->update_variable_for_proximity(variable_reference,proximal_weight);
180  }
181  }
182 
187  virtual void update_context(CMinimizerContext* context)
188  {
189  REQUIRE(context,"Context must set\n");
190  REQUIRE(m_gradient_updater,"Descend updater must set\n");
193  if(m_learning_rate)
195  std::string key="FirstOrderStochasticMinimizer::m_iter_counter";
196  context->save_data(key, m_iter_counter);
197  }
198 
201 
203  virtual void init_minimization()
204  {
205  REQUIRE(m_fun,"Cost function must set\n");
206  REQUIRE(m_gradient_updater,"Descend updater must set\n");
207  REQUIRE(m_num_passes>0, "The number to go through data must set\n");
208  m_cur_passes=0;
209  }
210 
212  int32_t m_num_passes;
213 
215  int32_t m_cur_passes;
216 
218  int32_t m_iter_counter;
219 
222 
223 private:
225  void init()
226  {
227  m_gradient_updater=NULL;
228  m_learning_rate=NULL;
229  m_num_passes=0;
230  m_cur_passes=0;
231  m_iter_counter=0;
232  }
233 };
234 
235 }
236 #endif /* FIRSTORDERSTOCHASTICMINIMIZER_H */
virtual void set_number_passes(int32_t num_passes)
virtual void save_data(const std::string &key, SGVector< float64_t > value)
virtual void update_context(CMinimizerContext *context)
virtual void set_gradient_updater(DescendUpdater *gradient_updater)
FirstOrderStochasticMinimizer(FirstOrderStochasticCostFunction *fun)
virtual void set_learning_rate(LearningRate *learning_rate)
The base class about learning rate for descent-based minimizers.
Definition: LearningRate.h:46
The class is used to serialize and deserialize variables for the optimization framework.
FirstOrderCostFunction * m_fun
#define REQUIRE(x,...)
Definition: SGIO.h:206
The base class for sparse penalty/regularization used in minimization.
Definition: SparsePenalty.h:46
The first order stochastic cost function base class.
The base class for sparse penalty/regularization used in minimization.
The base class for stochastic first-order gradient-based minimizers.
double float64_t
Definition: common.h:50
virtual void update_variable_for_proximity(SGVector< float64_t > variable, float64_t proximal_weight)=0
virtual void load_from_context(CMinimizerContext *context)=0
This is a base class for descend update.
virtual void update_context(CMinimizerContext *context)=0
all of classes and functions are contained in the shogun namespace
Definition: class_list.h:18
virtual void update_context(CMinimizerContext *context)=0
virtual void load_from_context(CMinimizerContext *context)
virtual float64_t get_learning_rate(int32_t iter_counter)=0
virtual void update_context(CMinimizerContext *context)
virtual void load_from_context(CMinimizerContext *context)=0
virtual void do_proximal_operation(SGVector< float64_t >variable_reference)
virtual void load_from_context(CMinimizerContext *context)
virtual int32_t get_data_int32(const std::string &key)
The first order minimizer base class.

SHOGUN Machine Learning Toolbox - Documentation