Hello!
Another essay. This time let's play with complex numbers, with formulas and their visualization.
data:image/s3,"s3://crabby-images/56662/5666280a49f115ee7d3c9777769a06c3c0275c9f" alt=""
Idea
A complex number is a certain extension of a real number, in fact a vector for which a whole set of axioms is defined. Any complex (and hence real) number can be written as
, where a is the real part, b is the imaginary part, i is the root of the equation
. For him, many operations are defined that are defined for a real number, for example,
. Interestingly, if you do various operations with them, raise to a power, multiply, etc., and then take
(real part) for the axis Ox, and
(imaginary part) for the Oy axis, you can get funny pictures.
By the way, I myself came up with all the following formulas.
Visualization function
Routine. The function, which according to this iterative function draws everything on the field:
import random import numpy as np def vis(A, f, step=1.0, c=None): x = [] y = [] for B in np.arange(0, A, step): v = f(A, B) x.append(v.real) y.append(v.imag) plt.figure(figsize=[8, 8]) mxabs = max([i[0] ** 2 + i[1] ** 2 for i in zip(x, y)]) ** 0.5 x = np.array(x) / mxabs y = np.array(y) / mxabs if c is None: plt.scatter(x, y) else: plt.scatter(x, y, color=[c(x[i], y[i]) for i in range(len(x))]) plt.show()
All our functions depend on two parameters A and B. Moreover, we iterate over B inside vis (), and A is the global parameter of the function.
The Curl Function
Her declaration in python:
def func_1(A, B): return math.sin(B) * B * math.e ** (1j * (B * math.cos(A)))
And run
A = 121.5 vis(A, func_1, step=0.1)
And the result for A = 121.5:
data:image/s3,"s3://crabby-images/88a4a/88a4af2a665fa01fcbd34065a150c929c9044ee1" alt=""
And for A = 221.5:
data:image/s3,"s3://crabby-images/f4fa1/f4fa12603071cdc7abf2151fa5586b72312af085" alt=""
Note that these numbers do not follow from the calculation of any definite integral on a smooth manifold and other smart words meaningless in this context. These are really random numbers, and there is still exactly infinity of different A, as a result of which beauty is obtained.
Need to paint
We declare a color function (such a function that returns a tuple of three numbers in coordinates):
def sigm(x):
Choose random parameter A, let it be 149:
vis(149, func_1, step=0.1, c=color_1)
data:image/s3,"s3://crabby-images/359ea/359eab1f2c4f0eb71d16ef47a6d47d8a59c6daf1" alt=""
Geese Function
Geese are described as follows:
Python declaration:
def func_2(A, B): return math.cos(B) * math.sin(B) * B * math.e ** (1j * (B * math.cos(A)))
Its result for A = 106:
data:image/s3,"s3://crabby-images/98686/986860c08c27ee7408c54f205c2272692f9cf546" alt=""
Focaccia function
def func_3(A, B): return math.cos((A + 1) * B) * math.e ** (1j * (B * math.cos(A)))
vis(246, func_3, step=0.1, c=color_2)
data:image/s3,"s3://crabby-images/bd975/bd9753dc06b74323bcff4f5bd0a10e3f26de0559" alt=""
vis(246, func_3, step=0.1, c=color_2)
data:image/s3,"s3://crabby-images/b08a4/b08a47bb8c7e0de34fdb3e839811079e0c3243e2" alt=""
Untitled Function
color_3 = lambda x, y: (0.5, 0.5, sigm(x ** 2 + y ** 2)) vis(162, func_4, step=0.1, c=color_3)
data:image/s3,"s3://crabby-images/62379/623792e620c145a42fbf17e5cba1be41bec97be5" alt=""
vis(179, func_4, step=0.1, c=color_3)
data:image/s3,"s3://crabby-images/e42be/e42be99797988473d9f9ef8579f7f6f9ecf9848c" alt=""
Beauty formula
def func_5(A, B): return math.cos((A + 1) * B) ** 1.5 * math.e ** (1j * (B * math.cos(A)))
color_4 = lambda x, y: (sigm(x ** 2 + y ** 2) / 2, 0.5, 1 - sigm(x ** 2 + y ** 2)) vis(345, func_5, step=0.1, c=color_4)
data:image/s3,"s3://crabby-images/83965/839659d43b62d8b191492e6e00244c8aea35de0e" alt=""
vis(350, func_5, step=0.1, c=color_4)
data:image/s3,"s3://crabby-images/8ef8a/8ef8a74206c5411a207586b7829641a283590584" alt=""
That's all for now.
Whole code import numpy as np import random import matplotlib.pyplot as plt import math def vis(A, f, step=1.0, c=None): x = [] y = [] for B in np.arange(0, A, step): v = f(A, B) x.append(v.real) y.append(v.imag) plt.figure(figsize=[7, 7]) mxabs = max([i[0] ** 2 + i[1] ** 2 for i in zip(x, y)]) ** 0.5 x = np.array(x) / mxabs y = np.array(y) / mxabs if c is None: plt.scatter(x, y) else: plt.scatter(x, y, color=[c(x[i], y[i]) for i in range(len(x))]) plt.show() def func_1(A, B): return math.sin(B) * B * math.e ** (1j * (B * math.cos(A))) def func_2(A, B): return math.cos(B) * math.sin(B) * B * math.e ** (1j * (B * math.cos(A))) def func_3(A, B): return math.cos((A + 1) * B) * math.e ** (1j * (B * math.cos(A))) def func_4(A, B): return math.sin(A + B) * B * math.e ** (1j * B * math.sin(A)) def func_5(A, B): return math.cos((A + 1) * B) ** 1.5 * math.e ** (1j * (B * math.cos(A))) def sigm(x): return (1 / (1 + 1.2 ** (-x*50)) - 0.5) * 2 color_1 = lambda x, y: (0.2, sigm(x ** 2 + y ** 2) / 1.4, 1 - sigm(x ** 2 + y ** 2)) color_2 = lambda x, y: (sigm(x ** 2 + y ** 2), 0.5, 0.5) color_3 = lambda x, y: (0.5, 0.5, sigm(x ** 2 + y ** 2)) color_4 = lambda x, y: (sigm(x ** 2 + y ** 2) / 2, 0.5, 1 - sigm(x ** 2 + y ** 2)) colors = [color_1, color_2, color_3, color_4] funcs = [func_1, func_2, func_3, func_4, func_5] while True: col = random.choice(colors) func = random.choice(funcs) vis(random.random() * 200 + 100, func, step=0.1, c=col) if input() == "exit": break