Intellipaat Back

Explore Courses Blog Tutorials Interview Questions
0 votes
2 views
in Machine Learning by (19k points)

While usually, people tend to simply resize any image into a square while training a CNN (for example resnet takes a 224x224 square image), that looks ugly to me, especially when the aspect ratio is not around 1.

(In fact, that might change ground truth eg the label that an expert might give the distorted image could be different than the original one).

So now I resize the image to, say, 224x160, keeping the original ratio, and then I pad the image with 0s (paste it into a random location in a totally black 224x224 image).

My approach doesn't seem original to me, and yet I cannot find any information whatsoever about my approach versus the "usual" approach. Funky!

So, which approach is better? Why? (if the answer is data-dependent please share your thought regarding when one is preferable over the other.)

1 Answer

0 votes
by (33.1k points)

Simply padding a big piece of the image (64x160 pixels) will have the following effect: The CNN will have to learn that the black part of the image is not relevant and might help to distinguish between the classes, because there is no correlation between the pixels in the black part and belonging to a given class.
CNN will have to learn it by gradient descent, and this might probably take some epochs. For this reason, you can do it if you have lots of images and computational power, resizing should also work better.

For more details, study Convolution Neural Network.

Hope this answer helps.

31k questions

32.8k answers

501 comments

693 users

Browse Categories

...