logo Use CA10RAM to get 10%* Discount.
Order Nowlogo
(5/5)

In this assignment, you will write a program that plot ASCII text approximations of the Mandelbrot set.

INSTRUCTIONS TO CANDIDATES
ANSWER ALL QUESTIONS

Assignment 2

In this assignment, you will write a program that plot ASCII text approximations of the Mandelbrot set.

 

Problem 1

Consider the function𝑃(π‘₯,𝑦)defined as follows

𝑃(π‘₯,𝑦)(𝑒, 𝑣) = (𝑒2− 𝑣2+ π‘₯, 2𝑒𝑣 + 𝑦)

We define the orbit𝑂(π‘₯, 𝑦)of a point(π‘₯, 𝑦)to be an infinite list of items

𝑂(π‘₯, 𝑦) = {(0, 0), 𝑃(π‘₯,𝑦)(0, 0), 𝑃(π‘₯,𝑦)(𝑃(π‘₯,𝑦)(0, 0)), 𝑃(π‘₯,𝑦)(𝑃(π‘₯,𝑦)(𝑃(π‘₯,𝑦)(0, 0))), ...}

In other words, the nth entry of the list𝑂(π‘₯, 𝑦)is the𝑃(π‘₯,𝑦)function composedwith itself n times and then applied to(0, 0)

Define a F# functionorbitthat takes a single point(π‘₯, 𝑦)and index𝑖asan arguments and returns anπ‘–π‘‘β„Želement of the infinite list corresponding to𝑂(π‘₯, 𝑦).

You may want to define a helper function corresponding to𝑃(π‘₯,𝑦).

Problem 2

Define a recursive function disp that takes two arguments: - a number d, and - a list of tuples pairs.

Every tuple in this input list consists of a number followed by a character, and you can assume the input list is always in ascending order. For example, a possible input list might be:

[(0.15, '#'), (0.5, 'x'), (1.0, '.')]

The function disp should return the character from the list that corresponds to the smallest number on the list that is greater than the input d, and if d is larger than all the number in the list, disp should return a space character, ’ ’. For example,

disp 0.01 [(0.15, '#'), (0.5, 'x'), (1.0, '.')] = '#'

disp 0.4 [(0.15, '#'), (0.5, 'x'), (1.0, '.')]     = 'x'

disp 100 [(0.15, '#'), (0.5, 'x'), (1.0, '.')]     = ' '

Problem 3

One way to approximate the Mandelbrot set is to consider a certain element within the orbit of every point on the plane (such as the 12th element) and to check whether that element is within a a certain distance from the origin; if it is within this distance, then a non-blank character should be printed, else it should be left blank. You should use the following function to calculate distances of points from the origin:

let norm (x,y) = x*x + y*y

These distance values can then be used with disp and orbit to turn points on the plane into appropriate ASCII characters within an ASCII plot of the Mandelbrot set.

Define a function mandelbrot that takes three arguments: - the resolution of the approximation, r (used with the plane function), - the index of the elements, i, to check in the orbit lists of the points, and - the formatting list, l (to be used with the disp function).

This function should return a list of characters that corresponds to a picture approximating the shape of the Mandelbrot set on the plane.

You will need to combine the split, plane, disp, and orbit functions appro- priately; list comprehensions are allowed.

Once you’ve defined the function mandelbrot, you can generate an ASCII ver- sion of an approximation of the Mandelbrot set by evaluating the expression:

mandelbrot1712disp_symbols |> printfn"%s";;

 

(5/5)
Attachments:

Related Questions

. Introgramming & Unix Fall 2018, CRN 44882, Oakland University Homework Assignment 6 - Using Arrays and Functions in C

DescriptionIn this final assignment, the students will demonstrate their ability to apply two ma

. The standard path finding involves finding the (shortest) path from an origin to a destination, typically on a map. This is an

Path finding involves finding a path from A to B. Typically we want the path to have certain properties,such as being the shortest or to avoid going t

. Develop a program to emulate a purchase transaction at a retail store. This program will have two classes, a LineItem class and a Transaction class. The LineItem class will represent an individual

Develop a program to emulate a purchase transaction at a retail store. Thisprogram will have two classes, a LineItem class and a Transaction class. Th

. SeaPort Project series For this set of projects for the course, we wish to simulate some of the aspects of a number of Sea Ports. Here are the classes and their instance variables we wish to define:

1 Project 1 Introduction - the SeaPort Project series For this set of projects for the course, we wish to simulate some of the aspects of a number of

. Project 2 Introduction - the SeaPort Project series For this set of projects for the course, we wish to simulate some of the aspects of a number of Sea Ports. Here are the classes and their instance variables we wish to define:

1 Project 2 Introduction - the SeaPort Project series For this set of projects for the course, we wish to simulate some of the aspects of a number of

Ask This Question To Be Solved By Our ExpertsGet A+ Grade Solution Guaranteed

expert
Um e HaniScience

973 Answers

Hire Me
expert
Muhammad Ali HaiderFinance

882 Answers

Hire Me
expert
Husnain SaeedComputer science

656 Answers

Hire Me
expert
Atharva PatilComputer science

512 Answers

Hire Me

Get Free Quote!

330 Experts Online