Haruns Sachen auf meinen branch zum testen

This commit is contained in:
LukVal54 2025-11-27 15:35:15 +01:00
parent 432e6f9513
commit 30b5586a1f
5 changed files with 140 additions and 9 deletions

View File

@ -206,7 +206,7 @@ void clearSeries(GrayScaleImageSeries *series)
//von innen nach außen freen
if(series == NULL)
{
return;
return;//beendet Funktion. Fall series == NULL würde das ausführen der folgenden zu einem segmentation fault führen.
}
if(series->images != NULL)
{

BIN
imageInput.o Normal file

Binary file not shown.

139
matrix.c
View File

@ -4,32 +4,157 @@
// TODO Matrix-Funktionen implementieren
//Matrix dimensionieren
Matrix createMatrix(unsigned int rows, unsigned int cols)
{
Matrix m; //Struktur anlegen, Varibale m von Typ Matrix
//Sonderfall aus Unit-Test, wenn rows == 0 oder cols == 0, darf kein Speicher allokiert werden
if(rows==0 || cols==0){
m.rows = 0;
m.cols = 0;
m.buffer = NULL;
return m;
}
//Normalfall
m.rows = rows; // strukurvariable.feldname --> Struktur-Zugriffsoperator
m.cols = cols;
m.buffer = malloc((rows * cols) * sizeof(MatrixType)); //Speicher reserviert für Elemente
return m;
}
void clearMatrix(Matrix *matrix)
{
// falls Speicher existiert (buffer NICHT NULL ist): freigeben
if(matrix->buffer != NULL)
{
free(matrix->buffer);// Speicher freigegeben aber zeigt irgendwo hin (dangling pointer)
}
//Matrix in definierten leeren Zustand setzen
matrix->buffer = NULL; // dangling pointer zurücksetzen
matrix->rows = 0;
matrix->cols = 0;
}
//Wert in Matrix schreiben und wo genau
void setMatrixAt(MatrixType value, Matrix matrix, unsigned int rowIdx, unsigned int colIdx)
{
// Sicherheit: wenn buffer == NULL (kein gültiger Speicher) oder Index außerhalb der Matrix --> return
if(matrix.buffer == NULL || rowIdx >= matrix.rows || colIdx >= matrix.cols)
{
return;
}
//index = Zeile * Anzahl_Spalten + Spalte
unsigned int index = rowIdx * matrix.cols + colIdx;
// Schreibt value direkt an die berechnete Position im Matrixspeicher
matrix.buffer[index] = value;
}
MatrixType getMatrixAt(const Matrix matrix, unsigned int rowIdx, unsigned int colIdx)
{
if (matrix.buffer == NULL || rowIdx >= matrix.rows || colIdx >= matrix.cols)
{
return 0;
}
unsigned int index = rowIdx * matrix.cols + colIdx;
return matrix.buffer[index];
}
Matrix add(const Matrix matrix1, const Matrix matrix2)
{
Matrix result;
//Zeilen müssen gleich sein
if (matrix1.rows != matrix2.rows)
{
result.rows = 0;
result.cols = 0;
result.buffer = NULL;
return result;
}
//Spalten müssen gleich sein (mit broadcasting)
//Fälle: gleiche Spalten ok, matrix1 hat 1 Spalte, matrix2 hat 1 Spalte
//sonst inkompatibel
if (matrix1.cols != matrix2.cols && matrix1.cols != 1 && matrix2.cols != 1)
{
result.rows = 0;
result.cols = 0;
result.buffer = NULL;
return result;
}
result.rows = matrix1.rows;
result.cols = (matrix1.cols > matrix2.cols) ? matrix1.cols : matrix2.cols;
result.buffer = malloc(result.rows * result.cols * sizeof(MatrixType));
for (unsigned int r = 0; r < result.rows; r++)
{
for (unsigned int c = 0; c < result.cols; c++)
{
// Bestimme Spalte für matrix1:
// Wenn nur 1 Spalte -> immer Spalte 0 benutzen
unsigned int c1 = (matrix1.cols == 1) ? 0 : c;
// Bestimme Spalte für matrix2:
unsigned int c2 = (matrix2.cols == 1) ? 0 : c;
MatrixType v1 = getMatrixAt(matrix1, r, c1);
MatrixType v2 = getMatrixAt(matrix2, r, c2);
setMatrixAt(v1 + v2, result, r, c);
}
}
return result;
}
Matrix multiply(const Matrix matrix1, const Matrix matrix2)
{
}
Matrix result;
if(matrix1.cols != matrix2.rows)
{
result.rows = 0;
result.cols = 0;
result.buffer = NULL;
return result;
}
result.rows = matrix1.rows;
result.cols = matrix2.cols;
result.buffer = malloc(result.rows * result.cols * sizeof(MatrixType));
for (unsigned int r = 0; r < result.rows; r++)
{
for (unsigned int c = 0; c < result.cols; c++)
{
MatrixType sum = 0;
// gemeinsame Dimension = matrix1.cols = matrix2.rows
for (unsigned int i = 0; i < matrix1.cols; i++)
{
MatrixType a = getMatrixAt(matrix1, r, i);
MatrixType b = getMatrixAt(matrix2, i, c);
sum += a * b;
}
setMatrixAt(sum, result, r, c);
}
}
return result;
}

View File

@ -1,4 +1,5 @@
#ifndef MATRIX_H
#ifndef MATRIX_H
#define MATRIX_H
#define UNDEFINED_MATRIX_VALUE 0
@ -6,6 +7,11 @@
typedef float MatrixType;
// TODO Matrixtyp definieren
typedef struct {
unsigned int rows;
unsigned int cols;
MatrixType* buffer; //buffer Pointer zeigt auf Heap, mit malloc dort dann Speicher reservieren
} Matrix;
Matrix createMatrix(unsigned int rows, unsigned int cols);
@ -16,4 +22,4 @@ Matrix add(const Matrix matrix1, const Matrix matrix2);
Matrix multiply(const Matrix matrix1, const Matrix matrix2);
#endif
#endif

BIN
runImageInputTests Executable file

Binary file not shown.