created function readImagedata
This commit is contained in:
parent
f68e92f429
commit
f152305c4f
30
imageInput.c
30
imageInput.c
@ -10,9 +10,8 @@
|
|||||||
// übersichtlich aufgeteilt werden!
|
// übersichtlich aufgeteilt werden!
|
||||||
|
|
||||||
// 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
|
||||||
|
|
||||||
|
|
||||||
int readStatusInfo(FILE **source, char *const headerString, int *const imageCount, int *const imageWidth, int *const imageHeight, int const amountToRead);
|
int readStatusInfo(FILE **source, char *const headerString, int *const imageCount, int *const imageWidth, int *const imageHeight, int const amountToRead);
|
||||||
|
void readImagedata(FILE **source, char *const imageBuffer, char *const labelBuffer,int const imageCount ,int const amountToRead);
|
||||||
|
|
||||||
|
|
||||||
// TODO Vervollständigen Sie die Funktion readImages unter Benutzung Ihrer Hilfsfunktionen
|
// TODO Vervollständigen Sie die Funktion readImages unter Benutzung Ihrer Hilfsfunktionen
|
||||||
@ -35,20 +34,10 @@ GrayScaleImageSeries *readImages(const char *path)
|
|||||||
|
|
||||||
numberOfBytesToRead = readStatusInfo(&readSource, headerString, &series->count, &series->images->width, &series->images->height, amountOfStatusInfoToRead);
|
numberOfBytesToRead = readStatusInfo(&readSource, headerString, &series->count, &series->images->width, &series->images->height, amountOfStatusInfoToRead);
|
||||||
|
|
||||||
// bufferspeicher anlegen der unsigned char pointer
|
|
||||||
// mit anzahl der pixel als größe ist um dann
|
|
||||||
// grauwerte in diesen buffer zu schreiben
|
|
||||||
// (grayscale pixeltype in grayscale image series)
|
|
||||||
series->images->buffer = calloc((series->count) * numberOfBytesToRead, sizeof(GrayScalePixelType));
|
series->images->buffer = calloc((series->count) * numberOfBytesToRead, sizeof(GrayScalePixelType));
|
||||||
// zusätzlich auch speicher anlegen der für die labels da ist
|
|
||||||
series->labels = calloc((series->count), sizeof(&(series->labels)));
|
series->labels = calloc((series->count), sizeof(&(series->labels)));
|
||||||
// AB HIER Schleife die für
|
|
||||||
// anzahl der Bilder je die Bytes und das Label einließt
|
readImagedata(&readSource, series->images->buffer, series->labels, series->count, numberOfBytesToRead);
|
||||||
for (i = 0; i <= (series->count); i++)
|
|
||||||
{
|
|
||||||
fread((series->images->buffer + i * numberOfBytesToRead), sizeof(&(series->images->buffer)), numberOfBytesToRead, readSource);
|
|
||||||
fread((series->labels + i), sizeof(&(series->labels)), amountOfStatusInfoToRead, readSource);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fclose(readSource);
|
fclose(readSource);
|
||||||
@ -104,3 +93,16 @@ int readStatusInfo(FILE **source, char *const headerString, int *const imageCoun
|
|||||||
|
|
||||||
return bytesToRead;
|
return bytesToRead;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// reads the imagebytes and the label of all images
|
||||||
|
void readImagedata(FILE **source, char *const imageBuffer, char *const labelBuffer,int const imageCount , int const amountOfBytes)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
|
||||||
|
for (i = 0; i <= imageCount; i++)
|
||||||
|
{
|
||||||
|
fread((imageBuffer + i * amountOfBytes), sizeof(&(imageBuffer)), amountOfBytes, *source);
|
||||||
|
fread((labelBuffer + i), sizeof(&(labelBuffer)), 1, *source);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user