OCR/NeuralNetwork/Load.c

172 lines
3.8 KiB
C
Raw Normal View History

2022-02-08 18:16:25 +00:00
#include "Load.h"
double *resizearray(double *img, int w, int h, int x, int y)
{
double *image = (double *)calloc(x * y, sizeof(double));
float ratioX = (float)w / x;
float ratioY = (float)h / y;
for (int i = 0; i < x; ++i)
{
for (int j = 0; j < y; ++j)
{
image[i * x + j] =
img[((int)(i * ratioY)) * w + ((int)(j * ratioX))];
}
}
return image;
}
int FindBlackPixelrow(double *img, int w, int x)
{
int bool = 0;
/*A boolean that memorize if the line contain black pixel or not*/
double pixel;
for (int i = 0; i < w; i++)
{
pixel = img[x * w + i];
if (pixel == 1)
{
bool = 1;
break;
}
}
return bool;
}
int FindBlackPixelcol(double *img, int w, int h, int x)
{
int bool = 0;
/*A boolean that memorize if the line contain black pixel or not*/
double pixel;
for (int i = 0; i < h; i++)
{
pixel = img[i * w + x];
if (pixel == 1)
{
bool = 1;
break;
}
}
return bool;
}
void get_binerize_matrix(SDL_Surface *img, double *image)
{
/* Variables */
Uint32 pixel;
Uint8 r;
Uint8 g;
Uint8 b;
int w = img->w;
int h = img->h;
for (int i = 0; i < h; i++)
{
for (int j = 0; j < w; j++)
{
pixel = getpixel(img, j, i);
SDL_GetRGB(pixel, img->format, &r, &g, &b);
Uint32 average = (r + b + g) / 3;
if (average > 150) /*we can make an average here*/
image[i * w + j] = 0.0;
else
image[i * w + j] = 1.0;
}
}
}
double *resizechar(SDL_Surface *img, int size)
{
int startcol = 0;
int endcol = 0;
int startrow = 0;
int endrow = 0;
int img_w = img->w;
int img_h = img->h;
double *img_array = (double *)malloc(img_h * img_w * sizeof(double));
get_binerize_matrix(img, img_array);
for (int i = 0; i < img_w; i++)
{
if (FindBlackPixelcol(img_array, img_w, img_h, i))
{
startcol = i;
break;
}
}
for (int i = img_w - 1; i >= 0; i--)
{
if (FindBlackPixelcol(img_array, img_w, img_h, i))
{
endcol = i + 1;
break;
}
}
for (int i = 0; i < img_h; i++)
{
if (FindBlackPixelrow(img_array, img_w, i))
{
startrow = i;
break;
}
}
for (int i = img_h - 1; i >= 0; i--)
{
if (FindBlackPixelrow(img_array, img_w, i))
{
endrow = i + 1;
break;
}
}
double *img_carre;
int img_carre_size;
int lencol = endcol - startcol;
int lenrow = endrow - startrow;
if (lencol > lenrow)
{
img_carre_size = lencol;
img_carre = (double *)calloc(lencol * lencol, sizeof(double));
int start = lencol / 2 - lenrow / 2;
for (int k = startrow; k < endrow; k++)
{
for (int z = startcol; z < endcol; z++)
{
img_carre[(k - startrow + start) * lencol + z - startcol] =
img_array[k * img_w + z];
}
}
}
else
{
img_carre_size = lenrow;
img_carre = (double *)calloc(lenrow * lenrow, sizeof(double));
int start = lenrow / 2 - lencol / 2;
for (int k = startrow; k < endrow; k++)
{
for (int z = startcol; z < endcol; z++)
{
img_carre[(k - startrow) * lenrow + z - startcol + start] =
img_array[k * img_w + z];
}
}
}
double *image;
image = resizearray(img_carre, img_carre_size, img_carre_size, size, size);
SDL_FreeSurface(img);
free(img_array);
free(img_carre);
return image;
}