.. _working_with_OF: Working with OpenFAST ===================== This section provides support for some of the typical use cases of OpenFAST. It assumes that the user has an executable of OpenFAST available (see :ref:`installation` for installation). Quick Start - Running OpenFAST ------------------------------ In this Quick Start, we will explain how to run OpenFAST. OpenFAST is typically run from a terminal (also referred to as command prompt or command line). The simplest method to run OpenFAST is to copy the OpenFAST executable into your working directory, and then open a terminal into that directory. The steps are therefore: - Copy the OpenFAST executable to the directory where you will run your simulations - Open a terminal - Navigate to the folder containing the OpenFAST executable - Run OpenFAST to check its version - Run OpenFAST on a given input file The steps are detailed below. Open a terminal ~~~~~~~~~~~~~~~ To learn how open a terminal on your given operating system, you can try the following search queries: - `On Windows `__ - `On Linux `__ - `On Mac `__ Navigate to your simulation directory ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ In the terminal, you can navigate between folders using the command `cd`. In this example, we assume that the simulation directory is `simulations/test`, therefore, to navigate to this directory you need to type: .. code-block:: bash cd simulations cd test or: .. code-block:: bash cd simulations/test To go to a parent directory, you can use `cd ..`. If the directory path contain spaces, use quotes around the path. It is usually good practice to avoid spaces in directory and file names. The path can also be an absolute path, e.g., `cd C:/simulations/test`. Run OpenFAST to check the version number ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Once your terminal is in the directory where OpenFAST is, you can try to run OpenFAST and check its version as follows: .. code-block:: bash ./openfast /h The `./` characters at the beginning of the command indicates that the executable is located in the current directory. The command above will display the version of OpenFAST, the compilation options, and display a help message on the syntax for calling the OpenFAST executable. .. note:: Try to always read the outputs of OpenFAST displayed in the terminal windows as errors and warnings will be displayed there. In general, if an error is displayed in the terminal, you can use the guidelines given in :ref:`troubleshooting` for troubleshooting. .. warning:: It is important to keep track of the version of OpenFAST you are using, since the input files format can change from version to version (see :ref:`api_change`). .. tip:: To avoid having to copy the executable in your working directory, you can place the executable into a folder and add this folder to your system path. If you chose this method, and restart your terminal, you should be able to run `openfast /h` from any folder, and this time, `./` is not needed. Run your first OpenFAST simulation ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The typical syntax to run a simulation is: .. code-block:: bash ./openfast InputFile.fst where `InputFile.fst` is a main OpenFAST input file. The extension `.fst` is recommended for the main input file of OpenFAST, `.dat` for other inputs files. The input file format specifications of OpenFAST input files are given in :ref:`input_file_overview`. We provide a minimal working example to get you started on your first OpenFAST run. This example uses the `NREL 5-MW `__ wind turbine, which is a fictitious but representative multi-MW wind turbine, with rated power 5 MW, rated rotor speed 12.1 rpm, Hub Height 90 m, and rotor diameter 126 m. This example is for an "onshore" version of the turbine, with only the structure (no aerodynamics), where the tower is initially displaced by 3m at the tower top. The files are located in the following `github directory `__ . You will have to download the following files and place them in your working directory: - `Main.fst `__ : the main OpenFAST input file - `ElastoDyn.dat `__ : the input file for the ElastoDyn module - `ElastoDyn_Blade.dat `__ : the input file defining the structural properties of the blade to be used by the ElastoDyn module - `ElastoDyn_Tower.dat `__ : the input file defining the structural properties of the tower to be used by the ElastoDyn module Once these 4 files are placed in your working directory (where the OpenFAST executable is located and where your terminal is at), you can run the simulation as follows: .. code-block:: bash ./openfast Main.fst The simulation should run successfully and OpenFAST will generate an output file with the extension `.out` or `.outb`. We provide a simple Python and Matlab script in the `github directory `__ to display some of the output channels of this simulation. For more information on how to visualize the outputs, see :ref:`visualizing_input_output_OF`. In general, if an error is displayed in the terminal, you can use the guidelines given in :ref:`troubleshooting` for troubleshooting. .. tip:: On certain platform (like Windows), you can drag and drop an input file to the OpenFAST executable in your file explorer, and this will run the simulation. If an error occurs using this method, you will not be able to see the error message. .. tip:: You can use relative and aboslute path to the OpenFAST executable and to the main OpenFAST input file. Input files of OpenFAST also contain filepaths that reference other input files. These filepaths are either relative to the current file, or, can be absolute paths. Troubleshooting a simulation ---------------------------- .. _troubleshooting: Simple troubleshooting ~~~~~~~~~~~~~~~~~~~~~~ When an error is caught during a simulation, OpenFAST will abort with a message of the following kind: .. code-block:: bash FAST encountered an error during module initialization. Simulation error level: FATAL ERROR Aborting OpenFAST. The lines above this message will reveal the nature of the error, and this information can be used to troubleshoot your simulation. Typical errors ************** Some typical errors and solutions are listed below: - *The input file "FILE" was not found*: As indicated, the input file is not found. Linux and Mac platforms are case sensitive, and require forward slashes. OpenFAST accepts relative or absolute path. Relative paths are expressed with respect to the file where they are referenced. - *Invalid input in file "FILE" while trying to read VAR*: Such errors typically occurs at initialization, when reading one of the input file of OpenFAST. It can be that the variable in the input file has a wrong type (integer instead of logical, float instead of string, etc.). Very often though, such an error indicates that the input file is not formatted propertly for the version of OpenFAST your are executing. Most likely your file is outdated. Lines are often added to the OpenFAST input files. You can have a look at :ref:`api_change` to see what lines have changed between versions of OpenFAST, or look at the `r-test `__ to find working examples of input files for the latest release and dev version of OpenFAST. - *A fatal error occurred when parsing data from "FILE". The variable "VAR" was not found on line #II*. Such errors are similar to the one described above. Check that your file has the proper format for the version of OpenFAST you are using. Similar messages indicate user-input errors (when selected options are not available or compatible). Such error messages are usually explicit enough. You can have a look at the comments in the input file for some guidance, and refer to the user guide for more details on individual inputs of each module: :ref:`user_guide`. .. tip:: 90% of the time, errors are due to a mismatch between the OpenFAST version and the input files (see second point above). Typical warnings **************** Some warnings might occasionally occur from different modules (typically the aerodynamic modules) and be reported to the command window. - *SkewedWakeCorrection encountered a large value of chi*: indicates that the turbine is highly yawed/titled. Could happen when the turbine undergoes important motions. - *The BEM solution is being turned off due to low TSR.*: indicate that the instantaneous rotor speed is close to zero, or the relative wind speed is large (check the outputs `RtSpeed` and `RtVavgx`). The warnings can sometimes be ignored, but they often indicate an issue in the model. See the next section of advanced troubleshooting. Advanced troubleshooting ~~~~~~~~~~~~~~~~~~~~~~~~ In some cases, simulations may abort during the simulation (*FAST encountered an error at simulation time T*), or they may run through but have empty or "NaN" outputs after few time steps (as little as one time steps). Such errors are typically due to the model being unphysical. In such case, you might see error messages of the following kind in the command window: - *Small angle assumption violated* or *Angles in GetSmllRotAngs() are larger than 0.4 radians*: such warnings indicate that part of the structure is undergoing large rotations, whereas some module of OpenFAST are only valid under the small angle approximation. - *Denominator is zero in GetSmllRotAngs()* Typically, when a simulation aborts or has unrealistic or NaN values, it is likely that there are errors in the model (the structure is too stiff, too soft, the inflow is incorrect, the initial conditions are incorrect, the controller is behaving unexpectedly, OLAF regularization parameters are set wrong, etc.). .. tip:: The key to troubleshooting is to simplify your model. You can chose to progressively simplify your model, until it runs and produces physical results. Or the other way around, simplify your model to the fullest, and progressively reintroduce complexity. Typical simplifications include: no aerodynamic, stiff structure, steady inflow, no controller. Below are some steps you can take to troubleshoot your model, in particular trying to isolate the problem to a given module and then input: - Simplify the model by using simple environmental conditions: steady uniform inflow, still water. - Remove the controller: Turn `GenDOF` to False in ElastoDyn, and set `CompServo` to 0 in the main input file. The rotor will spin at constant RPM. - Simplify your model by turning off most degrees of freedom in your ElastoDyn input file. You can start by keeping all degrees of freedom off, and progressively adding more degrees of freedom. This might indicat if the issue comes from the blade, nacelle, tower or substructure. Some degrees of freedom that are often problematic are the drive train torsion (`DrTrDOF`), and the yaw degree of freedom (`YawDOF`). The drive train stiffness and damping values in ElastoDyn are often set wrong. A common issues with yaw, is when `NacYaw` (in ElastoDyn) and `YawNeut` (in ServoDyn), are in disagreement, or, when the yaw spring and damping `YawSpr` and `YawDamp` are not physical. For offshore simulations, if `YawDOF` and `PtfmYDOF` are on, the model needs to have a realistic `PtfmYIner` present, otherwise these degrees of freedom will be ill-defined in ElastoDyn. PtfmYiner should contain the rotational inertia of the undeflected tower, and, if SubDyn is not used, the torsional inertia of the platform/TP (if any). - Simplify the physical models: use ElastoDyn (`CompElast=1`) over BeamDyn, use BEM (`WakeMod=1`) over OLAF, use 0 Craig-Bampton modes in SubDyn. - Visualize the time series outputs (see :ref:`visualizing_input_output_OF`). Add relevant displacement outputs to your model for instance: PtfmSurge, PtfmSway, PtfmHeave, PtfmRoll, PtfmPitch, PtfmYaw, NacYaw, TTDspFA, TTDspSS, RotSpeed, OoPDefl1, IPDefl1 and RtSkew. It is likely that the turbine has some large displacements due to some errors in the model. - Adjust your initial conditions. As mentioned above, `NacYaw` (ElastoDyn) and `YawNeut` (ServoDyn) need to match when the yaw degrees of freedom is on. If the structural is at an initial position that is unrealistic given the environmental condition, it is likely to overshoot (e.g. high wind speed but pitch too low). A common error is not initializing the rotor speed and blade-pitch angles to their expected (mean) values at the initial wind speed of the simulation, which causes issues with many wind turbine controllers. - Visualize the inputs (see :ref:`visualizing_input_output_OF`). Check that the mass and stiffness distributions of the blade and tower are as expected. - Verify the masses and stiffness of your system. The Blade mass and tower-top mass are shown in the ElastoDyn summary file. The equivalent 6x6 matrix of the substructure is found in the SubDyn summary file. - If you have isolated the problem to a given module, check the information provided in the summary file of this module. Most module have a flag at the end of their input file called `SumPrint` or similar, so that the summary file is written to disk. - Reduce the time step. The simulation time step needs to be adjusted based on the frequencies that are modelled in the system (typically the time step needs to be at around a tenth of the fastest frequency). Modules like BeamDyn and SubDyn usually require fine time steps. Instead of reducing the time step, it is often equivalent to introduce 1 correction step (`NumCrctn`). When corrections are used the Jacobian need to be updated regularly, for instance setting `DT_UJac` to 100 time steps. For a floating system, we recommend using `DT_UJac = 1/(10*f_pitch)`, where `f_pitch` is the natural frequency of the floating wind turbine in pitch. - Perform a linearization of your structure in vacuum (`CompInflow=0`, `CompAero=0`) and in standstill (`RotSpeed=0`) (see :ref:`linearization_analysis_OF`) and check that the frequencies and damping are within the range you expect. Adjust your structural inputs otherwise. - Generate VTK outputs for visualization of the turbine and the various meshes used by OpenFAST. VTK outputs are activated using `WrVTK=1` or `WrVTK=2`. The VTK are written in folders `vtk*` in the main directory, and can be visualized using Paraview (see :ref:`visualizing_input_output_OF`). .. _moduleTroubleshooting: Troubleshooting for specific modules ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ All modules of OpenFAST require a certain level of expertise to ensure that the simulations are physical. Guidelines for the different modules can be found throughout this documentation, see in particular: - AeroDyn: :ref:`ad_modeling` - HydroDyn: :ref:`hd-modeling-considerations` - OLAF: :ref:`Guidelines-OLAF` - SubDyn: :ref:`sd_modeling-considerations` - FAST.Farm: :ref:`FF:ModGuidance` Scripting --------- NREL maintains several repositories of scripts to work with OpenFAST. The scripts can for instance be used to read the input and outputs of OpenFAST, visualize them, and generate multiple simulation inputs, and postprocess them. Some of these applications will be detailed in the following sections. The repositories maintained by NREL are the following: - `openfast_toolbox `__: collection of low-level Python tools to work with OpenFAST and perform simple operations, with granularity. - `matlab-toolbox `__: collection of low-level Matlab tools to work with OpenFAST. - `WEIS `__ : high-level Python scripts, stands for Wind Energy with Integrated Servo-control. It can perform multifidelity co-design of wind turbines. WEIS is a framework that combines multiple NREL-developed tools to enable design optimization of floating offshore wind turbines. The users are invited to consult the documentations of the individual repository, and discuss related issues on their individual github pages. Contribution by the community to the NREL repositories are welcome and encouraged. Additional repositories maintained by NREL are listed below: - `WISDEM `__: models for assessing overall wind plant cost of energy (COE), also contains file IO, (DLC) case generation, polar manipulations, visualization, and much more! - `ROSCO_toolbox `__: tools to work with the `ROSCO `__ controller that is supported by OpenFAST Repositories maintained by third-parties are listed below: - `pyDatView `_ : tool to plot the input and output files of OpenFAST, CSV-files, and other files from other wind energy software (Hawc2, Flex, Bladed). Multiple files can be opened at once to compare results from different simulations. - `WindEnergyToolbox `_: library developed by DTU, providing some support for different file formats - `FASTTool `_ : NREL FASTv8, MATLAB GUI and Simulink integration developed by TUDelft .. _models_OF: Open-source OpenFAST models --------------------------- Open-source OpenFAST wind turbine models can be found here: - `r-test `__: regression tests for OpenFAST, contains models for OpenFAST and its drivers (AeroDyn, SubDyn, HydroDyn, etc.). This repository is not intended to be used as a "database" of models, but it has the advantage that the input files are always up to date with the latest `format specifications `_ . OpenFAST input files for previous version can be accessed via the git tags of this repository. - `IEA Wind Task 37 repository `_ : contains OpenFAST models of the IEA Wind 3.4-MW, 10-MW, 15-MW, and up-and-coming 22-MW reference wind turbines. - `openfast-turbine-models `_: open source wind turbine models (in development and out of date). .. _visualizing_input_output_OF: Visualizing inputs and outputs files ------------------------------------ To visualize the input and output files of OpenFAST the following graphical interface tool can be used: - `pyDatView `_ : tool to plot the input and output files of OpenFAST, CSV-files, and other files from other wind energy software (Hawc2, Flex, Bladed). Multiple files can be opened at once to compare results from different simulations. The VTK visualization files that are written by OpenFAST can be opened using: - `paraview `_ : tool to open the VTK files generated by OpenFAST, i.e. velocity fields and turbine geometry. For advanced cases, the user may want to script the reading and plotting of the input files. Python and Matlab tools are respectively being provided in the `openfast_toolbox `_ and `matlab-toolbox `_. In the matlab toolbox, the scripts `FAST2Matlab.m` and `Matlab2FAST.m` are used to read and write input files, the script `ReadFASTbinary` is used to open binary (`.outb`) output files. The README files of these repositories points to examples and more documentation. .. _running_multiple_OF: Running parametric studies and design load cases (DLC) ------------------------------------------------------ Parametric studies can be run by using the scripts to read and write OpenFAST input files provided in the `matlab-toolbox `__ and the Python `openfast_toolbox `__ . The openfast_toolbox provides dedicated Python scripts and examples to automatize the process (see the README of the repository for more). The `AeroelasticSE` module of `WEIS `__ can generate input files for the design load cases specified in the standards. Consult the WEIS repository for more information. .. _linearization_analysis_OF: Performing linearization analyses --------------------------------- Background ~~~~~~~~~~ Many applications require a linear model of a system: eigenvalue analyses, frequency domain analysis, linear state space models for observers, etc. Most models of OpenFAST are non-linear, and a linearization of the underlying system is therefore required. Linearization is done about a given operating point, which corresponds to the set of values of the states and inputs of the system (typically, a given time of a simulation). The output of the linearization is a linear state space model (four matrices relating states, inputs and outputs) valid in the neighborhood of the operating point. Because the rotor is spinning, the equilibrium solution, if present, will likely be periodic. It is necessary to linearize at different operating points over a period of revolution (i.e. at different azimuthal positions). An additional complication is that some of the states of OpenFAST are in the rotating frame of reference (e.g. the ElastoDyn blade states). To obtain a linear state space model of the system that is in a fixed (non-rotating) frame of reference the multiblade coordinate transformation (MBC) is applied. For a purely periodic system, the MBC can be applied to the linearized outputs at different azimuthal positions which can be combined to form a linearized system in a fixed frame of reference. We note that the MBC only applies to 3 or more blades. Floquet theory would be needed 1 or 2 blades, although NREL does not currently have a post-processor that makes use of Floquet theory. .. note:: Our current recommended practice is to avoid periodicity and simplify the model such that the equilibrium is constant (e.g., removing tilt and gravity). The MBC is still required but it is not required to use different linearization at different azimuthal positions. One of the outputs of the linearization is the state matrix (`A`) which relates the system states to their time derivatives. An eigenvalue analysis of `A` provides the full-system mode shapes, and their frequencies and damping. .. note:: Unlike a linear finite-element software, OpenFAST does not have a notion of a full-system stiffness and mass matrix (some modules have local matrices but only related to the module). The underlying system of equation is non-linear, the frequencies of the system will vary with the operating conditions (e.g. wind speed, rotational speed). The sections below detail the process of obtaining a linear model with OpenFAST, and will focus on its application to obtain the frequencies and damping of the system modes. Linearized models for one simulation (manually) ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ This section describes the key steps to generate a linearized model of the system with OpenFAST. The steps to perform simple linearization analysis are given below: 1. Edit the main `.fst` file, set `Linearize=True` 2. Set the output format `OutFmt` to "ES20.11E3". The output files will be written with this high resolution, which is required for accurate eigenvalue analyses. .. warning:: Because the linearization output files are in ASCII format, the results of the eigenvalue analyses will be sensitive to the output resolution (`OutFmt`). It is therefore important to set this parameter with a large precision as mentioned above. 3. There are two main methods to determine at which times the linearization will be made: - using `CalcSteady=False`, the user prescribes the times where linearization is to occur using `NLinTimes` and `LinTimes` (it is the responsibility of the user to provide times where the system is in equilibrium or at a periodic steady state, i.e. sufficiently long time); - `CalcSteady=True` (recommended approach), OpenFAST will automatically start the linearization when the system is at a periodic steady state (based on given tolerance `TrimTol`) and will perform `NLinTimes` linearizations over a rotor revolution. When a controller is used the option `CalcSteady` will also adjust the controller inputs (either Pitch, Yaw, or Generator Torque, based on the input `TrimCase`) such as to reach the rotational speed indicated by the initial condition. The `TrimGain` and `TrimTol` might need to be adjusted. `Twr_Kdmp` and `Bld_Kdmp` can be used to add damping to the tower and blades during the steady-state calculation. These may be helpful to speed up the steady-state calculation and may be necessary if the tower and/or blades are otherwise unstable. Once the steady-state solution is found. `Twr_Kdmp` and `Bld_Kdmp` will not impact the linearization results (i..e., the linear solution will not have extra tower and blade damping). 4. Chose the number of linearizations. For a standstill case, `NLinTimes=1`, for a rotating case, if the equilibrium point is periodic, it is recommended to use `NLinTimes=36` (corresponding to on linearization every 10-degrees of azimuth rotation), otherwise `NLinTimes=1`. If `CalcSteady=False` and the user sets `NLinTimes=36`, the user needs to set `LinTimes` with values that corresponds to the rotor being at 36 unique azimuthal position based on the rotor speed. 5. For a typical linearization, the user may set `LinInputs=0`, `LinOutputs=0`, `LinOutJac=False`, `LinOutMod=False`, `Twr_Kdmp=0`, `Bld_Kdmp=0` (see the OpenFAST input file documentation). Setting `LinInputs = LinOutputs = 0` avoids generating the B, C, and D matrices (no inputs and outputs). The standard set of linearization inputs inherent in the linearized system are available when `LinInputs=1`. This includes e.g. collective blade pitch. With `LinOutputs = 1`, the outputs of the `OutList` sections of each module are included in the linearized system. For instance, `GenSpeed` can be included by including `GenSpeed` in the `OutList` of ElastoDyn. Linearization about all the inputs and outputs of OpenFAST set `LinInputs=2`, `LinOutputs=2`, at the expense of having large output files. 6. Run OpenFAST on this `.fst` file. OpenFAST will display a message when it is performing each individual linearization, and individual files with the `.lin` extension will be written to disk. 7. It is recommended to check the regular output file `.out` or `.outb`. If `CalcSteady=False`, the user should look to see whether the turbine had indeed reached a steady state (or periodic steady state) at the time where linearization was run. If `CalcSteady=True` and a controller is used, the user can check that the rotational speed has indeed converged to the desired RPM, and potentially chose to adjust `TrimGain` and `TrimTol` for future runs. The linearization files `*.lin` are then to be postprocessed using the python or matlab tools provided. .. note:: Not all modules and options of OpenFAST are available when performing linearization. OpenFAST will abort with error message that will indicate which options are available. Adapt your input files accordingly. Postprocessing ~~~~~~~~~~~~~~ To obtain the eigenfrequencies of the system the user can open a `.lin` file, extract the state matrix `A` and perform a eigenvalue analysis. For a spinning rotors, all lin-files generated from a simulation at different azimuthal positions need to be opened, and converted using the MBC-transformation. We provide scripts for such cases. When only one linearization file is to be used (e.g. at standstill), the script `postproLin_OneLinFile_NoRotation` can be used. Is is found in `matlab-toolbox/Campbell/example` or `openfast_toolbox/openfast_toolbox/linearization/examples/`. When several linearization files are to be postprocessed (in particular several files corresponding to different azimuthal positions), the script `postproLin_MultiLinFile_Campbel` can be used, located in the same folders mentioned above. The script can also be used if linearizations were performed at different wind speed and RPM (via different OpenFAST calls). Displaying the frequencies and damping at these different wind turbine operating conditions is referred to as Campbell diagram. Campbell diagrams ~~~~~~~~~~~~~~~~~ In the near future, a dedicated tool will be provided to simplify the process of generating Campbell diagrams. Until then, to avoid the manual process of editing input files for different wind turbine operating conditions, we provide the script `runCampbell`, found in `matlab-toolbox/Campbell/example` or `openfast_toolbox/openfast_toolbox/linearization/examples/`. The script relies on a template folder which a reference "fst" file. The folder is duplicated, files are created for each wind turbine operating conditions wind speed/rpm), OpenFAST is run, and the linearization files are postprocessed. The script `runCampbell` generates either a set of CSV files or an Excel file. The script attempts to identify the modes (for instance 1st tower fore-aft mode, 1st flap mode, etc.), but a manual process is usually required to fully identify the mode. This process can be difficult and tedious. It is recommended to proceed first with simulations in vacuum, and with few operating points, to get familiar with the system. The manual identification process consists in changing the CSV file `Campbell_ModesID.csv` (or the Excel spread sheet `ModesID` if Excel output is used). To avoid having this file rewritten when rerunning `runCampbell`, it is recommended to rename this file as `Campbell_ModesID_Manual.csv`. The part of the script `runCampbell` that plots the Campbell diagram can be adjusted so as to use the "Manual" file. It is recommended to use the CSV format since this is the method compatible with Python and MacOS. The manual identification process consists in attributing indexes in the table of modes, where the index corresponds to the list of sorted mode frequencies. For instance, opening the CSV file in excel, the `ModeID` file might look as follows: .. code:: Mode Number Table Wind Speed (mps) 2.0 5.0 8.0 1st Tower FA 0 0 0 1st Tower SS 1 0 0 In this example, we assume that linearizations were run at 2, 5 and 8m/s. "0" in the table indicates that a mode was not identified. You can look at the file `Campbell_Summary.txt` to have a look at the frequencies, damping and "modal content" for each mode and operating point. For more details, you can open the individual CSV files for each operating point. (If you used the Excel format, these are in different sheets). You might find that for 2 and 5m/s, the tower Fore-Aft is the second frequency, and the tower side-side is the first frequency that shows up in the list of modes. At 8m/s you might find that the opposite occurs. In that case, you will edit the file such that it is as follows: .. code:: Mode Number Table Wind Speed (mps) 2.0 5.0 8.0 1st Tower FA 2 2 1 1st Tower SS 1 1 2 The main question is how to determine which mode is which. There is no true solution to this question, here are some elements to help the identifications: - The system frequencies are usually easy to determine at 0 m/s and 0 rpm. The system frequencies will vary progressively from this reference point as the RPM/WS/pitch changes. Blade regressive and progressive modes will typically display a "splitting" equal to +/- the rotational speed frequency as the rotational speed increases. The collective modes in flap tend to increase in frequency with rotor speed due to centrifugal stiffening. - Blade flap modes are typically highly damped (significantly more than edgewise modes) when aerodynamics are present. - From an operating point to the next, the damping will not change drastically. - Tower modes are not strongly affected by the change of operating conditions - You will need to look at the "mode content", to see where the energy is for each mode. The file `Campbell_Summary.csv` displays a summary of the mode content. In some cases, there is no clear maximum (the keyword `NoMax` is shown). In that case, identifying the mode might be difficult. A similar content is found in the individual operating point files. - Visualization of the modes can help identify them (see the next section). The process can yet be lengthy. Once the identification table is set. Save the file, and plot the Campbell diagram. The process may be iterative until a satisfying diagram is obtained. There should be no need to close Excel in this process. We are aware that the process is lengthy, we thank you for your patience while we attempt to streamline this process. Mode shape visualization ~~~~~~~~~~~~~~~~~~~~~~~~ Mode shape visualization is currently possible. It requires a generation of viz files for each simulations, and rerunning OpenFAST to generate VTK files. The matlab script `runCampbell` assists in this process, but for now limited support and documentation is provided. The user is invited to consult the following example: - https://github.com/OpenFAST/r-test/tree/main/glue-codes/openfast/5MW_Land_ModeShapes And it's associated documentation: - https://github.com/OpenFAST/r-test/blob/main/glue-codes/openfast/5MW_Land_ModeShapes/vtk-visualization.md Additional references ~~~~~~~~~~~~~~~~~~~~~ Some linearization issues have been discussed in the forum and as github issues: - https://wind.nrel.gov/forum/wind/ - https://github.com/OpenFAST/openfast/issues/480 Thank you for your patience while we attempt to streamline the linearization and Campbell digram generation process.