jubatus_core  0.1.2
Jubatus: Online machine learning framework for distributed environment
compressor.hpp
Go to the documentation of this file.
1 // Jubatus: Online machine learning framework for distributed environment
2 // Copyright (C) 2013 Preferred Networks and Nippon Telegraph and Telephone Corporation.
3 //
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License version 2.1 as published by the Free Software Foundation.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // Lesser General Public License for more details.
12 //
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16 
17 #ifndef JUBATUS_CORE_CLUSTERING_COMPRESSOR_HPP_
18 #define JUBATUS_CORE_CLUSTERING_COMPRESSOR_HPP_
19 
20 #include <msgpack.hpp>
21 #include "clustering_config.hpp"
22 #include "types.hpp"
23 #include "util.hpp"
24 
25 namespace jubatus {
26 namespace core {
27 namespace clustering {
28 namespace compressor {
29 
30 class compressor {
31  public:
32  explicit compressor(const clustering_config& cfg)
33  : config_(cfg) {}
34  virtual ~compressor() {}
35 
36  virtual void compress(
37  const wplist& src,
38  size_t bsize,
39  size_t dstsize,
40  wplist& dst) = 0;
41 
43  private:
45 };
46 
47 } // namespace compressor
48 } // namespace clustering
49 } // namespace core
50 } // namespace jubatus
51 
52 #endif // JUBATUS_CORE_CLUSTERING_COMPRESSOR_HPP_
virtual void compress(const wplist &src, size_t bsize, size_t dstsize, wplist &dst)=0
compressor(const clustering_config &cfg)
Definition: compressor.hpp:32
std::vector< weighted_point > wplist
Definition: types.hpp:55