.. DO NOT EDIT. .. THIS FILE WAS AUTOMATICALLY GENERATED BY SPHINX-GALLERY. .. TO MAKE CHANGES, EDIT THE SOURCE PYTHON FILE: .. "auto_examples/04_demos/viz_animated_surfaces.py" .. LINE NUMBERS ARE GIVEN BELOW. .. only:: html .. note:: :class: sphx-glr-download-link-note :ref:`Go to the end ` to download the full example code .. rst-class:: sphx-glr-example-title .. _sphx_glr_auto_examples_04_demos_viz_animated_surfaces.py: =============================================== Animated 2D functions =============================================== This is a simple demonstration of how one can animate 2D functions using FURY. .. GENERATED FROM PYTHON SOURCE LINES 11-12 Importing necessary modules .. GENERATED FROM PYTHON SOURCE LINES 12-18 .. code-block:: Python import itertools import numpy as np import fury .. GENERATED FROM PYTHON SOURCE LINES 19-24 The following function is used to create and update the coordinates of the points which are being used to plot the surface. It's also used to create and update the colormap being used to color the surface. Kindly note that only the z coordinate is being modified with time as only the z coordinate is a function of time. .. GENERATED FROM PYTHON SOURCE LINES 24-40 .. code-block:: Python def update_surface(x, y, equation, cmap_name="viridis"): # z is the function F i.e. F(x, y, t) z = eval(equation) xyz = np.vstack([x, y, z]).T # creating the colormap v = np.copy(z) m_v = np.max(np.abs(v), axis=0) v /= m_v if m_v else 1 colors = fury.colormap.create_colormap(v, name=cmap_name) return xyz, colors .. GENERATED FROM PYTHON SOURCE LINES 41-66 Variables and their usage: time: float initial value of the time variable i.e. value of the time variable at the beginning of the program; (default = 0) dt: float amount by which ``time`` variable is incremented for every iteration of timer_callback function (default = 0.1) lower_xbound: float lower bound of the x values in which the function is plotted (default = -1) upper_xbound: float Upper bound of the x values in which the function is plotted (default = 1) lower_ybound: float lower bound of the y values in which the function is plotted (default = -1) upper_ybound: float Upper bound of the y values in which the function is plotted (default = 1) npoints: int For high quality rendering, keep the number high but kindly note that higher values for npoints slows down the animation (default = 128) .. GENERATED FROM PYTHON SOURCE LINES 66-75 .. code-block:: Python time = 0 dt = 0.1 lower_xbound = -1 upper_xbound = 1 lower_ybound = -1 upper_ybound = 1 npoints = 128 .. GENERATED FROM PYTHON SOURCE LINES 76-78 creating the x, y points which will be used to fit the equation to get elevation and generate the surface .. GENERATED FROM PYTHON SOURCE LINES 78-84 .. code-block:: Python x = np.linspace(lower_xbound, upper_xbound, npoints) y = np.linspace(lower_ybound, upper_ybound, npoints) x, y = np.meshgrid(x, y) x = x.reshape(-1) y = y.reshape(-1) .. GENERATED FROM PYTHON SOURCE LINES 85-86 Function used to create surface obtained from 2D equation. .. GENERATED FROM PYTHON SOURCE LINES 86-101 .. code-block:: Python def create_surface(x, y, equation, colormap_name): xyz, colors = update_surface(x, y, equation=equation, cmap_name=colormap_name) surf = fury.actor.surface(xyz, colors=colors) surf.equation = equation surf.cmap_name = colormap_name surf.vertices = fury.utils.vertices_from_actor(surf) surf.no_vertices_per_point = len(surf.vertices) / npoints**2 surf.initial_vertices = surf.vertices.copy() - np.repeat( xyz, surf.no_vertices_per_point, axis=0 ) return surf .. GENERATED FROM PYTHON SOURCE LINES 102-103 Equations to be plotted .. GENERATED FROM PYTHON SOURCE LINES 103-111 .. code-block:: Python eq1 = "np.abs(np.sin(x*2*np.pi*np.cos(time/2)))**1*np.cos(time/2)*\ np.abs(np.cos(y*2*np.pi*np.sin(time/2)))**1*np.sin(time/2)*1.2" eq2 = "((x**2 - y**2)/(x**2 + y**2))**(2)*np.cos(6*np.pi*x*y-1.8*time)*0.24" eq3 = "(np.sin(np.pi*2*x-np.sin(1.8*time))*np.cos(np.pi*2*y+np.cos(1.8*time)))\ *0.48" eq4 = "np.cos(24*np.sqrt(x**2 + y**2) - 2*time)*0.18" equations = [eq1, eq2, eq3, eq4] .. GENERATED FROM PYTHON SOURCE LINES 112-113 List of colormaps to be used for the various functions. .. GENERATED FROM PYTHON SOURCE LINES 113-115 .. code-block:: Python cmap_names = ["hot", "plasma", "viridis", "ocean"] .. GENERATED FROM PYTHON SOURCE LINES 116-117 Creating a list of surfaces. .. GENERATED FROM PYTHON SOURCE LINES 117-124 .. code-block:: Python surfaces = [] for i in range(4): surfaces.append( create_surface(x, y, equation=equations[i], colormap_name=cmap_names[i]) ) .. GENERATED FROM PYTHON SOURCE LINES 125-126 Creating a scene object and configuring the camera's position .. GENERATED FROM PYTHON SOURCE LINES 126-133 .. code-block:: Python scene = fury.window.Scene() scene.set_camera( position=(4.45, -21, 12), focal_point=(4.45, 0.0, 0.0), view_up=(0.0, 0.0, 1.0) ) showm = fury.window.ShowManager(scene, size=(600, 600)) .. rst-class:: sphx-glr-script-out .. code-block:: none /opt/homebrew/Caskroom/miniforge/base/envs/py39/lib/python3.9/site-packages/sphinx_gallery/gen_rst.py:722: UserWarning: We'll no longer accept the way you call the __init__ function in future versions of FURY. Here's how to call the Function __init__: __init__(self_value, scene='value', title='value', size='value', png_magnify='value', reset_camera='value', order_transparent='value', interactor_style='value', stereo='value', multi_samples='value', max_peels='value', occlusion_ratio='value') exec(self.code, self.fake_main.__dict__) .. GENERATED FROM PYTHON SOURCE LINES 134-135 Creating a grid to interact with surfaces individually. .. GENERATED FROM PYTHON SOURCE LINES 135-159 .. code-block:: Python # To store the function names text = [] for i in range(4): t_actor = fury.actor.vector_text( "Function " + str(i + 1), pos=(0, 0, 0), scale=(0.17, 0.2, 0.2) ) text.append(t_actor) grid_ui = fury.ui.GridUI( actors=surfaces, captions=text, caption_offset=(-0.7, -2.5, 0), dim=(1, 4), cell_padding=2, aspect_ratio=1, rotation_axis=(0, 1, 0), ) showm.scene.add(grid_ui) # Adding an axes actor to the first surface. showm.scene.add(fury.actor.axes()) .. rst-class:: sphx-glr-script-out .. code-block:: none /opt/homebrew/Caskroom/miniforge/base/envs/py39/lib/python3.9/site-packages/sphinx_gallery/gen_rst.py:722: UserWarning: We'll no longer accept the way you call the vector_text function in future versions of FURY. Here's how to call the Function vector_text: vector_text(text='value', pos='value', scale='value', color='value', direction='value', extrusion='value', align_center='value') exec(self.code, self.fake_main.__dict__) .. GENERATED FROM PYTHON SOURCE LINES 160-161 Initializing text box to print the title of the animation .. GENERATED FROM PYTHON SOURCE LINES 161-165 .. code-block:: Python tb = fury.ui.TextBlock2D(bold=True, position=(200, 60)) tb.message = "Animated 2D functions" scene.add(tb) .. GENERATED FROM PYTHON SOURCE LINES 166-167 Initializing showm and counter .. GENERATED FROM PYTHON SOURCE LINES 167-170 .. code-block:: Python counter = itertools.count() .. GENERATED FROM PYTHON SOURCE LINES 171-172 end is used to decide when to end the animation .. GENERATED FROM PYTHON SOURCE LINES 172-175 .. code-block:: Python end = 200 .. GENERATED FROM PYTHON SOURCE LINES 176-177 The 2D functions are updated and rendered here. .. GENERATED FROM PYTHON SOURCE LINES 177-202 .. code-block:: Python def timer_callback(_obj, _event): global xyz, time time += dt cnt = next(counter) # updating the colors and vertices of the triangles used to form the # surfaces for surf in surfaces: xyz, colors = update_surface( x, y, equation=surf.equation, cmap_name=surf.cmap_name ) fury.utils.update_surface_actor_colors(surf, colors) surf.vertices[:] = surf.initial_vertices + np.repeat( xyz, surf.no_vertices_per_point, axis=0 ) fury.utils.update_actor(surf) showm.render() # to end the animation if cnt == end: showm.exit() .. GENERATED FROM PYTHON SOURCE LINES 203-204 Run every 30 milliseconds .. GENERATED FROM PYTHON SOURCE LINES 204-211 .. code-block:: Python showm.add_timer_callback(True, 30, timer_callback) interactive = False if interactive: showm.start() fury.window.record(showm.scene, size=(600, 600), out_path="viz_animated_surfaces.png") .. image-sg:: /auto_examples/04_demos/images/sphx_glr_viz_animated_surfaces_001.png :alt: viz animated surfaces :srcset: /auto_examples/04_demos/images/sphx_glr_viz_animated_surfaces_001.png :class: sphx-glr-single-img .. rst-class:: sphx-glr-script-out .. code-block:: none /opt/homebrew/Caskroom/miniforge/base/envs/py39/lib/python3.9/site-packages/sphinx_gallery/gen_rst.py:722: UserWarning: We'll no longer accept the way you call the record function in future versions of FURY. Here's how to call the Function record: record(scene='value', cam_pos='value', cam_focal='value', cam_view='value', out_path='value', path_numbering='value', n_frames='value', az_ang='value', magnification='value', size='value', reset_camera='value', screen_clip='value', stereo='value', verbose='value') exec(self.code, self.fake_main.__dict__) .. rst-class:: sphx-glr-timing **Total running time of the script:** (0 minutes 0.442 seconds) .. _sphx_glr_download_auto_examples_04_demos_viz_animated_surfaces.py: .. only:: html .. container:: sphx-glr-footer sphx-glr-footer-example .. container:: sphx-glr-download sphx-glr-download-jupyter :download:`Download Jupyter notebook: viz_animated_surfaces.ipynb ` .. container:: sphx-glr-download sphx-glr-download-python :download:`Download Python source code: viz_animated_surfaces.py ` .. only:: html .. rst-class:: sphx-glr-signature `Gallery generated by Sphinx-Gallery `_