Class: wsim.hydroBody ===================== .. code-block:: none wsim.hydroBody represents one hydrodynamically interacting body in a hydrodynamic system. It is intended to be used in conjunction with the wsim.hydroSystem class which manages a collection of wsim.hydroBody objects and is used to perform the time domain simulation of the bodies. The body simulation data is contained in a case directory. This case directory should contain two subdirectories, 'hydroData' and 'geometry'. The hydroData subdirectory should contain either one .h5 file containing the output of the BEMIO files which process the output of various BEM solvers to a format understood by the hydroBody class, or, a collection of .mat files containing hydroData structures which can be directly loaded by the body. In this case, there will be one mat file for each body. The geometry subdirectory should contain a collection of STL files, one for each body. wsim.hydroBody Methods: hydroBody - constructor for the hydroBody class adjustMassMatrix - Merges diagonal term of added mass matrix to the mass matrix advanceStep - advance to the next time step, accepting the current time bodyGeo - Reads an STL mesh file and calculates areas and centroids checkInputs - Checks the user inputs forceAddedMass - Recomputes the real added mass force time history for the getVelHist - not documented hydroForcePre - performs pre-processing calculations to populate hydroForce structure hydroForces - hydroForces calculates the hydrodynamic forces acting on a hydrostaticForces - calculates the hydrostatic forces acting on the body lagrangeInterp - not documented linearExcitationForces - calculates linear wave excitation forces during transient linearInterp - not documented listInfo - Display some information about the body at the command line loadHydroData - load hydrodynamic data from file or variable makeMBDynComponents - creates mbdyn components for the hydroBody morrisonElementForce - not documented nonlinearExcitationForces - calculates the non-linear excitation forces on the body offsetXYZ - Function to move the position vertices plotStl - Plots the body's mesh and normal vectors radForceODEOutputfcn - OutputFcn to be called after every completed ode time step radForceSSDerivatives - wsim.hydroBody/radForceSSDerivatives is a function. radiationForces - calculates the wave radiation forces readH5File - Reads an HDF5 file containing the hydrodynamic data for the body restoreMassMatrix - Restore the mass and added-mass matrix back to the original value rotateXYZ - Function to rotate a point about an arbitrary axis saveHydroData - saves the body's hydrodata structure to a .mat file setCaseDirectory - set the case directory for the simulation the body is part of setInitDisp - Sets the initial displacement when having initial rotation storeForceAddedMass - Store the modified added mass and total forces history (inputs) timeDomainSimReset - resets the body in readiness for a transient simulation timeDomainSimSetup - sets up the body in preparation for a transient simulation viscousDamping - not documented waveElevation - calculate the wave elevation at centroids of triangulated surface write_paraview_vtp - Writes vtp files for visualization with ParaView Inheiritance Graph -------------------------------------------------- .. raw:: html
.. graphviz:: digraph graph_for_hydroBody { "handle" -> "wsim.hydroBody"; } Parent Class Properties and Methods -------------------------------------------------- .. raw:: html
handle ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Inheirited Properties """""""""""""""""""""""""""""""""""""""""""""""""" None Inheirited Methods """""""""""""""""""""""""""""""""""""""""""""""""" * addlistener : *ADDLISTENER Add listener for event.* * addlistener : *ADDLISTENER Add listener for event.* * addlistener : *ADDLISTENER Add listener for event.* * addlistener : *ADDLISTENER Add listener for event.* * addlistener : *ADDLISTENER Add listener for event.* * delete : *DELETE Delete a handle object.* * eq : *== (EQ) Test handle equality.* * findobj : *FINDOBJ Find objects matching specified conditions.* * findprop : *FINDPROP Find property of MATLAB handle object.* * ge : *>= (GE) Greater than or equal relation for handles.* * gt : *> (GT) Greater than relation for handles.* * isvalid : *ISVALID Test handle validity.* * le : *<= (LE) Less than or equal relation for handles.* * listener : *LISTENER Add listener for event without binding the listener to the source object.* * listener : *LISTENER Add listener for event without binding the listener to the source object.* * listener : *LISTENER Add listener for event without binding the listener to the source object.* * listener : *LISTENER Add listener for event without binding the listener to the source object.* * listener : *LISTENER Add listener for event without binding the listener to the source object.* * lt : *< (LT) Less than relation for handles.* * ne : *~= (NE) Not equal relation for handles.* * notify : *NOTIFY Notify listeners of event.* * notify : *NOTIFY Notify listeners of event.* Properties ---------- .. raw:: html
* addedMassMethod * bodyGeometry * bodyNumber * bodyToBodyInteraction * bodyTotal * caseDirectory * cb * cg * disableAddedMassForce * disableRadiationForce * dispVol * doAddedMass * doLinearDamping * doMorrisonElementViscousDrag * doNonLinearFKExcitation * doRadiationDamping * doViscousDamping * dof * dof_end * dof_gbm * dof_start * excitationMethod * flexHydroBody * freeSurfaceMethod * geometryFile * hydroData * hydroDataBodyNum * hydroDataFile * hydroDataFileFullPath * hydroForce * hydroStiffness * linearDamping * mass * massCalcMethod * meanDriftForce * momOfInertia * morrisonElement * name * radiationMethod * totalLenDOF * userDefinedExcIRF * viscDrag * viz addedMassMethod ^^^^^^^^^^^^^^^ character vector with a description of the added mass method Contains one of the following character vectors describing what method will be used to calculate the added mass forces: 'extrapolate acceleration from previous steps' 'iterate' bodyGeometry ^^^^^^^^^^^^ Structure defining body's mesh Should contain the fields 'numFace', 'numVertex', 'vertex', 'face', 'norm', 'area', 'center'. Generally this is filled by reading the geometry STL file. numFace : Number of faces numVertex : Number of vertices vertex : List of vertices face : List of faces norm : List of normal vectors area : List of cell areas center : List of cell centers bodyNumber ^^^^^^^^^^ body number in the order body was added to a wsim.hydroSystem. Can be different from the BEM body number, this is the index of the body in the wsim.hydroSystem bodyToBodyInteraction ^^^^^^^^^^^^^^^^^^^^^ true/false flag indicating if body-to-body interaction is included bodyTotal ^^^^^^^^^ Total number of hydro bodies in the wsim.hydroSystem caseDirectory ^^^^^^^^^^^^^ Simulation case directory containing the hydroData and geometry subdirectories cb ^^ Center of buoyancy [x; y; z] in meters. For WEC bodies this is given in the h5 file. cg ^^ Center of gravity [x; y; z] in meters. This is obtained from the h5 or mat file. disableAddedMassForce ^^^^^^^^^^^^^^^^^^^^^ true/false flag indicating whether to calculate added mass forces If this is true, the added mass force will be set to always return [ 0; 0; 0; 0; 0; 0 ]. It is generally intended for debugging purposes only disableRadiationForce ^^^^^^^^^^^^^^^^^^^^^ true/false flag indicating whether to calculate radiation forces If this is true, the radiation damping force will be set to always return [ 0; 0; 0; 0; 0; 0 ]. It is generally intended for debugging purposes only dispVol ^^^^^^^ doAddedMass ^^^^^^^^^^^ true/false flag indicating if added mass forces are included doLinearDamping ^^^^^^^^^^^^^^^ true/false flag indicating if linear damping is included doMorrisonElementViscousDrag ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ true/false flag indicating if morrison element viscous drag is included doNonLinearFKExcitation ^^^^^^^^^^^^^^^^^^^^^^^ true/false flag indicating if FK force will be calculated Indicates whether the nonlinear Froude-Krylov wave excitation forces will be calculated doRadiationDamping ^^^^^^^^^^^^^^^^^^ true/false flag indicating if radiation forces are included doViscousDamping ^^^^^^^^^^^^^^^^ true/false flag indicating if viscous damping is included dof ^^^ Number of DOFs. For WEC bodies this is given in the h5 file. IF not, default is 6 dof_end ^^^^^^^ Index of DOF ends. For WEC bodies this is given in the h5 file. IF not, default is (bodyNumber-1)*6+6 dof_gbm ^^^^^^^ Number of DOFs for GBM. dof_start ^^^^^^^^^ Index of DOF starts. For WEC bodies this is given in the h5 file. IF not, default is (bodyNumber-1)*6+1 excitationMethod ^^^^^^^^^^^^^^^^ Character vector containing the wave excitation method to be used can be one of: 'noWave', 'noWaveCIC', 'regular', 'regularCIC', 'irregular', 'irregularImport', 'userDefined' flexHydroBody ^^^^^^^^^^^^^ Flag for flexible body. freeSurfaceMethod ^^^^^^^^^^^^^^^^^ character vector indicating what fre surface method will be used Will be 'mean' or 'instantaneous' geometryFile ^^^^^^^^^^^^ Names of geomtry stl file for this body in geometry subfolder hydroData ^^^^^^^^^ Hydrodynamic data from BEM or user defined. hydroDataBodyNum ^^^^^^^^^^^^^^^^ Body number within the hdf5 file. hydroDataFile ^^^^^^^^^^^^^ name of hdf5 or mat file containing the hydrodynamic data (without path) hydroDataFileFullPath ^^^^^^^^^^^^^^^^^^^^^ full path to h5 or mat file containing the hydrodynamic data for the body hydroForce ^^^^^^^^^^ Structure containing hydrodynamic forces and coefficients used during simulation Will be a structure containing various fields depending on what simulation settings were chosen. hydroStiffness ^^^^^^^^^^^^^^ linearDamping ^^^^^^^^^^^^^ Linear drag coefficient, vector length 6 mass ^^^^ Mass in kg or specify 'equilibrium' to have mass = displacement vol * density massCalcMethod ^^^^^^^^^^^^^^ Method used to obtain mass: 'user', 'fixed', 'equilibrium' 'user' means the user has specified the mass directly 'fixed' means the mass is irrelevant as the hydrobody will be clamped in place, so a default set of mass and inertia values will be used. 'equilibrium' means the mass is calculated meanDriftForce ^^^^^^^^^^^^^^ Flag for mean drift force. 0: No; 1: from control surface; 2: from momentum conservation. momOfInertia ^^^^^^^^^^^^ Moment of inertia [Ixx Iyy Izz] in kg*m^2 for the body morrisonElement ^^^^^^^^^^^^^^^ structure defining morrison element input Should be a structure containing the fields 'cd', 'ca', 'characteristicArea', 'VME' and 'rgME' cd : vector length 3 containing the viscous (quadratic) drag coefficients ca : Added mass coefficent for Morrison Element (format [Ca_x Ca_y Ca_z], default = [0 0 0]) characteristicArea : Characteristic area for Morrison Elements calculations (format [Area_x Area_y Area_z], default = [0 0 0]) VME : Characteristic volume for Morrison Element (default = 0) rgME : Vector from center of gravity to point of application for Morrison Element (format [X Y Z], default = [0 0 0]). name ^^^^ Body name. This is obtained from the h5 or mat file. radiationMethod ^^^^^^^^^^^^^^^ character vector with a description of the radiation method Contains one of the following character vectors describing what method will be used to calculated the radiation forces: 'constant radiation coefficients' 'state space representation' 'state space representation using external solver' 'convolution integral' totalLenDOF ^^^^^^^^^^^ Matrices length. 6 for no body-to-body interactions. 6*numBodies if body-to-body interactions. userDefinedExcIRF ^^^^^^^^^^^^^^^^^ Defined Time-Series viscDrag ^^^^^^^^ Structure defining the viscous (quadratic) drag Must contain either the field 'Drag', or the fields 'cd' and 'characteristicArea'. Drag : if supplied, this field should contain either a full (6x6) matrix defining the Viscous (quadratic) drag, or a vector of length 6 representing the diagonal of this matrix. These are the directly specified viscous drag coefficients. cd : should contain a vector length 6 defining the Viscous (quadratic) drag coefficients which will be multiplied by the corresponding values in the 'characteristicArea' field. characteristicArea : should contain a vector of length 6 defining the Characteristic areas for viscous drag. viz ^^^ Structure defining visualization properties for Paraview Should contain two fields, 'color' and 'opacity'. color : three element vector containing the rgb values defining the body color in Paraview opacity : scalar value defining the opacity of the body in Paraview. Methods ------- .. raw:: html
* hydroBody * addedMassForces * adjustMassMatrix * advanceStep * bodyGeo * checkInputs * forceAddedMass * getVelHist * hydroForcePre * hydroForces * hydrostaticForces * lagrangeInterp * linearDampingForce * linearExcitationForces * linearInterp * listInfo * loadHydroData * makeMBDynComponents * morrisonElementForce * nonlinearExcitationForces * offsetXYZ * plotStl * radForceODEOutputfcn * radForceSSDerivatives * radiationDampingForces * readH5File * restoreMassMatrix * rotateXYZ * saveHydroData * setCaseDirectory * storeForceAddedMass * timeDomainSimReset * timeDomainSimSetup * vcross * viscousDamping * waveElevation * write_paraview_vtp hydroBody ^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" constructor for the hydroBody class Syntax """""""""""""""""""" .. code-block:: none hb = hydroBody (filename) Inputs """""""""""""""""""" filename """""""" .. code-block:: none string containing the h5 or mat file containing the hydrodynamic data for the body, without the path, e.g. float.mat, or rm3.h5. The hydrobody searches for the file in the /hydroData folder. The validity of the file name is not checked until the setCaseDirectory method is called (which is usually called by a parent wism.hydroSystem object which sets the case directory for all hydroBodies in a system). Outputs """""""""""""""""""" hb "" .. code-block:: none a wsim.hydroBody object addedMassForces ^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" calculates the body added mass forces Syntax """""""""""""""""""" .. code-block:: none F_AddedMass = radiationForces (obj, t, vel, accel) Inputs """""""""""""""""""" accel """"" .. code-block:: none (6 x 1) translational and angular acceleration of the body, or, if body to body interactions are being considered, a (6 x n) vector of all the body accelerations. Outputs """""""""""""""""""" F_AddedMass """"""""""" .. code-block:: none force due to added mass adjustMassMatrix ^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Merges diagonal term of added mass matrix to the mass matrix Syntax """""""""""""""""""" .. code-block:: none adjustMassMatrix (hb) Description """""""""""""""""""" .. code-block:: none adjustMassMatrix performs the following tasks in preparation for a simulation: * Stores the original mass and added-mass properties * Adds diagonal added-mass inertia to moment of inertia * Adds the maximum diagonal translational added-mass to body mass Inputs """""""""""""""""""" hb "" .. code-block:: none wsim.hydroBody object advanceStep ^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" advance to the next time step, accepting the current time step and data into stored solution histories Syntax """""""""""""""""""" .. code-block:: none advanceStep (hb, t, vel, accel) Description """""""""""""""""""" .. code-block:: none advanceStep must be called at the end of each integration time step to update the history of the solution. This is required for the radiation forces when using either the convolution integral method, or the state-space integration using the default internal integration provided by this class (invoked with simu.ssCalc = 1). Inputs """""""""""""""""""" hb "" .. code-block:: none hydroBody object vel """ .. code-block:: none vector of velocities and angular velocities, of size (6 x 1) if there is no body to body interaction (just the velocities of this body), or size (6*nbodies x 1) if there is body to body interaction (the velocities of all bodies in the system). accel """"" .. code-block:: none vector of accelerations and angular accelerations, of size (6 x 1) if there is no body to body interaction (just the velocities of this body), or size (6*nbodies x 1) if there is body to body interaction (the accelerations of all bodies in the system). bodyGeo ^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Reads an STL mesh file and calculates areas and centroids Syntax """""""""""""""""""" .. code-block:: none bodyGeo (hb, fname) Description """""""""""""""""""" .. code-block:: none bodyGeo Inputs """""""""""""""""""" hb "" .. code-block:: none wsim.hydroBody object fname """"" .. code-block:: none (optional) full path to the STL file to be loaded. If not supplied, the file specified in the body's geometryFile property (and expected to be in the 'geometry' folder of the simulation case directory) will be used. checkInputs ^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Checks the user inputs forceAddedMass ^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Recomputes the real added mass force time history for the body Syntax """""""""""""""""""" .. code-block:: none fam = forceAddedMass(hb,acc,B2B) Inputs """""""""""""""""""" hb "" .. code-block:: none hydroBody object acc """ .. code-block:: none (n x 6) time history of body accelerations for which the added mass is to be recalculated B2B """ .. code-block:: none flag indicating whether body-to-body interactions are present Outputs """""""""""""""""""" fam """ .. code-block:: none added mass recalculated from time history of accelerations and body added mass. getVelHist ^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" wsim.hydroBody/getVelHist is a function. vel = getVelHist(obj, t) hydroForcePre ^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" performs pre-processing calculations to populate hydroForce structure Syntax """""""""""""""""""" .. code-block:: none hydroForcePre (hb) Description """""""""""""""""""" .. code-block:: none hydroForcePre performs various pre-processing calulations in prepration for a simulation. It populates the hydroForce property of the hydroBody as a structure with the linear hydrodynamic restoring coefficient, viscous drag, and linear damping matrices, and also sets the wave excitation force calculation method from the specified wave type. Inputs """""""""""""""""""" hb "" .. code-block:: none wsim.hydroBody object hydroForces ^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" hydroForces calculates the hydrodynamic forces acting on a body Syntax """""""""""""""""""" .. code-block:: none [forces, breakdown] = hydroForces (hb, t, x, vel, accel, elv) Inputs """""""""""""""""""" hb "" .. code-block:: none hydroBody object pos """ .. code-block:: none (6 x 1) displcement of this body in x,y and z and rotatation around the x, y and z axes vel """ .. code-block:: none (6 x n) velocities of all bodies in system accel """"" .. code-block:: none (6 x n) acceleration of all bodies in system Outputs """""""""""""""""""" forces """""" .. code-block:: none (6 x 1) forces and moments acting on the body breakdown """"""""" .. code-block:: none structure containing more detailed breakdown of the forces acting on the body. The fields present depend on the simulation settings and can include the following: F_ExcitLin : F_Excit : F_ExcitRamp : F_ViscousDamping : F_AddedMass : F_RadiationDamping : F_Restoring : BodyHSPressure : F_ExcitNonLin : WaveNonLinearPressure : WaveLinearPressure : F_MorrisonElement : hydrostaticForces ^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" calculates the hydrostatic forces acting on the body lagrangeInterp ^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" wsim.hydroBody.lagrangeInterp is a function. v = lagrangeInterp(x, y, u) linearDampingForce ^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" forces = obj.hydroForce.linearDamping * vel; linear damping is always a diagonal matrix, so just multiply the values along the diagonal linearExcitationForces ^^^^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" calculates linear wave excitation forces during transient simulation Syntax """""""""""""""""""" .. code-block:: none forces = linearExcitationForces (obj, t) Inputs """""""""""""""""""" linearInterp ^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" linearInterp simple linear interpolation with no input checking Syntax """""""""""""""""""" .. code-block:: none v = wsim.hydroBody.linearInterp (x1, x2, y1, y2, u) Description """""""""""""""""""" .. code-block:: none wsim.hydroBody.linearInterp returns a simple linear interpolation with extrapolation without any input checking for speed. A linear function is created from two input data points on the line, (x1,y1) and (x2,y2). Inputs """""""""""""""""""" x1 "" .. code-block:: none x coordinate of first data point on line x2 "" .. code-block:: none x coordinate of second data point on line y1 "" .. code-block:: none y coordinate of first data point on line y2 "" .. code-block:: none y coordinate of second data point on line Outputs """""""""""""""""""" See Also """""""""""""""""""" .. code-block:: none listInfo ^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Display some information about the body at the command line loadHydroData ^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" load hydrodynamic data from file or variable Syntax """""""""""""""""""" .. code-block:: none loadHydroData (obj) loadHydroData (obj, filename) loadHydroData (obj, hydroData) Description """""""""""""""""""" .. code-block:: none Loads hydrodynamic data from a .mat file, .h5 file or directly from a matlab structure. Inputs """""""""""""""""""" hg "" .. code-block:: none wsim.hydroBody object filename """""""" .. code-block:: none character vector containing the full path of the file from which to load the hydrodynamic data. Can be either a .h5 file or a .mat file. If a .mat file it must contain all the fields expected to be in the hydroBody hydroData property. This file can also be created using the wsim.hydroBody.saveHydroData method. hydroData """"""""" .. code-block:: none structure containing the data which is loaded directly into the hydrBody's hydroData property See Also """""""""""""""""""" .. code-block:: none wsim.hydroBody.saveHydroData makeMBDynComponents ^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" creates mbdyn components for the hydroBody Syntax """""""""""""""""""" .. code-block:: none [node, body] = makeMBDynComponents (obj) Description """""""""""""""""""" .. code-block:: none makeMBDynComponents creates a node and body element for use in an MBDyn multibody dynamics simulation. Requires the MBDyn toolbox. Inputs """""""""""""""""""" hg "" .. code-block:: none wsim.hydroBody object Outputs """""""""""""""""""" node """" .. code-block:: none mbdyn.pre.structuralNode6dof object represetning an inertial node located at the centre of gravity of the body. body """" .. code-block:: none mbdyn.pre.body object attached to the node and with the appropriate mass and inertial proerties for the hydroBody. morrisonElementForce ^^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" TODO: in WEC-Sim morrison element stuff uses acceleration delay like added mass forces nonlinearExcitationForces ^^^^^^^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" calculates the non-linear excitation forces on the body offsetXYZ ^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" translate the position vertices plotStl ^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Plots the body's mesh and normal vectors radForceODEOutputfcn ^^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" OutputFcn to be called after every completed ode time step when using the state-space representation of the radiation forces Syntax """""""""""""""""""" .. code-block:: none radForceODEOutputfcn (hb, t, x, flag) Inputs """""""""""""""""""" hb "" .. code-block:: none hydroBody oject radForceSSDerivatives ^^^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" wsim.hydroBody/radForceSSDerivatives is a function. statederivs = radForceSSDerivatives(obj, u) radiationDampingForces ^^^^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" calculates the wave radiation forces Syntax """""""""""""""""""" .. code-block:: none F_RadiationDamping = radiationForces (obj, t, vel, accel) Inputs """""""""""""""""""" vel """ .. code-block:: none (6 x 1) translational and angular velocity of the body, or, if body to body interactions are being considered, a (6 x n) vector of all the body velocities. Outputs """""""""""""""""""" F_RadiationDamping """""""""""""""""" .. code-block:: none force due to wave radiation damping readH5File ^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Reads an HDF5 file containing the hydrodynamic data for the body Syntax """""""""""""""""""" .. code-block:: none readH5File(hb) Description """""""""""""""""""" .. code-block:: none readH5File reads the HDF5 file containing the hydrodynamic data for the body and stores it in the body properties. The file location is expected to be in the case directory provided on construction of the object. Generating the hydrodynamic data: The hydroBody requires frequency-domain hydrodynamic coefficients (added mass, radiation damping, and wave excitation). Typically, these hydrodynamic coefficients for each body of the WEC device are generated using a boundary element method (BEM) code (e.g., WAMIT, NEMOH or AQWA). The HDF5 file must then be generated from the output of these codes. Create HDF5 file: readH5File reads the hydrodynamic data in HDF5 format from the (.h5) file provided when the object was constructed. A helper tool, BEMIO, is available to parse BEM solutions (from WAMIT, NEMOH and AQWA) into the required HDF5 data structure. Inputs """""""""""""""""""" hb "" .. code-block:: none hydroBody object restoreMassMatrix ^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Restore the mass and added-mass matrix back to the original value rotateXYZ ^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Function to rotate a point about an arbitrary axis x: 3-componenet coordinates ax: axis about which to rotate (must be a normal vector) theta: rotation angle xn: new coordinates after rotation saveHydroData ^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" saves the body's hydrodata structure to a .mat file Syntax """""""""""""""""""" .. code-block:: none saveHydroData (hb, filename) saveHydroData (..., 'Parameter', Value) Description """""""""""""""""""" .. code-block:: none saveHydroData saves the body's hydroData structure to a .mat file for later use. This avoids having to read the .h5 file. By default saveHydroData saves the file in the hydroData subdirectory of the case directory. The 'Directory' option may be used to change this behaviour. Inputs """""""""""""""""""" hb "" .. code-block:: none wsim.hydroBody object filename """""""" .. code-block:: none name withput path of the .mat file in which to save the hydrobody hydroData structure contents. Additional arguments may be supplied as parameter-value pairs: Directory """"""""" .. code-block:: none optional alternative directory in which to save the .mat file instead of the hydroData subdirectory of the simulation case directory. See Also """""""""""""""""""" .. code-block:: none setCaseDirectory ^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" set the case directory for the simulation the body is part of Syntax """""""""""""""""""" .. code-block:: none setCaseDirectory (hb, case_directory) Description """""""""""""""""""" .. code-block:: none setCaseDirectory sets the path to the case directory of the simulation of which the hydroBody is a part. This is intended to be called by the wsim.hydroSystem to which the body is added, rather than called by a user directly. The case directory should contain two subdirectories, 'hydroData' and 'geometry'. The hydroData directory should contain the .h5 file or .mat file containing the hydrodynamic data for the body using a BEM solver and the BEMIO functions. The geometry folder should contain any STL file describing the geometry of the body. Inputs """""""""""""""""""" hb "" .. code-block:: none a wsim.hydroBody object case_directory """""""""""""" .. code-block:: none character vector containing the full path to the case directory of the simulation. See Also """""""""""""""""""" .. code-block:: none storeForceAddedMass ^^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Store the modified added mass and total forces history (inputs) timeDomainSimReset ^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" resets the body in readiness for a transient simulation Syntax """""""""""""""""""" .. code-block:: none timeDomainSimReset (hb) Desciription timeDomainSimReset resets various internal storeage parameters and settings in preparation for performing a transient simulation based on the ODE solver routines, returning the hydroBody to the state it is in just after calling timeDomainSimSetup. This should be called before re-running a transient simulation with the same parameters. Inputs """""""""""""""""""" hb "" .. code-block:: none hydroBody object timeDomainSimSetup ^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" sets up the body in preparation for a transient simulation Syntax """""""""""""""""""" .. code-block:: none timeDomainSimSetup (hb, waves, simu, bodynum) Desciription timeDomainSimSetup initialises various parmaters and settings in preparation for performing a transient simulation based on the ODE solver routines. Inputs """""""""""""""""""" hb "" .. code-block:: none hydroBody object waves """"" .. code-block:: none waveClass object with the desired wave parameters to be used in the simulation simu """" .. code-block:: none simulationClass Object with the desired simulation parameters to be used in the simulation bodynum """"""" .. code-block:: none the number associated with this body. Typically this is generated by a parent hydrosys object vcross ^^^^^^ .. raw:: html
Summary """""""""""""""""""" Vector cross product for multiple 3 element vectors Syntax """""""""""""""""""" .. code-block:: none o = wsim.hydroBody.vcross (v1, v2) Description """""""""""""""""""" .. code-block:: none Inputs """""""""""""""""""" v1 "" .. code-block:: none (3 x n) matrix where the rows are each 3 element vectors v2 "" .. code-block:: none (3 x n) matrix where the rows are each 3 element vectors Outputs """""""""""""""""""" viscousDamping ^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" wsim.hydroBody/viscousDamping is a function. forces = viscousDamping(obj, vel) waveElevation ^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" calculate the wave elevation at centroids of triangulated surface NOTE: This function assumes that the STL file is imported with its CG at (0,0,0) write_paraview_vtp ^^^^^^^^^^^^^^^^^^ .. raw:: html
Summary """""""""""""""""""" Writes vtp files for visualization with ParaView