from builtins import int
import getpass
import logging
import warnings
from os import path
from six import string_types
from textwrap import dedent, fill
from ..tecutil import _tecutil
from ..constant import *
from ..exception import *
from .. import layout, tecutil, version
from ..tecutil import IndexSet, StringList, lock, sv
log = logging.getLogger(__name__)
@lock()
def _tecplot_loader_load_data(arglist,
frame,
read_data_option=None,
reset_style=None,
initial_plot_first_zone_only=None,
initial_plot_type=None,
assign_strand_ids=None,
add_zones_to_existing_strands=None):
frame = frame or layout.active_frame()
# If read_data_option is append and there is no data, we
# need to silently change it to "Replace in Active Frame"
if read_data_option == ReadDataOption.Append and (
not frame.has_dataset or frame.dataset.num_zones == 0):
read_data_option = ReadDataOption.ReplaceInActiveFrame
if read_data_option == ReadDataOption.ReplaceInActiveFrame:
read_data_option = None # Replace in active frame is the TecUtil default
with frame.activated():
arglist.update(**{
sv.READDATAOPTION: read_data_option,
sv.RESETSTYLE: reset_style,
sv.INITIALPLOTFIRSTZONEONLY: initial_plot_first_zone_only,
sv.INITIALPLOTTYPE: initial_plot_type,
sv.ASSIGNSTRANDIDS: assign_strand_ids,
sv.ADDZONESTOEXISTINGSTRANDS: add_zones_to_existing_strands})
if __debug__:
msg = 'loading data:'
for k, v in arglist.items():
if k == sv.FILENAMESORINSTRUCTIONS:
msg += '\n {}:'.format(k)
for i in v:
msg += '\n {}'.format(i)
else:
msg += '\n {}: {}'.format(k, v)
log.debug(msg)
if not _tecutil.DataSetReadX(arglist):
raise TecplotSystemError()
return frame.dataset
[docs]@lock()
def load_cgns(filenames,
frame=None,
read_data_option=ReadDataOption.Append,
reset_style=None,
initial_plot_first_zone_only=None,
initial_plot_type=None,
zones=None,
variables=None,
load_convergence_history=None,
combine_fe_sections=None,
average_to_nodes='Arithmetic',
uniform_grid=None,
assign_strand_ids=None,
add_zones_to_existing_strands=None,
include_boundary_conditions=True):
"""Read CGNS data files.
Parameters:
filenames (`string <str>` or `list` of `strings <str>`): CGNS data
files to be read. (See note below conerning absolute and relative
paths.)
frame (`Frame`, optional): The `Frame` to attach the resulting
`Dataset`. If `None`, the currently active `Frame` is used and the
zones are appended by default.
read_data_option (`ReadDataOption`, optional): Specify how the data
is loaded into Tecplot. (default: `ReadDataOption.Append`)
Possible values are:
* `ReadDataOption.ReplaceInActiveFrame`
Remove the dataset from the active frame prior to reading
in the new dataset. If other frames use the same `DataSet`
in the active frame, they will continue to use the old one.
* `ReadDataOption.Append`
Append the new `DataSet` to the dataset to the existing dataset.
* `ReadDataOption.Replace`
Replace the `DataSet` attached to the active frame and to all
other frames that use the same `DataSet`.
reset_style (`boolean <bool>`, optional): Reset the style for
destination `Frame`, if `False`, the `Frame`'s current style is
preserved. (default: `True`)
initial_plot_first_zone_only (`boolean <bool>`, optional): Informs
the |Tecplot Engine| that after the data is loaded it only needs to
activate the first enabled `Zone <data_access>` for the initial
plot. This option is particularly useful if you have many `Zones
<data_access>` and want to get the data into the |Tecplot Engine|
and the first `Zone <data_access>` drawn as fast as possible. The
inactive `Zones <data_access>` can always be activated when needed.
(default: `False`)
initial_plot_type (`PlotType`, optional): Forces a specific type of
plot upon loading of the data. Only used if *resetstyle* is `True`.
To have |Tecplot 360| determine the most appropriate plot type
for the data, use `PlotType.Automatic`. Possible values are:
`PlotType.Automatic` (default), `Cartesian3D`, `Cartesian2D`,
`XYLine`, `PlotType.Sketch`, `PolarLine`.
zones (`list` of `integers <int>`, optional): List of zone indexes to
load starting from zero. `None` implies loading all zones.
(default: `None`)
variables (`list` of `integers <int>`, optional): List of variable
indexes, beyond the first coordinate variables, to load starting
from zero. `None` implies loading all variables. The grid will
always be loaded and an index of zero indicates the first
non-coordinate variable. (default: `None`)
load_convergence_history (`boolean <bool>`, optional): Load the
global convergence history rather than any grid or solution data.
(default: `False`)
combine_fe_sections (`boolean <bool>`, optional): Combine all
finite-element sections with the zone cell-dimension into one
zone. (default: `False`)
average_to_nodes (`string <str>`, optional): Average
cell-centered data to grid nodes using the specified method.
(Options: `None`, "Arithmetic", "Laplacian", default: "Arithmetic")
uniform_grid (`boolean <bool>`, optional): Indicates the grid
structure is the same for all time steps. (default: `True`)
assign_strand_ids (`boolean <bool>`, optional): Assign strand ID's to
zones that have a strand ID of -1. (default: `True`)
add_zones_to_existing_strands (`boolean <bool>`, optional): Add the
`Zones <data_access>` to matching strands, if they exist.
Otherwise, if the new data specifies strands, new ones will be
created beginning after the last strand in the `Dataset`. (default:
`False`)
include_boundary_conditions (`boolean <bool>`, optional): Load the
boundary conditions along with the data. Upon loading, the
associated fieldmaps will remain inactive. For unstructured data,
boundary conditions are always loaded and this option is ignored.
(default: `True`)
Returns:
`Dataset`: The `Dataset` holding the loaded data.
Raises:
`TecplotSystemError`: Internal error when loading data.
`TecplotTypeError`: Invalid input.
.. note:: **Absolute and relative paths with PyTecplot**
Unless file paths are absolute, saving and loading files will be
relative to the current working directory of the parent process. This
is different when running the PyTecplot script in batch mode and when
running in connected mode with `tecplot.session.connect()`. In batch
mode, paths will be relative to Python's current working directory as
obtained by :func:`os.getcwd()`. When connected to an instance of
Tecplot 360, paths will be relative to Tecplot 360's' start-up folder
which is typically the Tecplot 360 installation "bin" folder.
"""
if __debug__:
avg_to_nodes_opts = [None, 'Arithmetic', 'Laplacian']
if average_to_nodes not in avg_to_nodes_opts:
msg = 'average_to_nodes must be one of: '
msg += ', '.join(str(x) for x in avg_to_nodes_opts)
raise TecplotTypeError(msg)
with StringList('STANDARDSYNTAX', '1.0') as instr:
with tecutil.ArgList() as arglist:
arglist[sv.DATASETREADER] = 'CGNS LOADER'
instr += ['LoaderVersion', 'V3']
# We need to add the cgns library version to the arglist,
# although this setting is not exposed in the API.
instr += ['CgnsLibraryVersion', '3.1.4']
if isinstance(filenames, string_types):
filenames = filenames.split(',')
instr += ['FILELIST_CGNSFILES', str(len(filenames))]
instr += [path.abspath(f) for f in filenames]
if zones is not None:
indexes = [str(int(z)) for z in zones]
instr += ['ZoneList', ','.join(indexes)]
if variables is not None:
indexes = [str(int(v)) for v in variables]
instr += ['VarList', ','.join(indexes)]
if average_to_nodes is None:
instr += ['AverageToNodes', 'No']
elif average_to_nodes != 'Arithmetic':
# Default for 'AverageToNoes' is 'Yes'
# Default for AveragingMethods is 'Arithmetic'
instr += ['AveragingMethod', average_to_nodes]
if uniform_grid is not None:
instr += ['UniformGridStructure',
'Yes' if uniform_grid else 'No']
if combine_fe_sections is not None:
instr += [
'SectionLoad', 'SeparateZones'
if combine_fe_sections else 'Combine']
if include_boundary_conditions is not None:
instr += ['LoadBCs',
'Yes' if include_boundary_conditions else 'No']
if load_convergence_history is not None:
instr += ['LoadConvergenceHistory',
'Yes' if load_convergence_history else 'No']
if assign_strand_ids is not None:
instr += ['AssignStrandIDs',
'Yes' if assign_strand_ids else 'No']
arglist[sv.FILENAMESORINSTRUCTIONS] = instr
return _tecplot_loader_load_data(
arglist, frame=frame, read_data_option=read_data_option,
reset_style=reset_style,
initial_plot_first_zone_only=initial_plot_first_zone_only,
initial_plot_type=initial_plot_type,
assign_strand_ids=assign_strand_ids,
add_zones_to_existing_strands=add_zones_to_existing_strands)
[docs]@lock()
def load_fluent(case_filenames=None,
data_filenames=None,
frame=None,
append=True,
zones=None,
variables=None,
all_poly_zones=None,
average_to_nodes='Arithmetic',
time_interval=None,
assign_strand_ids=True,
add_zones_to_existing_strands=None,
include_particle_data=None,
include_additional_quantities=True,
save_uncompressed_files=None):
"""Read Fluent data files.
Parameters:
case_filenames (`string <str>` or `list` of `strings <str>`, optional):
Case (*.cas*, *.cas.gz*) files to be read. Compressed files with extension *.gz* are supported. (See note below conerning absolute and relative paths.)
data_filenames (`string <str>` or `list` of `strings <str>`, optional):
Data (*.dat*, *.xml*, *.dat.gz*, *.fdat*, *.fdat.gz*, etc.) files to be read. Compressed files with extension *.gz* are supported.
frame (`Frame`, optional): The `Frame` to attach the resulting
`Dataset`. If `None`, the currently active `Frame` is used and the
zones are appended by default.
append (`boolean <bool>`, optional): Append the data to the existing
`Dataset`. If `False`, the existing data attached to the `Frame` is
deleted and replaced. (default: `True`)
zones (`string <str>` or `list` of `integers <int>`, optional): List of
zone indexes (zero-based) to load or string specifying the type of
zones to load. Possible values are: "CellsAndBoundaries",
"CellsOnly" and "BoundariesOnly". Specifying one of these options
is mutually exclusive with the ``variables`` option. (default:
"CellsAndBoundaries")
variables (`list` of `strings <str>`, optional): List of variable
names to load. `None` implies loading all variables. (default:
`None`)
all_poly_zones (`boolean <bool>`, optional): Converts all zones to
Tecplot polytope (polyhedral or polygonal) zones. (default:
`False`)
average_to_nodes (`string <str>`, optional): Average
cell-centered data to grid nodes using the specified method.
(Options: `None`, "Arithmetic", "Laplacian", default: "Arithmetic")
time_interval (`float`, optional): Use a constant time interval between
each *.dat* file. If `None`, the flow-data parameter of each
solution *.dat* file is used. (default: `None`)
assign_strand_ids (`boolean <bool>`, optional): Assign strand ID's to
zones that have a strand ID of -1. (default: `True`)
.. note::
assign_strand_ids only applies if you have also provided a
time_interval, otherwise it will be ignored.
add_zones_to_existing_strands (`boolean <bool>`, optional): Add the
`Zones <data_access>` to matching strands, if they exist.
Otherwise, if the new data specifies strands, new ones will be
created beginning after the last strand in the `Dataset`. (default:
`False`)
include_particle_data (`boolean <bool>`, optional): Load particle
data from the *.dat* files. If loading particle data from an XML
file, the XML file should be included in the ``data_filenames``
list. (default: `False`)
include_additional_quantities (`boolean <bool>`, optional): Load
quantities that were derived from the FLUENT's standard quantities.
(default: `True`) *New in Tecplot 360 2017 R2*.
save_uncompressed_files (`boolean <bool>`, optional): Save the
uncompressed files to the compressed files' location.
Returns:
`Dataset`: The `Dataset` holding the loaded data.
Raises:
`TecplotSystemError`: Internal error when loading data.
`TecplotTypeError`: In-valid input.
.. note:: **Absolute and relative paths with PyTecplot**
Unless file paths are absolute, saving and loading files will be
relative to the current working directory of the parent process. This
is different when running the PyTecplot script in batch mode and when
running in connected mode with `tecplot.session.connect()`. In batch
mode, paths will be relative to Python's current working directory as
obtained by :func:`os.getcwd()`. When connected to an instance of
Tecplot 360, paths will be relative to Tecplot 360's' start-up folder
which is typically the Tecplot 360 installation "bin" folder.
Notes:
The ``zones`` option takes either a `list` of zone indexes to be
imported or one of "CellsAndBoundaries", "CellsOnly" or
"BoundariesOnly" to indicate the type of zones the user wants to load,
however these options are mutually exclusive with the ``variables``
option::
>>> import tecplot
>>> dataset = tecplot.data.load_fluent(['one.cas', 'two.cas'],
... data_filenames=['one.dat', 'two.dat'],
... variables = ['Pressure','Velocity'],
... zones = [0,1,3])
"""
if isinstance(case_filenames, string_types):
case_filenames = [case_filenames]
if isinstance(data_filenames, string_types):
data_filenames = [data_filenames]
if __debug__:
zone_types_opts = ['CellsAndBoundaries', 'CellsOnly', 'BoundariesOnly']
avg_to_nodes_opts = [None, 'Arithmetic', 'Laplacian']
if isinstance(zones, string_types):
if zones not in zone_types_opts:
msg = 'Zones must be list of indexes or one of: '
msg += ', '.join(zone_types_opts)
raise TecplotTypeError(msg)
if variables is not None:
msg = 'Loading a subset of variables is allowed only if'
msg += ' zones is None or a list of zones.'
raise TecplotTypeError(msg)
if (case_filenames or data_filenames) is None:
raise TecplotTypeError('You must specify a case or data file.')
if (case_filenames is None) and (len(data_filenames) != 1):
msg = 'Case file is required when loading multiple data files'
raise TecplotTypeError(msg)
if average_to_nodes not in avg_to_nodes_opts:
msg = 'average_to_nodes must be one of: '
msg += ', '.join(str(x) for x in avg_to_nodes_opts)
raise TecplotTypeError(msg)
if include_additional_quantities:
sdk_required = (2017, 2)
if version.sdk_version_info < sdk_required:
def format_msg(msg):
"""reflow message, adjusting spaces"""
return fill(dedent(' '.join(msg.split())), width=60)
msg = 'Out-of-date Tecplot 360.\n'
msg += format_msg('''\
Loading of FLUENT's additional quantities requires Tecplot
360 version {} R{} or later. Data will be loaded without
these additional quantities.'''.format(*sdk_required))
warnings.warn(msg)
with StringList('STANDARDSYNTAX', '1.0') as instr:
with tecutil.ArgList() as arglist:
arglist[sv.DATASETREADER] = 'Fluent Data Loader'
if append:
instr += ['Append', 'Yes']
if case_filenames is not None:
if data_filenames is not None:
nfiles = len(case_filenames) + len(data_filenames)
instr += ['LoadOption', 'MultipleCaseAndData',
'FILELIST_Files', str(nfiles)]
instr += list(case_filenames) + list(data_filenames)
else:
instr += ['LoadOption', 'MultipleCaseAndData',
'FILELIST_Files', str(len(case_filenames))]
instr += list(case_filenames)
else:
instr += ['LoadOption', 'ResidualsOnly',
'FILENAME_DataFile', data_filenames[0]]
if time_interval is not None:
instr += ["UnsteadyOption", 'ApplyConstantTimeInterval']
instr += ['TimeInterval', str(float(time_interval))]
if isinstance(zones, string_types):
instr += ['GridZones', zones]
elif (zones or variables) is not None:
instr += ["GridZones", 'SelectedZones']
if zones is not None:
zone_indexes = ','.join(str(int(z) + 1) for z in zones)
instr += ['ZoneList', zone_indexes]
if variables is not None:
var_names = '\n'.join(variables)
instr += ['VarNameList', var_names]
if include_particle_data: # "No" is the default
instr += ['IncludeParticleData',
'Yes']
if all_poly_zones: # "No" is the default
instr += ['AllPolyZones',
'Yes']
if average_to_nodes is None:
instr += ['AverageToNodes', 'No']
elif average_to_nodes != 'Arithmetic':
# Default for 'AverageToNoes' is 'Yes'
# Default for AveragingMethods is 'Arithmetic'
instr += ['AveragingMethod', average_to_nodes]
if assign_strand_ids is not None:
instr += ['AssignStrandIDs',
'Yes' if assign_strand_ids else 'No']
if add_zones_to_existing_strands is not None:
instr += ['AddZonesToExistingStrands',
'Yes' if add_zones_to_existing_strands else 'No']
# Always explicitly provide SaveUncompressedFiles
instr += ['SaveUncompressedFiles',
'Yes' if save_uncompressed_files else 'No']
if version.sdk_version_info >= (2017, 2):
instr += ['LoadAdditionalQuantities',
'Yes' if include_additional_quantities else 'No']
arglist[sv.FILENAMESORINSTRUCTIONS] = instr
return _tecplot_loader_load_data(arglist, frame=frame)
[docs]@lock()
def load_plot3d(grid_filenames=None,
solution_filenames=None,
function_filenames=None,
name_filename=None,
frame=None,
append=True,
# setting any of these three implies auto_detect=False
data_structure=None, # (1D|2D|3DP|3DW|UNSTRUCTURED)
is_multi_grid=None, # (True|False)
style=None, # (PLOT2DCLASSIC|PLOT3DFUNCTION|OVERFLOW)
ascii_is_double=None, # (True|False)
ascii_has_blanking=None, # (True|False)
uniform_grid=None, # (True|False)
assign_strand_ids=True,
add_zones_to_existing_strands=True,
append_function_variables=None, # (True|False)
include_boundaries=True):
"""Read Plot3D data files.
Parameters:
grid_filenames (`list` of `strings <str>`, optional): One or more grid
file names to be read. (See note below conerning absolute and
relative paths.)
solution_filenames (`list` of `strings <str>`, optional): One or more
solution data file names to be read.
function_filenames (`list` of `strings <str>`, optional): One or more
function file names.
name_filename (`string <str>`, optional): Path to the name file.
frame (`Frame`, optional): The `Frame` to attach the resulting
`Dataset`. If `None`, the currently active `Frame` is used and the
zones are appended by default.
append (`boolean <bool>`, optional): Append the data to the existing
`Dataset`. If `False`, the existing data attached to the `Frame` is
deleted and replaced. (default: `True`)
data_structure (`string <str>`, optional): Specifies the data
structure and overrides the automatic detection. Options are:
``1D``, ``2D``, ``3DP``, ``3DW``, ``UNSTRUCTURED``. Setting this
requires ``is_multi_grid`` and ``style`` to be set as well.
is_multi_grid (`boolean <bool>`, optional): Sets data as multi-grid
and overrides the automatic data structure detection. Setting
this requires ``data_structure`` and ``style`` to be set as well.
style (`boolean <bool>`, optional): Specifies the data style and
overrides the automatic data structure detection. Options are:
``PLOT3DCLASSIC``, ``PLOT3DFUNCTION``, ``OVERFLOW``. Setting this
requires ``data_structure`` and ``is_multi_grid`` to be set as
well.
ascii_is_double (`boolean <bool>`, optional): Indicates that
floating-point numbers found in the text data files should be
store with 64-bit precision. (default: `False`)
ascii_has_blanking (`boolean <bool>`, optional): Indicates that the
text data files contain blanking. (default: `False`)
uniform_grid (`boolean <bool>`, optional): Indicates the grid
structure is the same for all time steps. (default: `True`)
assign_strand_ids (`boolean <bool>`, optional): Assign strand ID's to
zones that have a strand ID of -1. (default: `True`)
add_zones_to_existing_strands (`boolean <bool>`, optional): Add the
`Zones <data_access>` to matching strands, if they exist.
Otherwise, if the new data specifies strands, new ones will be
created beginning after the last strand in the `Dataset`. (default:
`True`)
append_function_variables (`boolean <bool>`, optional): Append
variables in function files to those found in solution files.
(default: `False`)
include_boundaries (`boolean <bool>`, optional): Loads boundary zones
found in the ".g.fvbnd" file located in the same directory as the
grid file, if available. (default: `True`)
Returns:
`Dataset`: The `Dataset` holding the loaded data.
Raises:
`TecplotSystemError`: Internal error when loading data.
`TecplotValueError`: In-valid input.
.. note:: **Absolute and relative paths with PyTecplot**
Unless file paths are absolute, saving and loading files will be
relative to the current working directory of the parent process. This
is different when running the PyTecplot script in batch mode and when
running in connected mode with `tecplot.session.connect()`. In batch
mode, paths will be relative to Python's current working directory as
obtained by :func:`os.getcwd()`. When connected to an instance of
Tecplot 360, paths will be relative to Tecplot 360's' start-up folder
which is typically the Tecplot 360 installation "bin" folder.
.. note:: Data structure is automatically detected by default.
The options ``data_structure``, ``is_multi_grid`` and ``style``
must be supplied together or not at all. When all of these are
`None`, the data structure is automatically detected.
The variables from the function files can be appended to the dataset
upon loading::
>>> dataset = tecplot.data.load_plot3d(
... grid_filenames = 'data.g',
... solution_filenames = ['t0.q', 't1.q'],
... function_filenames = ['t0.f', 't1.f'],
... append_function_variables = True)
"""
if isinstance(grid_filenames, string_types):
grid_filenames = [grid_filenames]
if isinstance(solution_filenames, string_types):
solution_filenames = [solution_filenames]
if isinstance(function_filenames, string_types):
function_filenames = [function_filenames]
if __debug__:
data_structure_opts = [None, '1D', '2D', '3DP', '3DW', 'UNSTRUCTURED']
style_opts = [None, 'PLOT3DCLASSIC', 'PLOT3DFUNCTION', 'OVERFLOW']
if data_structure not in data_structure_opts:
msg = 'data_structure must be one of: '
msg += ', '.join(str(x) for x in data_structure_opts)
raise TecplotValueError(msg)
if style not in style_opts:
msg = 'style must be one of: '
msg += ', '.join(str(x) for x in style_opts)
raise TecplotValueError(msg)
if grid_filenames and solution_filenames:
if len(grid_filenames) != 1 and \
len(grid_filenames) != len(solution_filenames):
raise TecplotValueError(dedent('''\
You must specify a single grid file or
the same number of grid and solution files.'''))
autodetect_opts = [data_structure, is_multi_grid, style]
if sum([x is None for x in autodetect_opts]) not in [0, 3]:
raise TecplotValueError(dedent('''\
The options: data_structure, is_multi_grid and style
must be supplied all together or not at all.'''))
frame = frame or layout.active_frame()
with StringList('STANDARDSYNTAX', '1.0') as instr:
with tecutil.ArgList() as arglist:
arglist[sv.DATASETREADER] = 'PLOT3D Loader'
preexisting_dataset = frame.has_dataset and frame.dataset.num_zones
if append is not None:
if append:
if preexisting_dataset:
instr += ['Append', 'Yes']
else:
instr += ['Append', 'No']
if grid_filenames is not None:
instr += ['FILELIST_GRIDFILES', str(len(grid_filenames))]
instr += grid_filenames
if solution_filenames is not None:
instr += ['FILELIST_SOLUTIONFILES',
str(len(solution_filenames))]
instr += solution_filenames
if function_filenames is not None:
instr += ['FILELIST_FUNCTIONFILES',
str(len(function_filenames))]
instr += function_filenames
if name_filename is not None:
instr += ['FILENAME_NAMEFILE', name_filename]
if (data_structure or is_multi_grid or style) is None:
instr += ['AUTODETECT', 'Yes']
else:
instr += ['AUTODETECT', 'No']
instr += ['DATASTRUCTURE', data_structure]
instr += ['ISMULTIGRID', 'Yes' if is_multi_grid else 'No']
instr += ['STYLE', style]
if ascii_is_double is not None:
instr += ['ASCIIISDOUBLE', 'Yes' if ascii_is_double else 'No']
if ascii_has_blanking is not None:
instr += ['ASCIIHASBLANK',
'Yes' if ascii_has_blanking else 'No']
if uniform_grid is not None:
instr += ['UNIFORMGRIDSTRUCTURE',
'Yes' if uniform_grid else 'No']
if assign_strand_ids is not None:
instr += ['ASSIGNSTRANDIDS',
'Yes' if assign_strand_ids else 'No']
if add_zones_to_existing_strands is not None:
if preexisting_dataset:
instr += ['ADDTOEXISTINGSTRANDS',
'Yes' if add_zones_to_existing_strands else 'No']
if append_function_variables is not None:
if solution_filenames or preexisting_dataset:
instr += ['APPENDFUNCTIONVARIABLES',
'Yes' if append_function_variables else 'No']
if include_boundaries is not None:
instr += ['LOADBOUNDARY', 'Yes' if include_boundaries else 'No']
arglist[sv.FILENAMESORINSTRUCTIONS] = instr
try:
return _tecplot_loader_load_data(arglist, frame=frame)
except TecplotLogicError as e:
if str(e).startswith('The boundary file does not'):
log.warning(e)
return layout.active_frame().dataset
raise
[docs]@lock()
def load_tecplot(filenames,
frame=None,
read_data_option=ReadDataOption.Append,
reset_style=None,
initial_plot_first_zone_only=None,
initial_plot_type=None,
zones=None,
variables=None,
collapse=None,
skip=None,
assign_strand_ids=True,
add_zones_to_existing_strands=None,
include_text=None,
include_geom=None,
include_custom_labels=None,
include_data=None):
"""Read a tecplot data file.
Parameters:
filenames (`string <str>` or `list` of `strings <str>`): Files to be
read. (See note below conerning absolute and relative paths.)
frame (`Frame`, optional): The `Frame` to attach the resulting
`Dataset`. If `None`, the currently active `Frame` is used and the
zones are appended by default.
read_data_option (`ReadDataOption`, optional): Specify how the data
is loaded into Tecplot. (default: `ReadDataOption.Append`)
Possible values are:
* `ReadDataOption.ReplaceInActiveFrame`
The `DataSet` in the active frame is replaced by the new
`DataSet`. If other frames were using the same `DataSet`
originally in the active frame, they will continue to use it.
* `ReadDataOption.Append`
Append the new `DataSet` to the existing `DataSet`.
* `ReadDataOption.Replace`
Replace the `DataSet` attached to the active frame, and to all
other frames that use the same `DataSet`.
Default: `ReadDataOption.Append`
reset_style (`boolean <bool>`, optional): Reset the style for
destination `Frame`, if `False`, the `Frame`'s current style is
preserved. (default: `True`)
initial_plot_first_zone_only (`boolean <bool>`, optional): Informs
the |Tecplot Engine| that after the data is loaded it only needs to
activate the first enabled `Zone <data_access>` for the initial
plot. This option is particularly useful if you have many `Zones
<data_access>` and want to get the data into the |Tecplot Engine|
and the first `Zone <data_access>` drawn as fast as possible. The
inactive `Zones <data_access>` can always be activated when needed.
(default: `False`)
initial_plot_type (`PlotType`, optional): Forces a specific type of
plot upon loading of the data. Only used if *resetstyle* is `True`.
To have |Tecplot 360| determine the most appropriate plot type
for the data, use `PlotType.Automatic`. Possible values are:
`PlotType.Automatic` (default), `Cartesian3D`, `Cartesian2D`,
`XYLine`, `PlotType.Sketch`, `PolarLine`.
zones (`set` of `integers <int>`, optional): Set of `Zones
<data_access>` to load. Use `None` to load all zones. (default:
`None`)
variables (`set` of `strings <str>` or `integers <int>`, optional):
Set of `Variables <Variable>` to load. Use `None` to load all
variables. (default: `None`)
collapse (`boolean <bool>`, optional): Reindex `Zones <data_access>` and
`Variables <Variable>` if any are disabled. (default: `False`)
skip: (3-`tuple` of `integers <int>`, optional) The *ijk*-skip. A value
of (1,1,1) loads every data point in the *(i,j,k)* directions. A
value of (2,2,2) loads every other data point and so forth. This
only applies to ordered data. (default: (1,1,1))
assign_strand_ids (`boolean <bool>`, optional): Assign strand ID's to
zones that have a strand ID of -1. (default: `True`)
add_zones_to_existing_strands (`boolean <bool>`, optional): Add the
`Zones <data_access>` to matching strands, if they exist.
Otherwise, if the new data specifies strands, new ones will be
created beginning after the last strand in the `Dataset`. (default:
`False`)
include_text (`boolean <bool>`, optional): Load any text, geometries, or
custom labels (default: `True`)
include_geom (`boolean <bool>`, optional): Load geometries. (default:
`True`)
include_custom_labels (`boolean <bool>`, optional): (default: `True`)
include_data (`boolean <bool>`, optional): Load data. Set this to
`False` if you only want annotations such as text or geometries.
(default: `True`)
Returns:
`Dataset`: The `Dataset` holding the loaded data.
Raises:
`TecplotSystemError`: Internal error when loading data.
`TecplotTypeError`: In-valid input.
.. note:: **Absolute and relative paths with PyTecplot**
Unless file paths are absolute, saving and loading files will be
relative to the current working directory of the parent process. This
is different when running the PyTecplot script in batch mode and when
running in connected mode with `tecplot.session.connect()`. In batch
mode, paths will be relative to Python's current working directory as
obtained by :func:`os.getcwd()`. When connected to an instance of
Tecplot 360, paths will be relative to Tecplot 360's' start-up folder
which is typically the Tecplot 360 installation "bin" folder.
"""
with StringList(filenames) as fnames:
with tecutil.ArgList() as arglist:
allocd = []
arglist.update(**{
sv.DATASETREADER: 'TECPLOT',
sv.FILENAMESORINSTRUCTIONS: fnames,
sv.INCLUDETEXT: include_text,
sv.INCLUDEGEOM: include_geom,
sv.INCLUDECUSTOMLABELS: include_custom_labels,
sv.INCLUDEDATA: include_data,
sv.COLLAPSEZONESANDVARS: collapse})
if zones is not None:
zoneset = IndexSet(zones)
allocd.append(zoneset)
arglist[sv.ZONELIST] = zoneset
if variables is None:
arglist[sv.VARLOADMODE] = VarLoadMode.ByName
else:
if isinstance(variables[0], int):
arglist[sv.VARLOADMODE] = VarLoadMode.ByPosition
varset = IndexSet(*variables)
allocd.append(varset)
arglist[sv.VARPOSITIONLIST] = varset
elif isinstance(variables[0], string_types):
arglist[sv.VARLOADMODE] = VarLoadMode.ByName
var_string_list = StringList(*variables)
allocd.append(var_string_list)
arglist[sv.VARNAMELIST] = var_string_list
else:
err = 'unknown type for variables: {}'
raise TecplotTypeError(err.format(type(variables)))
if skip is not None:
i, j, k = skip
arglist[sv.ISKIP] = i
arglist[sv.JSKIP] = j
arglist[sv.KSKIP] = k
try:
return _tecplot_loader_load_data(
arglist, frame=frame, read_data_option=read_data_option,
reset_style=reset_style,
initial_plot_first_zone_only=initial_plot_first_zone_only,
initial_plot_type=initial_plot_type,
assign_strand_ids=assign_strand_ids,
add_zones_to_existing_strands=add_zones_to_existing_strands)
finally:
for a in allocd:
a.dealloc()
[docs]@lock()
def load_tecplot_szl(filenames,
frame=None,
read_data_option=ReadDataOption.Append,
reset_style=None,
initial_plot_first_zone_only=None,
initial_plot_type=None,
assign_strand_ids=True,
add_zones_to_existing_strands=None,
server=None,
connection_method=None,
user=None,
ssh_private_keyfile=None):
"""Read tecplot SZL data file.
Parameters:
filenames (`string <str>` or `list` of `strings <str>`): Files to be
read. (See note below conerning absolute and relative paths.)
frame (`Frame`, optional): The `Frame` to attach the resulting
`Dataset`. If `None`, the currently active `Frame` is used and the
zones are appended by default.
read_data_option (`ReadDataOption`, optional): Specify how the data
is loaded into Tecplot. (default: `ReadDataOption.Append`)
Possible values are:
* `ReadDataOption.ReplaceInActiveFrame`
Remove the dataset from the active frame prior to reading
in the new dataset. If other frames use the same `DataSet`
in the active frame, they will continue to use the old one.
* `ReadDataOption.Append`
Append the new `DataSet` to the dataset to the existing dataset.
* `ReadDataOption.Replace`
Replace the `DataSet` attached to the active frame and to all
other frames that use the same `DataSet`.
reset_style (`boolean <bool>`, optional): Reset the style for
destination `Frame`, if `False`, the `Frame`'s current style is
preserved. (default: `True`)
initial_plot_first_zone_only (`boolean <bool>`, optional): Informs
the |Tecplot Engine| that after the data is loaded it only needs to
activate the first enabled `Zone <data_access>` for the initial
plot. This option is particularly useful if you have many `Zones
<data_access>` and want to get the data into the |Tecplot Engine|
and the first `Zone <data_access>` drawn as fast as possible. The
inactive `Zones <data_access>` can always be activated when needed.
(default: `False`)
initial_plot_type (`PlotType`, optional): Forces a specific type of
plot upon loading of the data. Only used if *resetstyle* is `True`.
To have |Tecplot 360| determine the most appropriate plot type
for the data, use `PlotType.Automatic`. Possible values are:
`PlotType.Automatic` (default), `Cartesian3D`, `Cartesian2D`,
`XYLine`, `PlotType.Sketch`, `PolarLine`.
assign_strand_ids (`boolean <bool>`, optional): Assign strand ID's to
zones that have a strand ID of -1. (default: `True`)
add_zones_to_existing_strands (`boolean <bool>`, optional): Add the
`Zones <data_access>` to matching strands, if they exist.
Otherwise, if the new data specifies strands, new ones will be
created beginning after the last strand in the `Dataset`. (default:
`False`)
server (`string <str>`, optional): Load the data remotely from this
server address. (default: `None`)
connection_method (`RemoteConnectionMethod`, optional): When *server*
is given, this specifies the type of connection to be made.
Possible values are: `RemoteConnectionMethod.Tunneled` (default),
`RemoteConnectionMethod.Direct`, `RemoteConnectionMethod.Manual`.
user (`string <str>`, optional): When *server* is given, this specifies
the username to use when logging into the server. This will default
to the client's user name.
private_ssh_keyfile (`string <str>`, optional): When *server* is given,
this specifies the full path to the private SSH keyfile which
defaults to ``~/.ssh/id_rsa`` where ``~`` expands out to the local
user's home directory.
Returns:
`Dataset`: The `Dataset` holding the loaded data.
.. note:: **Absolute and relative paths with PyTecplot**
Unless file paths are absolute, saving and loading files will be
relative to the current working directory of the parent process. This
is different when running the PyTecplot script in batch mode and when
running in connected mode with `tecplot.session.connect()`. In batch
mode, paths will be relative to Python's current working directory as
obtained by :func:`os.getcwd()`. When connected to an instance of
Tecplot 360, paths will be relative to Tecplot 360's' start-up folder
which is typically the Tecplot 360 installation "bin" folder.
"""
if isinstance(filenames, string_types):
filenames = [filenames]
if server is not None:
if connection_method is None:
connection_method = RemoteConnectionMethod.Tunneled
else:
connection_method = RemoteConnectionMethod(connection_method)
with tecutil.ArgList() as arglist:
allocd = []
instr = StringList('STANDARDSYNTAX', '1.0')
allocd.append(instr)
try:
if server is None:
instr += ['FILELIST_DATAFILES', str(len(filenames))]
instr += filenames
arglist['DATASETREADER'] = 'Tecplot Subzone Data Loader'
else:
if user is None:
user = getpass.getuser()
if ssh_private_keyfile is None:
homedir = path.expanduser('~')
ssh_private_keyfile = path.join(homedir, '.ssh', 'id_rsa')
instr += ['Connection Method', connection_method.value,
'MACHINE', server,
'USER', user,
'KEY_PATH', ssh_private_keyfile,
'FILELIST_DATAFILES', str(len(filenames))]
instr += filenames
arglist[sv.DATASETREADER] = 'SZL Remote Loader'
arglist['FILENAMESORINSTRUCTIONS'] = instr
return _tecplot_loader_load_data(
arglist, frame=frame, read_data_option=read_data_option,
reset_style=reset_style,
initial_plot_first_zone_only=initial_plot_first_zone_only,
initial_plot_type=initial_plot_type,
assign_strand_ids=assign_strand_ids,
add_zones_to_existing_strands=add_zones_to_existing_strands)
finally:
for a in allocd:
a.dealloc()