working on imageinput

This commit is contained in:
Tobias Kachel 2025-11-25 10:53:28 +01:00
parent 58df4199b5
commit 786aa2e6d8
3 changed files with 38 additions and 24 deletions

2
.gitignore vendored
View File

@ -6,3 +6,5 @@ runTests
.vscode/launch.json .vscode/launch.json
.vscode/settings.json .vscode/settings.json
.vscode/settings.json .vscode/settings.json
runImageInputTests
testFile.info2

View File

@ -6,9 +6,6 @@
#define BUFFER_SIZE 100 #define BUFFER_SIZE 100
#define FILE_HEADER_STRING "__info2_image_file_format__" #define FILE_HEADER_STRING "__info2_image_file_format__"
const unsigned short anzahlBilder;
const unsigned short breiteBilder;
const unsigned short hoeheBilder;
// TODO Implementieren Sie geeignete Hilfsfunktionen für das Lesen der Bildserie aus einer Datei // TODO Implementieren Sie geeignete Hilfsfunktionen für das Lesen der Bildserie aus einer Datei
GrayScaleImage readImage() GrayScaleImage readImage()
{ {
@ -18,26 +15,41 @@ GrayScaleImage readImage()
// TODO Vervollständigen Sie die Funktion readImages unter Benutzung Ihrer Hilfsfunktionen // TODO Vervollständigen Sie die Funktion readImages unter Benutzung Ihrer Hilfsfunktionen
GrayScaleImageSeries *readImages(const char *path) GrayScaleImageSeries *readImages(const char *path)
{ {
const char * headOfFile; unsigned short * numImages;
char sizeOfChar = "a"; unsigned short * breiteBilder;
const unsigned int numElemenHead = 28;//Anzahl von char in FILE_HEADER_STRING unsigned short * laengeBilder;
GrayScaleImageSeries * series;
FILE *file = fopen("mnist_test.info2","rb"); GrayScaleImageSeries *series = NULL;
if(file == NULL) { //check ob datei gelesen wurde FILE *file = fopen(*path,"rb");
char * headOfFile;
fread(headOfFile, sizeof(FILE_HEADER_STRING),1, file); //liest den header ein und überprüft ob korrekte datei
if(strcmp(headOfFile, FILE_HEADER_STRING) != 0)
return NULL; return NULL;
}
else{ // liest numIMages, breite und länge der Bilder ein
fread(headOfFile, sizeof(FILE_HEADER_STRING), 1, file); fseek(file, sizeof(FILE_HEADER_STRING), SEEK_SET);
fread(numImages, sizeof(short), 1, file);
fseek(file, sizeof(short), SEEK_CUR);
fread(breiteBilder, sizeof(short), 1, file);
fseek(file, sizeof(short), SEEK_CUR);
fread(laengeBilder, sizeof(short), 1, file);
series = malloc(*numImages * *breiteBilder * *laengeBilder * sizeof(short));
for(int i = 0; i < numImages; i++)
{
} }
if(strcmp(FILE_HEADER_STRING, headOfFile) != 0) //checkt ob datei die richtige ist durch header return series;
return NULL;
} }
// TODO Vervollständigen Sie die Funktion clearSeries, welche eine Bildserie vollständig aus dem Speicher freigibt // TODO Vervollständigen Sie die Funktion clearSeries, welche eine Bildserie vollständig aus dem Speicher freigibt
void clearSeries(GrayScaleImageSeries *series) void clearSeries(GrayScaleImageSeries *series)
{ {
free(series);
} }

View File

@ -57,12 +57,12 @@ imageInputTests: imageInput.o imageInputTests.c $(unityfolder)/unity.c
# -------------------------- # --------------------------
# Clean # Clean
# -------------------------- # --------------------------
#clean: clean:
#ifeq ($(OS),Windows_NT) ifeq ($(OS),Windows_NT)
# del /f *.o *.exe del /f *.o *.exe
#else else
# rm -f *.o mnist runMatrixTests runNeuralNetworkTests runImageInputTests rm -f *.o mnist runMatrixTests runNeuralNetworkTests runImageInputTests
#endif endif
# clean für windows clean für windows
clean: clean:
rm -f *.o *.exe rm -f *.o *.exe