我用Python编程实现了Mandelbrot集,但效果很奇怪,所以我寻找了平滑颜色的方法。我编写了一个使用对数和线性插值的平滑着色函数,但无论我尝试什么都达不到想要的效果。
self.palette = [(3, 25, 61),(5, 43, 107),(7, 61, 153),(20, 96, 226),(20, 164, 226),(74, 181, 226),(138, 211, 242),(205, 234, 247),(225, 237, 242),(255,255,255)]
这是我的调色板
if n == self.max_iterations:
self.screen.set_at((x, y), (110, 13, 13))
else:
gradient = 1 + n - math.log(math.log(abs(m))) / math.log(2.0)
iteration = n + 1 - gradient
color1 = list(self.palette[n % 10])
if n % 10 <= 8:
color2 = list(self.palette[n % 10+1])
else:
color2 = list(self.palette[-1])
color = [[], [], []]
for number, elt in enumerate(color):
color[number] = color1[number] + (iteration % 1)*(color2[number]-color1[number])
self.screen.set_at((x, y), tuple(color))
这是我的着色函数:
这是我得到的结果:
如您所见,颜色是平滑的,但方式不对,颜色之间没有连续性。
我希望得到像这样的结果:
理想的结果:
我们看不到颜色间隙。