summaryrefslogtreecommitdiff
path: root/FSF-2020/calculus-of-several-variables/div-curl-grad-and-all-that/gradient/file1_missile-example.py
blob: cd754cdf496b4b875d248469555cb3dff4c8df00 (plain)
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
from manimlib.imports import *
import numpy as np


def function(coordinate):
	x,y = coordinate[:2]
	return np.array([
		np.sin(x-y),
		np.exp(y),
		0
	])
def func(coordinate):
	x,y = coordinate[:2]
	return np.array([
		-2*x,
		y,
		0])

class Missiles(GraphScene):
	def construct(self):

		field = VectorField(function)
		#path = ParametricFunction(lambda x: -2*x)

		dot = SVGMobject("miss").move_to(DL).scale(0.09).set_color(WHITE).rotate(PI/4 + PI)
		path = ArcBetweenPoints(dot.get_center(), UP+0.2*LEFT)

		self.play(FadeIn(field))
		self.wait()
		self.play(FadeIn(dot))
		self.wait()
		self.play(MoveAlongPath(dot, path))
		self.play(ApplyMethod(dot.rotate, PI/4), rate = 0.2)
		self.play(ApplyMethod(dot.move_to, 3.5*UP), rate = 0.3)
		#self.play(ApplyMethod(dot.move_to, 3.5*UP))
		#self.add_fixed_in_frame_mobjects(text_field)
		self.wait()