Digital Image Processing on DIP Quick Guide

introduction

signal processing is a discipline in electrical engineering and in mathematics that deals with analysis and processing of analog and digital signals , and deals with storing , filtering , and other operations on signals. these signals include transmission signals , sound or voice signals , image signals , and other signals e.t.c.

out of all these signals , the field that deals with the type of signals for which the input is an image and the output is also an image is done in image processing. as it name suggests, it deals with the processing on images.

it can be further divided into analog image processing and digital image processing.

analog image processing

analog image processing is done on analog signals. it includes processing on two dimensional analog signals. in this type of processing, the images are manipulated by electrical means by varying the electrical signal. the common example include is the television image.

digital image processing has dominated over analog image processing with the passage of time due its wider range of applications.

digital image processing

the digital image processing deals with developing a digital system that performs operations on an digital image.

what is an image

an image is nothing more than a two dimensional signal. it is defined by the mathematical function f(x,y) where x and y are the two co-ordinates horizontally and vertically.

the value of f(x,y) at any point is gives the pixel value at that point of an image.

what is image

the above figure is an example of digital image that you are now viewing on your computer screen. but actually , this image is nothing but a two dimensional array of numbers ranging between 0 and 255.

128 30 123
232 123 321
123 77 89
80 255 255

each number represents the value of the function f(x,y) at any point. in this case the value 128 , 230 ,123 each represents an individual pixel value. the dimensions of the picture is actually the dimensions of this two dimensional array.

relationship between a digital image and a signal

if the image is a two dimensional array then what does it have to do with a signal? in order to understand that , we need to first understand what is a signal?

signal

in physical world, any quantity measurable through time over space or any higher dimension can be taken as a signal. a signal is a mathematical function, and it conveys some information. a signal can be one dimensional or two dimensional or higher dimensional signal. one dimensional signal is a signal that is measured over time. the common example is a voice signal. the two dimensional signals are those that are measured over some other physical quantities. the example of two dimensional signal is a digital image. we will look in more detail in the next tutorial of how a one dimensional or two dimensional signals and higher signals are formed and interpreted.

relationship

since anything that conveys information or broadcast a message in physical world between two observers is a signal. that includes speech or (human voice) or an image as a signal. since when we speak , our voice is converted to a sound wave/signal and transformed with respect to the time to person we are speaking to. not only this , but the way a digital camera works, as while acquiring an image from a digital camera involves transfer of a signal from one part of the system to the other.

how a digital image is formed

since capturing an image from a camera is a physical process. the sunlight is used as a source of energy. a sensor array is used for the acquisition of the image. so when the sunlight falls upon the object, then the amount of light reflected by that object is sensed by the sensors, and a continuous voltage signal is generated by the amount of sensed data. in order to create a digital image , we need to convert this data into a digital form. this involves sampling and quantization. (they are discussed later on). the result of sampling and quantization results in an two dimensional array or matrix of numbers which are nothing but a digital image.

overlapping fields

machine/computer vision

machine vision or computer vision deals with developing a system in which the input is an image and the output is some information. for example: developing a system that scans human face and opens any kind of lock. this system would look something like this.

computer vision

computer graphics

computer graphics deals with the formation of images from object models, rather then the image is captured by some device. for example: object rendering. generating an image from an object model. such a system would look something like this.

digital image processing

artificial intelligence

artificial intelligence is more or less the study of putting human intelligence into machines. artificial intelligence has many applications in image processing. for example: developing computer aided diagnosis systems that help doctors in interpreting images of x-ray , mri e.t.c and then highlighting conspicuous section to be examined by the doctor.

signal processing

signal processing is an umbrella and image processing lies under it. the amount of light reflected by an object in the physical world (3d world) is pass through the lens of the camera and it becomes a 2d signal and hence result in image formation. this image is then digitized using methods of signal processing and then this digital image is manipulated in digital image processing.

this tutorial covers the basics of signals and system necessary for understanding the concepts of digital image processing. before going into the detail concepts , lets first define the simple terms.

signals

in electrical engineering, the fundamental quantity of representing some information is called a signal. it doesnot matter what the information is i-e: analog or digital information. in mathematics, a signal is a function that conveys some information. in fact any quantity measurable through time over space or any higher dimension can be taken as a signal. a signal could be of any dimension and could be of any form.

analog signals

a signal could be an analog quantity that means it is defined with respect to the time. it is a continuous signal. these signals are defined over continuous independent variables. they are difficult to analyze, as they carry a huge number of values. they are very much accurate due to a large sample of values. in order to store these signals , you require an infinite memory because it can achieve infinite values on a real line. analog signals are denoted by sin waves.

for example:

human voice

human voice is an example of analog signals. when you speak , the voice that is produced travel through air in the form of pressure waves and thus belongs to a mathematical function, having independent variables of space and time and a value corresponding to air pressure.

another example is of sin wave which is shown in the figure below.

y = sin(x) where x is indepedent

sin wave

digital signals

as compared to analog signals, digital signals are very easy to analyze. they are discontinuous signals. they are the appropriation of analog signals.

the word digital stands for discrete values and hence it means that they use specific values to represent any information. in digital signal , only two values are used to represent something i-e: 1 and 0 (binary values). digital signals are less accurate then analog signals because they are the discrete samples of an analog signal taken over some period of time. however digital signals are not subject to noise. so they last long and are easy to interpret. digital signals are denoted by square waves.

for example:

computer keyboard

whenever a key is pressed from the keyboard , the appropriate electrical signal is sent to keyboard controller containing the ascii value that particular key. for example the electrical signal that is generated when keyboard key a is pressed, carry information of digit 97 in the form of 0 and 1, which is the ascii value of character a.

difference between analog and digital signals

comparison element analog signal digital signal
analysis difficult possible to analyze
representation continuous discontinuous
accuracy more accurate less accurate
storage infinite memory easily stored
subject to noise yes no
recording technique original signal is preserved samples of the signal are taken and preserved
examples human voice , thermometer , analog phones e.t.c computers , digital phones , digital pens , e.t.c

systems

a system is a defined by the type of input and output it deals with. since we are dealing with signals , so in our case , our system would be a mathematical model , a piece of code/software , or a physical device , or a black box whose input is a signal and it performs some processing on that signal , and the output is a signal. the input is known as excitation and the output is known as response.

system introduction

in the above figure a system has been shown whose input and output both are signals but the input is an analog signal. and the output is an digital signal. it means our system is actually a conversion system that converts analog signals to digital signals.

lets have a look at the inside of this black box system

conversion of analog to digital signals

since there are lot of concepts related to this analog to digital conversion and vice-versa. we will only discuss those which are related to digital image processing. there are two main concepts that are involved in the coversion.

  • sampling

  • quantization

sampling

sampling as its name suggests can be defined as take samples. take samples of a digital signal over x axis. sampling is done on an independent variable. in case of this mathematical equation:

sampling introduction

sampling is done on the x variable. we can also say that the conversion of x axis (infinite values) to digital is done under sampling.

sampling is further divide into up sampling and down sampling. if the range of values on x-axis are less then we will increase the sample of values. this is known as up sampling and its vice versa is known as down sampling

quantization

quantization as its name suggest can be defined as dividing into quanta (partitions). quantization is done on dependent variable. it is opposite to sampling.

in case of this mathematical equation y = sin(x)

quantization is done on the y variable. it is done on the y axis. the conversion of y axis infinite values to 1 , 0 , -1 (or any other level) is known as quantization.

these are the two basics steps that are involved while converting an analog signal to a digital signal.

the quantization of a signal has been shown in the figure below.

quantization introduction

why do we need to convert an analog signal to digital signal.

the first and obvious reason is that digital image processing deals with digital images , that are digital signals. so when ever the image is captured , it is converted into digital format and then it is processed.

the second and important reason is , that in order to perform operations on an analog signal with a digital computer , you have to store that analog signal in the computer. and in order to store an analog signal , infinite memory is required to store it. and since thats not possible , so thats why we convert that signal into digital format and then store it in digital computer and then performs operations on it.

continuous systems vs discrete systems

continuous systems

the type of systems whose input and output both are continuous signals or analog signals are called continuous systems.

continuous systems

discrete systems

the type of systems whose input and output both are discrete signals or digital signals are called digital systems

discrete systems

origin of camera

the history of camera and photography is not exactly the same. the concepts of camera were introduced a lot before the concept of photography

camera obscura

the history of the camera lies in asia. the principles of the camera were first introduced by a chinese philosopher mozi. it is known as camera obscura. the cameras evolved from this principle.

the word camera obscura is evolved from two different words. camera and obscura. the meaning of the word camera is a room or some kind of vault and obscura stands for dark.

the concept which was introduced by the chinese philosopher consist of a device, that project an image of its surrounding on the wall. however it was not built by the chinese.

camera obscura

the creation of camera obscura

the concept of chinese was bring in reality by a muslim scientist abu ali al-hassan ibn al-haitham commonly known as ibn al-haitham. he built the first camera obscura. his camera follows the principles of pinhole camera. he build this device in somewhere around 1000.

portable camera

in 1685, a first portable camera was built by johann zahn. before the advent of this device , the camera consist of a size of room and were not portable. although a device was made by an irish scientist robert boyle and robert hooke that was a transportable camera, but still that device was very huge to carry it from one place to the other.

origin of photography

although the camera obscura was built in 1000 by a muslim scientist. but its first actual use was described in the 13th century by an english philosopher roger bacon. roger suggested the use of camera for the observation of solar eclipses.

da vinci

although much improvement has been made before the 15th century , but the improvements and the findings done by leonardo di ser piero da vinci was remarkable. da vinci was a great artist , musician , anatomist , and a war enginner. he is credited for many inventions. his one of the most famous painting includes, the painting of mona lisa.

mona lisa

da vinci not only built a camera obscura following the principle of a pin hole camera but also uses it as drawing aid for his art work. in his work , which was described in codex atlanticus , many principles of camera obscura has been defined.

da vinci camera

his camera follows the principle of a pin hole camera which can be described as

when images of illuminated objects penetrate through a small hole into a very dark room you will see [on the opposite wall] these objects in their proper form and color, reduced in size in a reversed position, owing to the intersection of rays.

first photograph

the first photograph was taken in 1814 by a french inventor joseph nicephore niepce. he captures the first photograph of a view from the window at le gras, by coating the pewter plate with bitumen and after that exposing that plate to light.

first photograph

first underwater photograph

the first underwater photograph was taken by an english mathematician william thomson using a water tight box. this was done in 1856.

first underwater photograph

the origin of film

the origin of film was introduced by an american inventor and a philanthropist known as george eastman who is considered as the pioneer of photography.

he founded the company called as eastman kodak , which is famous for developing films. the company starts manufacturing paper film in 1885. he first created the camera kodak and then later brownie. brownie was a box camera and gain its popularity due to its feature of snapshot.

film

after the advent of the film , the camera industry once again got a boom and one invention lead to another.

leica and argus

leica and argus are the two analog cameras developed in 1925 and in 1939 respectively. the camera leica was built using a 35mm cine film.

leica

argus was another camera analog camera that uses the 35mm format and was rather inexpensive as compared by leica and became very popular.

argus

analog cctv cameras

in 1942 a german engineer walter bruch developed and installed the very first system of the analog cctv cameras. he is also credited for the invention of color television in the 1960.

photo pac

the first disposable camera was introduced in 1949 by photo pac. the camera was only a one time use camera with a roll of film already included in it. the later versions of photo pac were water proof and even have the flash.

photo pac

digital cameras

mavica by sony

mavica (the magnetic video camera) was launched by sony in 1981 was the first game changer in digital camera world. the images were recorded on floppy disks and images can be viewed later on any monitor screen.

it was not a pure digital camera , but an analog camera. but got its popularity due to its storing capacity of images on a floppy disks. it means that you can now store images for a long lasting period , and you can save a huge number of pictures on the floppy which are replaced by the new blank disc , when they got full. mavica has the capacity of storing 25 images on a disk.

one more important thing that mavica introduced was its 0.3 mega pixel capacity of capturing photos.

mavica

digital cameras

fuji ds-1p camera by fuji films 1988 was the first true digital camera

nikon d1 was a 2.74 mega pixel camera and the first commercial digital slr camera developed by nikon , and was very much affordable by the professionals.

nikon

today digital cameras are included in the mobile phones with very high resolution and quality.

since digital image processing has very wide applications and almost all of the technical fields are impacted by dip, we will just discuss some of the major applications of dip.

digital image processing is not just limited to adjust the spatial resolution of the everyday images captured by the camera. it is not just limited to increase the brightness of the photo, e.t.c. rather it is far more than that.

electromagnetic waves can be thought of as stream of particles, where each particle is moving with the speed of light. each particle contains a bundle of energy. this bundle of energy is called a photon.

the electromagnetic spectrum according to the energy of photon is shown below.

electro magnetic spectrum

in this electromagnetic spectrum, we are only able to see the visible spectrum. visible spectrum mainly includes seven different colors that are commonly term as (vibgoyr). vibgoyr stands for violet , indigo , blue , green , orange , yellow and red.

but that doesnot nullify the existence of other stuff in the spectrum. our human eye can only see the visible portion, in which we saw all the objects. but a camera can see the other things that a naked eye is unable to see. for example: x rays , gamma rays , e.t.c. hence the analysis of all that stuff too is done in digital image processing.

this discussion leads to another question which is

why do we need to analyze all that other stuff in em spectrum too?

the answer to this question lies in the fact, because that other stuff such as xray has been widely used in the field of medical. the analysis of gamma ray is necessary because it is used widely in nuclear medicine and astronomical observation. same goes with the rest of the things in em spectrum.

applications of digital image processing

some of the major fields in which digital image processing is widely used are mentioned below

  • image sharpening and restoration

  • medical field

  • remote sensing

  • transmission and encoding

  • machine/robot vision

  • color processing

  • pattern recognition

  • video processing

  • microscopic imaging

  • others

image sharpening and restoration

image sharpening and restoration refers here to process images that have been captured from the modern camera to make them a better image or to manipulate those images in way to achieve desired result. it refers to do what photoshop usually does.

this includes zooming, blurring , sharpening , gray scale to color conversion, detecting edges and vice versa , image retrieval and image recognition. the common examples are:

the original image

einstein

the zoomed image

einstein

blurr image

blur

sharp image

sharp

edges

edges

medical field

the common applications of dip in the field of medical is

  1. gamma ray imaging

  2. pet scan

  3. x ray imaging

  4. medical ct

  5. uv imaging

uv imaging

in the field of remote sensing , the area of the earth is scanned by a satellite or from a very high ground and then it is analyzed to obtain information about it. one particular application of digital image processing in the field of remote sensing is to detect infrastructure damages caused by an earthquake.

as it takes longer time to grasp damage, even if serious damages are focused on. since the area effected by the earthquake is sometimes so wide , that it not possible to examine it with human eye in order to estimate damages. even if it is , then it is very hectic and time consuming procedure. so a solution to this is found in digital image processing. an image of the effected area is captured from the above ground and then it is analyzed to detect the various types of damage done by the earthquake.

remote sensing

the key steps include in the analysis are

  1. the extraction of edges

  2. analysis and enhancement of various types of edges

transmission and encoding

the very first image that has been transmitted over the wire was from london to new york via a submarine cable. the picture that was sent is shown below.

transmission

the picture that was sent took three hours to reach from one place to another.

now just imagine , that today we are able to see live video feed , or live cctv footage from one continent to another with just a delay of seconds. it means that a lot of work has been done in this field too. this field doesnot only focus on transmission , but also on encoding. many different formats have been developed for high or low bandwith to encode photos and then stream it over the internet or e.t.c.

machine/robot vision

apart form the many challenges that a robot face today , one of the biggest challenge still is to increase the vision of the robot. make robot able to see things , identify them , identify the hurdles e.t.c. much work has been contributed by this field and a complete other field of computer vision has been introduced to work on it.

hurdle detection

hurdle detection is one of the common task that has been done through image processing, by identifying different type of objects in the image and then calculating the distance between robot and hurdles.

hurdle detection

line follower robot

most of the robots today work by following the line and thus are called line follower robots. this help a robot to move on its path and perform some tasks. this has also been achieved through image processing.

robot

color processing

color processing includes processing of colored images and different color spaces that are used. for example rgb color model , ycbcr, hsv. it also involves studying transmission , storage , and encoding of these color images.

pattern recognition

pattern recognition involves study from image processing and from various other fields that includes machine learning ( a branch of artificial intelligence). in pattern recognition , image processing is used for identifying the objects in an images and then machine learning is used to train the system for the change in pattern. pattern recognition is used in computer aided diagnosis , recognition of handwriting , recognition of images e.t.c

video processing

a video is nothing but just the very fast movement of pictures. the quality of the video depends on the number of frames/pictures per minute and the quality of each frame being used. video processing involves noise reduction , detail enhancement , motion detection , frame rate conversion , aspect ratio conversion , color space conversion e.t.c.

we will look at this example in order to understand the concept of dimension.

dimensions

consider you have a friend who lives on moon, and he wants to send you a gift on your birthday present. he ask you about your residence on earth. the only problem is that the courier service on moon doesnot understand the alphabetical address, rather it only understand the numerical co-ordinates. so how do you send him your position on earth?

thats where comes the concept of dimensions. dimensions define the minimum number of points required to point a position of any particular object within a space.

so lets go back to our example again in which you have to send your position on earth to your friend on moon. you send him three pair of co-ordinates. the first one is called longitude , the second one is called latitude, and the third one is called altitude.

these three co-ordinates define your position on the earth. the first two defines your location , and the third one defines your height above the sea level.

so that means that only three co-ordinates are required to define your position on earth. that means you live in world which is 3 dimensional. and thus this not only answers the question about dimension , but also answers the reason , that why we live in a 3d world.

since we are studying this concept in reference to the digital image processing, so we are now going to relate this concept of dimension with an image.

dimensions of image

so if we live in the 3d world , means a 3 dimensional world, then what are the dimensions of an image that we capture. an image is a two dimensional, thats why we also define an image as a 2 dimensional signal. an image has only height and width. an image doesnot have depth. just have a look at this image below.

one dimension

if you would look at the above figure , it shows that it has only two axis which are the height and width axis. you cannot perceive depth from this image. thats why we say that an image is two dimensional signal. but our eye is able to perceive three dimensional objects , but this would be more explained in the next tutorial of how the camera works , and image is perceived.

this discussion leads to some other questions that how 3 dimension systems is formed from 2 dimension.

how does television works?

if we look the image above , we will see that it is a two dimensional image. in order to convert it into three dimension , we need one other dimension. lets take time as the third dimension , in that case we will move this two dimensional image over the third dimension time. the same concept that happens in television, that helps us perceive the depth of different objects on a screen. does that mean that what comes on the t.v or what we see in the television screen is 3d. well we can yes. the reason is that, in case of t.v we if we are playing a video. then a video is nothing else but two dimensional pictures move over time dimension. as two dimensional objects are moving over the third dimension which is a time so we can say it is 3 dimensional.

different dimensions of signals

1 dimension signal

the common example of a 1 dimension signal is a waveform. it can be mathematically represented as

f(x) = waveform

where x is an independent variable. since it is a one dimension signal , so thats why there is only one variable x is used.

pictorial representation of a one dimensional signal is given below:

one dimension signal

the above figure shows a one dimensional signal.

now this lead to another question, which is, even though it is a one dimensional signal ,then why does it have two axis?. the answer to this question is that even though it is a one dimensional signal , but we are drawing it in a two dimensional space. or we can say that the space in which we are representing this signal is two dimensional. thats why it looks like a two dimensional signal.

perhaps you can understand the concept of one dimension more better by looking at the figure below.

one dimension points

now refer back to our initial discussion on dimension, consider the above figure a real line with positive numbers from one point to the other. now if we have to explain the location of any point on this line, we just need only one number, which means only one dimension.

2 dimensions signal

the common example of a two dimensional signal is an image , which has already been discussed above.

two dimension

as we have already seen that an image is two dimensional signal, i-e: it has two dimensions. it can be mathematically represented as:

f (x , y) = image

where x and y are two variables. the concept of two dimension can also be explained in terms of mathematics as:

two dimensions points

now in the above figure, label the four corners of the square as a,b,c and d respectively. if we call , one line segment in the figure ab and the other cd , then we can see that these two parallel segments join up and make a square. each line segment corresponds to one dimension , so these two line segments correspond to 2 dimensions.

3 dimension signal

three dimensional signal as it names refers to those signals which has three dimensions. the most common example has been discussed in the beginning which is of our world. we live in a three dimensional world. this example has been discussed very elaborately. another example of a three dimensional signal is a cube or a volumetric data or the most common example would be animated or 3d cartoon character.

the mathematical representation of three dimensional signal is:

f(x,y,z) = animated character.

another axis or dimension z is involved in a three dimension, that gives the illusion of depth. in a cartesian co-ordinate system it can be viewed as:

three dimensions points

4 dimension signal

in a four dimensional signal , four dimensions are involved. the first three are the same as of three dimensional signal which are: (x, y, z), and the fourth one which is added to them is t(time). time is often referred to as temporal dimension which is a way to measure change. mathematically a four d signal can be stated as:

f(x,y,z,t) = animated movie.

the common example of a 4 dimensional signal can be an animated 3d movie. as each character is a 3d character and then they are moved with respect to the time, due to which we saw an illusion of a three dimensional movie more like a real world.

so that means that in reality the animated movies are 4 dimensional i-e: movement of 3d characters over the fourth dimension time.

how human eye works?

before we discuss , the image formation on analog and digital cameras , we have to first discuss the image formation on human eye. because the basic principle that is followed by the cameras has been taken from the way , the human eye works.

when light falls upon the particular object , it is reflected back after striking through the object. the rays of light when passed through the lens of eye , form a particular angle , and the image is formed on the retina which is the back side of the wall. the image that is formed is inverted. this image is then interpreted by the brain and that makes us able to understand things. due to angle formation , we are able to perceive the height and depth of the object we are seeing. this has been more explained in the tutorial of perspective transformation.

eye image formation

as you can see in the above figure, that when sun light falls on the object (in this case the object is a face), it is reflected back and different rays form different angle when they are passed through the lens and an invert image of the object has been formed on the back wall. the last portion of the figure denotes that the object has been interpreted by the brain and re-inverted.

now lets take our discussion back to the image formation on analog and digital cameras.

image formation on analog cameras

image formation on strip

in analog cameras , the image formation is due to the chemical reaction that takes place on the strip that is used for image formation.

a 35mm strip is used in analog camera. it is denoted in the figure by 35mm film cartridge. this strip is coated with silver halide ( a chemical substance).

analog strip

a 35mm strip is used in analog camera. it is denoted in the figure by 35mm film cartridge. this strip is coated with silver halide ( a chemical substance).

light is nothing but just the small particles known as photon particles.so when these photon particles are passed through the camera, it reacts with the silver halide particles on the strip and it results in the silver which is the negative of the image.

in order to understand it better , have a look at this equation.

photons (light particles) + silver halide ? silver ? image negative.

image negative

this is just the basics, although image formation involves many other concepts regarding the passing of light inside , and the concepts of shutter and shutter speed and aperture and its opening but for now we will move on to the next part. although most of these concepts have been discussed in our tutorial of shutter and aperture.

this is just the basics, although image formation involves many other concepts regarding the passing of light inside , and the concepts of shutter and shutter speed and aperture and its opening but for now we will move on to the next part. although most of these concepts have been discussed in our tutorial of shutter and aperture.

image formation on digital cameras

in the digital cameras , the image formation is not due to the chemical reaction that take place , rather it is a bit more complex then this. in the digital camera , a ccd array of sensors is used for the image formation.

image formation through ccd array

ccd array

ccd stands for charge-coupled device. it is an image sensor, and like other sensors it senses the values and converts them into an electric signal. in case of ccd it senses the image and convert it into electric signal e.t.c.

this ccd is actually in the shape of array or a rectangular grid. it is like a matrix with each cell in the matrix contains a censor that senses the intensity of photon.

ccd sensor array

like analog cameras , in the case of digital too , when light falls on the object , the light reflects back after striking the object and allowed to enter inside the camera.

each sensor of the ccd array itself is an analog sensor. when photons of light strike on the chip , it is held as a small electrical charge in each photo sensor. the response of each sensor is directly equal to the amount of light or (photon) energy striked on the surface of the sensor.

since we have already define an image as a two dimensional signal and due to the two dimensional formation of the ccd array , a complete image can be achieved from this ccd array.

it has limited number of sensors , and it means a limited detail can be captured by it. also each sensor can have only one value against the each photon particle that strike on it.

so the number of photons striking(current) are counted and stored. in order to measure accurately these , external cmos sensors are also attached with ccd array.

introduction to pixel

the value of each sensor of the ccd array refers to each the value of the individual pixel. the number of sensors = number of pixels. it also means that each sensor could have only one and only one value.

storing image

the charges stored by the ccd array are converted to voltage one pixel at a time. with the help of additional circuits , this voltage is converted into a digital information and then it is stored.

each company that manufactures digital camera, make their own ccd sensors. that include , sony , mistubishi , nikon ,samsung , toshiba , fujifilm , canon e.t.c.

apart from the other factors , the quality of the image captured also depends on the type and quality of the ccd array that has been used.

in this tutorial, we will discuss some of the basic camera concepts, like aperture , shutter , shutter speed , iso and we will discuss the collective use of these concepts to capture a good image.

aperture

aperture is a small opening which allows the light to travel inside into camera. here is the picture of aperture.

aperture

you will see some small blades like stuff inside the aperture. these blades create a octagonal shape that can be opened closed. and thus it make sense that , the more blades will open, the hole from which the light would have to pass would be bigger. the bigger the hole , the more light is allowed to enter.

effect

the effect of the aperture directly corresponds to brightness and darkness of an image. if the aperture opening is wide , it would allow more light to pass into the camera. more light would result in more photons, which ultimately result in a brighter image.

the example of this is shown below

consider these two photos

einstein bright einstein dark

the one on the right side looks brighter, it means that when it was captured by the camera , the aperture was wide open. as compare to the other picture on the left side , which is very dark as compare to the first one, that shows that when that image was captured, its aperture was not wide open.

size

now lets discuss the maths behind the aperture. the size of the aperture is denoted by a f value. and it is inversely proportional to the opening of aperture.

here are the two equations , that best explain this concept.

large aperture size = small f value

small aperture size = greater f value

pictorially it can be represented as:

focal

shutter

after the aperture , there comes the shutter. the light when allowed to pass from the aperture , falls directly on to the shutter. shutter is actually a cover, a closed window , or can be thought of as a curtain. remember when we talk about the ccd array sensor on which the image is formed. well behind the shutter is the sensor. so shutter is the only thing that is between the image formation and the light , when it is passed from aperture.

as soon as the shutter is open , light falls on the image sensor , and the image is formed on the array.

effect

if the shutter allows light to pass a bit longer , the image would be brighter. similarly a darker picture is produced , when a shutter is allowed to move very quickly and hence, the light that is allowed to pass has very less photons , and the image that is formed on the ccd array sensor is very dark.

shutter has further two main concepts:

  • shutter speed

  • shutter time

shutter speed

the shutter speed can be referred to as the number of times the shutter get open or close. remember we are not talking about for how long the shutter get open or close.

shutter time

the shutter time can be defined as

when the shutter is open , then the amount of wait time it take till it is closed is called shutter time.

in this case we are not talking about how many times , the shutter got open or close , but we are talking about for how much time does it remain wide open.

for example:

we can better understand these two concepts in this way. that lets say that a shutter opens 15 times and then get closed, and for each time it opens for 1 second and then get closed. in this example , 15 is the shutter speed and 1 second is the shutter time.

relationship

the relationship between shutter speed and shutter time is that they are both inversely proportional to each other.

this relationship can be defined in the equation below.

more shutter speed = less shutter time

less shutter speed = more shutter time.

explanation:

the lesser the time required , the more is the speed. and the greater the time required , the less is the speed.

applications

these two concepts together make a variety of applications. some of them are given below.

fast moving objects:

if you were to capture the image of a fast moving object , could be a car or anything. the adjustment of shutter speed and its time would effect a lot.

so , in order to capture an image like this, we will make two amendments:

  • increase shutter speed

  • decrease shutter time

what happens is , that when we increase shutter speed , the more number of times , the shutter would open or close. it means different samples of light would allow to pass in. and when we decrease shutter time , it means we will immediately captures the scene, and close the shutter gate.

if you will do this , you get a crisp image of a fast moving object.

in order to understand it , we will look at this example. suppose you want to capture the image of fast moving water fall.

you set your shutter speed to 1 second and you capture a photo. this is what you get

one second

then you set your shutter speed to a faster speed and you get.

one by three second

then again you set your shutter speed to even more faster and you get.

one by two hundred second

you can see in the last picture , that we have increase our shutter speed to very fast, that means that a shutter get opened or closed in 200th of 1 second and so we got a crisp image.

iso

iso factor is measured in numbers. it denotes the sensitivity of light to camera. if iso number is lowered , it means our camera is less sensitive to light and if the iso number is high, it means it is more senstivie.

effect

the higher is the iso , the more brighter the picture would be. if iso is set to 1600 , the picture would be very brighter and vice versa.

side effect

if the iso increases, the noise in the image also increases. today most of the camera manufacturing companies are working on removing the noise from the image when iso is set to higher speed.

pixel

pixel is the smallest element of an image. each pixel correspond to any one value. in an 8-bit gray scale image, the value of the pixel between 0 and 255. the value of a pixel at any point correspond to the intensity of the light photons striking at that point. each pixel store a value proportional to the light intensity at that particular location.

pel

a pixel is also known as pel. you can have more understanding of the pixel from the pictures given below.

in the above picture, there may be thousands of pixels, that together make up this image. we will zoom that image to the extent that we are able to see some pixels division. it is shown in the image below.

einstein

in the above picture, there may be thousands of pixels, that together make up this image. we will zoom that image to the extent that we are able to see some pixels division. it is shown in the image below.

pixel

relation ship with ccd array

we have seen that how an image is formed in the ccd array. so a pixel can also be defined as

the smallest division the ccd array is also known as pixel.

each division of ccd array contains the value against the intensity of the photon striking to it. this value can also be called as a pixel

relationshiip with ccd array

calculation of total number of pixels

we have define an image as a two dimensional signal or matrix. then in that case the number of pel would be equal to the number of rows multiply with number of columns.

this can be mathematically represented as below:

total number of pixels = number of rows ( x ) number of columns

or we can say that the number of (x,y) coordinate pairs make up the total number of pixels.

we will look in more detail in the tutorial of image types , that how do we calculate the pixels in a color image.

gray level

the value of the pixel at any point denotes the intensity of image at that location , and that is also known as gray level.

we will see in more detail about the value of the pixels in the image storage and bits per pixel tutorial, but for now we will just look at the concept of only one pixel value.

pixel value.(0)

as it has already been define in the beginning of this tutorial , that each pixel can have only one value and each value denotes the intensity of light at that point of the image.

we will now look at a very unique value 0. the value 0 means absence of light. it means that 0 denotes dark, and it further means that when ever a pixel has a value of 0, it means at that point , black color would be formed.

have a look at this image matrix

0 0 0
0 0 0
0 0 0

now this image matrix has all filled up with 0. all the pixels have a value of 0. if we were to calculate the total number of pixels form this matrix , this is how we are going to do it.

total no of pixels = total no. of rows x total no. of columns

= 3 x 3

= 9.

it means that an image would be formed with 9 pixels, and that image would have a dimension of 3 rows and 3 column and most importantly that image would be black.

the resulting image that would be made would be something like this

black

now why is this image all black. because all the pixels in the image had a value of 0.

when human eyes see near things they look bigger as compare to those who are far away. this is called perspective in a general way. whereas transformation is the transfer of an object e.t.c from one state to another.

so overall , the perspective transformation deals with the conversion of 3d world into 2d image. the same principle on which human vision works and the same principle on which the camera works.

we will see in detail about why this happens , that those objects which are near to you look bigger , while those who are far away , look smaller even though they look bigger when you reach them.

we will start this discussion by the concept of frame of reference:

frame of reference:

frame of reference is basically a set of values in relation to which we measure something.

perspective

5 frames of reference

in order to analyze a 3d world/image/scene, 5 different frame of references are required.

  • object

  • world

  • camera

  • image

  • pixel

object coordinate frame

object coordinate frame is used for modeling objects. for example , checking if a particular object is in a proper place with respect to the other object. it is a 3d coordinate system.

world coordinate frame

world coordinate frame is used for co-relating objects in a 3 dimensional world. it is a 3d coordinate system.

camera coordinate frame

camera co-ordinate frame is used to relate objects with respect of the camera. it is a 3d coordinate system.

image coordinate frame

it is not a 3d coordinate system , rather it is a 2d system. it is used to describe how 3d points are mapped in a 2d image plane.

pixel coordinate frame

it is also a 2d coordinate system. each pixel has a value of pixel co ordinates.

transformation between these 5 frames

transformation

thats how a 3d scene is transformed into 2d , with image of pixels.

now we will explain this concept mathematically.

maths perspective where

y = 3d object

y = 2d image

f = focal length of the camera

z = distance between image and the camera

now there are two different angles formed in this transform which are represented by q.

the first angle is

tan

where minus denotes that image is inverted. the second angle that is formed is:

tan1

comparing these two equations we get

result

from this equation, we can see that when the rays of light reflect back after striking from the object , passed from the camera , an invert image is formed.

we can better understand this, with this example.

for example

calculating the size of image formed

suppose an image has been taken of a person 5m tall, and standing at a distance of 50m from the camera, and we have to tell that what is the size of the image of the person , with a camera of focal length is 50mm.

solution:

since the focal length is in millimeter , so we have to convert every thing in millimeter in order to calculate it.

so,

y = 5000 mm.

f = 50 mm.

z = 50000 mm.

putting the values in the formula , we get

formula

= -5 mm.

again, the minus sign indicates that the image is inverted.

bpp or bits per pixel denotes the number of bits per pixel. the number of different colors in an image is depends on the depth of color or bits per pixel.

bits in mathematics:

its just like playing with binary bits.

how many numbers can be represented by one bit.

0

1

how many two bits combinations can be made.

00

01

10

11

if we devise a formula for the calculation of total number of combinations that can be made from bit , it would be like this.

bits per pixels

where bpp denotes bits per pixel. put 1 in the formula you get 2, put 2 in the formula , you get 4. it grows exponentionally.

number of different colors:

now as we said it in the beginning , that the number of different colors depend on the number of bits per pixel.

the table for some of the bits and their color is given below.

bits per pixel number of colors
1 bpp 2 colors
2 bpp 4 colors
3 bpp 8 colors
4 bpp 16 colors
5 bpp 32 colors
6 bpp 64 colors
7 bpp 128 colors
8 bpp 256 colors
10 bpp 1024 colors
16 bpp 65536 colors
24 bpp 16777216 colors (16.7 million colors)
32 bpp 4294967296 colors (4294 million colors)

this table shows different bits per pixel and the amount of color they contain.

shades

you can easily notice the pattern of the exponentional growth. the famous gray scale image is of 8 bpp , means it has 256 different colors in it or 256 shades.

shades can be represented as:

shades

color images are usually of the 24 bpp format , or 16 bpp.

we will see more about other color formats and image types in the tutorial of image types.

color values:

we have previously seen in the tutorial of concept of pixel , that 0 pixel value denotes black color.

black color:

remember , 0 pixel value always denotes black color. but there is no fixed value that denotes white color.

white color:

the value that denotes white color can be calculated as :

white_color

in case of 1 bpp , 0 denotes black , and 1 denotes white.

in case 8 bpp , 0 denotes black , and 255 denotes white.

gray color:

when you calculate the black and white color value , then you can calculate the pixel value of gray color.

gray color is actually the mid point of black and white. that said,

in case of 8bpp, the pixel value that denotes gray color is 127 or 128bpp (if you count from 1, not from 0).

image storage requirements

after the discussion of bits per pixel , now we have every thing that we need to calculate a size of an image.

image size

the size of an image depends upon three things.

  • number of rows

  • number of columns

  • number of bits per pixel

the formula for calculating the size is given below.

size of an image = rows * cols * bpp

it means that if you have an image, lets say this one:

einstein

assuming it has 1024 rows and it has 1024 columns. and since it is a gray scale image , it has 256 different shades of gray or it has bits per pixel. then putting these values in the formula , we get

size of an image = rows * cols * bpp

= 1024 * 1024 * 8

= 8388608 bits.

but since its not a standard answer that we recognize , so will convert it into our format.

converting it into bytes = 8388608 / 8 = 1048576 bytes.

converting into kilo bytes = 1048576 / 1024 = 1024kb.

converting into mega bytes = 1024 / 1024 = 1 mb.

thats how an image size is calculated and it is stored. now in the formula , if you are given the size of image and the bits per pixel , you can also calculate the rows and columns of the image , provided the image is square(same rows and same column).

there are many type of images , and we will look in detail about different types of images , and the color distribution in them.

the binary image

the binary image as it name states , contain only two pixel values.

0 and 1.

in our previous tutorial of bits per pixel , we have explained this in detail about the representation of pixel values to their respective colors.

here 0 refers to black color and 1 refers to white color. it is also known as monochrome.

black and white image:

the resulting image that is formed hence consist of only black and white color and thus can also be called as black and white image.

black and white

no gray level

one of the interesting this about this binary image that there is no gray level in it. only two colors that are black and white are found in it.

format

binary images have a format of pbm ( portable bit map )

2 , 3 , 4 ,5 ,6 bit color format

the images with a color format of 2 , 3 , 4 ,5 and 6 bit are not widely used today. they were used in old times for old tv displays , or monitor displays.

but each of these colors have more then two gray levels , and hence has gray color unlike the binary image.

in a 2 bit 4, in a 3 bit 8 , in a 4 bit 16, in a 5 bit 32, in a 6 bit 64 different colors are present.

8 bit color format

8 bit color format is one of the most famous image format. it has 256 different shades of colors in it. it is commonly known as grayscale image.

the range of the colors in 8 bit vary from 0-255. where 0 stands for black , and 255 stands for white , and 127 stands for gray color.

this format was used initially by early models of the operating systems unix and the early color macintoshes.

a grayscale image of einstein is shown below:

einstein

format

the format of these images are pgm ( portable gray map ).

this format is not supported by default from windows. in order to see gray scale image , you need to have an image viewer or image processing toolbox such as matlab.

behind gray scale image:

as we have explained it several times in the previous tutorials , that an image is nothing but a two dimensional function , and can be represented by a two dimensional array or matrix. so in the case of the image of einstein shown above , there would be two dimensional matrix in behind with values ranging between 0 and 255.

but thats not the case with the color images.

16 bit color format

it is a color image format. it has 65,536 different colors in it. it is also known as high color format.

it has been used by microsoft in their systems that support more then 8 bit color format. now in this 16 bit format and the next format we are going to discuss which is a 24 bit format are both color format.

the distribution of color in a color image is not as simple as it was in grayscale image.

a 16 bit format is actually divided into three further formats which are red , green and blue. the famous (rgb) format.

it is pictorially represented in the image below.

16-bit

now the question arises , that how would you distribute 16 into three. if you do it like this,

5 bits for r , 5 bits for g , 5 bits for b

then there is one bit remains in the end.

so the distribution of 16 bit has been done like this.

5 bits for r , 6 bits for g , 5 bits for b.

the additional bit that was left behind is added into the green bit. because green is the color which is most soothing to eyes in all of these three colors.

note this is distribution is not followed by all the systems. some have introduced an alpha channel in the 16 bit.

another distribution of 16 bit format is like this:

4 bits for r , 4 bits for g , 4 bits for b , 4 bits for alpha channel.

or some distribute it like this

5 bits for r , 5 bits for g , 5 bits for b , 1 bits for alpha channel.

24 bit color format

24 bit color format also known as true color format. like 16 bit color format , in a 24 bit color format , the 24 bits are again distributed in three different formats of red , green and blue.

24-bit

since 24 is equally divided on 8 , so it has been distributed equally between three different color channels.

their distribution is like this.

8 bits for r , 8 bits for g , 8 bits for b.

behind a 24 bit image.

unlike a 8 bit gray scale image , which has one matrix behind it, a 24 bit image has three different matrices of r , g , b.

what is image

format

it is the most common used format. its format is ppm ( portable pixmap) which is supported by linux operating system. the famous windows has its own format for it which is bmp ( bitmap ).

in this tutorial , we will see that how different color codes can be combined to make other colors, and how we can covert rgb color codes to hex and vice versa.

different color codes

all the colors here are of the 24 bit format, that means each color has 8 bits of red , 8 bits of green , 8 bits of blue , in it. or we can say each color has three different portions. you just have to change the quantity of these three portions to make any color.

binary color format

color:black

image:

black

decimal code:

(0,0,0)

explanation:

as it has been explained in the previous tutorials , that in an 8-bit format , 0 refers to black. so if we have to make a pure black color , we have to make all the three portion of r , g , b to 0.

color:white

image:

white

decimal code:

(255,255,255)

explanation:

since each portion of r,g,b is an 8 bit portion. so in 8-bit , the white color is formed by 255. it is explained in the tutorial of pixel. so in order to make a white color we set each portion to 255 and thats how we got a white color. by setting each of the value to 255 , we get overall value of 255 , thats make the color white.

rgb color model:

color:red

image:

red

decimal code:

(255,0,0)

explanation:

since we need only red color , so we zero out the rest of the two portions which are green and blue , and we set the red portion to its maximum which is 255.

color:green

image:

green

decimal code:

(0,255,0)

explanation:

since we need only green color , so we zero out the rest of the two portions which are red and blue , and we set the green portion to its maximum which is 255.

color: blue

image:

blue

decimal code:

(0,0,255)

explanation:

since we need only blue color , so we zero out the rest of the two portions which are red and green , and we set the blue portion to its maximum which is 255

gray color:

color: gray

image:

gray

decimal code:

(128,128,128)

explanation:

as we have already defined in our tutorial of pixel , that gray color is actually the mid point. in an 8-bit format , the mid point is 128 or 127. in this case we choose 128. so we set each of the portion to its mid point which is 128 , and that results in overall mid value and we got gray color.

cmyk color model:

cmyk is another color model where c stands for cyan , m stands for magenta , y stands for yellow , and k for black. cmyk model is commonly used in color printers in which there are two carters of color is used. one consist of cmy and other consist of black color.

the colors of cmy can also made from changing the quantity or portion of red , green and blue.

color: cyan

image:

cyan

decimal code:

(0,255,255)

explanation:

cyan color is formed from the combination of two different colors which are green and blue. so we set those two to maximum and we zero out the portion of red. and we get cyan color.

color: magenta

image:

magenta

decimal code:

(255,0,255)

explanation:

magenta color is formed from the combination of two different colors which are red and blue. so we set those two to maximum and we zero out the portion of green. and we get magenta color.

color: yellow

image:

yellow

decimal code:

(255,255,0)

explanation:

yellow color is formed from the combination of two different colors which are red and green. so we set those two to maximum and we zero out the portion of blue. and we get yellow color.

conversion

now we will see that how color are converted are from one format to another.

conversion from rgb to hex code:

conversion from hex to rgb is done through this method:

  • take a color. e.g: white = (255, 255 , 255).

  • take the first portion e.g 255.

  • divide it by 16. like this:

  • conversion

  • take the two numbers below line , the factor , and the remainder. in this case it is 15 � 15 which is ff.

  • repeat the step 2 for the next two portions.

  • combine all the hex code into one.

answer: #ffffff

conversion from hex to rgb:

conversion from hex code to rgb decimal format is done in this way.

take a hex number. e.g: #ffffff

break this number into 3 parts: ff ff ff

take the first part and separate its components: f f

convert each of the part separately into binary: (1111) ( 1111)

now combine the individual binaries into one: 11111111

convert this binary into decimal: 255

now repeat step 2 , two more times.

the value comes in the first step is r , second one is g, and the third one belongs to b.

answer: ( 255 , 255 , 255 )

common colors and their hex code has been given in this table.

color hex code
black #000000
white #ffffff
gray #808080
red #ff0000
green #00ff00
blue #0000ff
cyan #00ffff
magenta #ff00ff
yellow #ffff00
we have already define the rgb color model and gray scale format in our tutorial of image types. now we will convert an color image into a grayscale image. there are two methods to convert it. both has their own merits and demerits. the methods are:
  • average method

  • weighted method or luminosity method

average method

average method is the most simple one. you just have to take the average of three colors. since its an rgb image , so it means that you have add r with g with b and then divide it by 3 to get your desired grayscale image.

its done in this way.

grayscale = (r + g + b) / 3

for example:

rgb

if you have an color image like the image shown above and you want to convert it into grayscale using average method. the following result would appear.

rgb_gray

explanation

there is one thing to be sure , that something happens to the original works. it means that our average method works. but the results were not as expected. we wanted to convert the image into a grayscale , but this turned out to be a rather black image.

problem

this problem arise due to the fact , that we take average of the three colors. since the three different colors have three different wavelength and have their own contribution in the formation of image , so we have to take average according to their contribution , not done it averagely using average method. right now what we are doing is this,

33% of red, 33% of green, 33% of blue

we are taking 33% of each, that means , each of the portion has same contribution in the image. but in reality thats not the case. the solution to this has been given by luminosity method.

weighted method or luminosity method

you have seen the problem that occur in the average method. weighted method has a solution to that problem. since red color has more wavelength of all the three colors , and green is the color that has not only less wavelength then red color but also green is the color that gives more soothing effect to the eyes.

it means that we have to decrease the contribution of red color , and increase the contribution of the green color , and put blue color contribution in between these two.

so the new equation that form is:

new grayscale image = ( (0.3 * r) + (0.59 * g) + (0.11 * b) ).

according to this equation , red has contribute 30% , green has contributed 59% which is greater in all three colors and blue has contributed 11%.

applying this equation to the image, we get this

original image:

rgb

grayscale image:

weighted_gray

explanation

as you can see here , that the image has now been properly converted to grayscale using weighted method. as compare to the result of average method , this image is more brighter.

conversion of analog signal to digital signal:

the output of most of the image sensors is an analog signal, and we can not apply digital processing on it because we can not store it. we can not store it because it requires infinite memory to store a signal that can have infinite values.

so we have to convert an analog signal into a digital signal.

to create an image which is digital , we need to covert continuous data into digital form. there are two steps in which it is done.

  • sampling

  • quantization

we will discuss sampling now , and quantization will be discussed later on but for now on we will discuss just a little about the difference between these two and the need of these two steps.

basic idea:

the basic idea behind converting an analog signal to its digital signal is

basic_idea

to convert both of its axis (x,y) into a digital format.

since an image is continuous not just in its co-ordinates (x axis) , but also in its amplitude (y axis), so the part that deals with the digitizing of co-ordinates is known as sampling. and the part that deals with digitizing the amplitude is known as quantization.

sampling.

sampling has already been introduced in our tutorial of introduction to signals and system. but we are going to discuss here more.

here what we have discussed of the sampling.

the term sampling refers to take samples

we digitize x axis in sampling

it is done on independent variable

in case of equation y = sin(x), it is done on x variable

it is further divided into two parts , up sampling and down sampling

sampling

if you will look at the above figure , you will see that there are some random variations in the signal. these variations are due to noise. in sampling we reduce this noise by taking samples. it is obvious that more samples we take , the quality of the image would be more better, the noise would be more removed and same happens vice versa.

however , if you take sampling on the x axis , the signal is not converted to digital format , unless you take sampling of the y-axis too which is known as quantization. the more samples eventually means you are collecting more data, and in case of image , it means more pixels.

relation ship with pixels

since a pixel is a smallest element in an image. the total number of pixels in an image can be calculated as

pixels = total no of rows * total no of columns.

lets say we have total of 25 pixels , that means we have a square image of 5 x 5. then as we have dicussed above in sampling , that more samples eventually result in more pixels. so it means that of our continuous signal , we have taken 25 samples on x axis. that refers to 25 pixels of this image.

this leads to another conclusion that since pixel is also the smallest division of a ccd array. so it means it has a relationship with ccd array too , which can be explained as this.

relationship with ccd array

the number of sensors on a ccd array is directly equal to the number of pixels. and since we have concluded that the number of pixels is directly equal to the number of samples, that means that number sample is directly equal to the number of sensors on ccd array.

oversampling.

in the beginning we have define that sampling is further categorize into two types. which is up sampling and down sampling. up sampling is also called as over sampling.

the oversampling has a very deep application in image processing which is known as zooming.

zooming

we will formally introduce zooming in the upcoming tutorial , but for now on , we will just briefly explain zooming.

zooming refers to increase the quantity of pixels , so that when you zoom an image , you will see more detail.

the increase in the quantity of pixels is done through oversampling. the one way to zoom is , or to increase samples, is to zoom optically , through the motor movement of the lens and then capture the image. but we have to do it , once the image has been captured.

there is a difference between zooming and sampling.

the concept is same , which is, to increase samples. but the key difference is that while sampling is done on the signals , zooming is done on the digital image.

before we define pixel resolution, it is necessary to define a pixel.

pixel

we have already defined a pixel in our tutorial of concept of pixel, in which we define a pixel as the smallest element of an image. we also defined that a pixel can store a value proportional to the light intensity at that particular location.

now since we have defined a pixel, we are going to define what is resolution.

resolution

the resolution can be defined in many ways. such as pixel resolution , spatial resolution , temporal resolution , spectral resolution. out of which we are going to discuss pixel resolution.

you have probably seen that in your own computer settings , you have monitor resolution of 800 x 600 , 640 x 480 e.t.c

in pixel resolution , the term resolution refers to the total number of count of pixels in an digital image. for example. if an image has m rows and n columns , then its resolution can be defined as m x n.

if we define resolution as the total number of pixels , then pixel resolution can be defined with set of two numbers. the first number the width of the picture , or the pixels across columns , and the second number is height of the picture , or the pixels across its width.

we can say that the higher is the pixel resolution , the higher is the quality of the image.

we can define pixel resolution of an image as 4500 x 5500.

megapixels

we can calculate mega pixels of a camera using pixel resolution.

column pixels (width ) x row pixels ( height ) / 1 million.

the size of an image can be defined by its pixel resolution.

size = pixel resolution x bpp ( bits per pixel )

calculating the mega pixels of the camera

lets say we have an image of dimension: 2500 x 3192.

its pixel resolution = 2500 * 3192 = 7982350 bytes.

dividing it by 1 million = 7.9 = 8 mega pixel (approximately).

aspect ratio

another important concept with the pixel resolution is aspect ratio.

aspect ratio is the ratio between width of an image and the height of an image. it is commonly explained as two numbers separated by a colon (8:9). this ratio differs in different images , and in different screens. the common aspect ratios are:

1.33:1, 1.37:1, 1.43:1, 1.50:1, 1.56:1, 1.66:1, 1.75:1, 1.78:1, 1.85:1, 2.00:1, e.t.c

advantage:

aspect ratio maintains a balance between the appearance of an image on the screen , means it maintains a ratio between horizontal and vertical pixels. it does not let the image to get distorted when aspect ratio is increased.

for example:

this is a sample image , which has 100 rows and 100 columns. if we wish to make is smaller, and the condition is that the quality remains the same or in other way the image does not get distorted , here how it happens.

original image:

aspect ratio

changing the rows and columns by maintain the aspect ratio in ms paint.

paint

result

reduced aspect ratio

smaller image , but with same balance.

you have probably seen aspect ratios in the video players, where you can adjust the video according to your screen resolution.

finding the dimensions of the image from aspect ratio:

aspect ratio tells us many things. with the aspect ratio, you can calculate the dimensions of the image along with the size of the image.

for example

if you are given an image with aspect ratio of 6:2 of an image of pixel resolution of 480000 pixels given the image is an gray scale image.

and you are asked to calculate two things.

  • resolve pixel resolution to calculate the dimensions of image

  • calculate the size of the image

solution:

given:

aspect ratio: c:r = 6:2

pixel resolution: c * r = 480000

bits per pixel: grayscale image = 8bpp

find:

number of rows = ?

number of cols = ?

solving first part:

solving 1st part

solving 2nd part:

size = rows * cols * bpp

size of image in bits = 400 * 1200 * 8 = 3840000 bits

size of image in bytes = 480000 bytes

size of image in kilo bytes = 48 kb (approx).

in this tutorial we are going to introduce the concept of zooming , and the common techniques that are used to zoom an image.

zooming

zooming simply means enlarging a picture in a sense that the details in the image became more visible and clear. zooming an image has many wide applications ranging from zooming through a camera lens , to zoom an image on internet e.t.c.

for example

einstein

is zoomed into

einsteinzoomed

you can zoom something at two different steps.

the first step includes zooming before taking an particular image. this is known as pre processing zoom. this zoom involves hardware and mechanical movement.

the second step is to zoom once an image has been captured. it is done through many different algorithms in which we manipulate pixels to zoom in the required portion.

we will discuss them in detail in the next tutorial.

optical zoom vs digital zoom

these two types of zoom are supported by the cameras.

optical zoom:

the optical zoom is achieved using the movement of the lens of your camera. an optical zoom is actually a true zoom. the result of the optical zoom is far better then that of digital zoom. in optical zoom , an image is magnified by the lens in such a way that the objects in the image appear to be closer to the camera. in optical zoom the lens is physically extend to zoom or magnify an object.

digital zoom:

digital zoom is basically image processing within a camera. during a digital zoom , the center of the image is magnified and the edges of the picture got crop out. due to magnified center , it looks like that the object is closer to you.

during a digital zoom , the pixels got expand , due to which the quality of the image is compromised.

the same effect of digital zoom can be seen after the image is taken through your computer by using an image processing toolbox / software, such as photoshop.

the following picture is the result of digital zoom done through one of the following methods given below in the zooming methods.

digital_zoom

now since we are leaning digital image processing , we will not focus , on how an image can be zoomed optically using lens or other stuff. rather we will focus on the methods, that enable to zoom a digital image.

zooming methods:

although there are many methods that does this job , but we are going to discuss the most common of them here.

they are listed below.

  • pixel replication or (nearest neighbor interpolation)

  • zero order hold method

  • zooming k times

all these three methods are formally introduced in the next tutorial.

in this tutorial we are going to formally introduce three methods of zooming that were introduced in the tutorial of introduction to zooming.

methods

  • pixel replication or (nearest neighbor interpolation)

  • zero order hold method

  • zooming k times

each of the methods have their own advantages and disadvantages. we will start by discussing pixel replication.

method 1: pixel replication:

introduction:

it is also known as nearest neighbor interpolation. as its name suggest , in this method , we just replicate the neighboring pixels. as we have already discussed in the tutorial of sampling , that zooming is nothing but increase amount of sample or pixels. this algorithm works on the same principle.

working:

in this method we create new pixels form the already given pixels. each pixel is replicated in this method n times row wise and column wise and you got a zoomed image. its as simple as that.

for example:

if you have an image of 2 rows and 2 columns and you want to zoom it twice or 2 times using pixel replication, here how it can be done.

for a better understanding , the image has been taken in the form of matrix with the pixel values of the image.

1 2
3 4

the above image has two rows and two columns, we will first zoom it row wise.

row wise zooming:

when we zoom it row wise , we will just simple copy the rows pixels to its adjacent new cell.

here how it would be done.

1 1 2 2
3 3 4 4

as you can that in the above matrix , each pixel is replicated twice in the rows.

column size zooming:

the next step is to replicate each of the pixel column wise, that we will simply copy the column pixel to its adjacent new column or simply below it.

here how it would be done.

1 1 2 2
1 1 2 2
3 3 4 4
3 3 4 4

new image size:

as it can be seen from the above example , that an original image of 2 rows and 2 columns has been converted into 4 rows and 4 columns after zooming. that means the new image has a dimensions of

(original image rows * zooming factor, original image cols * zooming factor)

advantage and disadvantage:

one of the advantage of this zooming technique is , it is very simple. you just have to copy the pixels and nothing else.

the disadvantage of this technique is that image got zoomed but the output is very blurry. and as the zooming factor increased , the image got more and more blurred. that would eventually result in fully blurred image.

method 2: zero order hold

introduction

zero order hold method is another method of zooming. it is also known as zoom twice. because it can only zoom twice. we will see in the below example that why it does that.

working

in zero order hold method , we pick two adjacent elements from the rows respectively and then we add them and divide the result by two, and place their result in between those two elements. we first do this row wise and then we do this column wise.

for example

lets take an image of the dimensions of 2 rows and 2 columns and zoom it twice using zero order hold.

1 2
3 4

first we will zoom it row wise and then column wise.

row wise zooming

1 1 2
3 3 4

as we take the first two numbers : (2 + 1) = 3 and then we divide it by 2, we get 1.5 which is approximated to 1. the same method is applied in the row 2.

column wise zooming

1 1 2
2 2 3
3 3 4

we take two adjacent column pixel values which are 1 and 3. we add them and got 4. 4 is then divided by 2 and we get 2 which is placed in between them. the same method is applied in all the columns.

new image size

as you can see that the dimensions of the new image are 3 x 3 where the original image dimensions are 2 x 2. so it means that the dimensions of the new image are based on the following formula

(2(number of rows) minus 1) x (2(number of columns) minus 1)

advantages and disadvantage.

one of the advantage of this zooming technique , that it does not create as blurry picture as compare to the nearest neighbor interpolation method. but it also has a disadvantage that it can only run on the power of 2. it can be demonstrated here.

reason behind twice zooming:

consider the above image of 2 rows and 2 columns. if we have to zoom it 6 times , using zero order hold method , we can not do it. as the formula shows us this.

it could only zoom in the power of 2 2,4,8,16,32 and so on.

even if you try to zoom it, you can not. because at first when you will zoom it two times, and the result would be same as shown in the column wise zooming with dimensions equal to 3x3. then you will zoom it again and you will get dimensions equal to 5 x 5. now if you will do it again, you will get dimensions equal to 9 x 9.

whereas according to the formula of yours the answer should be 11x11. as (6(2) minus 1) x (6(2) minus 1) gives 11 x 11.

method 3: k-times zooming

introduction:

k times is the third zooming method we are going to discuss. it is one of the most perfect zooming algorithm discussed so far. it caters the challenges of both twice zooming and pixel replication. k in this zooming algorithm stands for zooming factor.

working:

it works like this way.

first of all , you have to take two adjacent pixels as you did in the zooming twice. then you have to subtract the smaller from the greater one. we call this output (op).

divide the output(op) with the zooming factor(k). now you have to add the result to the smaller value and put the result in between those two values.

add the value op again to the value you just put and place it again next to the previous putted value. you have to do it till you place k-1 values in it.

repeat the same step for all the rows and the columns , and you get a zoomed images.

for example:

suppose you have an image of 2 rows and 3 columns , which is given below. and you have to zoom it thrice or three times.

15 30 15
30 15 30

k in this case is 3. k = 3.

the number of values that should be inserted is k-1 = 3-1 = 2.

row wise zooming

take the first two adjacent pixels. which are 15 and 30.

subtract 15 from 30. 30-15 = 15.

divide 15 by k. 15/k = 15/3 = 5. we call it op.(where op is just a name)

add op to lower number. 15 + op = 15 + 5 = 20.

add op to 20 again. 20 + op = 20 + 5 = 25.

we do that 2 times because we have to insert k-1 values.

now repeat this step for the next two adjacent pixels. it is shown in the first table.

after inserting the values , you have to sort the inserted values in ascending order, so there remains a symmetry between them.

it is shown in the second table

table 1.

15 20 25 30 20 25 15
30 20 25 15 20 25 30

table 2.

table2

column wise zooming

the same procedure has to be performed column wise. the procedure include taking the two adjacent pixel values, and then subtracting the smaller from the bigger one. then after that , you have to divide it by k. store the result as op. add op to smaller one, and then again add op to the value that comes in first addition of op. insert the new values.

here what you got after all that.

15 20 25 30 25 20 15
20 21 21 25 21 21 20
25 22 22 20 22 22 25
30 25 20 15 20 25 30

new image size

the best way to calculate the formula for the dimensions of a new image is to compare the dimensions of the original image and the final image. the dimensions of the original image were 2 x 3. and the dimensions of the new image are 4 x 7.

the formula thus is:

(k (number of rows minus 1) + 1) x (k (number of cols minus 1) + 1)

advantages and disadvantages

the one of the clear advantage that k time zooming algorithm has that it is able to compute zoom of any factor which was the power of pixel replication algorithm , also it gives improved result (less blurry) which was the power of zero order hold method. so hence it comprises the power of the two algorithms.

the only difficulty this algorithm has that it has to be sort in the end , which is an additional step , and thus increases the cost of computation.

image resolution

image resolution can be defined in many ways. one type of it which is pixel resolution that has been discussed in the tutorial of pixel resolution and aspect ratio.

in this tutorial, we are going to define another type of resolution which is spatial resolution.

spatial resolution:

spatial resolution states that the clarity of an image cannot be determined by the pixel resolution. the number of pixels in an image does not matter.

spatial resolution can be defined as the

smallest discernible detail in an image. (digital image processing - gonzalez, woods - 2nd edition)

or in other way we can define spatial resolution as the number of independent pixels values per inch.

in short what spatial resolution refers to is that we cannot compare two different types of images to see that which one is clear or which one is not. if we have to compare the two images , to see which one is more clear or which has more spatial resolution , we have to compare two images of the same size.

for example:

you cannot compare these two images to see the clarity of the image.

einstein einstein zoomed

although both images are of the same person , but that is not the condition we are judging on. the picture on the left is zoomed out picture of einstein with dimensions of 227 x 222. whereas the picture on the right side has the dimensions of 980 x 749 and also it is a zoomed image. we cannot compare them to see that which one is more clear. remember the factor of zoom does not matter in this condition, the only thing that matters is that these two pictures are not equal.

so in order to measure spatial resolution , the pictures below would server the purpose.

einstein einstein spatial

now you can compare these two pictures. both the pictures has same dimensions which are of 227 x 222. now when you compare them , you will see that the picture on the left side has more spatial resolution or it is more clear then the picture on the right side. that is because the picture on the right is a blurred image.

measuring spatial resolution:

since the spatial resolution refers to clarity , so for different devices , different measure has been made to measure it.

for example:

  • dots per inch

  • lines per inch

  • pixels per inch

they are discussed in more detail in the next tutorial but just a brief introduction has been given below.

dots per inch:

dots per inch or dpi is usually used in monitors.

lines per inch:

lines per inch or lpi is usually used in laser printers.

pixel per inch:

pixel per inch or ppi is measure for different devices such as tablets , mobile phones e.t.c.

in the previous tutorial of spatial resolution , we discussed the brief introduction of ppi, dpi, lpi. now we are formally going to discuss all of them.

pixels per inch.

pixel density or pixels per inch is a measure of spatial resolution for different devices that includes tablets , mobile phones.

the higher is the ppi , the higher is the quality. in order to more understand it, that how it calculated. lets calculate the ppi of a mobile phone.

calculating pixels per inch (ppi) of samsung galaxy s4:

samsung

the samsung galaxy s4 has ppi or pixel density of 441. but how does it is calculated?

first of all we will pythagoras theorem to calculate the diagonal resolution in pixels.

it can be given as:

pythagoras

where a and b are the height and width resolutions in pixel and c is the diagonal resolution in pixels.

for samsung galaxy s4 , it is 1080 x 1920 pixels.

so putting those values in the equation gives the result

c = 2202.90717

now we will calculate ppi

ppi = c / diagonal size in inches

the diagonal size in inches of samsun galaxy s4 is 5.0 inches , which can be confirmed from anywhere.

ppi = 2202.90717/5.0

ppi = 440.58

ppi = 441 (approx)

that means that the pixel density of samsung galaxy s4 is 441 ppi.

dots per inch.

the dpi is often relate to ppi , whereas there is a difference between these two. dpi or dots per inch is a measure of spatial resolution of printers. in case of printers , dpi means that how many dots of ink are printed per inch when an image get printed out from the printer.

remember , it is not necessary that each pixel per inch is printed by one dot per inch. there may be many dots per inch used for printing one pixel. the reason behind this that most of the color printers uses cmyk model. the colors are limited. printer has to choose from these colors to make the color of the pixel whereas within pc , you have hundreds of thousands of colors.

the higher is the dpi of the printer , the higher is the quality of the printed document or image on paper.

usually some of the laser printers have dpi of 300 and some have 600 or more.

lines per inch.

when dpi refers to dots per inch, liner per inch refers to lines of dots per inch. the resolution of halftone screen is measured in lines per inch.

the following table shows some of the lines per inch capacity of the printers.

printer lpi
screen printing 45-65 lpi
laser printer (300 dpi) 65 lpi
laser printer (600 dpi) 85-105 lpi
offset press (newsprint paper) 85 lpi
offset press (coated paper) 85-185 lpi

image resolution:

a resolution can be defined as the total number of pixels in an image. this has been discussed in image resolution. and we have also discussed, that clarity of an image doesnot depends on number of pixels, but on the spatial resolution of the image. this has been discussed in the spatial resolution. here we are going to discuss another type of resolution which is called gray level resolution.

gray level resolution:

gray level resolution refers to the predictable or deterministic change in the shades or levels of gray in an image.

in short gray level resolution is equal to the number of bits per pixel.

we have already discussed bits per pixel in our tutorial of bits per pixel and image storage requirements. we will define bpp here briefly.

bpp:

the number of different colors in an image is depends on the depth of color or bits per pixel.

mathematically:

the mathematical relation that can be established between gray level resolution and bits per pixel can be given as.

bpp

in this equation l refers to number of gray levels. it can also be defined as the shades of gray. and k refers to bpp or bits per pixel. so the 2 raise to the power of bits per pixel is equal to the gray level resolution.

for example:

einstein

the above image of einstein is an gray scale image. means it is an image with 8 bits per pixel or 8bpp.

now if were to calculate the gray level resolution, here how we gonna do it.

quantize

it means it gray level resolution is 256. or in other way we can say that this image has 256 different shades of gray.

the more is the bits per pixel of an image , the more is its gray level resolution.

defining gray level resolution in terms of bpp:

it is not necessary that a gray level resolution should only be defined in terms of levels. we can also define it in terms of bits per pixel.

for example:

if you are given an image of 4 bpp , and you are asked to calculate its gray level resolution. there are two answers to that question.

the first answer is 16 levels.

the second answer is 4 bits.

finding bpp from gray level resolution:

you can also find the bits per pixels from the given gray level resolution. for this , we just have to twist the formula a little.

equation 1.

bpp

this formula finds the levels. now if we were to find the bits per pixel or in this case k, we will simply change it like this.

k = log base 2(l) equation (2)

because in the first equation the relationship between levels (l ) and bits per pixel (k) is exponentional. now we have to revert it , and thus the inverse of exponentional is log.

lets take an example to find bits per pixel from gray level resolution.

for example:

if you are given an image of 256 levels. what is the bits per pixel required for it.

putting 256 in the equation , we get.

k = log base 2 ( 256)

k = 8.

so the answer is 8 bits per pixel.

gray level resolution and quantization:

the quantization will be formally introduced in the next tutorial , but here we are just going to explain the relation ship between gray level resolution and quantization.

gray level resolution is found on the y axis of the signal. in the tutorial of introduction to signals and system , we have studied that digitizing a an analog signal requires two steps. sampling and quantization.

system

sampling is done on x axis. and quantization is done in y axis.

so that means digitizing the gray level resolution of an image is done in quantization.

we have introduced quantization in our tutorial of signals and system. we are formally going to relate it with digital images in this tutorial. lets discuss first a little bit about quantization.

digitizing a signal.

as we have seen in the previous tutorials , that digitizing an analog signal into a digital , requires two basic steps. sampling and quantization. sampling is done on x axis. it is the conversion of x axis (infinite values) to digital values.

the below figure shows sampling of a signal.

sampling

sampling with relation to digital images:

the concept of sampling is directly related to zooming. the more samples you take , the more pixels , you get. oversampling can also be called as zooming. this has been discussed under sampling and zooming tutorial.

but the story of digitizing a signal does not end at sampling too, there is another step involved which is known as quantization.

what is quantization.

quantization is opposite to sampling. it is done on y axis. when you are qunaitizing an image , you are actually dividing a signal into quanta(partitions).

on the x axis of the signal , are the co-ordinate values, and on the y axis , we have amplitudes. so digitizing the amplitudes is known as quantization.

here how it is done

quantization

you can see in this image , that the signal has been quantified into three different levels. that means that when we sample an image , we actually gather a lot of values, and in quantization , we set levels to these values. this can be more clear in the image below.

quantization levels

in the figure shown in sampling , although the samples has been taken , but they were still spanning vertically to a continuous range of gray level values. in the figure shown above , these vertically ranging values have been quantized into 5 different levels or partitions. ranging from 0 black to 4 white. this level could vary according to the type of image you want.

the relation of quantization with gray levels has been further discussed below.

relation of quantization with gray level resolution:

the quantized figure shown above has 5 different levels of gray. it means that the image formed from this signal , would only have 5 different colors. it would be a black and white image more or less with some colors of gray. now if you were to make the quality of the image more better, there is one thing you can do here. which is , to increase the levels , or gray level resolution up. if you increase this level to 256, it means you have an gray scale image. which is far better then simple black and white image.

now 256 , or 5 or what ever level you choose is called gray level. remember the formula that we discussed in the previous tutorial of gray level resolution which is,

bpp

we have discussed that gray level can be defined in two ways. which were these two.

  • gray level = number of bits per pixel (bpp).(k in the equation)

  • gray level = number of levels per pixel.

in this case we have gray level is equal to 256. if we have to calculate the number of bits , we would simply put the values in the equation. in case of 256levels , we have 256 different shades of gray and 8 bits per pixel, hence the image would be a gray scale image.

reducing the gray level

now we will reduce the gray levels of the image to see the effect on the image.

for example:

lets say you have an image of 8bpp, that has 256 different levels. it is a grayscale image and the image looks something like this.

256 gray levels

einstein

now we will start reducing the gray levels. we will first reduce the gray levels from 256 to 128.

128 gray levels

128

there is not much effect on an image after decrease the gray levels to its half. lets decrease some more.

64 gray levels

64

still not much effect , then lets reduce the levels more.

32 gray levels

32

surprised to see , that there is still some little effect . may be its due to reason , that it is the picture of einstein , but lets reduce the levels more.

16 gray levels

16

boom here , we go , the image finally reveals , that it is effected by the levels.

8 gray levels

8

4 gray levels

4

now before reducing it , further two 2 levels , you can easily see that the image has been distorted badly by reducing the gray levels. now we will reduce it to 2 levels, which is nothing but a simple black and white level. it means the image would be simple black and white image.

2 gray levels

2

thats the last level we can achieve , because if reduce it further , it would be simply a black image , which can not be interpreted.

contouring:

there is an interesting observation here , that as we reduce the number of gray levels , there is a special type of effect start appearing in the image , which can be seen clear in 16 gray level picture. this effect is known as contouring.

iso preference curves:

the answer to this effect , that why it appears , lies in iso preference curves. they are discussed in our next tutorial of contouring and iso preference curves.

what is contouring?

as we decrease the number of gray levels in an image , some false colors , or edges start appearing on an image. this has been shown in our last tutorial of quantization.

lets have a look at it.

consider we , have an image of 8bpp (a grayscale image) with 256 different shades of gray or gray levels.

einstein

this above picture has 256 different shades of gray. now when we reduce it to 128 and further reduce it 64, the image is more or less the same. but when re reduce it further to 32 different levels , we got a picture like this

32

if you will look closely , you will find that the effects start appearing on the image.these effects are more visible when we reduce it further to 16 levels and we got an image like this.

16

these lines, that start appearing on this image are known as contouring that are very much visible in the above image.

increase and decrease in contouring

the effect of contouring increase as we reduce the number of gray levels and the effect decrease as we increase the number of gray levels. they are both vice versa

16

vs

128

that means more quantization , will effect in more contouring and vice versa. but is this always the case. the answer is no. that depends on something else that is discussed below.

isopreference curves

a study conducted on this effect of gray level and contouring , and the results were shown in the graph in the form of curves , known as iso preference curves.

the phenomena of isopreference curves shows , that the effect of contouring not only depends on the decreasing of gray level resolution but also on the image detail.

the essence of the study is:

if an image has more detail , the effect of contouring would start appear on this image later, as compare to an image which has less detail, when the gray levels are quantized.

according to the original research, the researchers took these three images and they vary the gray level resolution , in all three images.

the images were

lena cameraman public

level of detail:

the first image has only a face in it, and hence very less detail. the second image has some other objects in the image too , such as camera man, his camera , camera stand, and background objects e.t.c. whereas the third image has more details then all the other images.

experiment:

the gray level resolution was varied in all the images , and the audience was asked to rate these three images subjectively. after the rating , a graph was drawn according to the results.

result:

the result was drawn on the graph. each curve on the graph represents one image. the values on the x axis represents the number of gray levels and the values on the y axis represents bits per pixel (k).

the graph has been shown below.

graph

according to this graph , we can see that the first image which was of face , was subject to contouring early then all of the other two images. the second image , that was of the cameraman was subject to contouring a bit after the first image when its gray levels are reduced. this is because it has more details then the first image. and the third image was subject to contouring a lot after the first two images i-e: after 4 bpp. this is because , this image has more details.

conclusion:

so for more detailed images, the isopreference curves become more and more vertical. it also means that for an image with a large amount of details , very few gray levels are needed.

in the last two tutorials of quantization and contouring , we have seen that reducing the gray level of an image reduces the number of colors required to denote an image. if the gray levels are reduced two 2 , the image that appears doesnot have much spatial resolution or is not very much appealing.

dithering:

dithering is the process by which we create illusions of the color that are not present actually. it is done by the random arrangement of pixels.

for example. consider this image.

dithering

this is an image with only black and white pixels in it. its pixels are arranged in an order to form another image that is shown below. note at the arrangement of pixels has been changed , but not the quantity of pixels.

dither2

why dithering?

why do we need dithering , the answer of this lies in its relation with quantization.

dithering with quantization.

when we perform quantization , to the last level , we see that the image that comes in the last level (level 2) looks like this.

2

now as we can see from the image here , that the picture is not very clear, especially if you will look at the left arm and back of the image of the einstein. also this picture does not have much information or detail of the einstein.

now if we were to change this image into some image that gives more detail then this, we have to perform dithering.

performing dithering.

first of all , we will work on threholding. dithering is usually working to improve thresholding. during threholding, the sharp edges appear where gradients are smooth in an image.

in thresholding , we simply choose a constant value. all the pixels above that value are considered as 1 and all the value below it are considered as 0.

we got this image after thresholding.

dither3

since there is not much change in the image , as the values are already 0 and 1 or black and white in this image.

now we perform some random dithering to it. its some random arrangement of pixels.

dither4

we got an image that gives slighter of the more details , but its contrast is very low.

so we do some more dithering that will increase the contrast. the image that we got is this:

dither5

now we mix the concepts of random dithering , along with threshold and we got an image like this.

dither6

now you see , we got all these images by just re-arranging the pixels of an image. this re-arranging could be random or could be according to some measure.

before discussing the use of histograms in image processing , we will first look at what histogram is, how it is used and then an example of histograms to have more understanding of histogram.

histograms:

a histogram is a graph. a graph that shows frequency of anything. usually histogram have bars that represent frequency of occurring of data in the whole data set.

a histogram has two axis the x axis and the y axis.

the x axis contains event whose frequency you have to count.

the y axis contains frequency.

the different heights of bar shows different frequency of occurrence of data.

usually a histogram looks like this.

histogram1

now we will see an example of this histogram is build

example:

consider a class of programming students and you are teaching python to them.

at the end of the semester , you got this result that is shown in table. but it is very messy and doesnot show your overall result of class. so you have to make a histogram of your result , showing the overall frequency of occurrence of grades in your class. here how you are going to do it.

result sheet:

name grade
john a
jack d
carter b
tommy a
lisa c+
derek a-
tom b+

histogram of result sheet:

now what you are going to do is, that you have to find what comes on the x and the y axis.

there is one thing to be sure, that y axis contains the frequency, so what comes on the x axis. x axis contains the event whose frequency has to be calculated. in this case x axis contains grades.

histogram2

now we will how do we use a histogram in an image.

histogram of an image

histogram of an image , like other histograms also shows frequency. but an image histogram , shows frequency of pixels intensity values. in an image histogram, the x axis shows the gray level intensities and the y axis shows the frequency of these intensities.

for example:

einstein

the histogram of the above picture of the einstein would be something like this

histogram3

the x axis of the histogram shows the range of pixel values. since its an 8 bpp image , that means it has 256 levels of gray or shades of gray in it. thats why the range of x axis starts from 0 and end at 255 with a gap of 50. whereas on the y axis , is the count of these intensities.

as you can see from the graph , that most of the bars that have high frequency lies in the first half portion which is the darker portion. that means that the image we have got is darker. and this can be proved from the image too.

applications of histograms:

histograms has many uses in image processing. the first use as it has also been discussed above is the analysis of the image. we can predict about an image by just looking at its histogram. its like looking an x ray of a bone of a body.

the second use of histogram is for brightness purposes. the histograms has wide application in image brightness. not only in brightness , but histograms are also used in adjusting contrast of an image.

another important use of histogram is to equalize an image.

and last but not the least, histogram has wide use in thresholding. this is mostly used in computer vision.

brightness:

brightness is a relative term. it depends on your visual perception. since brightness is a relative term , so brightness can be defined as the amount of energy output by a source of light relative to the source we are comparing it to. in some cases we can easily say that the image is bright , and in some cases, its not easy to perceive.

for example:

just have a look at both of these images , and compare which one is brighter.

bright1

we can easily see , that the image on the right side is brighter as compared to the image on the left.

but if the image on the right is made more darker then the first one , then we can say that the image on the left is more brighter then the left.

how to make an image brighter.

brightness can be simply increased or decreased by simple addition or subtraction, to the image matrix.

consider this black image of 5 rows and 5 columns

black image

since we already know, that each image has a matrix at its behind that contains the pixel values. this image matrix is given below.

0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0

since the whole matrix is filled with zero, and the image is very much darker.

now we will compare it with another same black image to see this image got brighter or not.

image

still both the images are same, now we will perform some operations on image1 , due to which it becomes brighter then the second one.

what we will do is , that we will simply add a value of 1 to each of the matrix value of image 1. after adding the image 1 would something like this.

black image

now we will again compare it with image 2 , and see any difference.

black image

we see, that still we cannot tell which image is brighter as both images looks the same.

now what we will do , is that we will add 50 to each of the matrix value of the image 1 and see what the image has become.

the output is given below.

bright image

now again , we will compare it with image 2.

bright image

now you can see that the image 1 is slightly brighter then the image 2. we go on , and add another 45 value to its matrix of image 1 , and this time we compare again both images.

bright image

now when you compare it , you can see that this image1 is clearly brighter then the image 2.

even it is brighter then the old image1. at this point the matrix of the image1 contains 100 at each index as first add 5 , then 50 , then 45. so 5 + 50 + 45 = 100.

contrast

contrast can be simply explained as the difference between maximum and minimum pixel intensity in an image.

for example.

consider the final image1 in brightness.

bright image

the matrix of this image is:

100 100 100 100 100
100 100 100 100 100
100 100 100 100 100
100 100 100 100 100
100 100 100 100 100

the maximum value in this matrix is 100.

the minimum value in this matrix is 100.

contrast = maximum pixel intensity(subtracted by) minimum pixel intensity

= 100 (subtracted by) 100

= 0

0 means that this image has 0 contrast.

before we discuss, what is image transformation, we will discuss what a transformation is.

transformation.

transformation is a function. a function that maps one set to another set after performing some operations.

digital image processing system:

we have already seen in the introductory tutorials that in digital image processing , we will develop a system that whose input would be an image and output would be an image too. and the system would perform some processing on the input image and gives its output as an processed image. it is shown below.

introduction image

now function applied inside this digital system that process an image and convert it into output can be called as transformation function.

as it shows transformation or relation , that how an image1 is converted to image2.

image transformation.

consider this equation

g(x,y) = t{ f(x,y) }

in this equation ,

f(x,y) = input image on which transformation function has to be applied.

g(x,y) = the output image or processed image.

t is the transformation function.

this relation between input image and the processed output image can also be represented as.

s = t (r)

where r is actually the pixel value or gray level intensity of f(x,y) at any point. and s is the pixel value or gray level intensity of g(x,y) at any point.

the basic gray level transformation has been discussed in our tutorial of basic gray level transformations.

now we are going to discuss some of the very basic transformation functions.

examples:

consider this transformation function.

transformation1

lets take the point r to be 256, and the point p to be 127. consider this image to be a one bpp image. that means we have only two levels of intensities that are 0 and 1. so in this case the transformation shown by the graph can be explained as.

all the pixel intensity values that are below 127 (point p) are 0 , means black. and all the pixel intensity values that are greater then 127, are 1 , that means white. but at the exact point of 127, there is a sudden change in transmission, so we cannot tell that at that exact point , the value would be 0 or 1.

mathematically this transformation function can be denoted as:

transformation

consider another transformation like this:

transformation

now if you will look at this particular graph , you will see a straight transition line between input image and output image.

it shows that for each pixel or intensity value of input image, there is a same intensity value of output image. that means the output image is exact replica of the input image.

it can be mathematically represented as:

g(x,y) = f(x,y)

the input and output image would be in this case are shown below.

input image and output image

the basic concept of histograms has been discussed in the tutorial of introduction to histograms. but we will briefly introduce the histogram here.

histogram:

histogram is nothing but a graph that shows frequency of occurrence of data. histograms has many use in image processing, out of which we are going to discuss one user here which is called histogram sliding.

histogram sliding.

in histogram sliding , we just simply shift a complete histogram rightwards or leftwards. due to shifting or sliding of histogram towards right or left , a clear change can be seen in the image.in this tutorial we are going to use histogram sliding for manipulating brightness.

the term i-e: brightness has been discussed in our tutorial of introduction to brightness and contrast. but we are going to briefly define here.

brightness:

brightness is a relative term. brightness can be defined as intensity of light emit by a particular light source.

contrast:

contrast can be defined as the difference between maximum and minimum pixel intensity in an image.

sliding histograms

increasing brightness using histogram sliding

einstein

histogram of this image has been shown below.

sliding

on the y axis of this histogram are the frequency or count. and on the x axis , we have gray level values. as you can see from the above histogram , that those gray level intensities whose count is more then 700, lies in the first half portion, means towards blacker portion. thats why we got an image that is a bit darker.

in order to bright it, we will slide its histogram towards right , or towards whiter portion. in order to do we need to add atleast a value of 50 to this image. because we can see from the histogram above , that this image also has 0 pixel intensities , that are pure black. so if we add 0 to 50 , we will shift all the values lies at 0 intensity to 50 intensity and all the rest of the values will be shifted accordingly.

lets do it.

here what we got after adding 50 to each pixel intensity.

the image has been shown below.

sliding

and its histogram has been shown below.

sliding

lets compare these two images and their histograms to see that what change have to got.

sliding

conclusion:

as we can clearly see from the new histogram that all the pixels values has been shifted towards right and its effect can be seen in the new image.

decreasing brightness using histogram sliding

now if we were to decrease brightness of this new image to such an extent that the old image look brighter , we got to subtract some value from all the matrix of the new image. the value which we are going to subtract is 80. because we already add 50 to the original image and we got a new brighter image, now if we want to make it darker , we have to subtract at least more than 50 from it.

and this what we got after subtracting 80 from the new image.

sliding

conclusion:

it is clear from the histogram of the new image , that all the pixel values has been shifted towards right and thus , it can be validated from the image that new image is darker and now the original image look brighter as compare to this new image.

one of the other advantage of histogram s that we discussed in our tutorial of introduction to histograms is contrast enhancement.

there are two methods of enhancing contrast. the first one is called histogram stretching that increase contrast. the second one is called histogram equalization that enhance contrast and it has been discussed in our tutorial of histogram equalization.

before we will discuss the histogram stretching to increase contrast , we will briefly define contrast.

contrast.

contrast is the difference between maximum and minimum pixel intensity.

consider this image.

stretching

the histogram of this image is shown below.

stretching

now we calculate contrast from this image.

contrast = 225.

now we will increase the contrast of the image.

increasing the contrast of the image:

the formula for stretching the histogram of the image to increase the contrast is stretching

the formula requires finding the minimum and maximum pixel intensity multiply by levels of gray. in our case the image is 8bpp, so levels of gray are 256.

the minimum value is 0 and the maximum value is 225. so the formula in our case is

stretching

where f(x,y) denotes the value of each pixel intensity. for each f(x,y) in an image , we will calculate this formula.

after doing this, we will be able to enhance our contrast.

the following image appear after applying histogram stretching.

stretching

the stretched histogram of this image has been shown below.

note the shape and symmetry of histogram. the histogram is now stretched or in other means expand. have a look at it.

stretching

in this case the contrast of the image can be calculated as

contrast = 240

hence we can say that the contrast of the image is increased.

note: this method of increasing contrast doesnot work always, but it fails on some cases.

failing of histogram stretching

as we have discussed , that the algorithm fails on some cases. those cases include images with when there is pixel intensity 0 and 255 are present in the image

because when pixel intensities 0 and 255 are present in an image , then in that case they become the minimum and maximum pixel intensity which ruins the formula like this.

original formula

stretching

putting fail case values in the formula:

stretching

simplify that expression gives

stretching

that means the output image is equal to the processed image. that means there is no effect of histogram stretching has been done at this image.

pmf and cdf both terms belongs to probability and statistics. now the question that should arise in your mind , is that why are we studying probability. it is because these two concepts of pmf and cdf are going to be used in the next tutorial of histogram equalization. so if you dont know how to calculate pmf and cdf , you can not apply histogram equalization on your image

.

what is pmf?

pmf stands for probability mass function. as it name suggest , it gives the probability of each number in the data set or you can say that it basically gives the count or frequency of each element.

how pmf is calculated:

we will calculate pmf from two different ways. first from a matrix , because in the next tutorial , we have to calculate the pmf from a matrix , and an image is nothing more then a two dimensional matrix.

then we will take another example in which we will calculate pmf from the histogram.

consider this matrix.

1 2 7 5 6
7 2 3 4 5
0 1 5 7 3
1 2 5 6 7
6 1 0 3 4

now if we were to calculate the pmf of this matrix , here how we are going to do it.

at first , we will take the first value in the matrix , and then we will count , how much time this value appears in the whole matrix. after count they can either be represented in a histogram , or in a table like this below.

pmf

0 2 2/25
1 4 4/25
2 3 3/25
3 3 3/25
4 2 2/25
5 4 4/25
6 3 3/25
7 4 4/25

note that the sum of the count must be equal to total number of values.

calculating pmf from histogram

histogram

the above histogram shows frequency of gray level values for an 8 bits per pixel image.

now if we have to calculate its pmf , we will simple look at the count of each bar from vertical axis and then divide it by total count.

so the pmf of the above histogram is this.

histogram

another important thing to note in the above histogram is that it is not monotonically increasing. so in order to increase it monotonically, we will calculate its cdf.

what is cdf?

cdf stands for cumulative distributive function. it is a function that calculates the cumulative sum of all the values that are calculated by pmf. it basically sums the previous one.

how it is calculated?

we will calculate cdf using a histogram. here how it is done. consider the histogram shown above which shows pmf.

since this histogram is not increasing monotonically , so will make it grow monotonically.

we will simply keep the first value as it is , and then in the 2nd value , we will add the first one and so on.

here is the cdf of the above pmf function.

histogram

now as you can see from the graph above , that the first value of pmf remain as it is. the second value of pmf is added in the first value and placed over 128. the third value of pmf is added in the second value of cdf , that gives 110/110 which is equal to 1.

and also now , the function is growing monotonically which is necessary condition for histogram equalization.

pmf and cdf usage in histogram equalization

histogram equalization.

histogram equalization is discussed in the next tutorial but a brief introduction of histogram equalization is given below.

histogram equalization is used for enhancing the contrast of the images.

pmf and cdf are both use in histogram equalization as it is described in the beginning of this tutorial. in the histogram equalization , the first and the second step are pmf and cdf. since in histogram equalization , we have to equalize all the pixel values of an image. so pmf helps us calculating the probability of each pixel value in an image. and cdf gives us the cumulative sum of these values. further on , this cdf is multiplied by levels , to find the new pixel intensities , which are mapped into old values , and your histogram is equalized.

we have already seen that contrast can be increased using histogram stretching. in this tutorial we will see that how histogram equalization can be used to enhance contrast.

before performing histogram equalization, you must know two important concepts used in equalizing histograms. these two concepts are known as pmf and cdf.

they are discussed in our tutorial of pmf and cdf. please visit them in order to successfully grasp the concept of histogram equalization.

histogram equalization:

histogram equalization is used to enhance contrast. it is not necessary that contrast will always be increase in this. there may be some cases were histogram equalization can be worse. in that cases the contrast is decreased.

lets start histogram equalization by taking this image below as a simple image.

image

einstein

histogram of this image:

the histogram of this image has been shown below.

equalize1

now we will perform histogram equalization to it.

pmf:

first we have to calculate the pmf (probability mass function) of all the pixels in this image. if you donot know how to calculate pmf, please visit our tutorial of pmf calculation.

cdf:

our next step involves calculation of cdf (cumulative distributive function). again if you donot know how to calculate cdf , please visit our tutorial of cdf calculation.

calculate cdf according to gray levels

lets for instance consider this , that the cdf calculated in the second step looks like this.

gray level value cdf
0 0.11
1 0.22
2 0.55
3 0.66
4 0.77
5 0.88
6 0.99
7 1

then in this step you will multiply the cdf value with (gray levels (minus) 1) .

considering we have an 3 bpp image. then number of levels we have are 8. and 1 subtracts 8 is 7. so we multiply cdf by 7. here what we got after multiplying.

gray level value cdf cdf * (levels-1)
0 0.11 0
1 0.22 1
2 0.55 3
3 0.66 4
4 0.77 5
5 0.88 6
6 0.99 6
7 1 7

now we have is the last step , in which we have to map the new gray level values into number of pixels.

lets assume our old gray levels values has these number of pixels.

gray level value frequency
0 2
1 4
2 6
3 8
4 10
5 12
6 14
7 16

now if we map our new values to , then this is what we got.

gray level value new gray level value frequency
0 0 2
1 1 4
2 3 6
3 4 8
4 5 10
5 6 12
6 6 14
7 7 16

now map these new values you are onto histogram , and you are done.

lets apply this technique to our original image. after applying we got the following image and its following histogram.

histogram equalization image

equalized image

cumulative distributive function of this image

cdf

histogram equalization histogram

histogram

comparing both the histograms and images

compare

conclusion

as you can clearly see from the images that the new image contrast has been enhanced and its histogram has also been equalized. there is also one important thing to be note here that during histogram equalization the overall shape of the histogram changes, where as in histogram stretching the overall shape of histogram remains same.

we have discussed some of the basic transformations in our tutorial of basic transformation. in this tutorial we will look at some of the basic gray level transformations.

image enhancement

enhancing an image provides better contrast and a more detailed image as compare to non enhanced image. image enhancement has very applications. it is used to enhance medical images , images captured in remote sensing , images from satellite e.t.c

the transformation function has been given below

s = t ( r )

where r is the pixels of the input image and s is the pixels of the output image. t is a transformation function that maps each value of r to each value of s. image enhancement can be done through gray level transformations which are discussed below.

gray level transformation

there are three basic gray level transformation.

  • linear

  • logarithmic

  • power – law

the overall graph of these transitions has been shown below.

gray level transformation

linear transformation

first we will look at the linear transformation. linear transformation includes simple identity and negative transformation. identity transformation has been discussed in our tutorial of image transformation, but a brief description of this transformation has been given here.

identity transition is shown by a straight line. in this transition, each value of the input image is directly mapped to each other value of output image. that results in the same input image and output image. and hence is called identity transformation. it has been shown below

gray level transformation

negative transformation

the second linear transformation is negative transformation, which is invert of identity transformation. in negative transformation, each value of the input image is subtracted from the l-1 and mapped onto the output image.

the result is somewhat like this.

input image

gray level transformation

output image

gray level transformation

in this case the following transition has been done.

s = (l – 1) – r

since the input image of einstein is an 8 bpp image , so the number of levels in this image are 256. putting 256 in the equation, we get this

s = 255 – r

so each value is subtracted by 255 and the result image has been shown above. so what happens is that , the lighter pixels become dark and the darker picture becomes light. and it results in image negative.

it has been shown in the graph below.

gray level transformation

logarithmic transformations:

logarithmic transformation further contains two type of transformation. log transformation and inverse log transformation.

log transformation

the log transformations can be defined by this formula

s = c log(r + 1).

where s and r are the pixel values of the output and the input image and c is a constant. the value 1 is added to each of the pixel value of the input image because if there is a pixel intensity of 0 in the image, then log (0) is equal to infinity. so 1 is added , to make the minimum value at least 1.

during log transformation , the dark pixels in an image are expanded as compare to the higher pixel values. the higher pixel values are kind of compressed in log transformation. this result in following image enhancement.

the value of c in the log transform adjust the kind of enhancement you are looking for.

input image

gray level transformation

log tranform image

gray level transformation

the inverse log transform is opposite to log transform.

power – law transformations

there are further two transformation is power law transformations, that include nth power and nth root transformation. these transformations can be given by the expression:

s=cr^γ

this symbol γ is called gamma, due to which this transformation is also known as gamma transformation.

variation in the value of γ varies the enhancement of the images. different display devices / monitors have their own gamma correction, that’s why they display their image at different intensity.

this type of transformation is used for enhancing images for different type of display devices. the gamma of different display devices is different. for example gamma of crt lies in between of 1.8 to 2.5 , that means the image displayed on crt is dark.

correcting gamma.

s=cr^γ

s=cr^(1/2.5)

the same image but with different gamma values has been shown here.

for example:

gamma = 10

gray level transformation

gamma = 8

gray level transformation

gamma = 6

gray level transformation

this tutorial is about one of the very important concept of signals and system. we will completely discuss convolution. what is it? why is it? what can we achieve with it?

we will start discussing convolution from the basics of image processing.

what is image processing.

as we have discussed in the introduction to image processing tutorials and in the signal and system that image processing is more or less the study of signals and systems because an image is nothing but a two dimensional signal.

also we have discussed , that in image processing , we are developing a system whose input is an image and output would be an image. this is pictorially represented as.

concept of convoloution

the box is that is shown in the above figure labeled as “digital image processing system” could be thought of as a black box

it can be better represented as:

concept of convoloution

where have we reached until now

till now we have discussed two important methods to manipulate images. or in other words we can say that, our black box works in two different ways till now.

the two different ways of manipulating images were

graphs (histograms)

concept of convoloution

this method is known as histogram processing. we have discussed it in detail in previous tutorials for increase contrast , image enhancement , brightness e.t.c

transformation functions

concept of convoloution

this method is known as transformations , in which we discussed different type of transformations and some gray level transformations

another way of dealing images

here we are going to discuss another method of dealing with images. this other method is known as convolution. usually the black box(system) used for image processing is an lti system or linear time invariant system. by linear we mean that such a system where output is always linear , neither log nor exponent or any other. and by time invariant we means that a system which remains same during time.

so now we are going to use this third method. it can be represented as.

concept of convoloution

it can be mathematically represented as two ways

g(x,y) = h(x,y) * f(x,y)

it can be explained as the “mask convolved with an image”.

or

g(x,y) = f(x,y) * h(x,y)

it can be explained as “image convolved with mask”.

there are two ways to represent this because the convolution operator(*) is commutative. the h(x,y) is the mask or filter.

what is mask?

mask is also a signal. it can be represented by a two dimensional matrix. the mask is usually of the order of 1x1, 3x3, 5x5 , 7x7 . a mask should always be in odd number , because other wise you cannot find the mid of the mask. why do we need to find the mid of the mask. the answer lies below, in topic of , how to perform convolution?

how to perform convolution?

in order to perform convolution on an image , following steps should be taken.

  • flip the mask (horizontally and vertically) only once

  • slide the mask onto the image.

  • multiply the corresponding elements and then add them

  • repeat this procedure until all values of the image has been calculated.

example of convolution

let’s perform some convolution. step 1 is to flip the mask.

mask:

let’s take our mask to be this.

1 2 3
4 5 6
7 8 9

flipping the mask horizontally

3 2 1
6 5 4
9 8 7

flipping the mask vertically

9 8 7
6 5 4
3 2 1

image:

let’s consider an image to be like this

2 4 6
8 10 12
14 16 18

convolution

convolving mask over image. it is done in this way. place the center of the mask at each element of an image. multiply the corresponding elements and then add them , and paste the result onto the element of the image on which you place the center of mask.

concept of convoloution

the box in red color is the mask , and the values in the orange are the values of the mask. the black color box and values belong to the image. now for the first pixel of the image , the value will be calculated as

first pixel = (5*2) + (4*4) + (2*8) + (1*10)

= 10 + 16 + 16 + 10

= 52

place 52 in the original image at the first index and repeat this procedure for each pixel of the image.

why convolution

convolution can achieve something, that the previous two methods of manipulating images can’t achieve. those include the blurring , sharpening , edge detection , noise reduction e.t.c

what is a mask.

a mask is a filter. concept of masking is also known as spatial filtering. masking is also known as filtering. in this concept we just deal with the filtering operation that is performed directly on the image.

a sample mask has been shown below

-1 0 1
-1 0 1
-1 0 1

what is filtering.

the process of filtering is also known as convolving a mask with an image. as this process is same of convolution so filter masks are also known as convolution masks.

how it is done.

the general process of filtering and applying masks is consists of moving the filter mask from point to point in an image. at each point (x,y) of the original image, the response of a filter is calculated by a pre defined relationship. all the filters values are pre defined and are a standard.

types of filters

generally there are two types of filters. one is called as linear filters or smoothing filters and others are called as frequency domain filters.

why filters are used?

filters are applied on image for multiple purposes. the two most common uses are as following:

  • filters are used for blurring and noise reduction

  • filters are used or edge detection and sharpness

blurring and noise reduction:

filters are most commonly used for blurring and for noise reduction. blurring is used in pre processing steps, such as removal of small details from an image prior to large object extraction.

masks for blurring.

the common masks for blurring are.

  • box filter

  • weighted average filter

in the process of blurring we reduce the edge content in an image and try to make the transitions between different pixel intensities as smooth as possible.

noise reduction is also possible with the help of blurring.

edge detection and sharpness:

masks or filters can also be used for edge detection in an image and to increase sharpness of an image.

what are edges.

we can also say that sudden changes of discontinuities in an image are called as edges. significant transitions in an image are called as edges.a picture with edges is shown below.

original picture.

cocept of mask

same picture with edges

concept of mask

a brief introduction of blurring has been discussed in our previous tutorial of concept of masks, but we are formally going to discuss it here.

blurring

in blurring , we simple blur an image. an image looks more sharp or more detailed if we are able to perceive all the objects and their shapes correctly in it. for example. an image with a face, looks clear when we are able to identify eyes , ears , nose , lips , forehead e.t.c very clear. this shape of an object is due to its edges. so in blurring , we simple reduce the edge content and makes the transition form one color to the other very smooth.

blurring vs zooming.

you might have seen a blurred image when you zoom an image. when you zoom an image using pixel replication , and zooming factor is increased, you saw a blurred image. this image also has less details , but it is not true blurring.

because in zooming , you add new pixels to an image , that increase the overall number of pixels in an image , whereas in blurring , the number of pixels of a normal image and a blurred image remains the same.

common example of a blurred image.

blurring

types of filters.

blurring can be achieved by many ways. the common type of filters that are used to perform blurring are.

  • mean filter

  • weighted average filter

  • gaussian filter

out of these three , we are going to discuss the first two here and gaussian will be discussed later on in the upcoming tutorials.

mean filter.

mean filter is also known as box filter and average filter. a mean filter has the following properties.

  • it must be odd ordered

  • the sum of all the elements should be 1

  • all the elements should be same

if we follow this rule , then for a mask of 3x3. we get the following result.

1/9 1/9 1/9
1/9 1/9 1/9
1/9 1/9 1/9

since it is a 3x3 mask, that means it has 9 cells. the condition that all the element sum should be equal to 1 can be achieved by dividing each value by 9. as

1/9 + 1/9 + 1/9 + 1/9 + 1/9 + 1/9 + 1/9 + 1/9 + 1/9 = 9/9 = 1

the result of a mask of 3x3 on an image is shown below.

original image:

blurring

blurred image

blurring

may be the results are not much clear. let’s increase the blurring. the blurring can be increased by increasing the size of the mask. the more is the size of the mask , the more is the blurring. because with greater mask , greater number of pixels are catered and one smooth transition is defined.

the result of a mask of 5x5 on an image is shown below.

original image:

blurring

blurred image:

blurring

same way if we increase the mask , the blurring would be more and the results are shown below.

the result of a mask of 7x7 on an image is shown below.

original image:

blurring

blurred image:

blurring

the result of a mask of 9x9 on an image is shown below.

original image:

blurring

blurred image:

blurring

the result of a mask of 11x11 on an image is shown below.

original image:

blurring

blurred image:

blurring

weighted average filter.

in weighted average filter, we gave more weight to the center value. due to which the contribution of center becomes more then the rest of the values. due to weighted average filtering , we can actually control the blurring.

properties of the weighted average filter are.

  • it must be odd ordered

  • the sum of all the elements should be 1

  • the weight of center element should be more then all of the other elements

filter 1

1 1 1
1 2 1
1 1 1

the two properties are satisfied which are (1 and 3). but the property 2 is not satisfied. so in order to satisfy that we will simple divide the whole filter by 10, or multiply it with 1/10.

filter 2

1 1 1
1 10 1
1 1 1

dividing factor = 18.

we have discussed briefly about edge detection in our tutorial of introduction to masks. we will formally discuss edge detection here.

what are edges.

we can also say that sudden changes of discontinuities in an image are called as edges. significant transitions in an image are called as edges.

types of edges.

geenerally edges are of three types:

  • horizontal edges

  • vertical edges

  • diagonal edges

why detect edges.

most of the shape information of an image is enclosed in edges. so first we detect these edges in an image and by using these filters and then by enhancing those areas of image which contains edges, sharpness of the image will increase and image will become clearer.

here are some of the masks for edge detection that we will discuss in the upcoming tutorials.

  • prewitt operator

  • sobel operator

  • robinson compass masks

  • krisch compass masks

  • laplacian operator.

above mentioned all the filters are linear filters or smoothing filters.

prewitt operator

prewitt operator is used for detecting edges horizontally and vertically.

sobel operator

the sobel operator is very similar to prewitt operator. it is also a derivate mask and is used for edge detection. it also calculates edges in both horizontal and vertical direction.

robinson compass masks

this operator is also known as direction mask. in this operator we take one mask and rotate it in all the 8 compass major directions to calculate edges of each direction.

kirsch compass masks

kirsch compass mask is also a derivative mask which is used for finding edges. kirsch mask is also used for calculating edges in all the directions.

laplacian operator.

laplacian operator is also a derivative operator which is used to find edges in an image. laplacian is a second order derivative mask. it can be further divided into positive laplacian and negative laplacian.

all these masks find edges. some find horizontally and vertically, some find in one direction only and some find in all the directions. the next concept that comes after this is sharpening which can be done once the edges are extracted from the image

sharpening :

sharpening is opposite to the blurring. in blurring, we reduce the edge content and in sharpneng , we increase the edge content. so in order to increase the edge content in an image , we have to find edges first.

edges can be find by one of the any method described above by using any operator. after finding edges , we will add those edges on an image and thus the image would have more edges , and it would look sharpen.

this is one way of sharpening an image.

the sharpen image is shown below.

original image

edge detection

sharpen image

edge detection

prewitt operator is used for edge detection in an image. it detects two types of edges:

  • horizontal edges

  • vertical edges

edges are calculated by using difference between corresponding pixel intensities of an image. all the masks that are used for edge detection are also known as derivative masks. because as we have stated many times before in this series of tutorials that image is also a signal so changes in a signal can only be calculated using differentiation. so that’s why these operators are also called as derivative operators or derivative masks.

all the derivative masks should have the following properties:

  • opposite sign should be present in the mask.

  • sum of mask should be equal to zero.

  • more weight means more edge detection.

prewitt operator provides us two masks one for detecting edges in horizontal direction and another for detecting edges in an vertical direction.

vertical direction:

-1 0 1
-1 0 1
-1 0 1

above mask will find the edges in vertical direction and it is because the zeros column in the vertical direction. when you will convolve this mask on an image, it will give you the vertical edges in an image.

how it works:

when we apply this mask on the image it prominent vertical edges. it simply works like as first order derivate and calculates the difference of pixel intensities in a edge region. as the center column is of zero so it does not include the original values of an image but rather it calculates the difference of right and left pixel values around that edge. this increase the edge intensity and it become enhanced comparatively to the original image.

horizontal direction:

-1 -1 -1
0 0 0
1 1 1

above mask will find edges in horizontal direction and it is because that zeros column is in horizontal direction. when you will convolve this mask onto an image it would prominent horizontal edges in the image.

how it works:

this mask will prominent the horizontal edges in an image. it also works on the principle of above mask and calculates difference among the pixel intensities of a particular edge. as the center row of mask is consist of zeros so it does not include the original values of edge in the image but rather it calculate the difference of above and below pixel intensities of the particular edge. thus increasing the sudden change of intensities and making the edge more visible. both the above masks follow the principle of derivate mask. both masks have opposite sign in them and both masks sum equals to zero. the third condition will not be applicable in this operator as both the above masks are standardize and we can’t change the value in them.

now it’s time to see these masks in action:

sample image:

following is a sample picture on which we will apply above two masks one at time.

prewitt operator

after applying vertical mask:

after applying vertical mask on the above sample image, following image will be obtained. this image contains vertical edges. you can judge it more correctly by comparing with horizontal edges picture.

prewitt operator

after applying horizontal mask:

after applying horizontal mask on the above sample image, following image will be obtained.

prewitt operator

comparison:

as you can see that in the first picture on which we apply vertical mask, all the vertical edges are more visible than the original image. similarly in the second picture we have applied the horizontal mask and in result all the horizontal edges are visible. so in this way you can see that we can detect both horizontal and vertical edges from an image.

the sobel operator is very similar to prewitt operator. it is also a derivate mask and is used for edge detection. like prewitt operator sobel operator is also used to detect two kinds of edges in an image:

  • vertical direction

  • horizontal direction

difference with prewitt operator:

the major difference is that in sobel operator the coefficients of masks are not fixed and they can be adjusted according to our requirement unless they do not violate any property of derivative masks.

following is the vertical mask of sobel operator:

-1 0 1
-2 0 2
-1 0 1

this mask works exactly same as the prewitt operator vertical mask. there is only one difference that is it has “2” and “-2” values in center of first and third column. when applied on an image this mask will highlight the vertical edges.

how it works:

when we apply this mask on the image it prominent vertical edges. it simply works like as first order derivate and calculates the difference of pixel intensities in a edge region.

as the center column is of zero so it does not include the original values of an image but rather it calculates the difference of right and left pixel values around that edge. also the center values of both the first and third column is 2 and -2 respectively.

this give more weight age to the pixel values around the edge region. this increase the edge intensity and it become enhanced comparatively to the original image.

following is the horizontal mask of sobel operator:

-1 -2 -1
0 0 0
1 2 1

above mask will find edges in horizontal direction and it is because that zeros column is in horizontal direction. when you will convolve this mask onto an image it would prominent horizontal edges in the image. the only difference between it is that it have 2 and -2 as a center element of first and third row.

how it works:

this mask will prominent the horizontal edges in an image. it also works on the principle of above mask and calculates difference among the pixel intensities of a particular edge. as the center row of mask is consist of zeros so it does not include the original values of edge in the image but rather it calculate the difference of above and below pixel intensities of the particular edge. thus increasing the sudden change of intensities and making the edge more visible.

now it’s time to see these masks in action:

sample image:

following is a sample picture on which we will apply above two masks one at time.

sobel operator

after applying vertical mask:

after applying vertical mask on the above sample image, following image will be obtained.

sobel operator

after applying horizontal mask:

after applying horizontal mask on the above sample image, following image will be obtained

sobel operator

comparison:

as you can see that in the first picture on which we apply vertical mask, all the vertical edges are more visible than the original image. similarly in the second picture we have applied the horizontal mask and in result all the horizontal edges are visible.

so in this way you can see that we can detect both horizontal and vertical edges from an image. also if you compare the result of sobel operator with prewitt operator, you will find that sobel operator finds more edges or make edges more visible as compared to prewitt operator.

this is because in sobel operator we have allotted more weight to the pixel intensities around the edges.

applying more weight to mask

now we can also see that if we apply more weight to the mask, the more edges it will get for us. also as mentioned in the start of the tutorial that there is no fixed coefficients in sobel operator, so here is another weighted operator

-1 0 1
-5 0 5
-1 0 1

if you can compare the result of this mask with of the prewitt vertical mask, it is clear that this mask will give out more edges as compared to prewitt one just because we have allotted more weight in the mask.

robinson compass masks are another type of derrivate mask which is used for edge detection. this operator is also known as direction mask. in this operator we take one mask and rotate it in all the 8 compass major directions that are following:

  • north

  • north west

  • west

  • south west

  • south

  • south east

  • east

  • north east

there is no fixed mask. you can take any mask and you have to rotate it to find edges in all the above mentioned directions. all the masks are rotated on the bases of direction of zero columns.

for example let’s see the following mask which is in north direction and then rotate it to make all the direction masks.

north direction mask

-1 0 1
-2 0 2
-1 0 1

north west direction mask

0 1 2
-1 0 1
-2 -1 0

west direction mask

1 2 1
0 0 0
-1 -2 -1

south west direction mask

2 1 0
1 0 -1
0 -1 -2

south direction mask

1 0 -1
2 0 -2
1 0 -1

south east direction mask

0 -1 -2
1 0 -1
2 1 0

east direction mask

-1 -2 -1
0 0 0
1 2 1

north east direction mask

-2 -1 0
-1 0 1
0 1 2

as you can see that all the directions are covered on the basis of zeros direction. each mask will give you the edges on its direction. now let’s see the result of the entire above masks. suppose we have a sample picture from which we have to find all the edges. here is our sample picture:

sample picture:

robinson compass mask

now we will apply all the above filters on this image and we get the following result.

north direction edges

robinson compass mask

north west direction edges

robinson compass mask

west direction edges

robinson compass mask

south west direction edges

robinson compass mask

south direction edges

robinson compass mask

south east direction edges

robinson compass mask

east direction edges

robinson compass mask

north east direction edges

robinson compass mask

as you can see that by applying all the above masks you will get edges in all the direction. result is also depends on the image. suppose there is an image, which do not have any north east direction edges so then that mask will be ineffective.

kirsch compass mask is also a derivative mask which is used for finding edges. this is also like robinson compass find edges in all the eight directions of a compass. the only difference between robinson and kirsch compass masks is that in kirsch we have a standard mask but in kirsch we change the mask according to our own requirements.

with the help of kirsch compass masks we can find edges in the following eight directions.

  • north

  • north west

  • west

  • south west

  • south

  • south east

  • east

  • north east

we take a standard mask which follows all the properties of a derivative mask and then rotate it to find the edges.

for example let’s see the following mask which is in north direction and then rotate it to make all the direction masks.

north direction mask

-3 -3 5
-3 0 5
-3 -3 5

north west direction mask

-3 5 5
-3 0 5
-3 -3 -3

west direction mask

5 5 5
-3 0 -3
-3 -3 -3

south west direction mask

5 5 -3
5 0 -3
-3 -3 -3

south direction mask

5 -3 -3
5 0 -3
5 -3 -3

south east direction mask

-3 -3 -3
5 0 -3
5 5 -3

east direction mask

-3 -3 -3
-3 0 -3
5 5 5

north east direction mask

-3 -3 -3
-3 0 5
-3 5 5

as you can see that all the directions are covered and each mask will give you the edges of its own direction. now to help you better understand the concept of these masks we will apply it on a real image. suppose we have a sample picture from which we have to find all the edges. here is our sample picture:

sample picture

kirsch compass mask

now we will apply all the above filters on this image and we get the following result.

north direction edges

kirsch compass mask

north west direction edges

kirsch compass mask

west direction edges

kirsch compass mask

south west direction edges

kirsch compass mask

south direction edges

kirsch compass mask

south east direction edges

kirsch compass mask

east direction edges

kirsch compass mask

north east direction edges

kirsch compass mask

as you can see that by applying all the above masks you will get edges in all the direction. result is also depends on the image. suppose there is an image, which do not have any north east direction edges so then that mask will be ineffective.

laplacian operator is also a derivative operator which is used to find edges in an image. the major difference between laplacian and other operators like prewitt, sobel, robinson and kirsch is that these all are first order derivative masks but laplacian is a second order derivative mask. in this mask we have two further classifications one is positive laplacian operator and other is negative laplacian operator.

another difference between laplacian and other operators is that unlike other operators laplacian didn’t take out edges in any particular direction but it take out edges in following classification.

  • inward edges

  • outward edges

let’s see that how laplacian operator works.

positive laplacian operator:

in positive laplacian we have standard mask in which center element of the mask should be negative and corner elements of mask should be zero.

0 1 0
1 -4 1
0 1 0

positive laplacian operator is use to take out outward edges in an image.

negative laplacian operator:

in negative laplacian operator we also have a standard mask, in which center element should be positive. all the elements in the corner should be zero and rest of all the elements in the mask should be -1.

0 -1 0
-1 4 -1
0 -1 0

negative laplacian operator is use to take out inward edges in an image

how it works:

laplacian is a derivative operator; its uses highlight gray level discontinuities in an image and try to deemphasize regions with slowly varying gray levels. this operation in result produces such images which have grayish edge lines and other discontinuities on a dark background. this produces inward and outward edges in an image

the important thing is how to apply these filters onto image. remember we can’t apply both the positive and negative laplacian operator on the same image. we have to apply just one but the thing to remember is that if we apply positive laplacian operator on the image then we subtract the resultant image from the original image to get the sharpened image. similarly if we apply negative laplacian operator then we have to add the resultant image onto original image to get the sharpened image.

let’s apply these filters onto an image and see how it will get us inward and outward edges from an image. suppose we have a following sample image.

sample image

laplacian operaor

after applying positive laplacian operator:

after applying positive laplacian operator we will get the following image.

laplacian operaor

after applying negative laplacian operator:

after applying negative laplacian operator we will get the following image.

laplacian operaor

we have deal with images in many domains. now we are processing signals (images) in frequency domain. since this fourier series and frequency domain is purely mathematics , so we will try to minimize that math’s part and focus more on its use in dip.

frequency domain analysis

till now , all the domains in which we have analyzed a signal , we analyze it with respect to time. but in frequency domain we don’t analyze signal with respect to time , but with respect of frequency.

difference between spatial domain and frequency domain.

in spatial domain , we deal with images as it is. the value of the pixels of the image change with respect to scene. whereas in frequency domain , we deal with the rate at which the pixel values are changing in spatial domain.

for simplicity , let’s put it this way.

spatial domain

frequency domain

in simple spatial domain , we directly deal with the image matrix. whereas in frequency domain , we deal an image like this.

frequency domain

we first transform the image to its frequency distribution. then our black box system perform what ever processing it has to performed , and the output of the black box in this case is not an image , but a transformation. after performing inverse transformation , it is converted into an image which is then viewed in spatial domain.

it can be pictorially viewed as

frequency domain

here we have used the word transformation. what does it actually mean?

transformation.

a signal can be converted from time domain into frequency domain using mathematical operators called transforms. there are many kind of transformation that does this. some of them are given below.

  • fourier series

  • fourier transformation

  • laplace transform

  • z transform

out of all these , we will thoroughly discuss fourier series and fourier transformation in our next tutorial.

frequency components

any image in spatial domain can be represented in a frequency domain. but what do this frequencies actually mean.

we will divide frequency components into two major components.

high frequency components

high frequency components correspond to edges in an image.

low frequency components

low frequency components in an image correspond to smooth regions.

in the last tutorial of frequency domain analysis, we discussed that fourier series and fourier transform are used to convert a signal to frequency domain.

fourier

fourier was a mathematician in 1822. he give fourier series and fourier transform to convert a signal into frequency domain.

fourier series

fourier series simply states that , periodic signals can be represented into sum of sines and cosines when multiplied with a certain weight.it further states that periodic signals can be broken down into further signals with the following properties.

  • the signals are sines and cosines

  • the signals are harmonics of each other

it can be pictorially viewed as

fourier transform

in the above signal , the last signal is actually the sum of all the above signals. this was the idea of the fourier.

how it is calculated.

since as we have seen in the frequency domain , that in order to process an image in frequency domain , we need to first convert it using into frequency domain and we have to take inverse of the output to convert it back into spatial domain. that’s why both fourier series and fourier transform has two formulas. one for conversion and one converting it back to the spatial domain.

fourier series

the fourier series can be denoted by this formula.

fourier transform

the inverse can be calculated by this formula.

fourier transform

fourier transform

the fourier transform simply states that that the non periodic signals whose area under the curve is finite can also be represented into integrals of the sines and cosines after being multiplied by a certain weight.

the fourier transform has many wide applications that include , image compression (e.g jpeg compression) , filtrering and image analysis.

difference between fourier series and transform

although both fourier series and fourier transform are given by fourier , but the difference between them is fourier series is applied on periodic signals and fourier transform is applied for non periodic signals

which one is applied on images.

now the question is that which one is applied on the images , the fourier series or the fourier transform. well , the answer to this question lies in the fact that what images are. images are non – periodic. and since the images are non periodic , so fourier transform is used to convert them into frequency domain.

discrete fourier transform.

since we are dealing with images, and infact digital images , so for digital images we will be working on discrete fourier transform

fourier transform

consider the above fourier term of a sinusoid. it include three things.

  • spatial frequency

  • magnitude

  • phase

the spatial frequency directly relates with the brightness of the image. the magnitude of the sinusoid directly relates with the contrast. contrast is the difference between maximum and minimum pixel intensity. phase contains the color information.

the formula for 2 dimensional discrete fourier transform is given below.

fourier transform

the discrete fourier transform is actually the sampled fourier transform, so it contains some samples that denotes an image. in the above formula f(x,y) denotes the image , and f(u,v) denotes the discrete fourier transform. the formula for 2 dimensional inverse discrete fourier transform is given below.

fourier transform

the inverse discrete fourier transform converts the fourier transform back to the image

consider this signal.

now we will see an image , whose we will calculate fft magnitude spectrum and then shifted fft magnitude spectrum and then we will take log of that shifted spectrum.

original image

fourier transform

the fourier transform magnitude spectrum

fourier transform

the shifted fourier transform

fourier transform

the shifted magnitude spectrum

fourier transform

in the last tutorial , we discussed about the images in frequency domain. in this tutorial , we are going to define a relationship between frequency domain and the images(spatial domain).

for example:

consider this example.

convolution

the same image in the frequency domain can be represented as.

convolution

now what’s the relationship between image or spatial domain and frequency domain. this relationship can be explained by a theorem which is called as convolution theorem.

convolution theorem

the relationship between the spatial domain and the frequency domain can be established by convolution theorem.

the convolution theorem can be represented as.

convolution

it can be stated as the convolution in spatial domain is equal to filtering in frequency domain and vice versa.

the filtering in frequency domain can be represented as following:

convolution

the steps in filtering are given below.

  • at first step we have to do some pre – processing an image in spatial domain, means increase its contrast or brightness

  • then we will take discrete fourier transform of the image

  • then we will center the discrete fourier transform , as we will bring the discrete fourier transform in center from corners

  • then we will apply filtering , means we will multiply the fourier transform by a filter function

  • then we will again shift the dft from center to the corners

  • last step would be take to inverse discrete fourier transform , to bring the result back from frequency domain to spatial domain

  • and this step of post processing is optional , just like pre processing , in which we just increase the appearance of image.

filters

the concept of filter in frequency domain is same as the concept of a mask in convolution.

after converting an image to frequency domain, some filters are applied in filtering process to perform different kind of processing on an image. the processing include blurring an image , sharpening an image e.t.c.

the common type of filters for these purposes are:

  • ideal high pass filter

  • ideal low pass filter

  • gaussian high pass filter

  • gaussian low pass filter

in the next tutorial, we will discuss about filter in detail.

in the last tutorial , we briefly discuss about filters. in this tutorial we will thoroughly discuss about them. before discussing about let’s talk about masks first. the concept of mask has been discussed in our tutorial of convolution and masks.

blurring masks vs derivative masks.

we are going to perform a comparison between blurring masks and derivative masks.

blurring masks:

a blurring mask has the following properties.

  • all the values in blurring masks are positive

  • the sum of all the values is equal to 1

  • the edge content is reduced by using a blurring mask

  • as the size of the mask grow, more smoothing effect will take place

derrivative masks:

a derivative mask has the following properties.

  • a derivative mask have positive and as well as negative values

  • the sum of all the values in a derivative mask is equal to zero

  • the edge content is increased by a derivative mask

  • as the size of the mask grows , more edge content is increased

relationship between blurring mask and derivative mask with high pass filters and low pass filters.

the relationship between blurring mask and derivative mask with a high pass filter and low pass filter can be defined simply as.

  • blurring masks are also called as low pass filter

  • derivative masks are also called as high pass filter

high pass frequency components and low pass frequency components

the high pass frequency components denotes edges whereas the low pass frequency components denotes smooth regions.

ideal low pass and ideal high pass filters

this is the common example of low pass filter.

high pass

when one is placed inside and the zero is placed outside , we got a blurred image. now as we increase the size of 1, blurring would be increased and the edge content would be reduced.

this is a common example of high pass filter.

high pass

when 0 is placed inside, we get edges , which gives us a sketched image. an ideal low pass filter in frequency domain is given below

high pass

the ideal low pass filter can be graphically represented as

high pass

now let’s apply this filter to an actual image and let’s see what we got.

sample image.

high pass

image in frequency domain

high pass

applying filter over this image

high pass

resultant image

high pass

with the same way , an ideal high pass filter can be applied on an image. but obviously the results would be different as , the low pass reduces the edged content and the high pass increase it.

gaussian low pass and gaussian high pass filter

gaussian low pass and gaussian high pass filter minimize the problem that occur in ideal low pass and high pass filter.

this problem is known as ringing effect. this is due to reason because at some points transition between one color to the other cannot be defined precisely, due to which the ringing effect appears at that point.

have a look at this graph.

high pass

this is the representation of ideal low pass filter. now at the exact point of do , you cannot tell that the value would be 0 or 1. due to which the ringing effect appears at that point.

so in order to reduce the effect that appears is ideal low pass and ideal high pass filter , the following gaussian low pass filter and gaussian high pass filter is introduced.

gaussian low pass filter

the concept of filtering and low pass remains the same, but only the transition becomes different and become more smooth.

the gaussian low pass filter can be represented as

high pass

note the smooth curve transition, due to which at each point, the value of do , can be exactly defined.

gaussian high pass filter

gaussian high pass filter has the same concept as ideal high pass filter , but again the transition is more smooth as compared to the ideal one.

in this tutorial, we are going to talk about color spaces.

what are color spaces?

color spaces are different types of color modes, used in image processing and signals and system for various purposes. some of the common color spaces are:

  • rgb

  • cmy’k

  • y’uv

  • yiq

  • y’cbcr

  • hsv

rgb

color spaces

rgb is the most widely used color space , and we have already discussed it in the past tutorials. rgb stands for red green and blue.

what rgb model states , that each color image is actually formed of three different images. red image , blue image , and black image. a normal grayscale image can be defined by only one matrix, but a color image is actually composed of three different matrices.

one color image matrix = red matrix + blue matrix + green matrix

this can be best seen in this example below.

color spaces

applications of rgb

the common applications of rgb model are

  • cathode ray tube (crt)

  • liquid crystal display (lcd)

  • plasma display or led display such as a television

  • a compute monitor or a large scale screen

cmyk

color spaces

rgb to cmy conversion

the conversion from rgb to cmy is done using this method.

color spaces

consider you have an color image , means you have three different arrays of red , green and blue. now if you want to convert it into cmy , here’s what you have to do. you have to subtract it by the maximum number of levels – 1. each matrix is subtracted and its respective cmy matrix is filled with result.

y’uv

y’uv defines a color space in terms of one luma (y’) and two chrominance (uv) components. the y’uv color model is used in the following composite color video standards.

  • ntsc ( national television system committee)

  • pal (phase alternating line)

  • secam (sequential couleur a amemoire, french for “sequential color with memory)

color spaces

y’cbcr

y’cbcr color model contains y’ , the luma component and cb and cr are the blue-differnece and red difference chroma components.

it is not an absolute color space. it is mainly used for digital systems

its common applications include jpeg and mpeg compression.

y’uv is often used as the term for y’cbcr, however they are totally different formats. the main difference between these two is that the former is analog while the later is digital.

color spaces

in our last tutorial of image compression , we discuss some of the techniques used for compression

we are going to discuss jpeg compression which is lossy compression , as some data is loss in the end.

let’s discuss first what image compression is.

image compression

image compression is the method of data compression on digital images.

the main objective in the image compression is:

  • store data in an efficient form

  • transmit data in an efficient form

image compression can be lossy or lossless.

jpeg compression

jpeg stands for joint photographic experts group. it is the first interanational standard in image compression. it is widely used today. it could be lossy as well as lossless . but the technique we are going to discuss here today is lossy compression technique.

how jpeg compression works:

first step is to divide an image into blocks with each having dimensions of 8 x8.

jpeg compression

let’s for the record , say that this 8x8 image contains the following values.

jpeg compression

the range of the pixels intensities now are from 0 to 255. we will change the range from -128 to 127.

subtracting 128 from each pixel value yields pixel value from -128 to 127. after subtracting 128 from each of the pixel value , we got the following results.

jpeg compression

now we will compute using this formula.

jpeg compression

the result comes from this is stored in let’s say a(j,k) matrix.

there is a standard matrix that is used for computing jpeg compression, which is given by a matrix called as luminance matrix.

this matrix is given below

jpeg compression

applying the following formula

jpeg compression

we got this result after applying.

jpeg compression

now we will perform the real trick which is done in jpeg compression which is zig-zag movement. the zig zag sequence for the above matrix is shown below. you have to perform zig zag until you find all zeroes ahead. hence our image is now compressed.

jpeg compression

summarizing jpeg compression

the first step is to convert an image to y’cbcr and just pick the y’ channel and break into 8 x 8 blocks. then starting from the first block , map the range from -128 to 127. after that you have to find the discrete fourier transform of the matrix. the result of this should be quantized. the last step is to apply encoding in the zig zag manner and do it till you find all zero.

save this one dimensional array and you are done.

note. you have to repeat this procedure for all the block of 8 x 8.

optical character recognition is usually abbreviated as ocr. it includes the mechanical and electrical conversion of scanned images of handwritten, typewritten text into machine text. it is common method of digitizing printed texts so that they can be electronically searched, stored more compactly, displayed on line, and used in machine processes such as machine translation, text to speech and text mining.

in recent years, ocr (optical character recognition) technology has been applied throughout the entire spectrum of industries, revolutionizing the document management process. ocr has enabled scanned documents to become more than just image files, turning into fully searchable documents with text content that is recognized by computers. with the help of ocr, people no longer need to manually retype important documents when entering them into electronic databases. instead, ocr extracts relevant information and enters it automatically. the result is accurate, efficient information processing in less time.

optical character recognition has multiple research areas but the most common areas are as following:

banking:

he uses of ocr vary across different fields. one widely known application is in banking, where ocr is used to process checks without human involvement. a check can be inserted into a machine, the writing on it is scanned instantly, and the correct amount of money is transferred. this technology has nearly been perfected for printed checks, and is fairly accurate for handwritten checks as well, though it occasionally requires manual confirmation. overall, this reduces wait times in many banks.

blind and visually impaired persons:

one of the major factors in the beginning of research behind the ocr is that scientist want to make a computer or device which could read book to the blind people out loud. on this research scientist made flatbed scanner which is most commonly known to us as document scanner.

legal department:

in the legal industry, there has also been a significant movement to digitize paper documents. in order to save space and eliminate the need to sift through boxes of paper files, documents are being scanned and entered into computer databases. ocr further simplifies the process by making documents text-searchable, so that they are easier to locate and work with once in the database. legal professionals now have fast, easy access to a huge library of documents in electronic format, which they can find simply by typing in a few keywords.

retail industry:

barcode recognition technology is also related to ocr. we see the use of this technology in our common day use.

other uses:

ocr is widely used in many other fields, including education, finance, and government agencies. ocr has made countless texts available online, saving money for students and allowing knowledge to be shared. invoice imaging applications are used in many businesses to keep track of financial records and prevent a backlog of payments from piling up. in government agencies and independent organizations, ocr simplifies data collection and analysis, among other processes. as the technology continues to develop, more and more applications are found for ocr technology, including increased use of handwriting recognition.

computer vision

computer vision is concerned with modeling and replicating human vision using computer software and hardware. formally if we define computer vision then its definition would be that computer vision is a discipline that studies how to reconstruct, interrupt and understand a 3d scene from its 2d images in terms of the properties of the structure present in scene.

it needs knowledge from the following fields in order to understand and stimulate the operation of human vision system.

  • computer science

  • electrical engineering

  • mathematics

  • physiology

  • biology

  • cognitive science

computer vision hierarchy:

computer vision is divided into three basic categories that are as following:

low-level vision: includes process image for feature extraction.

intermediate-level vision: includes object recognition and 3d scene interpretation

high-level vision: includes conceptual description of a scene like activity, intention and behavior.

related fields:

computer vision overlaps significantly with the following fields:

image processing: it focuses on image manipulation.

pattern recognition: it studies various techniques to classify patterns.

photogrammetry: it is concerned with obtaining accurate measurements from images.

computer vision vs image processing:

image processing studies image to image transformation. the input and output of image processing are both images.

computer vision is the construction of explicit, meaningful descriptions of physical objects from their image. the output of computer vision is a description or an interpretation of structures in 3d scene.

example applications:

  • robotics

  • medicine

  • security

  • transportation

  • industrial automation

robotics application:

  • localization-determine robot location automatically

  • navigation

  • obstacles avoidance

  • assembly (peg-in-hole, welding, painting)

  • manipulation (e.g. puma robot manipulator)

  • human robot interaction (hri): intelligent robotics to interact with and serve people

medicine application:

  • classification and detection (e.g. lesion or cells classification and tumor detection)

  • 2d/3d segmentation

  • 3d human organ reconstruction (mri or ultrasound)

  • vision-guided robotics surgery

industrial automation application:

  • industrial inspection (defect detection)

  • assembly

  • barcode and package label reading

  • object sorting

  • document understanding (e.g. ocr)

security application:

  • biometrics (iris, finger print, face recognition)

  • surveillance-detecting certain suspicious activities or behaviors

transportation application:

  • autonomous vehicle

  • safety, e.g., driver vigilance monitoring

computer graphics

computer graphics are graphics created using computers and the representation of image data by a computer specifically with help from specialized graphic hardware and software. formally we can say that computer graphics is creation, manipulation and storage of geometric objects (modeling) and their images (rendering).

the field of computer graphics developed with the emergence of computer graphics hardware. today computer graphics is use in almost every field. many powerful tools have been developed to visualize data. computer graphics field become more popular when companies started using it in video games. today it is a multibillion dollar industry and main driving force behind the computer graphics development. some common applications areas are as following:

  • computer aided design (cad)

  • presentation graphics

  • 3d animation

  • education and training

  • graphical user interfaces

computer aided design:

  • used in design of buildings, automobiles, aircraft and many other product

  • use to make virtual reality system.

presentation graphics:

  • commonly used to summarize financial ,statistical data

  • use to generate slides

3d animation:

  • used heavily in the movie industry by companies such as pixar, dresmsworks

  • to add special effects in games and movies.

education and training:

  • computer generated models of physical systems

  • medical visualization

  • 3d mri

  • dental and bone scans

  • stimulators for training of pilots etc.

graphical user interfaces:

  • it is used to make graphical user interfaces objects like buttons, icons and other components