summaryrefslogtreecommitdiff
path: root/FSF-2020/approximations-and-optimizations
diff options
context:
space:
mode:
authorVaishnavi2020-05-26 12:16:41 +0530
committerGitHub2020-05-26 12:16:41 +0530
commitf4d67bbc33ae30992bf3b66ccdb4c8110ed8700b (patch)
treef59ce4ffcc21e690e490de40871b617fb225f132 /FSF-2020/approximations-and-optimizations
parent33f8da2e2df30ee550010d7186ce56821181fd59 (diff)
downloadFSF-mathematics-python-code-archive-f4d67bbc33ae30992bf3b66ccdb4c8110ed8700b.tar.gz
FSF-mathematics-python-code-archive-f4d67bbc33ae30992bf3b66ccdb4c8110ed8700b.tar.bz2
FSF-mathematics-python-code-archive-f4d67bbc33ae30992bf3b66ccdb4c8110ed8700b.zip
Create file 2_Tangent plane at extrema of a function.py
Diffstat (limited to 'FSF-2020/approximations-and-optimizations')
-rw-r--r--FSF-2020/approximations-and-optimizations/Critical-Points/file 2_Tangent plane at extrema of a function.py55
1 files changed, 55 insertions, 0 deletions
diff --git a/FSF-2020/approximations-and-optimizations/Critical-Points/file 2_Tangent plane at extrema of a function.py b/FSF-2020/approximations-and-optimizations/Critical-Points/file 2_Tangent plane at extrema of a function.py
new file mode 100644
index 0000000..6889a52
--- /dev/null
+++ b/FSF-2020/approximations-and-optimizations/Critical-Points/file 2_Tangent plane at extrema of a function.py
@@ -0,0 +1,55 @@
+from manimlib.imports import*
+
+class TheoremAnimation(ThreeDScene):
+ def construct(self):
+
+ axes = ThreeDAxes()
+
+ #----parabola: x**2+y**2
+ parabola1 = ParametricSurface(
+ lambda u, v: np.array([
+ u,
+ v,
+ u**2+v**2
+ ]),v_min=-1,v_max=1,u_min=-1,u_max=1,checkerboard_colors=[TEAL_E],
+ resolution=(20, 20)).scale(1)
+
+ #----parabola: -x**2-y**2
+ parabola2 = ParametricSurface(
+ lambda u, v: np.array([
+ u,
+ v,
+ -u**2-v**2
+ ]),v_min=-1,v_max=1,u_min=-1,u_max=1,checkerboard_colors=[PURPLE_E,PURPLE_E],
+ resolution=(20, 20)).scale(1)
+
+ self.set_camera_orientation(phi=75 * DEGREES)
+ self.begin_ambient_camera_rotation(rate=0.4)
+
+ d = Dot(np.array([0,0,0]), color = '#800000') #---- critical point
+ r = Rectangle(fill_color= '#C0C0C0',fill_opacity =0.3).move_to(ORIGIN) #----tangent plane
+
+ parabola1_text = TextMobject("Maximum with horizontal tangent plane").scale(0.7).to_corner(UL)
+
+ parabola2_text = TextMobject("Minimum with horizontal tangent plane").scale(0.7).to_corner(UL)
+
+ self.add(axes)
+ self.add_fixed_in_frame_mobjects(parabola2_text)
+ self.wait(1)
+ self.play(Write(parabola1))
+ self.wait(1)
+ self.play(ShowCreation(d))
+ self.wait(1)
+ self.play(ShowCreation(r))
+ self.wait(2)
+ self.play(FadeOut(parabola2_text),FadeOut(parabola1),FadeOut(r),FadeOut(d))
+
+ self.wait(1)
+ self.add_fixed_in_frame_mobjects(parabola1_text)
+ self.wait(1)
+ self.play(Write(parabola2))
+ self.wait(1)
+ self.play(ShowCreation(d))
+ self.wait(1)
+ self.play(ShowCreation(r))
+ self.wait(2)