Advertisement
AlezM

Untitled

Mar 13th, 2019
82
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.42 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.     Matrix I(size_t size) {
  17.         auto matrix = Matrix(size);
  18.         for (size_t i = 0; i < size; ++i)
  19.             matrix(i, i) = 1;
  20.  
  21.         return matrix;
  22.     }
  23.  
  24.     Matrix operator+(const Matrix& b) {
  25.         auto sum = Matrix(_size, _data);
  26.         for (size_t i = 0; i < _size; ++i)
  27.             for (size_t j = 0; j < _size; ++j)
  28.                 sum(i, j) += b(i, j);
  29.  
  30.         return sum;
  31.     }
  32.  
  33.     Matrix& operator+=(const Matrix& b) {
  34.         for (size_t i = 0; i < _size; ++i)
  35.             for (size_t j = 0; j < _size; ++j)
  36.                 operator()(i, j) += b(i, j);
  37.  
  38.         return *this;
  39.     }
  40.  
  41.     Matrix operator*(const Matrix& b) {
  42.         auto product = Matrix(_size);
  43.  
  44.         for (size_t i = 0; i < _size; ++i)
  45.             for (size_t j = 0; j < _size; ++j)
  46.                 for (size_t k = 0; k < _size; ++k) {
  47.                     product(i, j) += operator()(i, k) * b(k, j);
  48.                 }
  49.  
  50.         return product;
  51.     }
  52.  
  53.     Matrix operator*(const double& d) {
  54.         auto scalarMult = Matrix(_size, _data);
  55.         for (size_t i = 0; i < _size; ++i)
  56.             for (size_t j = 0; j < _size; ++j)
  57.                 scalarMult(i, j) *= d;
  58.  
  59.         return scalarMult;
  60.     }
  61.  
  62.     Matrix pow(size_t n) {
  63.         auto result = Matrix(_size);
  64.  
  65.         for (size_t i = 0; i < _size; i++)
  66.         {
  67.             result(i, i) = 1;
  68.         }
  69.  
  70.         for (size_t i = 0; i < n; i++) {
  71.             result = result * *this;
  72.         }
  73.  
  74.         return result;
  75.     }
  76.  
  77.  
  78. private:
  79.     size_t _size;
  80.     std::vector<double> _data;
  81. };
  82.  
  83. int main() {
  84.     auto A = Matrix(2, {1, 1, 1, 0});
  85.     auto P1 = Matrix(2);
  86.     auto P2 = Matrix(2, {1, 1, 1, 0});
  87.  
  88.     std::vector<double> polinomialCoefs { 1, 2, 3, 4, 5 };
  89.  
  90.     auto test = A.pow(0);
  91.  
  92.     for (int i = 0; i < 5; i++) {
  93.         P1 += A.pow(i) * polinomialCoefs[i];
  94.     }
  95.  
  96.     P2 = Matrix.I(2);
  97.     for (int i = 4; i >= 1; i--) {
  98.         P2 += A * P2 + polinomialCoefs[i - 1];
  99.     }
  100.  
  101.     return 0;
  102. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement