diff --git a/Crypto/Start.cpp b/Crypto/Start.cpp index 6024f33..cfd50aa 100644 --- a/Crypto/Start.cpp +++ b/Crypto/Start.cpp @@ -3,6 +3,5 @@ int main() { - return 0; } \ No newline at end of file diff --git a/XMath/Matrix.cpp b/XMath/Matrix.cpp new file mode 100644 index 0000000..271a9c5 --- /dev/null +++ b/XMath/Matrix.cpp @@ -0,0 +1,164 @@ +#define MATRIX_API +#include "Matrix.h" + +namespace CryptoCPP { + namespace Math { + + MATRIX_API Vector::Vector(size_t count) : count(count), valueSet(new long long[count]) + { + memset(valueSet, 0, count * sizeof(long long)); + } + + MATRIX_API Vector::Vector(size_t count, long long * values) : count(count), valueSet(new long long[count]) + { + memcpy(valueSet, values, count * sizeof(long long)); + } + + MATRIX_API Vector::~Vector() + { + delete[] valueSet; + } + + MATRIX_API long long Vector::at(size_t index) const + { + if (index < 0 || index >= count) throw new std::exception("Index out of bounds"); + return valueSet[index]; + } + + MATRIX_API long long Vector::at(size_t index, long long newval) + { + if (index < 0 || index >= count) throw new std::exception("Index out of bounds"); + long long l = valueSet[index]; + valueSet[index] = newval; + return l; + } + + + DelegatingFPTR::DelegatingFPTR(Delegate impl, Matrix* context) + { + this->impl = impl; + this->context = context; + } + + MATRIX_API const DelegatingFPTR* DelegatingFPTR::operator()(const Vector & input, size_t index) + { + return (context->*impl)(input, index); + } + + + Matrix::Matrix(size_t height, size_t width) : columns(new Vector*[width]), width(width), height(height) + { + for (size_t t = 0; t < width; ++t) + columns[t] = new Vector(height); + } + + Matrix::Matrix(const Matrix & copy) : columns(new Vector*[copy.width]), width(copy.width), height(copy.height) + { + for (size_t t = 0; t < width; ++t) + for (size_t t1 = 0; t < height; ++t1) + columns[t]->at(t1, copy.columns[t]->at(t1)); + } + + MATRIX_API Matrix::~Matrix() { + delete ar; + delete ac; + + for (size_t t = 0; t < width; ++t) + delete columns[t]; + delete[] columns; + // TODO: Add other deletions + } + + MATRIX_API const DelegatingFPTR* Matrix::set_row(const Vector & row, size_t rowidx) + { + if (rowidx < 0 || rowidx >= height) throw new std::exception("Index out of bounds"); + size_t min = row.count < width ? row.count : width; + for (size_t t = 0; t < min; ++t) columns[t]->at(rowidx, row.at(t)); + return ar; + } + + MATRIX_API const DelegatingFPTR* Matrix::set_col(const Vector & col, size_t colidx) + { + return ac; + } + + MATRIX_API long long Matrix::set_at(size_t col, size_t row, long long value) + { + if (col < 0 || col >= width || row < 0 || row >= height) throw new std::exception("Index out of bounds"); + columns[col]->at(row, value); + } + + MATRIX_API long long Matrix::set_at(size_t index, bool rowMajor, long long value) + { + return set_at(rowMajor ? index % width : index / height, rowMajor ? index / width : index % height, value); + } + + MATRIX_API Vector * Matrix::at_row(size_t index) const + { + if (index < 0 || index >= height) throw new std::exception("Index out of bounds"); + Vector * collect = new Vector(width); + for (size_t t = 0; t < width; ++t) + collect->at(t, columns[t]->at(index)); + return collect; + } + + MATRIX_API Vector * Matrix::at_col(size_t index) const + { + if (index < 0 || index >= width) throw new std::exception("Index out of bounds"); + Vector * collect = new Vector(height); + for (size_t t = 0; t < height; ++t) + collect->at(t, columns[index]->at(t)); + return collect; + } + + MATRIX_API long long Matrix::at(size_t col, size_t row) const + { + if (col < 0 || col >= width || row < 0 || row >= height) throw new std::exception("Index out of bounds"); + return columns[col]->at(row); + } + + MATRIX_API long long Matrix::at(size_t index, bool rowMajor) const + { + return at(rowMajor ? index % width : index / height, rowMajor ? index / width : index % height); + } + + MATRIX_API Matrix * Matrix::mul(const Matrix & factor) const + { + if (factor.height != width) throw new std::exception("Mismatched dimensions"); + Matrix* result = new Matrix(height, factor.width); + for (int i = 0; i < factor.width; ++i) + for (int j = 0; j < height; ++j) + for (int k = 0; k < width; ++k) + result->columns[i]->at(j, result->columns[i]->at(j) + (factor.columns[i]->at(k) * columns[k]->at(j))); + return result; + } + + MATRIX_API Matrix * Matrix::mul(long long scalar) const + { + Matrix* m = new Matrix(*this); + for (size_t t = 0; t < width; ++t) + for (size_t t1 = 0; t < height; ++t1) + m->columns[t]->at(t1, m->columns[t]->at(t1) * scalar); + return m; + } + + MATRIX_API Matrix * Matrix::minor(size_t row, size_t col) const + { + Matrix* result = new Matrix(height - 1, width - 1); + for (int i = 0; i < width; ++i) { + if (i == col) continue; + for (int j = 0; j < height; ++j) { + if (j == row) continue; + result->columns[i + ((i > col) ? -1 : 0)]->at(j + ((j > row) ? -1 : 0), columns[i]->at(j)); + } + } + return result; + } + + MATRIX_API long long Matrix::det() const + { + return 0; + } + + } +} \ No newline at end of file diff --git a/XMath/Matrix.h b/XMath/Matrix.h index c4bea3e..c1d93e6 100644 --- a/XMath/Matrix.h +++ b/XMath/Matrix.h @@ -11,20 +11,56 @@ namespace CryptoCPP { namespace Math { + class Matrix; + + class Vector + { + friend class Matrix; + public: + MATRIX_API Vector(size_t count); + MATRIX_API Vector(size_t count, long long * values); + MATRIX_API ~Vector(); + + MATRIX_API long long at(size_t index) const; + MATRIX_API long long at(size_t index, long long newval); + + protected: + const size_t count; + long long * const valueSet; + }; + + class DelegatingFPTR; + typedef const DelegatingFPTR*(Matrix::*Delegate)(const Vector & input, size_t at); + + class DelegatingFPTR { + public: + + DelegatingFPTR(Delegate impl, Matrix* context); + + MATRIX_API const DelegatingFPTR* operator()(const Vector & input, size_t index); + protected: + Delegate impl; + Matrix* context; + }; + class Matrix { + friend class Vector; + friend class DelegatingFPTR; public: - MATRIX_API typedef void(*ChainFunction) (Vector & valueSet); - MATRIX_API Matrix(size_t height, size_t width); - MATRIX_API Matrix(Matrix & copy); + MATRIX_API Matrix(const Matrix & copy); + MATRIX_API ~Matrix(); - MATRIX_API ChainFunction set_row(const Vector & row); - MATRIX_API ChainFunction set_col(const Vector & col); + MATRIX_API const DelegatingFPTR* set_row(const Vector & row, size_t rowidx); + MATRIX_API const DelegatingFPTR* set_col(const Vector & col, size_t colidx); + MATRIX_API long long set_at(size_t col, size_t row, long long value); + MATRIX_API long long set_at(size_t index, bool rowMajor, long long value); MATRIX_API Vector* at_row(size_t index) const; MATRIX_API Vector* at_col(size_t index) const; - MATRIX_API long long at(size_t row, size_t col) const; + MATRIX_API long long at(size_t col, size_t row) const; + MATRIX_API long long at(size_t index, bool rowMajor) const; MATRIX_API Matrix* mul(const Matrix & factor) const; MATRIX_API Matrix* mul(long long scalar) const; @@ -33,24 +69,11 @@ namespace CryptoCPP { MATRIX_API long long det() const; protected: - Vector * columns; - size_t height; - size_t width; - - }; - - class Vector - { - public: - MATRIX_API Vector(size_t count); - MATRIX_API Vector(size_t count, long long * values); - - MATRIX_API long long at(size_t index) const; - MATRIX_API long long at(size_t index, long long newval); - - protected: - long double * valueSet; - size_t count; + const DelegatingFPTR* ar = new DelegatingFPTR(add_row, this); + const DelegatingFPTR* ac = new DelegatingFPTR(add_col, this); + Vector * * const columns; + const size_t height; + const size_t width; }; } } \ No newline at end of file diff --git a/XMath/XMath.vcxproj b/XMath/XMath.vcxproj index 41ec3b6..03c7612 100644 --- a/XMath/XMath.vcxproj +++ b/XMath/XMath.vcxproj @@ -122,6 +122,7 @@ + diff --git a/XMath/XMath.vcxproj.filters b/XMath/XMath.vcxproj.filters index fb58ac1..f72a80e 100644 --- a/XMath/XMath.vcxproj.filters +++ b/XMath/XMath.vcxproj.filters @@ -18,6 +18,9 @@ Source Files + + Source Files +