- 
                Notifications
    You must be signed in to change notification settings 
- Fork 56
docs: Added example on one way fsi #4407
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
          
     Open
      
        
      
            MohammedAnsys
  wants to merge
  26
  commits into
  main
  
    
      
        
          
  
    
      Choose a base branch
      
     
    
      
        
      
      
        
          
          
        
        
          
            
              
              
              
  
           
        
        
          
            
              
              
           
        
       
     
  
        
          
            
          
            
          
        
       
    
      
from
docs/example_on_fsi_one_way
  
      
      
   
  
    
  
  
  
 
  
      
    base: main
Could not load branches
            
              
  
    Branch not found: {{ refName }}
  
            
                
      Loading
              
            Could not load tags
            
            
              Nothing to show
            
              
  
            
                
      Loading
              
            Are you sure you want to change the base?
            Some commits from the old base branch may be removed from the timeline,
            and old review comments may become outdated.
          
          
  
     Open
                    Changes from 22 commits
      Commits
    
    
            Show all changes
          
          
            26 commits
          
        
        Select commit
          Hold shift + click to select a range
      
      c07231a
              
                Docs: Added example on one way fsi
              
              
                MohammedAnsys ae0b4e9
              
                Merge branch 'main' into docs/example_on_fsi_one_way
              
              
                MohammedAnsys d9e2442
              
                chore: adding changelog file 4407.added.md [dependabot-skip]
              
              
                pyansys-ci-bot 55b3950
              
                chore: adding changelog file 4407.documentation.md [dependabot-skip]
              
              
                pyansys-ci-bot 90f53a5
              
                Updated total displacement plot to isometric view
              
              
                MohammedAnsys 5e66b55
              
                Merge branch 'main' into docs/example_on_fsi_one_way
              
              
                MohammedAnsys ba03689
              
                Updated as per review comments
              
              
                MohammedAnsys 8f8da6e
              
                yml update
              
              
                MohammedAnsys 9f9540b
              
                updated as per main
              
              
                MohammedAnsys b392341
              
                updated module_config file as per main
              
              
                MohammedAnsys 3d040d2
              
                updated report.py file as per main
              
              
                MohammedAnsys c994310
              
                updated init.pu file as per main
              
              
                MohammedAnsys 59f6f62
              
                updated filed_data.py file as per main
              
              
                MohammedAnsys 70fe656
              
                updated session.py file as per main
              
              
                MohammedAnsys 5b427b3
              
                updated single batter cell file as per main
              
              
                MohammedAnsys 8152e42
              
                updated modeling cavitaion file as per main
              
              
                MohammedAnsys 42c108c
              
                updated environment file as per main
              
              
                MohammedAnsys 3b02a38
              
                fix to environment_variables.rst
              
              
                abhishekchitwar 747032b
              
                Merge branch 'main' into docs/example_on_fsi_one_way
              
              
                MohammedAnsys 7452563
              
                Fix: review changes + conflict resolution
              
              
                MohammedAnsys fa84c36
              
                Fix: review changes and conflict resolution
              
              
                MohammedAnsys ddf8917
              
                Merge branch 'main' into docs/example_on_fsi_one_way
              
              
                MohammedAnsys 02123d0
              
                fix to ci.yml
              
              
                MohammedAnsys 3b2aed5
              
                Merge branch 'main' into docs/example_on_fsi_one_way
              
              
                MohammedAnsys 5e2e2b2
              
                Update examples/00-fluent/fsi_1way_workflow.py
              
              
                MohammedAnsys e24af44
              
                Merge branch 'main' into docs/example_on_fsi_one_way
              
              
                MohammedAnsys File filter
Filter by extension
Conversations
          Failed to load comments.   
        
        
          
      Loading
        
  Jump to
        
          Jump to file
        
      
      
          Failed to load files.   
        
        
          
      Loading
        
  Diff view
Diff view
          Some comments aren't visible on the classic Files Changed page.
        
There are no files selected for viewing
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
              
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
              
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
              | Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1 @@ | ||
| Added example on one way fsi | 
      
      Loading
      
  Sorry, something went wrong. Reload?
      Sorry, we cannot display this file.
      Sorry, this file is invalid so it cannot be displayed.
      
    
      
      Loading
      
  Sorry, something went wrong. Reload?
      Sorry, we cannot display this file.
      Sorry, this file is invalid so it cannot be displayed.
      
    
      
      Loading
      
  Sorry, something went wrong. Reload?
      Sorry, we cannot display this file.
      Sorry, this file is invalid so it cannot be displayed.
      
    
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
              
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
              
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
              
              | Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,262 @@ | ||
| # Copyright (C) 2021 - 2025 ANSYS, Inc. and/or its affiliates. | ||
| # SPDX-License-Identifier: MIT | ||
| # | ||
| # | ||
| # Permission is hereby granted, free of charge, to any person obtaining a copy | ||
| # of this software and associated documentation files (the "Software"), to deal | ||
| # in the Software without restriction, including without limitation the rights | ||
| # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
| # copies of the Software, and to permit persons to whom the Software is | ||
| # furnished to do so, subject to the following conditions: | ||
| # | ||
| # The above copyright notice and this permission notice shall be included in all | ||
| # copies or substantial portions of the Software. | ||
| # | ||
| # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
| # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
| # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
| # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
| # SOFTWARE. | ||
|  | ||
| """.. _One_Way_FSI_Simulation: | ||
| Modeling One-Way Fluid-Structure Interaction | ||
| ------------------------------------------------------------- | ||
| """ | ||
|  | ||
| # %% | ||
| # Objective | ||
| # --------- | ||
| # | ||
| # This example models turbulent airflow through a cylindrical test chamber | ||
| # that contains a steel probe. The airflow generates aerodynamic forces on | ||
| # the probe, causing it to deform. In this case, the deformation is expected | ||
| # to be small compared with the overall flow field. Because the probe’s motion | ||
| # does not significantly alter the airflow, we can treat the problem using | ||
| # a one-way fluid–structure interaction (FSI) approach. | ||
| # | ||
| # In a one-way FSI analysis, the fluid flow is solved first and the | ||
| # resulting forces are transferred to the structural model. The | ||
| # structural response is then computed independently, without feeding | ||
| # back into the fluid solution. This contrasts with a two-way FSI | ||
| # analysis, where structural deformation and fluid flow are solved | ||
| # in a fully coupled manner. The one-way approach is computationally | ||
| # more efficient and appropriate when structural feedback on the flow | ||
| # can be neglected. | ||
|  | ||
|         
                  MohammedAnsys marked this conversation as resolved.
              Show resolved
            Hide resolved | ||
| # %% | ||
| # Problem Description | ||
| # ------------------- | ||
| # | ||
| # The cylindrical test chamber is 20 cm long, with a diameter of 10 cm. | ||
| # Turbulent air enters the chamber at 100 m/s, flows around and through | ||
| # the steel probe, and exits through a pressure outlet. | ||
| # | ||
| # | ||
| # .. image:: ../../_static/fsi_1way_1.png | ||
| # :align: center | ||
| # :alt: One-Way Fluid-Structure Interaction Model | ||
|  | ||
| # %% | ||
| # Import modules | ||
| # -------------- | ||
| # | ||
| # .. note:: | ||
| # Importing the following classes offer streamlined access to key solver settings, | ||
| # eliminating the need to manually browse through the full settings structure. | ||
|  | ||
| import os | ||
|  | ||
| import ansys.fluent.core as pyfluent | ||
| from ansys.fluent.core import FluentMode, Precision, examples | ||
| from ansys.fluent.core.solver import ( | ||
| BoundaryConditions, | ||
| Contour, | ||
| Graphics, | ||
| Initialization, | ||
| RunCalculation, | ||
| Setup, | ||
| Solution, | ||
| VelocityInlet, | ||
| ) | ||
|  | ||
| # %% | ||
| # Launch Fluent session in solver mode | ||
| # ------------------------------------ | ||
|  | ||
| solver = pyfluent.launch_fluent( | ||
| precision=Precision.DOUBLE, | ||
| mode=FluentMode.SOLVER, | ||
| ) | ||
|  | ||
| # %% | ||
| # Download and read the mesh file | ||
| # ------------------------------- | ||
|  | ||
|         
                  MohammedAnsys marked this conversation as resolved.
              Show resolved
            Hide resolved | ||
| mesh_file = examples.download_file( | ||
| "fsi_1way.msh.h5", | ||
| "pyfluent/fsi_1way", | ||
| save_path=os.getcwd(), | ||
| ) | ||
| solver.settings.file.read_case(file_name=mesh_file) | ||
|  | ||
| # %% | ||
| # Configure solver settings for fluid flow | ||
| # ---------------------------------------- | ||
|  | ||
| velocity_inlet = VelocityInlet(solver, name="velocity_inlet") | ||
| velocity_inlet.momentum.velocity_magnitude = 100.0 # High-speed inlet flow (m/s) | ||
| velocity_inlet.turbulence.turbulent_viscosity_ratio = ( | ||
| 5 # Dimensionless, typically 1-10 for moderate turbulence | ||
| ) | ||
|  | ||
| # %% | ||
| # Initialize and run fluid flow simulation | ||
| # ---------------------------------------- | ||
|  | ||
| initialize = Initialization(solver) | ||
| initialize.hybrid_initialize() | ||
|  | ||
| calculation = RunCalculation(solver) | ||
| calculation.iterate(iter_count=100) | ||
|  | ||
| # %% | ||
| # Post-processing | ||
| # --------------- | ||
|  | ||
| graphics = Graphics(solver) | ||
| graphics.picture.x_resolution = 650 # Horizontal resolution for clear visualization | ||
| graphics.picture.y_resolution = 450 # Vertical resolution matching typical aspect ratio | ||
|  | ||
| graphics.contour["contour-vel"] = { | ||
| "field": "velocity-magnitude", | ||
| "surfaces_list": ["fluid-symmetry"], | ||
| "coloring": {"option": "banded"}, | ||
| } | ||
|  | ||
|         
                  MohammedAnsys marked this conversation as resolved.
              Show resolved
            Hide resolved | ||
| graphics.contour["contour-vel"].display() | ||
| graphics.views.restore_view(view_name="front") | ||
|  | ||
| graphics.picture.save_picture(file_name="fsi_1way_2.png") | ||
|  | ||
|  | ||
| # %% | ||
| # .. image:: ../../_static/fsi_1way_2.png | ||
| # :align: center | ||
| # :alt: Velocity Contour | ||
|  | ||
| # %% | ||
| # Structural model and material setup | ||
| # ----------------------------------- | ||
| # To analyze the deformation of a steel probe under fluid flow, | ||
| # Linear Elasticity Structural model is chosen | ||
|  | ||
| setup = Setup(solver) | ||
| setup.models.structure.model = "linear-elasticity" | ||
| solver.settings.setup.models.structure.model = "linear-elasticity" | ||
|         
                  MohammedAnsys marked this conversation as resolved.
              Outdated
          
            Show resolved
            Hide resolved | ||
|  | ||
| # Copy materials from the database and assign to solid zone | ||
|  | ||
| setup.materials.database.copy_by_name(type="solid", name="steel") | ||
| setup.cell_zone_conditions.solid["solid"] = {"general": {"material": "steel"}} | ||
|  | ||
| # %% | ||
| # Structural boundary conditions | ||
| # ------------------------------ | ||
| # configure Fluent to define the steel probe's support and movement using | ||
| # structural boundary conditions | ||
|  | ||
| wall_boundary = BoundaryConditions(solver) | ||
|  | ||
| # Configure solid-symmetry boundary | ||
| wall_boundary.wall["solid-symmetry"] = { | ||
| "structure": { | ||
| "z_disp_boundary_value": 0, | ||
|         
                  MohammedAnsys marked this conversation as resolved.
              Show resolved
            Hide resolved | ||
| "z_disp_boundary_condition": "Node Z-Displacement", | ||
| } | ||
| } | ||
|  | ||
| # Set solid-top boundary (fully fixed) | ||
| wall_boundary.wall["solid-top"] = { | ||
| "structure": { | ||
| "z_disp_boundary_value": 0, | ||
| "z_disp_boundary_condition": "Node Z-Displacement", | ||
| "y_disp_boundary_value": 0, | ||
| "y_disp_boundary_condition": "Node Y-Displacement", | ||
| "x_disp_boundary_value": 0, | ||
| "x_disp_boundary_condition": "Node X-Displacement", | ||
| } | ||
| } | ||
|  | ||
| # Copy boundary conditions from solid-symmetry to solid-symmetry:011 | ||
| wall_boundary.copy(from_="solid-symmetry", to=["solid-symmetry:011"]) | ||
|  | ||
| # Configure FSI surface | ||
| wall_boundary.wall["fsisurface-solid"] = { | ||
| "structure": { | ||
| "x_disp_boundary_condition": "Intrinsic FSI", | ||
| "y_disp_boundary_condition": "Intrinsic FSI", | ||
| "z_disp_boundary_condition": "Intrinsic FSI", | ||
| } | ||
| } | ||
|  | ||
| # %% | ||
| # Inclusion of Operating Pressure in Fluid-Structure Interaction Forces | ||
| # --------------------------------------------------------------------- | ||
| # Fluent uses gauge pressure for fluid-structure interaction force calculations. | ||
| # By setting ``include_pop_in_fsi_force`` to ``True``, Fluent uses absolute pressure. | ||
|  | ||
| setup.models.structure.expert.include_pop_in_fsi_force = True | ||
|  | ||
| # %% | ||
| # Configure flow settings | ||
| # ----------------------- | ||
| # Disable flow equations for structural simulation | ||
|  | ||
| solution = Solution(solver) | ||
| solution.controls.equations["flow"] = False | ||
| solution.controls.equations["kw"] = False | ||
|  | ||
| # %% | ||
| # Run FSI simulation | ||
| # ------------------ | ||
|  | ||
| solver.settings.file.write_case(file_name="probe_fsi_1way.cas.h5") | ||
|  | ||
| calculation.iterate(iter_count=2) | ||
|  | ||
| # %% | ||
| # Structural Postprocessing | ||
| # ------------------------- | ||
|  | ||
| displacement_contour = Contour(solver, new_instance_name="displacement_contour") | ||
|  | ||
| displacement_contour.field = "total-displacement" | ||
| displacement_contour.surfaces_list = ["fsisurface-solid"] | ||
|  | ||
| displacement_contour.display() | ||
| graphics.views.restore_view(view_name="isometric") | ||
| graphics.picture.save_picture(file_name="fsi_1way_3.png") | ||
|  | ||
| # save the case and data file | ||
| solver.settings.file.write_case_data(file_name="probe_fsi_1way") | ||
|  | ||
| # %% | ||
| # .. image:: ../../_static/fsi_1way_3.png | ||
| # :align: center | ||
| # :alt: Structural Displacement Contour | ||
|  | ||
| # %% | ||
| # Close Fluent | ||
| # ------------ | ||
| solver.exit() | ||
|  | ||
| ####################################################################################### | ||
| # References: | ||
| # ===================================================================================== | ||
| # .. _Reference: | ||
| # [1] Modeling One-Way Fluid-Structure Interaction (FSI) Within Fluent, `Ansys Fluent documentation <https://ansyshelp.ansys.com/public/account/secured?returnurl=/Views/Secured/corp/v252/en/flu_tg/flu_tg_fsi_1way.html>`_. | ||
|  | ||
| # sphinx_gallery_thumbnail_path = '_static/fsi_1way_2.png' | ||
      
      Oops, something went wrong.
        
    
  
  Add this suggestion to a batch that can be applied as a single commit.
  This suggestion is invalid because no changes were made to the code.
  Suggestions cannot be applied while the pull request is closed.
  Suggestions cannot be applied while viewing a subset of changes.
  Only one suggestion per line can be applied in a batch.
  Add this suggestion to a batch that can be applied as a single commit.
  Applying suggestions on deleted lines is not supported.
  You must change the existing code in this line in order to create a valid suggestion.
  Outdated suggestions cannot be applied.
  This suggestion has been applied or marked resolved.
  Suggestions cannot be applied from pending reviews.
  Suggestions cannot be applied on multi-line comments.
  Suggestions cannot be applied while the pull request is queued to merge.
  Suggestion cannot be applied right now. Please check back later.
  
    
  
    
Uh oh!
There was an error while loading. Please reload this page.