This repository has been archived on 2025-02-26. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
Pivot/src/Matrix.h
2024-02-14 21:31:05 +01:00

63 lines
1.3 KiB
C++

#pragma once
#include <cmath>
#include <cstddef>
#include <string>
#include <vector>
class Matrix {
private:
std::size_t m_Lignes;
std::size_t m_Colonnes;
std::vector<long double> m_Data;
public:
Matrix(const std::string& fileNameInput);
Matrix(std::size_t lignes, std::size_t colonnes);
Matrix(std::size_t lignes, std::size_t colonnes, std::initializer_list<long double>&& initList);
~Matrix();
std::size_t GetRawCount() const;
std::size_t GetColumnCount() const;
Matrix operator*(const Matrix& other) const;
void GaussNonJordan(bool reduite);
void GaussJordan(bool reduite);
void Print() const;
void PrintDebug();
void Insert();
void Save(const std::string& fileName);
void Load(const std::string& filename);
void Transpose();
void Identity();
static Matrix Identity(std::size_t taille);
bool IsInversed() const;
void Augmenter(const Matrix& droite);
Matrix SubMatrix(std::size_t origine_ligne, std::size_t origine_colonne, std::size_t ligne, std::size_t colonne) const;
bool operator==(const Matrix& other) const;
long double& operator[](std::size_t indice);
long double& at(std::size_t ligne, std::size_t colonne);
long double at(std::size_t ligne, std::size_t colonne) const;
};
template <typename T>
bool IsEqualZero(T var) {
return std::abs(var) < std::pow(10, -5);
}