Geometry Generation
Introduction
The geometry definition is a necessary precursor to generate a mesh, so it comes first in this tutorial. The native geometry file type for ICEM (our meshing software of choice) is a “.tin” file, but there are many ways to get it. You can use any CAD software to generate an “.igs” file and then convert the “.igs” file to a “.tin” file with ICEM or pyGeo. However, this tutorial will teach you how to generate a wing surface from airfoil data using pyGeo. pyGeo is set up to loft a surface between a set of airfoils distributed along the span of the wing. For more details on the options in pyGeo see the docs.
Files
Navigate to the directory aero/geometry
in your tutorial folder.
Copy the following file from the tutorial
directory:
cp ../../../tutorial/aero/geometry/rae2822.dat .
Create the following empty runscript in the current directory:
generate_wing.py
Dissecting the pyGeo runscript
Open the file generate_wing.py
in your favorite text editor.
Then copy the code from each of the following sections into this file.
Import libraries
Numpy is used for scientific computing such as matrix/vector operations. We need to import the pyGeo library in order to use its functions.
import numpy as np
from pygeo import pyGeo
Wing Definition
airfoil_list = ["rae2822.dat"] * 2
naf = len(airfoil_list) # number of airfoils
The wing is lofted from a set of airfoils distributed along the span of the wing. The airfoil data files can be downloaded from online or generated from a variety of software. The airfoil should be scaled to a unit chord with the leading edge centered at the origin. The number of sections needed for a geometry generation is dependent on the intention of the geometry. In general, any wing will require at least 2 sections to produce a valid geometry. Adding more sections allows more precise wing definition, which is generally necessary for matching previously defined wing geometries. Note that the number of sections must match the length of all the wing geometry data lists discussed below. Also note that the number of control points should vary with the number of sections. For cases with few sections, using a small number of control points yields the best results. If there are a large number of sections, the number of control points needs to be increased to prevent the size of the output files from becoming unreasonably large.
For this tutorial, we use the RAE 2822 transonic airfoil as the cross-section of our wing.
A visualization of the airfoil geometry is given on Figure 1.
The coordinates of the airfoil are contained in the file rae2822.dat
.
The position, orientation, and scaling of the airfoil sections are stipulated in lists corresponding with the original airfoil data list.
The leading edge of each airfoil is positioned in space based on the values in the x, y, and z lists.
An offset in the x-y plane can be added to this position with the offset
array before chord scaling is applied.
In this case, we don’t want to apply any rotation (the rotation options shown below would be for rotation about the airfoil leading edge points and the units are degrees) or offset.
# Airfoil leading edge positions
x = [0.0, 7.5]
y = [0.0, 0.0]
z = [0.0, 14.0]
offset = np.zeros((naf, 2)) # x-y offset applied to airfoil position before scaling
# Airfoil rotations
rot_x = [0.0, 0.0]
rot_y = [0.0, 0.0]
rot_z = [0.0, 0.0]
# Airfoil scaling
chord = [5.0, 1.5] # chord lengths
Call pyGeo
wing = pyGeo(
"liftingSurface",
xsections=airfoil_list,
scale=chord,
offset=offset,
x=x,
y=y,
z=z,
rotX=rot_x,
rotY=rot_y,
rotZ=rot_z,
tip="rounded",
bluntTe=True,
squareTeTip=True,
teHeight=0.25 * 0.0254,
)
A detailed explanation of each argument is available in the pyGeo docs. The final four options stipulate a rounded wingtip and a blunt trailing edge with a square tip (i.e., a square face at the trailing edge instead of a rounded face) and a thickness of 0.25 inches.
Write output files
There are three options for writing the geometry surface definition to file.
Write a dat file to view wing in Tecplot.
Write an IGES file. This can be converted to a TIN file in ICEM.
Write a TIN file directly from pyGeo.
wing.writeTecplot("wing.dat")
wing.writeIGES("wing.igs")
wing.writeTin("wing.tin")
Run it yourself!
After copying rae2822.dat
to your aero/geometry
folder and making the generate_wing.py
script, you can now run the python file with the command
python generate_wing.py
You can open wing.dat
in Tecplot. To view the wing surface, hide all zones called control_pts
.
The expected geometry output is shown below.