1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
from manimlib.imports import *
import numpy as np
def returnSum(k,x):
summ=0
for i in range(1,k+1,2):
summ+=((np.sin(2*np.pi*i*x))/i)
return summ
def returnFunc(self,k):
graph=self.get_graph(lambda x:(4/np.pi)*returnSum(k,x),color=WHITE,x_max=1,x_min=-1)
return graph
class fourierSeries(GraphScene,MovingCameraScene):
CONFIG = {
"x_min": -3,
"x_max": 3,
"x_axis_width": 13,
"y_min": -3,
"y_max": 3,
"graph_origin": ORIGIN,
"function_color": RED,
"axes_color": BLUE,
"x_axis_label": "$x$",
"y_axis_label": "$y$",
"exclude_zero_label": True,
"x_labeled_nums": range(-2, 3, 1),
}
def setup(self):
GraphScene.setup(self)
MovingCameraScene.setup(self)
def construct(self):
x_each_unit = self.x_axis_width / (self.x_max - self.x_min)
y_each_unit = self.y_axis_height / (self.y_max - self.y_min)
equation=TextMobject("$f(x)=\\frac { 4 }{ \pi } \sum _{ k=1,3,5.. }^{ \infty }{ \\frac { 1 }{ k } \sin { 2\pi kx } }$").shift(5*RIGHT+3*UP).set_color(RED).scale(0.5)
self.add(equation)
self.setup_axes(animate=True,scalee=1)
line1=Line(start=(-x_each_unit,y_each_unit,0),end=(-(1/2)*x_each_unit,y_each_unit,0),color=RED)
line2=Line(start=(-(1/2)*x_each_unit,y_each_unit,0),end=(-(1/2)*x_each_unit,-y_each_unit,0),color=RED)
line3=Line(start=(-(1/2)*x_each_unit,-y_each_unit,0),end=(0,-y_each_unit,0),color=RED)
line4=Line(start=(0,-y_each_unit,0),end=(0,y_each_unit,0),color=RED)
line5=Line(start=(0,y_each_unit,0),end=((1/2)*x_each_unit,y_each_unit,0),color=RED)
line6=Line(start=((1/2)*x_each_unit,y_each_unit,0),end=((1/2)*x_each_unit,-y_each_unit,0),color=RED)
line7=Line(start=((1/2)*x_each_unit,-y_each_unit,0),end=(x_each_unit,-y_each_unit,0),color=RED)
self.play(ShowCreation(line1))
self.play(ShowCreation(line2))
self.play(ShowCreation(line3))
self.play(ShowCreation(line4))
self.play(ShowCreation(line5))
self.play(ShowCreation(line6))
self.play(ShowCreation(line7))
self.wait(0.5)
labels=[
TextMobject("$f_{ k=1 }(x)$"),
TextMobject("$f_{ k=3 }(x)$"),
TextMobject("$f_{ k=5 }(x)$"),
TextMobject("$f_{ k=7 }(x)$"),
TextMobject("$f_{ k=9 }(x)$"),
TextMobject("$f_{ k=11 }(x)$"),
TextMobject("$f_{ k=13 }(x)$"),
TextMobject("$f_{ k=15 }(x)$"),
TextMobject("$f_{ k=17 }(x)$"),
TextMobject("$f_{ k=19 }(x)$"),
TextMobject("$f_{ k=85 }(x)$")
]
p=0
for i in range(1,20,2):
if(i==1):
graphInitial=returnFunc(self,1)
label=labels[p].scale(0.5).shift(y_each_unit*1.5*UP+RIGHT*x_each_unit*0.3)
self.play(ShowCreation(graphInitial),Write(labels[0]))
old=graphInitial
oldLabel=label
else:
graph=returnFunc(self,i)
graphLabel=labels[p].scale(0.5).shift(y_each_unit*1.5*UP+RIGHT*x_each_unit*0.3)
self.play(ReplacementTransform(old,graph),ReplacementTransform(oldLabel,graphLabel))
old=graph
oldLabel=graphLabel
p+=1
graphFinal=returnFunc(self,85)
labelFinal=labels[10].scale(0.5).shift(y_each_unit*1.5*UP+RIGHT*x_each_unit*0.3)
self.play(FadeOut(old),FadeOut(oldLabel))
self.play(ShowCreation(graphFinal),Write(labelFinal))
self.wait(1)
self.camera_frame.save_state()
self.play(self.camera_frame.set_width, 2.25,self.camera_frame.move_to, y_each_unit*UP+RIGHT*x_each_unit*0.3)
circleMark=Circle(radius=0.1,color=GREEN).shift(x_each_unit*RIGHT*0.47+UP*y_each_unit*1.1)
text=TextMobject("Gibbs","phenomenon").set_color_by_tex_to_color_map({"Gibbs":BLUE,"phenomenon":YELLOW}).scale(0.1).shift(RIGHT*x_each_unit*0.65+UP*y_each_unit*1.1)
self.wait(0.7)
self.play(ShowCreation(circleMark))
self.play(Write(text))
self.wait(0.5)
self.play(self.camera_frame.set_width,14,self.camera_frame.move_to,0,FadeOut(circleMark),FadeOut(text))
self.wait(2)
|