Champagne Portraits of Complex Functions
Lots of tiny bubbles.
Contents
Domain
The basic domain is the quadruple unit square,
$$\max{(|x|,|y|)} \le 1, \ z = x+iy $$
Colors
I could use the HSV colormap.
hsv_bubbles(@(z) z)
data:image/s3,"s3://crabby-images/5034a/5034a0154c9b2d2683809c8b8040a9b405c0d916" alt=""
But I prefer "periodic parula", the parula colormap concatenated with its reverse, [parula; flipud(parula)].
bubbles(@(z) z)
data:image/s3,"s3://crabby-images/3c1e4/3c1e47f658e9ab3b85a486d5a61fec8dfee37955" alt=""
Powers
z^2
bubbles(@(z) z.^2)
data:image/s3,"s3://crabby-images/93a80/93a80ae39d1118b9603f46bb01b4380502ba270a" alt=""
z^3
bubbles(@(z) z.^3)
data:image/s3,"s3://crabby-images/f08c3/f08c3a61557f53daa037606065ee74f9a536e1a3" alt=""
z^9
bubbles(@(z) z.^9)
data:image/s3,"s3://crabby-images/7fcbc/7fcbc9471d4bf2eb3410097243db58f7e3ba38dd" alt=""
1/z
bubbles(@(z) 1./z)
data:image/s3,"s3://crabby-images/e7aff/e7aff21c1b8d4fed04e37d8484b3dd3a7887594f" alt=""
sqrt(z)
A complex number has two square roots. One is in the right half plane.
bubbles(@sqrt)
data:image/s3,"s3://crabby-images/96eda/96eda72c86c6c1cbdcbdbd27be03de7e41e38ef4" alt=""
-sqrt(z)
And the other is in the left half plane.
bubbles(@(z) -sqrt(z))
data:image/s3,"s3://crabby-images/9062e/9062e657757dbfc7fadc10e2c8951f310a4518cb" alt=""
Trig functions
sin(z)
bubbles(@sin)
data:image/s3,"s3://crabby-images/d938b/d938b9bf82df32173cdf33dcb3e5613963b0ca02" alt=""
cos(z)
bubbles(@cos)
data:image/s3,"s3://crabby-images/29df0/29df0d0bb177927ef2568d3b7c0916d976e13986" alt=""
tan(z)
bubbles(@tan)
data:image/s3,"s3://crabby-images/19632/1963217db3f21f10d2de61d0ceeb7f9b1d8d5d3a" alt=""
cot(z)
bubbles(@cot)
data:image/s3,"s3://crabby-images/7dd0e/7dd0ee88d6dee74ed80056a2c0db5ce371cd772e" alt=""
Exponentials
exp(z)
These polar angles are between -1 and +1 radian.
bubbles(@exp)
data:image/s3,"s3://crabby-images/fb00e/fb00e282fb79bd661be92d4ed17373e7d0383640" alt=""
exp(pi*z)/exp(pi)
These fill out the entire complex plane.
bubbles(@(z) exp(pi*z)/exp(pi))
data:image/s3,"s3://crabby-images/34609/34609c34f1f348f94a07d6e340bfda79719c6c36" alt=""
log(z)
bubbles(@log)
data:image/s3,"s3://crabby-images/d3a80/d3a80f00bf6dacbaa8123bcb580c5bc711771a0c" alt=""
Polynomials and rationals
z^3 - z
bubbles(@(z) z.^3-z)
data:image/s3,"s3://crabby-images/c64e5/c64e5197e5ea34b2ae064d86bfb7f0f36662d0a9" alt=""
.5/(z^5-z/5)
bubbles(@(z) .5./(z.^5-z/5))
data:image/s3,"s3://crabby-images/06080/06080407defaea7fa02b88e4aa44a66b11cbeeaa" alt=""
Essential singularity.
exp(-1/(8 z^2)
bubbles(@(z) exp(-1./(8*z.^2)))
data:image/s3,"s3://crabby-images/bedef/bedefcb6184063de91b80245407a44dc02e8b152" alt=""
Quiz
What is happening in the animation at the top of this post? If you think you know, or even if you just know part of the answer, submit a comment. I'll have some sort of prize for the first, or best, solution.
Code
Also available at https://blogs.mathworks.com/cleve/files/bubbles.m.
type bubbles
function bubbles(F) % bubbles. Color portrait of complex-valued function F(z), % ex. bubbles(@sin) % bubbles(@(z) .5./(z.^5-z/5) ) if nargin < 1 F = @(z)z; end axis(1.5*[-1 1 -1 1]) axis square box on cla m = 256; colormap = [parula(m);flipud(parula(m))]; n = 25; s = -1:2/(n-1):1; [x,y] = meshgrid(s); z = x + y*1i; circle = exp((0:32)/16*pi*1i)/n; w = F(z); r = abs(w); theta = angle(w)+pi; scale = 20; for k = 1:n for j = 1:n t = m*theta(k,j)/pi/scale; idx = ceil(scale*t+realmin); color = colormap(idx,:); p = w(k,j) + r(k,j)*circle; patch(real(p),imag(p),color) end end titleF = char(F); if (titleF(1) == '@') titleF(1:4) = []; end title(titleF) snapnow end
댓글
댓글을 남기려면 링크 를 클릭하여 MathWorks 계정에 로그인하거나 계정을 새로 만드십시오.