File size: 1,808 Bytes
9f5b176
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
65
66
67
68
69
70
71
72
73
/*
Copyright 2015 Google Inc. All rights reserved.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

#ifndef _FLOAT_MATRIX_INL_H_
#define _FLOAT_MATRIX_INL_H_

// IWYU pragma: private, include "float_matrix.h"



inline uint32_t FloatMatrix::get_x_size(void) const {
  return x_size_;
}

inline uint32_t FloatMatrix::get_y_size(void) const {
  return y_size_;
}

// y1x1 y1x2 y1x3 y1x4 y2x1 y2x2 y2x3 y2x4
inline float FloatMatrix::Get(uint32_t x, uint32_t y) const {
  return data_[y * x_size_ + x];
}

inline float &FloatMatrix::Get(uint32_t x, uint32_t y) {
#ifdef _DEBUG
  if (y >= y_size_ || x >= x_size_) {
    fprintf(stderr, "Matrix boundary overrun error");
  }
#endif
  return data_[y * x_size_ + x];
}

inline void FloatMatrix::Set(uint32_t x, uint32_t y, float val) {
#ifdef _DEBUG
  if (y >= y_size_ || x >= x_size_) {
    fprintf(stderr, "Matrix boundary overrun error");
  }
#endif
  data_[y *x_size_ + x] = val;
}

inline uint32_t FloatMatrix::size() const {
  return x_size_ * y_size_;
}

inline const float *FloatMatrix::data(void) const {
  return data_;
}

inline void FloatMatrix::StringWrite(std::string *out) const {
  if (size()) {
    char *source = reinterpret_cast<char*>(data_);
    out->append(source, size() * sizeof(*data_));
  }
}



#endif  // SPEECH_PATTS_ENGINE_COMMON_CORE_FLOAT_MATRIX_INL_H_