| // $Id$ | |
| /*********************************************************************** | |
| Moses - factored phrase-based language decoder | |
| Copyright (C) 2006 University of Edinburgh | |
| This library is free software; you can redistribute it and/or | |
| modify it under the terms of the GNU Lesser General Public | |
| License as published by the Free Software Foundation; either | |
| version 2.1 of the License, or (at your option) any later version. | |
| This library is distributed in the hope that it will be useful, | |
| but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
| Lesser General Public License for more details. | |
| You should have received a copy of the GNU Lesser General Public | |
| License along with this library; if not, write to the Free Software | |
| Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
| ***********************************************************************/ | |
| namespace Moses2 | |
| { | |
| template<typename T> | |
| class Matrix | |
| { | |
| protected: | |
| size_t m_rows, m_cols; /**< length of the square (sentence length) */ | |
| T *m_array; /**< two-dimensional array to store floats */ | |
| Matrix(); // not implemented | |
| Matrix(const Matrix ©); // not implemented | |
| public: | |
| Matrix(MemPool &pool, size_t rows, size_t cols) : | |
| m_rows(rows), m_cols(cols) { | |
| m_array = pool.Allocate<T>(rows * cols); | |
| } | |
| //~Matrix(); // not implemented | |
| // set upper triangle | |
| void InitTriangle(const T &val) { | |
| assert(m_rows == m_cols); | |
| for (size_t row = 0; row < m_rows; row++) { | |
| for (size_t col = row; col < m_cols; col++) { | |
| SetValue(row, col, val); | |
| } | |
| } | |
| } | |
| // everything | |
| void Init(const T &val) { | |
| for (size_t row = 0; row < m_rows; row++) { | |
| for (size_t col = 0; col < m_cols; col++) { | |
| SetValue(row, col, val); | |
| } | |
| } | |
| } | |
| /** Returns length of the square: typically the sentence length */ | |
| inline size_t GetSize() const { | |
| assert(m_rows == m_cols); | |
| return m_rows; | |
| } | |
| inline size_t GetRows() const { | |
| return m_rows; | |
| } | |
| inline size_t GetCols() const { | |
| return m_cols; | |
| } | |
| /** Get a future cost score for a span */ | |
| inline const T &GetValue(size_t row, size_t col) const { | |
| return m_array[row * m_cols + col]; | |
| } | |
| inline T &GetValue(size_t row, size_t col) { | |
| return m_array[row * m_cols + col]; | |
| } | |
| /** Set a future cost score for a span */ | |
| inline void SetValue(size_t row, size_t col, const T &value) { | |
| m_array[row * m_cols + col] = value; | |
| } | |
| }; | |
| } | |