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
|
/**
* 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 Vector {
protected:
std::vector<real> data_;
public:
explicit Vector(int64_t);
Vector(const Vector&) = default;
Vector(Vector&&) noexcept = default;
Vector& operator=(const Vector&) = default;
Vector& operator=(Vector&&) = default;
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 Matrix&, int64_t, real);
void mul(const Matrix&, const Vector&);
int64_t argmax();
};
std::ostream& operator<<(std::ostream&, const Vector&);
} // namespace fasttext
|