Advertisement
AlezM

Untitled

Mar 12th, 2019
104
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.14 KB | None | 0 0
  1. #include <iostream>
  2. #include <vector>
  3.  
  4. class Matrix {
  5. public:
  6.     Matrix(size_t size) : _size(size), _data(size * size) {}
  7.     Matrix(size_t size, std::vector<double> data) : _size(size), _data(size * size) {
  8.         _data = data;
  9.     }
  10.     double& operator()(size_t i, size_t j) {
  11.         return _data[i * _size + j];
  12.     }
  13.     double operator()(size_t i, size_t j) const {
  14.         return _data[i * _size + j];
  15.     }
  16.  
  17.     Matrix& operator+(const Matrix& b) {
  18.         auto sum = Matrix(_size, _data);
  19.         for (size_t i = 0; i < _size; ++i)
  20.             for (size_t j = 0; j < _size; ++j)
  21.                 sum(i, j) += b(i, j);
  22.  
  23.         return sum;
  24.     }
  25.  
  26.     Matrix& operator+=(Matrix& b) {
  27.         for (size_t i = 0; i < _size; ++i)
  28.             for (size_t j = 0; j < _size; ++j)
  29.                 operator()(i, j) += b(i, j);
  30.  
  31.         return *this;
  32.     }
  33.  
  34.     Matrix& operator*(const Matrix& b) {
  35.         auto product = Matrix(_size);
  36.  
  37.         for (size_t i = 0; i < _size; ++i)
  38.             for (size_t j = 0; j < _size; ++j)
  39.                 for (size_t k = 0; k < _size; ++k) {
  40.                     product(i, j) += operator()(i, k) * b(k, j);
  41.                 }
  42.  
  43.         return product;
  44.     }
  45.  
  46.     Matrix& operator*(const double& d) {
  47.         auto scalarMult = Matrix(_size, _data);
  48.         for (size_t i = 0; i < _size; ++i)
  49.             for (size_t j = 0; j < _size; ++j)
  50.                 scalarMult(i, j) *= d;
  51.  
  52.         return scalarMult;
  53.     }
  54.  
  55.     Matrix& pow(size_t n)
  56.     {
  57.         auto result = Matrix(_size);
  58.  
  59.         for (size_t i = 0; i < _size; i++)
  60.         {
  61.             result(i, i) = 1;
  62.         }
  63.  
  64.         for (size_t i = 0; i < n; i++) {
  65.             result = result * *this;
  66.         }
  67.  
  68.         return result;
  69.     }
  70.  
  71.  
  72. private:
  73.     size_t _size;
  74.     std::vector<double> _data;
  75. };
  76.  
  77. int main() {
  78.     auto matrix = Matrix(2, {1, 1, 1, 0});
  79.     auto polinomial = Matrix(2, { 0, 0, 0, 0 });
  80.     std::vector<double> polinomialCoefs { 1, 2, 3, 4, 5 };
  81.  
  82.     auto test = matrix.pow(0);
  83.  
  84.     for (int i = 0; i < 5; i++) {
  85.         polinomial += matrix.pow(i) * polinomialCoefs[i];
  86.     }
  87.  
  88.     return 0;
  89. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement