Skip to content

vinayak1998/bw-Image-Manipulation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 

Repository files navigation

bw-Image-Manipulation

Used linked lists (actually a list of lists/ array of lists) to encode an image in a compact format and perform operations on this format Mainly the following operations:-

  • Compression
  • De-compression
  • Inversion
  • Merge(OR/AND/XOR) with another image

Imagine a gray scale image of size NxN. Each pixel is either black (0) or white (1).

The idea of the compressed representation is to use the redundancy in the pixel value information among ne ighboring pixels to reduce the amount of information that needs to be stored. The representation proceeds row-wise and stores the column indices of contiguous segments of black (0) pixels.

For example, see the fie "sampleInputFile.txt" : (first line is image width and height)

Its equivalent compressed representation is: 16 16 -1 5 7 -1 3 7 -1 2 7 -1 2 2 6 7 -1 6 7 -1 6 7 -1 4 6 -1 2 4 -1 2 3 14 15 -1 2 2 13 15 -1 11 13 -1 11 12 -1 10 11 -1 9 10 -1 7 9 -1

The first line has image width and height respectively. Second line onwards, each line corresponds to image rows (we will number them as 0 to width -1).

In each line we store column indices for contiguous segments of black pixels.

For example in the line corresponding to row 2 the set of black pixels are from column number 3 to 7. Hence we have 3 7 in the fourth line of the representation. The -1s demarcate the rows. If there are more than 1 contiguous black segments in a row then we store the start and end indices of each segment in order, as for rows 4, 9 and 10.

Implemented the interface(see CompressedImageInterface.java):

Here, compressedImage constructors may either take in a 2D array of 0s and 1s, or a name of the file that has the same representation written in the textfile. getPixelValue and setPixelValue are operations to access and modify individual pixels.

numberOfBlackPixels counts the number of black pixels in each row.

Invert method makes each black pixel white and each white pixel black. Boolean operations over images are defined as: for each pixel (i,j), or returns white if any pixel is white, whereas and returns white if both pixels are white.

Finally, xor returns white if exactly one of the pixels is white. It also has two methods to convert the current image into a string.

The strings should be exactly the representation in either compressed or uncompressed form (including line breakscommas).

About

Used linked lists (actually a list of lists/ array of lists) to encode an image in a compact format and perform operations on this format

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages