Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
r""" Mandelbrot and Julia sets
Plots the Mandelbrot and Julia sets for the map `Q_c(z)=z^2+c` in the complex plane.
The Mandelbrot set is the set of complex numbers `c` for which the function `Q_c(z)=z^2+c` does not diverge when iterated from `z = 0`. This set of complex numbers can be visualized by plotting each value for `c` in the complex plane. The Mandelbrot set is an example of a fractal when plotted in the complex plane.
The Julia set for a given `c` is the set of complex numbers for which the function `Q_c(z)=z^2+c` is bounded under iteration.
AUTHORS:
- Ben Barros
"""
#***************************************************************************** # Copyright (C) 2017 BEN BARROS <bbarros@slu.edu> # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 2 of the License, or # (at your option) any later version. # http://www.gnu.org/licenses/ #*****************************************************************************
fast_external_ray, convert_to_pixels, get_line, fast_julia_plot, julia_helper) slider, input_box, color_selector, checkbox)
r""" Interactive plot of the Mandelbrot set for the map `Q_c(z) = z^2 + c`.
ALGORITHM:
Let each pixel in the image be a point `c \in \mathbb{C}` and define the map `Q_c(z) = z^2 + c`. If `|Q_{c}^{k}(c)| > 2` for some `k \geq 0`, it follows that `Q_{c}^{n}(c) \to \infty`. Let `N` be the maximum number of iterations. Compute the first `N` points on the orbit of `0` under `Q_c`. If for any `k < N`, `|Q_{c}^{k}(0)| > 2`, we stop the iteration and assign a color to the point `c` based on how quickly `0` escaped to infinity under iteration of `Q_c`. If `|Q_{c}^{i}(0)| \leq 2` for all `i \leq N`, we assume `c` is in the Mandelbrot set and assign the point `c` the color black.
REFERENCE:
[Dev2005]_
kwds:
- ``x_center`` -- double (optional - default: ``-1.0``), Real part of center point.
- ``y_center`` -- double (optional - default: ``0.0``), Imaginary part of center point.
- ``image_width`` -- double (optional - default: ``4.0``), width of image in the complex plane.
- ``max_iteration`` -- long (optional - default: ``500``), maximum number of iterations the map ``Q_c(z)``.
- ``pixel_count`` -- long (optional - default: ``500``), side length of image in number of pixels.
- ``base_color`` -- RGB color (optional - default: ``[40, 40, 40]``) color used to determine the coloring of set.
- ``iteration_level`` -- long (optional - default: 1) number of iterations between each color level.
- ``number_of_colors`` -- long (optional - default: 30) number of colors used to plot image.
- ``interact`` -- boolean (optional - default: ``False``), controls whether plot will have interactive functionality.
OUTPUT:
24-bit RGB image of the Mandelbrot set in the complex plane.
EXAMPLES:
::
sage: mandelbrot_plot() # long time 500x500px 24-bit RGB image
::
sage: mandelbrot_plot(pixel_count=1000) # long time 1000x1000px 24-bit RGB image
::
sage: mandelbrot_plot(x_center=-1.11, y_center=0.2283, image_width=1/128, # long time ....: max_iteration=2000, number_of_colors=500, base_color=[40, 100, 100]) 500x500px 24-bit RGB image
To display an interactive plot of the Mandelbrot set in the Notebook, set ``interact`` to ``True``::
sage: mandelbrot_plot(interact=True) <html>...</html>
::
sage: mandelbrot_plot(interact=True, x_center=-0.75, y_center=0.25, ....: image_width=1/2, number_of_colors=75) <html>...</html> """
'top':[['iterations'], ['level_sep'], ['color_num'], ['image_color']]}) im_center=input_box(y_center, 'Imaginary'), width=input_box(image_width, 'Width of Image'), iterations=input_box(max_iteration, 'Max Number of Iterations'), level_sep=input_box(iteration_level, 'Iterations between Colors'), color_num=input_box(number_of_colors, 'Number of Colors'), image_color=color_selector(default=Color([j/255 for j in base_color]), label="Image Color", hide_box=True)): return fast_mandelbrot_plot(real_center, im_center, width, iterations, pixel_count, level_sep, color_num, image_color).show()
else: pixel_count, iteration_level, number_of_colors, base_color)
r""" Draws the external ray(s) of a given angle (or list of angles) by connecting a finite number of points that were approximated using Newton's method. The algorithm used is described in a paper by Tomoki Kawahira.
REFERENCE:
[Kaw2009]_
INPUT:
- ``theta`` -- double or list of doubles, angles between 0 and 1 inclusive.
kwds:
- ``image`` -- 24-bit RGB image (optional - default: None) user specified image of Mandelbrot set.
- ``D`` -- long (optional - default: ``25``) depth of the approximation. As ``D`` increases, the external ray gets closer to the boundary of the Mandelbrot set. If the ray doesn't reach the boundary of the Mandelbrot set, increase ``D``.
- ``S`` -- long (optional - default: ``10``) sharpness of the approximation. Adjusts the number of points used to approximate the external ray (number of points is equal to ``S*D``). If ray looks jagged, increase ``S``.
- ``R`` -- long (optional - default: ``100``) radial parameter. If ``R`` is large, the external ray reaches sufficiently close to infinity. If ``R`` is too small, Newton's method may not converge to the correct ray.
- ``prec`` -- long (optional - default: ``300``) specifies the bits of precision used by the Complex Field when using Newton's method to compute points on the external ray.
- ``ray_color`` -- RGB color (optional - default: ``[255, 255, 255]``) color of the external ray(s).
OUTPUT:
24-bit RGB image of external ray(s) on the Mandelbrot set.
EXAMPLES::
sage: external_ray(1/3) 500x500px 24-bit RGB image
::
sage: external_ray(0.6, ray_color=[255, 0, 0]) 500x500px 24-bit RGB image
::
sage: external_ray([0, 0.2, 0.4, 0.7]) # long time 500x500px 24-bit RGB image
::
sage: external_ray([i/5 for i in range(1,5)]) # long time 500x500px 24-bit RGB image
WARNING:
If you are passing in an image, make sure you specify which parameters to use when drawing the external ray. For example, the following is incorrect::
sage: M = mandelbrot_plot(x_center=0) # not tested sage: external_ray(5/7, image=M) # not tested 500x500px 24-bit RGB image
To get the correct external ray, we adjust our parameters::
sage: M = mandelbrot_plot(x_center=0) # not tested sage: external_ray(5/7, x_center=0, image=M) # not tested 500x500px 24-bit RGB image
.. TODO::
The ``copy()`` function for bitmap images needs to be implemented in Sage. """
# Make a copy of the bitmap image. # M = copy(image)
# Make sure that theta is a list so loop below works
# Check if theta is in the interval [0,1] raise \ ValueError("values for theta must be in the closed interval [0,1].")
# Loop through each value for theta in list and plot the external ray. prec=precision, image_width=plot_width, pixel_count=pixel_width)
# Convert points to pixel coordinates.
# Find the pixels between points in pixel_list.
# Add these points to pixel_list to fill in gaps in the ray.
# Remove duplicates from list.
# Check if point is in window and if it is, plot it on the image to # create an external ray.
r""" Plots the Julia set of a given complex `c` value. Users can specify whether they would like to display the Mandelbrot side by side with the Julia set.
The Julia set of a given `c` value is the set of complex numbers for which the function `Q_c(z)=z^2+c` is bounded under iteration. The Julia set can be visualized by plotting each point in the set in the complex plane. Julia sets are examples of fractals when plotted in the complex plane.
ALGORITHM:
Define the map `Q_c(z) = z^2 + c` for some `c \in \mathbb{C}`. For every `p \in \mathbb{C}`, if `|Q_{c}^{k}(p)| > 2` for some `k \geq 0`, then `Q_{c}^{n}(p) \to \infty`. Let `N` be the maximum number of iterations. Compute the first `N` points on the orbit of `p` under `Q_c`. If for any `k < N`, `|Q_{c}^{k}(p)| > 2`, we stop the iteration and assign a color to the point `p` based on how quickly `p` escaped to infinity under iteration of `Q_c`. If `|Q_{c}^{i}(p)| \leq 2` for all `i \leq N`, we assume `p` is in the Julia set and assign the point `p` the color black.
INPUT:
- ``c`` -- complex (optional - default: ``-1``), complex point `c` that determines the Julia set.
kwds:
- ``period`` -- list (optional - default: ``None``), returns the Julia set for a random `c` value with the given (formal) cycle structure.
- ``mandelbrot`` -- boolean (optional - default: ``True``), when set to ``True``, an image of the Mandelbrot set is appended to the right of the Julia set.
- ``point_color`` -- RGB color (optional - default: ``[255, 0, 0]``), color of the point `c` in the Mandelbrot set.
- ``x_center`` -- double (optional - default: ``-1.0``), Real part of center point.
- ``y_center`` -- double (optional - default: ``0.0``), Imaginary part of center point.
- ``image_width`` -- double (optional - default: ``4.0``), width of image in the complex plane.
- ``max_iteration`` -- long (optional - default: ``500``), maximum number of iterations the map `Q_c(z)`.
- ``pixel_count`` -- long (optional - default: ``500``), side length of image in number of pixels.
- ``base_color`` -- RGB color (optional - default: ``[40, 40, 40]``), color used to determine the coloring of set.
- ``iteration_level`` -- long (optional - default: 1), number of iterations between each color level.
- ``number_of_colors`` -- long (optional - default: 30), number of colors used to plot image.
- ``interact`` -- boolean (optional - default: ``False``), controls whether plot will have interactive functionality.
OUTPUT:
24-bit RGB image of the Julia set in the complex plane.
EXAMPLES::
sage: julia_plot() 1001x500px 24-bit RGB image
To display only the Julia set, set ``mandelbrot`` to ``False``::
sage: julia_plot(mandelbrot=False) 500x500px 24-bit RGB image
To display an interactive plot of the Julia set in the Notebook, set ``interact`` to ``True``::
sage: julia_plot(interact=True) <html>...</html>
To return the Julia set of a random `c` value with (formal) cycle structure `(2,3)`, set ``period = [2,3]``::
sage: julia_plot(period=[2,3]) 1001x500px 24-bit RGB image
To return all of the Julia sets of `c` values with (formal) cycle structure `(2,3)`::
sage: period = [2,3] # not tested ....: R.<c> = QQ[] ....: P.<x,y> = ProjectiveSpace(R,1) ....: f = DynamicalSystem([x^2+c*y^2, y^2]) ....: L = f.dynatomic_polynomial(period).subs({x:0,y:1}).roots(ring=CC) ....: c_values = [k[0] for k in L] ....: for c in c_values: ....: julia_plot(c) """
'top':[['iterations'], ['level_sep'], ['color_num'], ['mandel'], ['cx'], ['cy']], 'right':[['image_color'], ['pt_color']]}) cy = input_box(c_imag, '$Im(c)$'), real_center=input_box(x_center, 'Real Center'), im_center=input_box(y_center, 'Imaginary Center'), width=input_box(image_width, 'Width of Image'), iterations=input_box(max_iteration, 'Max Number of Iterations'), level_sep=input_box(iteration_level, 'Iterations between Colors'), color_num=input_box(number_of_colors, 'Number of Colors'), image_color=color_selector(default=Color([j/255 for j in base_color]), label="Image Color", hide_box=True), pt_color=color_selector(default=Color([j/255 for j in point_color]), label="Point Color", hide_box=True), mandel=checkbox(mandelbrot, label='Mandelbrot set')):
if mandel: return julia_helper(cx, cy, real_center, im_center, width, iterations, pixel_count, level_sep, color_num, image_color, pt_color).show()
else: return fast_julia_plot(cx, cy, real_center, im_center, width, iterations, pixel_count, level_sep, color_num, image_color).show()
else: image_width, max_iteration, pixel_count, iteration_level, number_of_colors, base_color, point_color)
else: image_width, max_iteration, pixel_count, iteration_level, number_of_colors, base_color) |