Compare commits

...

28 Commits

Author SHA1 Message Date
659121f65d made imageInput completely contcorrect 2025-11-22 17:22:04 +01:00
ccfceba21c replaced hardcoded elements with variables and cleaned up Programm 2025-11-22 17:07:13 +01:00
e9d3ddb999 removed not needed code and old comments, also updated readImagedata() so that labels are now read correctly 2025-11-22 16:31:44 +01:00
d7fb02e6b4 imageInput now passes tests but still needs to be cleaned up 2025-11-21 01:51:26 +01:00
14569ad308 isolated error in clearSeries() 2025-11-20 09:00:50 +01:00
8ab69dd403 added function to check for correct header 2025-11-20 08:27:00 +01:00
84139cae5f tested programm 2025-11-20 00:33:50 +01:00
ae541fec66 vsc update fixed tests not working, removed print instructions previously used for debugging 2025-11-20 00:02:10 +01:00
c937323342 found potential mistake in imageTesting function 2025-11-19 13:23:08 +01:00
cddd141ea6 second test seems to be failing while trying to call *readImages() 2025-11-19 00:43:51 +01:00
9d913f80f9 first test now working, second test causes programm to fail 2025-11-19 00:36:25 +01:00
6189a5aa1e inconclusive debugging 2025-11-18 11:14:51 +01:00
26073f77af Merge branch 'master' into branchjonas 2025-11-18 10:11:07 +01:00
24b843fb77 testing 2025-11-18 10:07:09 +01:00
6a2a5f7997 further testing 2025-11-18 08:59:40 +01:00
6b039bf852 added testfile to repository 2025-11-18 07:18:12 +01:00
f403d4ffa8 continued debugging 'readStatusInfo()' in 'imageInput.c' not yet working correctly, see comment 2025-11-18 00:22:57 +01:00
a2c2aae0fb fixed errors that occured when building imageInputTests 2025-11-17 21:57:25 +01:00
07012e5c35 matrixtest korigiert 2025-11-17 20:45:11 +01:00
2057216df8 debugging 2025-11-13 23:37:38 +01:00
f152305c4f created function readImagedata 2025-11-13 08:52:39 +01:00
f68e92f429 created support-Function 'readStatusInfo' 2025-11-13 01:44:47 +01:00
12359f3ac5 created support-Function 'readStatusInfo' 2025-11-13 01:43:59 +01:00
3ca24ebdb7 added comment in imageInput.c 2025-11-11 22:58:10 +01:00
e3d9f2d741 first version of clearSeries written 2025-11-11 22:52:36 +01:00
d17f495f98 erste version von readImages geschrieben 2025-11-11 19:38:29 +01:00
49f7de9dc1 Merge branch 'master' into branchjonas 2025-11-11 16:57:01 +01:00
580e8d4296 pseudocode zum imageInput erstellt 2025-11-11 11:13:42 +01:00
2 changed files with 140 additions and 9 deletions

View File

@ -6,17 +6,149 @@
#define BUFFER_SIZE 100
#define FILE_HEADER_STRING "__info2_image_file_format__"
// TODO Implementieren Sie geeignete Hilfsfunktionen für das Lesen der Bildserie aus einer Datei
// TODO Vervollständigen Sie die Funktion readImages unter Benutzung Ihrer Hilfsfunktionen
// DONE Implementieren Sie geeignete Hilfsfunktionen für das Lesen der Bildserie aus einer Datei
unsigned int readStatusInfo (FILE *const source, GrayScaleImageSeries *const series, char *const headerString, int const sizeToRead, int const amountToRead);
void readImagedata (FILE *const source, GrayScaleImageSeries *const series, int const amountToRead);
unsigned int checkHeaderString (const char *const header);
// DONE Vervollständigen Sie die Funktion readImages unter Benutzung Ihrer Hilfsfunktionen
GrayScaleImageSeries *readImages(const char *path)
{
GrayScaleImageSeries *series = NULL;
GrayScaleImageSeries *series = NULL;
FILE *readSource = 0;
const unsigned int sizeOfStausInfoElementsInBytes = 2;
const unsigned int amountOfStatusInfoToRead = 1;
unsigned int numberOfBytesToRead = 0;
unsigned int expectedHeader = 0;
char headerString[sizeof(FILE_HEADER_STRING)] = "";
readSource = fopen(path, "rb");
if (readSource != NULL)
{
series = calloc(sizeof(unsigned int) + 3* sizeof(headerString), amountOfStatusInfoToRead);
series->images = calloc(2*sizeof(unsigned int) + sizeof(headerString), amountOfStatusInfoToRead);
numberOfBytesToRead = readStatusInfo(readSource, series, headerString, sizeOfStausInfoElementsInBytes, amountOfStatusInfoToRead);
expectedHeader = checkHeaderString(headerString);
series->images->buffer = calloc((series->count) * numberOfBytesToRead, sizeof(GrayScalePixelType));
series->labels = calloc((series->count), sizeof(&(series->labels)));
if (expectedHeader)
{
// reallocate memory so that each image width can be saved seperately
series->images = realloc(series->images, series->count * 2 * sizeof(unsigned int) + sizeof(headerString));
for (int i = 0; i < series->count; i++)
{
series->images[i].width = series->images->width;
series->images[i].height = series->images->height;
}
readImagedata(readSource, series, numberOfBytesToRead);
}
else
{
series = NULL;
}
fclose(readSource);
}
return series;
}
// TODO Vervollständigen Sie die Funktion clearSeries, welche eine Bildserie vollständig aus dem Speicher freigibt
void clearSeries(GrayScaleImageSeries *series)
// DONE Vervollständigen Sie die Funktion clearSeries, welche eine Bildserie vollständig aus dem Speicher freigibt
void clearSeries(GrayScaleImageSeries * series)
{
int i = 0;
// Write NULL into all memory spaces
for (i = 0; i < ((series->count) * (series->images->width) * (series->images->height) / 4); i++)
{
*(series->images->buffer + i * 4 * (series->images->width) * (series->images->height)) = '\0';
}
for (i = 0; i < (series->count); i++)
{
*(series->labels + i) = '\0';
}
series->count = 0;
series->images->width = 0;
series->images->height = 0;
// Closse all allocated memory
// AND write NULL into every pointer
// so they can't be accessed
free(series->images->buffer);
series->images->buffer = NULL;
free(series->labels);
series->labels = NULL;
free(series->images);
series->images = NULL;
free(series);
series = NULL;
}
// reads headerString, pictureCount, pictureWidth, pictureHight
unsigned int readStatusInfo(FILE *const source, GrayScaleImageSeries *const series, char *const headerString, int const sizeToRead, int const amountToRead)
{
unsigned int bytesToRead = 0;
fread(headerString, sizeof(FILE_HEADER_STRING) - 1, amountToRead, source);
fread(&(series->count), sizeToRead, amountToRead, source);
fread(&(series->images->width), sizeToRead, amountToRead, source);
fread(&(series->images->height), sizeToRead, amountToRead, source);
bytesToRead = (series->images->width) * (series->images->height);
return bytesToRead;
}
// reads the imagebytes and the label of all images
void readImagedata(FILE *const source, GrayScaleImageSeries *const series, int const amountOfBytes)
{
int i = 0;
for (i = 0; i < series->count ; i++)
{
fread(&(series->images->buffer[i]), sizeof(*series->images->buffer), amountOfBytes, source);
fread(&(series->labels[i]), sizeof(*series->images->buffer), sizeof(*series->labels), source);
}
}
// checks if the read headerString matches the expected headerString
unsigned int checkHeaderString(const char *const header)
{
int i = 0;
int notIdenticall = 0;
char expectedHeader[sizeof(FILE_HEADER_STRING)] = FILE_HEADER_STRING;
for (i = 0; i < sizeof(FILE_HEADER_STRING); i++)
{
if (header[i] != expectedHeader[i])
{
notIdenticall = 1;
}
}
return !notIdenticall;
}

View File

@ -9,19 +9,18 @@
static void prepareImageFile(const char *path, unsigned short int width, unsigned short int height, unsigned int short numberOfImages, unsigned char label)
{
FILE *file = fopen(path, "wb");
if(file != NULL)
{
const char *fileTag = "__info2_image_file_format__";
GrayScalePixelType *zeroBuffer = (GrayScalePixelType *)calloc(numberOfImages * width * height, sizeof(GrayScalePixelType));
if(zeroBuffer != NULL)
{
fwrite(fileTag, sizeof(fileTag[0]), strlen(fileTag), file);
fwrite(&numberOfImages, sizeof(numberOfImages), 1, file);
fwrite(&width, sizeof(width), 1, file);
fwrite(&height, sizeof(height), 1, file);
for(int i = 0; i < numberOfImages; i++)
{
fwrite(zeroBuffer, sizeof(GrayScalePixelType), width * height, file);
@ -30,7 +29,7 @@ static void prepareImageFile(const char *path, unsigned short int width, unsigne
free(zeroBuffer);
}
fclose(file);
}
}