summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--FSF-2020/calculus-of-several-variables/integrals-of-multivariable-functions/line-integrals/unfinished_vector_line_integral.py359
1 files changed, 82 insertions, 277 deletions
diff --git a/FSF-2020/calculus-of-several-variables/integrals-of-multivariable-functions/line-integrals/unfinished_vector_line_integral.py b/FSF-2020/calculus-of-several-variables/integrals-of-multivariable-functions/line-integrals/unfinished_vector_line_integral.py
index 2a6467d..17febce 100644
--- a/FSF-2020/calculus-of-several-variables/integrals-of-multivariable-functions/line-integrals/unfinished_vector_line_integral.py
+++ b/FSF-2020/calculus-of-several-variables/integrals-of-multivariable-functions/line-integrals/unfinished_vector_line_integral.py
@@ -1,42 +1,25 @@
from manimlib.imports import *
-class LineIntegrationProcess(SpecialThreeDScene):
+class LineIntegrationProcess(GraphScene):
CONFIG = {
- "axes_config": {
- "x_min": 0,
- "x_max": 4,
- "y_min": 0,
- "y_max": 4,
- "z_min": 0,
- "z_max": 3,
- "a":-3 ,"b": 3, "c":0 , "d":3,
- "axes_shift":IN+2*DL,
- "x_axis_config": {
- "tick_frequency": 1,
- # "include_tip": False,
- },
- "y_axis_config": {
- "tick_frequency": 1,
- # "include_tip": False,
- },
- "z_axis_config": {
- "tick_frequency": 1,
- # "include_tip": False,
- },
- "num_axis_pieces": 20,
- },
+ "x_min" : -0,
+ "x_max" : 1,
+ "y_min" : -0,
+ "y_max" : 1,
+ "axes_color":WHITE,
+ "graph_origin": ORIGIN+5*LEFT+3*DOWN,
+ "x_axis_width": 5,
+ "y_axis_height": 5,
+ "x_tick_frequency": 1,
+ "y_tick_frequency": 1,
"default_vector_field_config": {
"delta_x": .5,
"delta_y": .5,
- "x_min": -3,
- "x_max": 2,
- "y_min": -3,
- "y_max": 2,
"min_magnitude": 0,
- "max_magnitude": 4,
+ "max_magnitude": 15,
"colors": [GREEN,YELLOW,RED],
- "length_func": lambda norm : .4*sigmoid(norm),
+ "length_func": lambda norm : .45*sigmoid(norm),
"opacity": 1.0,
"vector_config": {
"stroke_width":2
@@ -46,21 +29,16 @@ class LineIntegrationProcess(SpecialThreeDScene):
"stroke_width": 2,
"stroke_color": WHITE,
},
-
- "Func": lambda x,y: 1+x**2*y/15
}
def construct(self):
-
- self.setup_axes()
- axes=self.axes
-
- self.set_camera_orientation(distance=10,
- phi=0 * DEGREES,
- theta=-90 * DEGREES,
- )
+ X = RIGHT*self.x_axis_width/(self.x_max- self.x_min)
+ Y = UP*self.y_axis_height/(self.y_max- self.y_min)
+ self.X=X ;self.Y=Y
+ self.setup_axes(animate=False)
+
fn_text=TexMobject(
r"\vec F = x^2\hat i-xy\hat j"
).set_color_by_gradient(
@@ -68,42 +46,28 @@ class LineIntegrationProcess(SpecialThreeDScene):
)
fn_text.to_corner(UR,buff=.8).shift(DOWN)
- origin=axes.c2p(0,0,0)
+ origin=self.graph_origin
v_field=self.get_vector_field(
lambda v: np.array([
(v[0]-origin[0])**2,
-(v[0]-origin[0])*(v[1]-origin[1]),
0,
]),
+ x_min= 0+origin[0],
+ x_max= 5+origin[0],
+ y_min= -0+origin[1],
+ y_max= 5+origin[1],
)
- # self.play(Write(surface))
- self.add_fixed_in_frame_mobjects(fn_text)
+ # self.play(Write(surface))
# self.play(Write(v_field),Write(fn_text))
self.add(v_field, fn_text)
self.get_line_of_int()
- # self.begin_ambient_camera_rotation(rate=0.04)
self.get_dot_product_values()
- '''self.get_dot_prod_values_on_line()
+ '''self.get_field_values_on_line()
self.wait(1.5)
- self.area=self.get_area()
- area_text=TextMobject("Line"," Integral in the",r" scalar field\\"," means this" ,"area")
- area_text.set_color_by_tex_to_color_map({
- "Line": PINK, "scalar":BLUE, "area":TEAL_A
- })
- area_text.to_edge(TOP,buff=MED_SMALL_BUFF)
-
- self.remove(self.values_on_line_text)
- self.add_fixed_in_frame_mobjects(area_text)
- self.play(Write(area_text))
- self.play(Write(self.area),run_time=2)
- self.play(FadeOut(VGroup(surface,fn_text)))
- self.wait()
-
- self.stop_ambient_camera_rotation()
- # self.get_lines()
- self.remove(axes,surface)
+ self.remove(surface)
self.trasform_to_graphs()'''
self.wait(2)
@@ -123,19 +87,20 @@ class LineIntegrationProcess(SpecialThreeDScene):
line_of_int_text.to_edge(TOP,buff=SMALL_BUFF)
- line_of_int=(self.get_curve(
- self.Func,on_surface=False
- ))
+ line_of_int= self.get_graph(
+ lambda x : np.sqrt(1-x**2),
+ x_min=1,
+ x_max=0,
+ )
line_of_int.set_style(
stroke_width=5,
- stroke_color=PINK,
+ stroke_color=BLUE,
)
- self.add_fixed_in_frame_mobjects(line_of_int_text)
# self.play(Write(line_of_int_text))
self.wait(.5)
- self.play(ShowCreation(line_of_int),run_time=1.5)
- # self.add(line_of_int)
+ # self.play(ShowCreation(line_of_int),run_time=1.5)
+ self.add(line_of_int)
self.line_of_int=line_of_int
self.line_of_int_text=line_of_int_text
@@ -143,7 +108,7 @@ class LineIntegrationProcess(SpecialThreeDScene):
def get_dot_product_values(self):
self.get_vector_and_tangent()
self.play(ApplyMethod(
- t_tracker.set_value, PI/2,
+ self.t_tracker.set_value, PI/2,
rate_func=linear,
run_time=.5,
)
@@ -175,7 +140,7 @@ class LineIntegrationProcess(SpecialThreeDScene):
)
vect = Vector().rotate(angle,about_point=coord)
vect.set_color("#DC75CD")
- tangent=vect.next_to(x,DR,buff=0)
+ tangent=vect.next_to(coord,DR,buff=0)
tangent_sym.next_to(tangent,DOWN,buff=.1)
self.play(Write(VGroup(tangent,tangent_sym)))
@@ -198,34 +163,29 @@ class LineIntegrationProcess(SpecialThreeDScene):
))
self.dot_sym=dot_sym
-
- """def get_dot_prod_values_on_line(self):
- self.remove(self.line_of_int_text)
-
- values_on_line_text=TextMobject("Values"," of"," function","on the ","line")
- values_on_line_text.set_color_by_tex_to_color_map({
- "Values":YELLOW, "function":BLUE,"line":PINK
+
+
+
+ def get_curve(self,func,on_surface=False ,**kwargs):
+ config = dict()
+ config.update(self.default_graph_style)
+ config.update({
+ "t_min": 0,
+ "t_max": PI/2,
})
- values_on_line_text.to_edge(TOP,buff=SMALL_BUFF)
-
- values_on_surface=(self.get_curve(
- self.Func,on_surface=True
- ))
- values_on_surface.set_style(
- stroke_width=5,
- stroke_color=YELLOW,
- )
-
- self.add_fixed_in_frame_mobjects(values_on_line_text)
- self.play(Write(values_on_line_text))
- # self.wait()
- self.play(ShowCreation(values_on_surface),run_time=3)
- # self.add(values_on_surface)
-
- self.values_on_surface=values_on_surface
- self.values_on_line_text=values_on_line_text"""
+ config.update(kwargs)
+ r=1
+ curve=ParametricFunction(
+ lambda t: self.coords_to_point(
+ r*np.cos(t),
+ r*np.sin(t),
+ ),
+ **config,
+ )
+ return curve
-
+
+ #-------------------------------------------------------
def trasform_to_graphs(self):
on_surface_graph=(self.get_graph(
self.Func,on_surface=True
@@ -268,8 +228,7 @@ class LineIntegrationProcess(SpecialThreeDScene):
theta=-90 * DEGREES,
added_anims=into_graph,
run_time=2
- )
-
+ )
def get_area(self,graph=False):
axes=self.axes
if graph:
@@ -293,188 +252,34 @@ class LineIntegrationProcess(SpecialThreeDScene):
)
return area
-
- def get_curve(self,func,on_surface=False ,**kwargs):
- config = dict()
- config.update(self.default_graph_style)
- config.update({
- "t_min": 0,
- "t_max": PI/2,
- })
- config.update(kwargs)
- r=abs(self.axes.a)
- curve=ParametricFunction(
- lambda t: self.axes.c2p(
- r*np.cos(t),
- r*np.sin(t),
- func(r*np.cos(t), r*np.sin(t))*bool(on_surface)
- ),
- **config,
- )
- return curve
-
- def get_surface(self, func, **kwargs):
- axes=self.axes
- config = {
- "u_min": axes.a-.2,
- "u_max": axes.b+.2,
- "v_min": axes.c-.1,
- "v_max": axes.d,
- "resolution": (
- 2*(axes.y_max - axes.y_min) // axes.y_axis.tick_frequency,
- (axes.x_max - axes.x_min) // axes.x_axis.tick_frequency,
- ),
- }
-
- config.update(self.default_surface_config)
- config.update(kwargs)
- return ParametricSurface(
- lambda x,y : axes.c2p(
- x, y, func(x, y)
- ),
- **config
- )
-
- def get_graph(self,func,on_surface=False ,**kwargs):
- config = dict()
- config.update(self.default_graph_style)
- config.update({
- "t_min": 0,
- "t_max": PI,
+ def get_field_values_on_line(self):
+ self.remove(self.line_of_int_text)
+
+ values_on_line_text=TextMobject("Values"," of"," function","on the ","line")
+ values_on_line_text.set_color_by_tex_to_color_map({
+ "Values":YELLOW, "function":BLUE,"line":PINK
})
- config.update(kwargs)
- slice_curve=ParametricFunction(
- lambda t: self.axes.c2p(
- 4*np.cos(t),
- 0,
- 2+func(3*np.cos(t), 3*np.sin(t))*bool(on_surface)
- ),
- **config,
- )
- return slice_curve
-
- def get_lines(self):
- pass
- axes = self.axes
- labels=[axes.x_axis.n2p(axes.a), axes.x_axis.n2p(axes.b), axes.y_axis.n2p(axes.c),
- axes.y_axis.n2p(axes.d)]
-
-
- surface_corners=[]
- for x,y,z in self.region_corners:
- surface_corners.append([x,y,self.Func(x,y)])
-
- lines=VGroup()
- for start , end in zip(surface_corners,
- self.region_corners):
- lines.add(self.draw_lines(start,end,"PINK"))
-
- for start , end in zip(labels,
- self.region_corners):
- # lines.add(self.draw_lines(start,end,"BLUE"))
- # print (start,end)
- pass
- # self.play(ShowCreation(lines))
- self.add(lines)
-
-
- def draw_lines(self,start,end,color):
- start=self.axes.c2p(*start)
- end=self.axes.c2p(*end)
- line=DashedLine(start,end,color=color)
-
- return line
-
-#-------------------------------------------------------
- #customize 3D axes
- def get_three_d_axes(self, include_labels=True, include_numbers=True, **kwargs):
- config = dict(self.axes_config)
- config.update(kwargs)
- axes = ThreeDAxes(**config)
- axes.set_stroke(width=2)
- self.axes=axes
-
- if include_numbers:
- self.add_axes_numbers(axes)
-
- if include_labels:
- self.add_axes_labels(axes)
-
- # Adjust axis orientation
- '''axes.x_axis.rotate(
- -90 * DEGREES, LEFT,
- about_point=axes.c2p(0, 0, 0),
- )
- axes.y_axis.rotate(
- 90 * DEGREES, UP,
- about_point=axes.c2p(0, 0, 0),
- )'''
-
- return axes
-
+ values_on_line_text.to_edge(TOP,buff=SMALL_BUFF)
- def setup_axes(self):
- axes = self.get_three_d_axes(include_labels=True)
- axes.scale(1)
- # axes.center()
- axes.shift(axes.axes_shift)
-
- self.add(axes)
- self.axes = axes
+ values_on_surface=(self.get_curve(
+ self.Func,on_surface=True
+ ))
+ values_on_surface.set_style(
+ stroke_width=5,
+ stroke_color=YELLOW,
+ )
- def add_axes_numbers(self, axes):
- x_axis = axes.x_axis
- y_axis = axes.y_axis
- tex_vals_x = [
-
- ("1", axes.b),
- ]
- tex_vals_y=[
-
- ("1", axes.d)
- ]
- x_labels = VGroup()
- y_labels = VGroup()
- for tex, val in tex_vals_x:
- label = TexMobject(tex)
- label.scale(1)
- label.next_to(x_axis.n2p(val), DOWN)
- # label.rotate(180 * DEGREES)
- x_labels.add(label)
- x_axis.add(x_labels)
- x_axis.numbers = x_labels
-
- for tex, val in tex_vals_y:
- label = TexMobject(tex)
- label.scale(1)
- label.next_to(y_axis.n2p(val), LEFT)
- label.rotate(90 * DEGREES)
- y_labels.add(label)
-
- y_axis.add(y_labels)
- y_axis.numbers = y_labels
+ self.add_fixed_in_frame_mobjects(values_on_line_text)
+ self.play(Write(values_on_line_text))
+ # self.wait()
+ self.play(ShowCreation(values_on_surface),run_time=3)
+ # self.add(values_on_surface)
- return axes
+ self.values_on_surface=values_on_surface
+ self.values_on_line_text=values_on_line_text
+
+
- def add_axes_labels(self, axes):
- x_label = TexMobject("x")
- x_label.next_to(axes.x_axis.get_end(), RIGHT)
- axes.x_axis.label = x_label
-
- y_label = TextMobject("y")
- y_label.rotate(90 * DEGREES, OUT)
- y_label.next_to(axes.y_axis.get_end(), UP)
- axes.y_axis.label = y_label
-
- z_label = TexMobject("")
- z_label.rotate(90 * DEGREES, RIGHT)
- z_label.next_to(axes.z_axis.get_zenith(), LEFT)
- axes.z_axis.label = z_label
- for axis in axes:
- axis.add(axis.label)
- return axes
-
-
-
+
#uploaded by Somnath Pandit.FSF2020_Line_Integrals