image_processing_hw

.pdf

School

University of California, Berkeley *

*We aren’t endorsed by this school

Course

109

Subject

Astronomy

Date

Apr 3, 2024

Type

pdf

Pages

4

Uploaded by MateResolveChinchilla36

Report
EPS 109 “Computer Simulations in Earth and Planetary Science” Instructor: B. Militzer Homework Assignment 12 Image Processing Please download all accompanying ‘.jpg’ and ‘.tif’ images from bCourses. Part 1 – How much hair and beard? The Australian sculptor Ron Mueck is known for his oversized and very realistic but slightly creepy looking sculptures. The head, about 5 feet long, was displayed at SF MOMA and is believed to be self-portrait. In this part, we want to count the number of pixels that show hair and beard in the image on the left. Download and display the image file “head_by_Ron_Mueck.jpg”. Then apply an entropy filter with the following commands: from skimage.filters.rank import entropy from skimage.morphology import disk from skimage.color import rgb2gray gray_image = rgb2gray(image) entropy_image = entropy(gray_image, disk(50)) (1) Display the resulting image and adjust the size of the disk until the hair and beard stand out best. (2) Convert the entropy image to black and white by choosing a reasonable threshold value. Your black-and-white image should approximately look like image on the right image above. (3) Determine the fraction of pixels in percent that show hair and beard. Answers with 1% will earn you full credit.
EPS 109 “Computer Simulations in Earth and Planetary Science” Instructor: B. Militzer (4) For this image, provide one example why this approach may overestimate the pixel fraction and one why it may underestimate this fraction. Part 2 – Bubbles in Pumice 2 Review part 2 of the lab, in which we used Scikit-image to identify and label regions of a black and white image, and then to quantified properties of the labeled regions. We provide with two images 3.jpg that show dark bubbles in pumice. (1) Read and display the image in file ‘3.jpg’. Display the histogram of pixel intensities. Notice that this time there are light grey crystals in addition to the black bubbles. (2) Apply the necessary intensity threshold(s) to create two black & white images, one displaying ONLY the bubbles, and the other displaying ONLY the lighter grains. You can find the part of the image within a specific intensity ranges using Boolean arithmetic: image_grains = ( image < val1 ) * (image > val0 ) (3) Apply the scikit-image measure.label(image) and measure.regionprops(labels) functions as you did in the lab separately for BOTH bubbles and the and the grains. How many bubbles and how many grains do you detect ? The following command is needed to import the functions. from skimage import measure
EPS 109 “Computer Simulations in Earth and Planetary Science” Instructor: B. Militzer (4) Generate a histogram of areas for BOTH the bubbles and the grains. Once again, you can iterate through the area of each entry in the regionprops object using the starting with the following loop. for p in props: print(p.area) (5) Calculate the total area of bubbles and grains. Calculate the fraction of the image by area take up by the bubbles and the grains. Part 3 – False Color LANDSAT Image Review Parts 3 and 4 of the lab, in which we used Scikit-image to construct an RGB image from specific bands observed by the LANDSAT satellite, and then used color discretization to quantify different types of land coverage. Another commonly used type of false color images uses LANDSAT bands 6, 5 and 2 (short- wave infrared, near infrared, blue) to highlight agricultural versus urban areas. With this combination of bands, vigorous vegetation appears bright green, healthy vegetation appears as a darker green, while stressed vegetation appears dull green. Coniferous forests appear as a dark, rich green, while deciduous forests appear as a bright green. Sparsely vegetated and bare areas appear beige or brown and urban areas appear purple or grey. (1) Use the provided prepare_landsat_image() function from Part 4 of the lab to load, re-scale intensities, rotate and crop LANDSAT image. Instead of the red, green and blue bands, run the following code to prepare and display a false color image with the channels set to bands 6, 5 and 2. from image_manipulation import prepare_landsat_image bands = [6,5,2] ls_false = prepare_landsat_image(bands) (2) Apply the color quantization from part 4 of the lab with N=7 to obtain a quantized image, and bar plot of the color counts. You can use the provided bar_plot_with_colors() function, but remember that the indexed and RGB from index imaged may return colors in a different order. the Identify which color(s) corresponds to urban areas. Which color(s) corresponds to water? Forests? (3) Calculate the fraction of the image that is covered by land (as opposed to water). Then calculate the fraction of that land that is covered by urban areas.
Your preview ends here
Eager to read complete document? Join bartleby learn and gain access to the full version
  • Access to all documents
  • Unlimited textbook solutions
  • 24/7 expert homework help
EPS 109 “Computer Simulations in Earth and Planetary Science” Instructor: B. Militzer (4) Finally, identify what label in the label corresponds to urban areas, and then generate and display a black and white image showing only the part of the image characterized as urban. labeled_image = np.array(imageIndexed) bw_urban = (labeled_image == label) where label is the integer number representing in the indexed image. (5) What are some reasons this method might miscount the fraction representing urban areas? What do you think is the cause of the bright streak in the northern part of the image?