From 24c7ac65ce1ab5eb05a538e58ee381e1b0c4530f Mon Sep 17 00:00:00 2001 From: Florian Wetzel Date: Tue, 18 Nov 2025 10:36:22 +0100 Subject: [PATCH] =?UTF-8?q?Mit=20branchjens=20gemerged=20und=20Definition?= =?UTF-8?q?=20nochmal=20ge=C3=A4ndert?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- matrix.c | 108 ++++++++++++++++++++++++++++++++++++++++++++++++++----- matrix.h | 7 +++- 2 files changed, 106 insertions(+), 9 deletions(-) diff --git a/matrix.c b/matrix.c index ad00628..02f2473 100644 --- a/matrix.c +++ b/matrix.c @@ -6,30 +6,122 @@ Matrix createMatrix(unsigned int rows, unsigned int cols) { - + Matrix matrix; + + matrix.rows = rows; + matrix.cols = cols; + matrix.buffer = malloc(rows * cols * sizeof(float)); + + if(matrix.buffer == NULL) + { + printf("Fehler bei der Speicherreservierung! Keine Matrix erstellt!"); + matrix.rows = 0; + matrix.cols = 0; + } + + return matrix; } void clearMatrix(Matrix *matrix) { - + free(matrix.buffer); + + matrix->buffer = NULL; + matrix->rows = 0; + matrix->cols = 0; } -void setMatrixAt(MatrixType value, Matrix matrix, unsigned int rowIdx, unsigned int colIdx) +void setMatrixAt(MatrixType value, Matrix *matrix, unsigned int rowIdx, unsigned int colIdx) { - + if(matrix->buffer == NULL) + { + printf("Fehler beim Setzen! Matrix nicht initialisiert"); + return; + } + + if(rowIdx >= matrix->rows || colIdx >= matrix->cols) + { + printf("Ungueltige Indizes beim Setzen!\n"); + return; + } + + matrix->buffer[rowIdx * matrix->cols + colIdx] = value; } MatrixType getMatrixAt(const Matrix matrix, unsigned int rowIdx, unsigned int colIdx) { - + if(matrix.buffer == NULL) + { + printf("Fehler beim Lesen! Matrix nicht initialisiert"); + return 0; + } + + if(rowIdx >= matrix.rows || colIdx >= matrix.cols) + { + printf("Ungueltige Indizes beim Lesen!\n"); + return 0; + } + + return matrix.buffer[rowIdx * matrix.cols + colIdx]; } Matrix add(const Matrix matrix1, const Matrix matrix2) { - + if((matrix1.rows != matrix2.rows) || (matrix1.cols != matrix2.cols)) + { + printf("Fehler bei Addition: Matrix Dimensionen passen nicht ueberein!\n"); + Matrix empty = {0, 0, NULL}; + return empty; + } + + float matrix1Wert = 0; + float matrix2Wert = 0; + float summe = 0; + + Matrix ergebnisMatrix = createMatrix(matrix1.rows, matrix1.cols); + + for(int row = 0; row < ergebnisMatrix.rows; row++) + { + for(int col = 0; col < ergebnisMatrix.cols; col++) + { + matrix1Wert = getMatrixAt(matrix1, row, col); + matrix2Wert = getMatrixAt(matrix2, row, col); + summe = matrix1Wert + matrix2Wert; + + setMatrixAt(summe, &ergebnisMatrix, row, col); + } + } + + return ergebnisMatrix; } Matrix multiply(const Matrix matrix1, const Matrix matrix2) { - -} \ No newline at end of file + if(matrix1.cols != matrix2.rows) + { + printf("Fehler bei Multiplikation: Matrix Dimensionen passen nicht ueberein!\n"); + Matrix empty = {0, 0, NULL}; + return empty; + } + + float erg = 0; + + Matrix ergebnisMatrix = createMatrix(matrix1.rows, matrix2.cols); + + for(int row = 0; row < ergebnisMatrix.rows; row++) + { + for(int col = 0; col < ergebnisMatrix.cols; col++) + { + erg = 0; + + for(int k = 0; k < matrix1.cols; k++) + { + erg += getMatrixAt(matrix1, row, k) * getMatrixAt(matrix2, k, col); + } + + setMatrixAt(erg, &ergebnisMatrix, row, col); + } + } + + return ergebnisMatrix; +} diff --git a/matrix.h b/matrix.h index cc640d1..42879d5 100644 --- a/matrix.h +++ b/matrix.h @@ -6,7 +6,12 @@ typedef float MatrixType; // TODO Matrixtyp definieren - +typedef struct +{ + int rows; + int cols; + float *buffer; +} Matrix; Matrix createMatrix(unsigned int rows, unsigned int cols); void clearMatrix(Matrix *matrix);