forked from facebookresearch/fastText
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvector.h
64 lines (53 loc) · 1.32 KB
/
vector.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
63
64
/**
* Copyright (c) 2016-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#pragma once
#include <cstdint>
#include <ostream>
#include <vector>
#include "real.h"
namespace fasttext {
class Matrix;
class QMatrix;
class Vector {
protected:
std::vector<real> data_;
public:
explicit Vector(int64_t);
Vector(const Vector&) = delete;
Vector(Vector&&) noexcept;
Vector& operator=(const Vector&) = delete;
Vector& operator=(Vector&&);
inline real* data() {
return data_.data();
}
inline const real* data() const {
return data_.data();
}
inline real& operator[](int64_t i) {
return data_[i];
}
inline const real& operator[](int64_t i) const {
return data_[i];
}
inline int64_t size() const {
return data_.size();
}
void zero();
void mul(real);
real norm() const;
void addVector(const Vector& source);
void addVector(const Vector&, real);
void addRow(const Matrix&, int64_t);
void addRow(const QMatrix&, int64_t);
void addRow(const Matrix&, int64_t, real);
void mul(const QMatrix&, const Vector&);
void mul(const Matrix&, const Vector&);
int64_t argmax();
};
std::ostream& operator<<(std::ostream&, const Vector&);
} // namespace fasttext